| [459] | 1 | unit fEditConsult; | 
|---|
|  | 2 |  | 
|---|
|  | 3 | interface | 
|---|
|  | 4 |  | 
|---|
|  | 5 | uses | 
|---|
|  | 6 | Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, | 
|---|
|  | 7 | StdCtrls, ORCtrls, ExtCtrls, ComCtrls, ORfn, uConst, uConsults, Buttons, | 
|---|
|  | 8 | Menus ; | 
|---|
|  | 9 |  | 
|---|
|  | 10 | type | 
|---|
|  | 11 | TfrmEditCslt = class(TForm) | 
|---|
|  | 12 | cboService: TORComboBox; | 
|---|
|  | 13 | cboUrgency: TORComboBox; | 
|---|
|  | 14 | radInpatient: TRadioButton; | 
|---|
|  | 15 | radOutpatient: TRadioButton; | 
|---|
|  | 16 | cboPlace: TORComboBox; | 
|---|
|  | 17 | txtProvDiag: TCaptionEdit; | 
|---|
|  | 18 | txtAttn: TORComboBox; | 
|---|
|  | 19 | lblReason: TLabel; | 
|---|
|  | 20 | lblService: TLabel; | 
|---|
|  | 21 | lblUrgency: TStaticText; | 
|---|
|  | 22 | lblPlace: TStaticText; | 
|---|
|  | 23 | lblAttn: TStaticText; | 
|---|
|  | 24 | lblProvDiag: TStaticText; | 
|---|
|  | 25 | cboCategory: TORComboBox; | 
|---|
|  | 26 | pnlMessage: TPanel; | 
|---|
|  | 27 | imgMessage: TImage; | 
|---|
|  | 28 | memMessage: TRichEdit; | 
|---|
|  | 29 | cmdAccept: TButton; | 
|---|
|  | 30 | cmdQuit: TButton; | 
|---|
|  | 31 | memComment: TRichEdit; | 
|---|
|  | 32 | lblComment: TLabel; | 
|---|
|  | 33 | lblComments: TLabel; | 
|---|
|  | 34 | btnCmtCancel: TButton; | 
|---|
|  | 35 | btnCmtOther: TButton; | 
|---|
|  | 36 | mnuPopProvDx: TPopupMenu; | 
|---|
|  | 37 | mnuPopProvDxDelete: TMenuItem; | 
|---|
|  | 38 | cmdLexSearch: TButton; | 
|---|
|  | 39 | lblInpOutp: TStaticText; | 
|---|
|  | 40 | memReason: TRichEdit; | 
|---|
|  | 41 | popReason: TPopupMenu; | 
|---|
|  | 42 | popReasonCut: TMenuItem; | 
|---|
|  | 43 | popReasonCopy: TMenuItem; | 
|---|
|  | 44 | popReasonPaste: TMenuItem; | 
|---|
|  | 45 | popReasonPaste2: TMenuItem; | 
|---|
|  | 46 | popReasonReformat: TMenuItem; | 
|---|
|  | 47 | procedure txtAttnNeedData(Sender: TObject; const StartFrom: String; | 
|---|
|  | 48 | Direction, InsertAt: Integer); | 
|---|
|  | 49 | procedure radInpatientClick(Sender: TObject); | 
|---|
|  | 50 | procedure radOutpatientClick(Sender: TObject); | 
|---|
|  | 51 | procedure ControlChange(Sender: TObject); | 
|---|
|  | 52 | procedure FormClose(Sender: TObject; var Action: TCloseAction); | 
|---|
|  | 53 | procedure cmdQuitClick(Sender: TObject); | 
|---|
|  | 54 | procedure cmdAcceptClick(Sender: TObject); | 
|---|
|  | 55 | procedure memReasonExit(Sender: TObject); | 
|---|
|  | 56 | procedure OrderMessage(const AMessage: string); | 
|---|
|  | 57 | procedure btnCmtCancelClick(Sender: TObject); | 
|---|
|  | 58 | procedure btnCmtOtherClick(Sender: TObject); | 
|---|
|  | 59 | procedure cmdLexSearchClick(Sender: TObject); | 
|---|
|  | 60 | procedure mnuPopProvDxDeleteClick(Sender: TObject); | 
|---|
|  | 61 | procedure popReasonCutClick(Sender: TObject); | 
|---|
|  | 62 | procedure popReasonCopyClick(Sender: TObject); | 
|---|
|  | 63 | procedure popReasonPasteClick(Sender: TObject); | 
|---|
|  | 64 | procedure popReasonPopup(Sender: TObject); | 
|---|
|  | 65 | procedure popReasonReformatClick(Sender: TObject); | 
|---|
|  | 66 | procedure memCommentKeyUp(Sender: TObject; var Key: Word; | 
|---|
|  | 67 | Shift: TShiftState); | 
|---|
|  | 68 | procedure memCommentKeyDown(Sender: TObject; var Key: Word; | 
|---|
|  | 69 | Shift: TShiftState); | 
|---|
|  | 70 | procedure memCommentKeyPress(Sender: TObject; var Key: Char); | 
|---|
|  | 71 | private | 
|---|
|  | 72 | FLastServiceID: string; | 
|---|
|  | 73 | FChanged: boolean; | 
|---|
|  | 74 | FChanging: boolean; | 
|---|
|  | 75 | FEditCtrl: TCustomEdit; | 
|---|
|  | 76 | FNavigatingTab: boolean; | 
|---|
|  | 77 | procedure SetProvDiagPromptingMode; | 
|---|
|  | 78 | protected | 
|---|
|  | 79 | procedure InitDialog; | 
|---|
|  | 80 | procedure Validate(var AnErrMsg: string); | 
|---|
|  | 81 | function  ValidSave: Boolean; | 
|---|
|  | 82 | end; | 
|---|
|  | 83 |  | 
|---|
|  | 84 | function EditResubmitConsult(FontSize: Integer; ConsultIEN: integer): boolean; | 
|---|
|  | 85 |  | 
|---|
|  | 86 | var | 
|---|
|  | 87 | frmEditCslt: TfrmEditCslt; | 
|---|
|  | 88 |  | 
|---|
|  | 89 | implementation | 
|---|
|  | 90 |  | 
|---|
|  | 91 | {$R *.DFM} | 
|---|
|  | 92 |  | 
|---|
|  | 93 | uses | 
|---|
|  | 94 | rODBase, rConsults, uCore, rCore, fConsults, fRptBox, fPCELex, rPCE, | 
|---|
|  | 95 | ORClasses, clipbrd, UBAGlobals, rOrders ; | 
|---|
|  | 96 |  | 
|---|
|  | 97 | var | 
|---|
|  | 98 | SvcList: TStrings ; | 
|---|
|  | 99 | OldRec, NewRec: TEditResubmitRec; | 
|---|
|  | 100 | Defaults: TStringList; | 
|---|
|  | 101 | uMessageVisible: DWORD; | 
|---|
|  | 102 | ProvDx: TProvisionalDiagnosis; | 
|---|
|  | 103 | {Begin BillingAware} | 
|---|
|  | 104 | BADxUpdated: boolean; | 
|---|
|  | 105 | {End BillingAware} | 
|---|
|  | 106 |  | 
|---|
|  | 107 | const | 
|---|
|  | 108 | TX_NOTTHISSVC_TEXT = 'Consults cannot be ordered from this service' ; | 
|---|
|  | 109 | TX_NO_SVC          = 'A service must be specified.'    ; | 
|---|
|  | 110 | TX_NO_REASON       = 'A reason for this consult must be entered.'  ; | 
|---|
|  | 111 | TX_SVC_ERROR       = 'This service has not been defined in your Orderable Items file.' + | 
|---|
|  | 112 | #13#10'Contact IRM for assistance.' ; | 
|---|
|  | 113 | TX_NO_URGENCY      = 'An urgency must be specified.'; | 
|---|
|  | 114 | TX_NO_PLACE        = 'A place of consultation must be specified'; | 
|---|
|  | 115 | TX_NO_DIAG         = 'A provisional diagnosis must be entered for consults to this service.'; | 
|---|
|  | 116 | TX_SELECT_DIAG     = 'You must use the "Lexicon" button to select a diagnosis for consults to this service.'; | 
|---|
|  | 117 | TX_INACTIVE_CODE   = 'The provisional diagnosis code is not active as of today''s date.' + #13#10 + | 
|---|
|  | 118 | 'Another code must be selected'; | 
|---|
|  | 119 | TC_INACTIVE_CODE   = 'Inactive ICD Code'; | 
|---|
|  | 120 |  | 
|---|
|  | 121 | function EditResubmitConsult(FontSize: Integer; ConsultIEN: integer): boolean; | 
|---|
|  | 122 | begin | 
|---|
|  | 123 | Result := False; | 
|---|
|  | 124 | if ConsultIEN = 0 then exit; | 
|---|
|  | 125 | FillChar(OldRec, SizeOf(OldRec), 0); | 
|---|
|  | 126 | FillChar(NewRec, SizeOf(NewRec), 0); | 
|---|
|  | 127 | FillChar(ProvDx, SizeOf(ProvDx), 0); | 
|---|
|  | 128 | OldRec := LoadConsultForEdit(ConsultIEN); | 
|---|
|  | 129 | NewRec.IEN := OldRec.IEN; | 
|---|
|  | 130 | NewRec.RequestType := OldRec.RequestType; | 
|---|
|  | 131 | with NewRec do | 
|---|
|  | 132 | begin | 
|---|
|  | 133 | RequestReason:= TStringList.Create ; | 
|---|
|  | 134 | DenyComments:= TStringList.Create ; | 
|---|
|  | 135 | OtherComments:= TStringList.Create ; | 
|---|
|  | 136 | NewComments:= TStringList.Create ; | 
|---|
|  | 137 | end; | 
|---|
|  | 138 | StatusText('Loading Consult for Edit'); | 
|---|
|  | 139 | frmEditCslt := TfrmEditCslt.Create(Application); | 
|---|
|  | 140 | SvcList     := TStringList.Create ; | 
|---|
|  | 141 | Defaults    := TStringList.Create; | 
|---|
|  | 142 | try | 
|---|
|  | 143 | with frmEditCslt do | 
|---|
|  | 144 | begin | 
|---|
|  | 145 | ResizeAnchoredFormToFont(frmEditCslt); | 
|---|
|  | 146 | FChanged     := False; | 
|---|
|  | 147 | InitDialog; | 
|---|
|  | 148 | ShowModal ; | 
|---|
|  | 149 | Result := FChanged ; | 
|---|
|  | 150 | end ; | 
|---|
|  | 151 | finally | 
|---|
|  | 152 | OldRec.RequestReason.Free; | 
|---|
|  | 153 | OldRec.DenyComments.Free; | 
|---|
|  | 154 | OldRec.OtherComments.Free; | 
|---|
|  | 155 | OldRec.NewComments.Free; | 
|---|
|  | 156 | NewRec.RequestReason.Free; | 
|---|
|  | 157 | NewRec.DenyComments.Free; | 
|---|
|  | 158 | NewRec.OtherComments.Free; | 
|---|
|  | 159 | NewRec.NewComments.Free; | 
|---|
|  | 160 | SvcList.Free; | 
|---|
|  | 161 | Defaults.Free; | 
|---|
|  | 162 | frmEditCslt.Release; | 
|---|
|  | 163 | end; | 
|---|
|  | 164 | end; | 
|---|
|  | 165 |  | 
|---|
|  | 166 | procedure TfrmEditCslt.InitDialog; | 
|---|
|  | 167 | var | 
|---|
|  | 168 | i:integer; | 
|---|
|  | 169 | begin | 
|---|
|  | 170 | FChanging := True; | 
|---|
|  | 171 | Defaults.Assign(ODForConsults); | 
|---|
|  | 172 | FLastServiceID := ''; | 
|---|
|  | 173 | cboService.Items.Clear; | 
|---|
|  | 174 | if OldRec.InpOutp <> '' then | 
|---|
|  | 175 | case OldRec.InpOutp[1] of | 
|---|
|  | 176 | 'I': radInpatient.Checked  := True;                 //INPATIENT CONSULT | 
|---|
|  | 177 | 'O': radOutpatient.Checked := True;                 //OUTPATIENT CONSULT | 
|---|
|  | 178 | end | 
|---|
|  | 179 | else | 
|---|
|  | 180 | begin | 
|---|
|  | 181 | if Patient.Inpatient then | 
|---|
|  | 182 | radInpatient.Checked  := True | 
|---|
|  | 183 | else | 
|---|
|  | 184 | radOutpatient.Checked := True; | 
|---|
|  | 185 | end; | 
|---|
|  | 186 | StatusText('Initializing Long List'); | 
|---|
|  | 187 | SvcList.Assign(LoadServiceList(CN_SVC_LIST_ORD))   ; | 
|---|
|  | 188 | with cboService do | 
|---|
|  | 189 | begin | 
|---|
|  | 190 | for i := 0 to SvcList.Count - 1 do | 
|---|
|  | 191 | if SelectByID(Piece(SvcList.Strings[i], U, 1)) = -1 then | 
|---|
|  | 192 | Items.Add(SvcList.Strings[i]); | 
|---|
|  | 193 | SelectByID(IntToStr(OldRec.ToService)); | 
|---|
|  | 194 | end; | 
|---|
|  | 195 | cboPlace.SelectByID(OldRec.Place); | 
|---|
|  | 196 | with cboUrgency do for i := 0 to Items.Count-1 do | 
|---|
|  | 197 | if UpperCase(DisplayText[i]) = UpperCase(OldRec.UrgencyName) then ItemIndex := i; | 
|---|
|  | 198 | txtProvDiag.Text := OldRec.ProvDiagnosis; | 
|---|
|  | 199 | ProvDx.Code := OldRec.ProvDxCode; | 
|---|
|  | 200 | if OldRec.ProvDxCodeInactive then | 
|---|
|  | 201 | begin | 
|---|
|  | 202 | InfoBox(TX_INACTIVE_CODE, TC_INACTIVE_CODE, MB_ICONWARNING or MB_OK); | 
|---|
|  | 203 | ProvDx.CodeInactive := True; | 
|---|
|  | 204 | end; | 
|---|
|  | 205 | memReason.Lines.Assign(OldRec.RequestReason); | 
|---|
|  | 206 | memComment.Clear ; | 
|---|
|  | 207 | btnCmtCancel.Enabled := (OldRec.DenyComments.Count > 0); | 
|---|
|  | 208 | btnCmtOther.Enabled := (OldRec.OtherComments.Count > 0); | 
|---|
|  | 209 | txtAttn.InitLongList(OldRec.AttnName) ; | 
|---|
|  | 210 | if OldRec.Attention > 0 then | 
|---|
|  | 211 | txtAttn.SelectByIEN(OldRec.Attention) | 
|---|
|  | 212 | else | 
|---|
|  | 213 | txtAttn.ItemIndex := -1; | 
|---|
|  | 214 | SetProvDiagPromptingMode; | 
|---|
|  | 215 | FChanging := False; | 
|---|
|  | 216 | StatusText(''); | 
|---|
|  | 217 | end; | 
|---|
|  | 218 |  | 
|---|
|  | 219 | procedure TfrmEditCslt.Validate(var AnErrMsg: string); | 
|---|
|  | 220 |  | 
|---|
|  | 221 | procedure SetError(const x: string); | 
|---|
|  | 222 | begin | 
|---|
|  | 223 | if Length(AnErrMsg) > 0 then AnErrMsg := AnErrMsg + CRLF; | 
|---|
|  | 224 | AnErrMsg := AnErrMsg + x; | 
|---|
|  | 225 | end; | 
|---|
|  | 226 |  | 
|---|
|  | 227 | begin | 
|---|
|  | 228 | inherited; | 
|---|
|  | 229 | if cboService.ItemIEN = 0               then SetError(TX_NO_SVC); | 
|---|
|  | 230 | if cboUrgency.ItemIEN = 0 then SetError(TX_NO_URGENCY); | 
|---|
|  | 231 | if cboPlace.ItemID = '' then SetError(TX_NO_PLACE); | 
|---|
|  | 232 | if memReason.Lines.Count = 0            then SetError(TX_NO_REASON); | 
|---|
|  | 233 | with cboService do | 
|---|
|  | 234 | begin | 
|---|
|  | 235 | if Piece(Items[ItemIndex], U, 5) = '1' then SetError(TX_NOTTHISSVC_TEXT); | 
|---|
|  | 236 | if (Piece(Items[ItemIndex],U,5) <> '1') | 
|---|
|  | 237 | and (Piece(Items[ItemIndex], U, 6) = '') | 
|---|
|  | 238 | then SetError(TX_SVC_ERROR) ; | 
|---|
|  | 239 | end; | 
|---|
|  | 240 | if (ProvDx.Reqd = 'R') and (Length(txtProvDiag.Text) = 0) then | 
|---|
|  | 241 | begin | 
|---|
|  | 242 | if ProvDx.PromptMode = 'F' then | 
|---|
|  | 243 | SetError(TX_NO_DIAG) | 
|---|
|  | 244 | else | 
|---|
|  | 245 | SetError(TX_SELECT_DIAG); | 
|---|
|  | 246 | end; | 
|---|
|  | 247 | if OldRec.ProvDxCodeInactive and ProvDx.CodeInactive then | 
|---|
|  | 248 | SetError(TX_INACTIVE_CODE); | 
|---|
|  | 249 | end; | 
|---|
|  | 250 |  | 
|---|
|  | 251 | procedure TfrmEditCslt.txtAttnNeedData(Sender: TObject; | 
|---|
|  | 252 | const StartFrom: string; Direction, InsertAt: Integer); | 
|---|
|  | 253 | begin | 
|---|
|  | 254 | inherited; | 
|---|
|  | 255 | txtAttn.ForDataUse(SubSetOfPersons(StartFrom, Direction)); | 
|---|
|  | 256 | end; | 
|---|
|  | 257 |  | 
|---|
|  | 258 | procedure TfrmEditCslt.radInpatientClick(Sender: TObject); | 
|---|
|  | 259 | begin | 
|---|
|  | 260 | inherited; | 
|---|
|  | 261 | cboUrgency.Items.Clear; | 
|---|
|  | 262 | cboPlace.Items.Clear; | 
|---|
|  | 263 | cboCategory.Items.Clear; | 
|---|
|  | 264 | cboCategory.Items.Add('I^Inpatient'); | 
|---|
|  | 265 | cboCategory.SelectById('I'); | 
|---|
|  | 266 | ExtractItems(cboPlace.Items, Defaults, 'Inpt Place'); | 
|---|
|  | 267 | ExtractItems(cboUrgency.Items, Defaults, 'Inpt Cslt Urgencies');      //S.GMRCR | 
|---|
|  | 268 | ControlChange(Self); | 
|---|
|  | 269 | end; | 
|---|
|  | 270 |  | 
|---|
|  | 271 | procedure TfrmEditCslt.radOutpatientClick(Sender: TObject); | 
|---|
|  | 272 | begin | 
|---|
|  | 273 | inherited; | 
|---|
|  | 274 | cboUrgency.Items.Clear; | 
|---|
|  | 275 | cboPlace.Items.Clear; | 
|---|
|  | 276 | cboCategory.Items.Clear; | 
|---|
|  | 277 | cboCategory.Items.Add('O^Outpatient'); | 
|---|
|  | 278 | cboCategory.SelectById('O'); | 
|---|
|  | 279 | ExtractItems(cboPlace.Items, Defaults, 'Outpt Place'); | 
|---|
|  | 280 | ExtractItems(cboUrgency.Items, Defaults, 'Outpt Urgencies');     //S.GMRCO | 
|---|
|  | 281 | ControlChange(Self); | 
|---|
|  | 282 | end; | 
|---|
|  | 283 |  | 
|---|
|  | 284 |  | 
|---|
|  | 285 | procedure TfrmEditCslt.ControlChange(Sender: TObject); | 
|---|
|  | 286 | begin | 
|---|
|  | 287 | if FChanging then exit; | 
|---|
|  | 288 | with NewRec do | 
|---|
|  | 289 | begin | 
|---|
|  | 290 | with cboService do if ItemIEN > 0 then | 
|---|
|  | 291 | if ItemIEN <> OldRec.ToService then | 
|---|
|  | 292 | begin | 
|---|
|  | 293 | ToService     := ItemIEN; | 
|---|
|  | 294 | ToServiceName := Text; | 
|---|
|  | 295 | end | 
|---|
|  | 296 | else | 
|---|
|  | 297 | begin | 
|---|
|  | 298 | ToService     := 0; | 
|---|
|  | 299 | ToServiceName := ''; | 
|---|
|  | 300 | end; | 
|---|
|  | 301 |  | 
|---|
|  | 302 | with cboCategory do if Length(ItemID) > 0 then | 
|---|
|  | 303 | if ItemID <> OldRec.InpOutP then | 
|---|
|  | 304 | InpOutP := ItemID | 
|---|
|  | 305 | else | 
|---|
|  | 306 | InpOutP := ''; | 
|---|
|  | 307 |  | 
|---|
|  | 308 | with cboUrgency do if ItemIEN > 0 then | 
|---|
|  | 309 | if StrToIntDef(Piece(Items[ItemIndex], U, 3), 0) <> OldRec.Urgency then | 
|---|
|  | 310 | begin | 
|---|
|  | 311 | Urgency     := StrToIntDef(Piece(Items[ItemIndex], U, 3), 0); | 
|---|
|  | 312 | UrgencyName := Text; | 
|---|
|  | 313 | end | 
|---|
|  | 314 | else | 
|---|
|  | 315 | begin | 
|---|
|  | 316 | Urgency     := 0; | 
|---|
|  | 317 | UrgencyName := ''; | 
|---|
|  | 318 | end; | 
|---|
|  | 319 |  | 
|---|
|  | 320 | with cboPlace do if Length(ItemID) > 0 then | 
|---|
|  | 321 | if ItemID <> OldRec.Place then | 
|---|
|  | 322 | begin | 
|---|
|  | 323 | Place     := ItemID; | 
|---|
|  | 324 | PlaceName := Text; | 
|---|
|  | 325 | end | 
|---|
|  | 326 | else | 
|---|
|  | 327 | begin | 
|---|
|  | 328 | Place     := ''; | 
|---|
|  | 329 | PlaceName := ''; | 
|---|
|  | 330 | end; | 
|---|
|  | 331 |  | 
|---|
|  | 332 | with txtAttn do | 
|---|
|  | 333 | if ItemIEN > 0 then | 
|---|
|  | 334 | begin | 
|---|
|  | 335 | if ItemIEN <> OldRec.Attention then | 
|---|
|  | 336 | begin | 
|---|
|  | 337 | Attention := ItemIEN; | 
|---|
|  | 338 | AttnName  := Text; | 
|---|
|  | 339 | end | 
|---|
|  | 340 | else | 
|---|
|  | 341 | begin | 
|---|
|  | 342 | Attention := 0; | 
|---|
|  | 343 | AttnName  := ''; | 
|---|
|  | 344 | end; | 
|---|
|  | 345 | end | 
|---|
|  | 346 | else  // blank | 
|---|
|  | 347 | begin | 
|---|
|  | 348 | if OldRec.Attention > 0 then | 
|---|
|  | 349 | begin | 
|---|
|  | 350 | Attention := -1; | 
|---|
|  | 351 | AttnName  := ''; | 
|---|
|  | 352 | end | 
|---|
|  | 353 | else | 
|---|
|  | 354 | begin | 
|---|
|  | 355 | Attention := 0; | 
|---|
|  | 356 | AttnName  := ''; | 
|---|
|  | 357 | end; | 
|---|
|  | 358 | end; | 
|---|
|  | 359 |  | 
|---|
|  | 360 | with txtProvDiag do | 
|---|
|  | 361 | if Length(Text) > 0 then | 
|---|
|  | 362 | begin | 
|---|
|  | 363 | if Text <> OldRec.ProvDiagnosis then | 
|---|
|  | 364 | ProvDiagnosis := Text | 
|---|
|  | 365 | else | 
|---|
|  | 366 | ProvDiagnosis := ''; | 
|---|
|  | 367 |  | 
|---|
|  | 368 | if ProvDx.Code <> OldRec.ProvDxCode then | 
|---|
|  | 369 | ProvDxCode := ProvDx.Code | 
|---|
|  | 370 | else | 
|---|
|  | 371 | ProvDxCode := ''; | 
|---|
|  | 372 |  | 
|---|
|  | 373 | if OldRec.ProvDxCodeInactive then | 
|---|
|  | 374 | ProvDx.CodeInactive := (ProvDx.Code = OldRec.ProvDxCode); | 
|---|
|  | 375 | end | 
|---|
|  | 376 | else  //blank | 
|---|
|  | 377 | begin | 
|---|
|  | 378 | ProvDx.Code := ''; | 
|---|
|  | 379 | ProvDx.CodeInactive := False; | 
|---|
|  | 380 | if OldRec.ProvDiagnosis <> '' then | 
|---|
|  | 381 | ProvDiagnosis := '@' | 
|---|
|  | 382 | else | 
|---|
|  | 383 | ProvDiagnosis := ''; | 
|---|
|  | 384 | end; | 
|---|
|  | 385 |  | 
|---|
|  | 386 | with memReason do if Lines.Count > 0 then | 
|---|
|  | 387 | if Lines.Equals(OldRec.RequestReason) then | 
|---|
|  | 388 | RequestReason.Clear | 
|---|
|  | 389 | else | 
|---|
|  | 390 | RequestReason.Assign(Lines); | 
|---|
|  | 391 |  | 
|---|
|  | 392 | with memComment do | 
|---|
|  | 393 | if GetTextLen > 0 then | 
|---|
|  | 394 | NewComments.Assign(Lines) | 
|---|
|  | 395 | else | 
|---|
|  | 396 | NewComments.Clear; | 
|---|
|  | 397 | end; | 
|---|
|  | 398 | end; | 
|---|
|  | 399 |  | 
|---|
|  | 400 | procedure TfrmEditCslt.FormClose(Sender: TObject; var Action: TCloseAction); | 
|---|
|  | 401 | const | 
|---|
|  | 402 | TX_ACCEPT = 'Resubmit this request?' + CRLF + CRLF; | 
|---|
|  | 403 | TX_ACCEPT_CAP = 'Unsaved Changes'; | 
|---|
|  | 404 | begin | 
|---|
|  | 405 | if FChanged then | 
|---|
|  | 406 | if InfoBox(TX_ACCEPT, TX_ACCEPT_CAP, MB_YESNO) = ID_YES then | 
|---|
|  | 407 | if not ValidSave then Action := caNone; | 
|---|
|  | 408 | end; | 
|---|
|  | 409 |  | 
|---|
|  | 410 | procedure TfrmEditCslt.cmdAcceptClick(Sender: TObject); | 
|---|
|  | 411 | {Begin BillingAware} | 
|---|
|  | 412 | var | 
|---|
|  | 413 | BADiagnosis: string; | 
|---|
|  | 414 | //newDxRec: TBADxRecord; | 
|---|
|  | 415 | //AnOrder: TOrder; | 
|---|
|  | 416 | {End BillingAware} | 
|---|
|  | 417 | begin | 
|---|
|  | 418 |  | 
|---|
|  | 419 | {Begin BillingAware} | 
|---|
|  | 420 | if  BILLING_AWARE then | 
|---|
|  | 421 | begin | 
|---|
|  | 422 | if BADxUpdated then | 
|---|
|  | 423 | begin | 
|---|
|  | 424 | BADiagnosis := ProvDx.Text + '^' + ProvDx.Code; | 
|---|
|  | 425 | UBAGlobals.Dx1 := BADiagnosis;  //  add selected dx to BA Dx List. | 
|---|
|  | 426 | UBAGlobals.SimpleAddTempDxList(UBAGlobals.BAOrderID); | 
|---|
|  | 427 | end; | 
|---|
|  | 428 | end; | 
|---|
|  | 429 | {End BillingAware} | 
|---|
|  | 430 |  | 
|---|
|  | 431 | if ValidSave then | 
|---|
|  | 432 | begin | 
|---|
|  | 433 | FChanged := (ResubmitConsult(NewRec) = '0'); | 
|---|
|  | 434 | Close; | 
|---|
|  | 435 | end; | 
|---|
|  | 436 | end; | 
|---|
|  | 437 |  | 
|---|
|  | 438 | procedure TfrmEditCslt.memReasonExit(Sender: TObject); | 
|---|
|  | 439 | var | 
|---|
|  | 440 | AStringList: TStringList; | 
|---|
|  | 441 | begin | 
|---|
|  | 442 | inherited; | 
|---|
|  | 443 | AStringList := TStringList.Create; | 
|---|
|  | 444 | try | 
|---|
|  | 445 | AStringList.Assign(memReason.Lines); | 
|---|
|  | 446 | LimitStringLength(AStringList, 74); | 
|---|
|  | 447 | memReason.Lines.Assign(AstringList); | 
|---|
|  | 448 | ControlChange(Self); | 
|---|
|  | 449 | finally | 
|---|
|  | 450 | AStringList.Free; | 
|---|
|  | 451 | end; | 
|---|
|  | 452 | end; | 
|---|
|  | 453 |  | 
|---|
|  | 454 | procedure TfrmEditCslt.cmdQuitClick(Sender: TObject); | 
|---|
|  | 455 | begin | 
|---|
|  | 456 | inherited; | 
|---|
|  | 457 | FChanged := False; | 
|---|
|  | 458 | Close; | 
|---|
|  | 459 | end; | 
|---|
|  | 460 |  | 
|---|
|  | 461 | function TfrmEditCslt.ValidSave: Boolean; | 
|---|
|  | 462 | const | 
|---|
|  | 463 | TX_NO_SAVE     = 'This request cannot be saved for the following reason(s):' + CRLF + CRLF; | 
|---|
|  | 464 | TX_NO_SAVE_CAP = 'Unable to Save Request'; | 
|---|
|  | 465 | TX_SAVE_ERR    = 'Unexpected error - it was not possible to save this request.'; | 
|---|
|  | 466 | var | 
|---|
|  | 467 | ErrMsg: string; | 
|---|
|  | 468 | begin | 
|---|
|  | 469 | Result := True; | 
|---|
|  | 470 | Validate(ErrMsg); | 
|---|
|  | 471 | if Length(ErrMsg) > 0 then | 
|---|
|  | 472 | begin | 
|---|
|  | 473 | InfoBox(TX_NO_SAVE + ErrMsg, TX_NO_SAVE_CAP, MB_OK); | 
|---|
|  | 474 | Result := False; | 
|---|
|  | 475 | end; | 
|---|
|  | 476 | if (ProvDx.Reqd = 'R') and (Length(txtProvDiag.Text) = 0) and (ProvDx.PromptMode = 'L') then | 
|---|
|  | 477 | cmdLexSearchClick(Self); | 
|---|
|  | 478 | end; | 
|---|
|  | 479 |  | 
|---|
|  | 480 |  | 
|---|
|  | 481 | procedure TfrmEditCslt.OrderMessage(const AMessage: string); | 
|---|
|  | 482 | begin | 
|---|
|  | 483 | memMessage.Lines.SetText(PChar(AMessage)); | 
|---|
|  | 484 | if ContainsVisibleChar(AMessage) then | 
|---|
|  | 485 | begin | 
|---|
|  | 486 | pnlMessage.Visible := True; | 
|---|
|  | 487 | pnlMessage.BringToFront; | 
|---|
|  | 488 | uMessageVisible := GetTickCount; | 
|---|
|  | 489 | end | 
|---|
|  | 490 | else pnlMessage.Visible := False; | 
|---|
|  | 491 | end; | 
|---|
|  | 492 |  | 
|---|
|  | 493 | procedure TfrmEditCslt.btnCmtCancelClick(Sender: TObject); | 
|---|
|  | 494 | begin | 
|---|
|  | 495 | ReportBox(OldRec.DenyComments, 'Cancellation Comments', False); | 
|---|
|  | 496 | end; | 
|---|
|  | 497 |  | 
|---|
|  | 498 | procedure TfrmEditCslt.btnCmtOtherClick(Sender: TObject); | 
|---|
|  | 499 | begin | 
|---|
|  | 500 | ReportBox(OldRec.OtherComments, 'Added Comments', False); | 
|---|
|  | 501 | end; | 
|---|
|  | 502 |  | 
|---|
|  | 503 | procedure TfrmEditCslt.cmdLexSearchClick(Sender: TObject); | 
|---|
|  | 504 | var | 
|---|
|  | 505 | Match: string; | 
|---|
|  | 506 | i: integer; | 
|---|
|  | 507 | begin | 
|---|
|  | 508 | inherited; | 
|---|
|  | 509 | {Begin BillingAware} | 
|---|
|  | 510 | if  BILLING_AWARE then BADxUpdated := FALSE; | 
|---|
|  | 511 | {End BillingAware} | 
|---|
|  | 512 | LexiconLookup(Match, LX_ICD); | 
|---|
|  | 513 | if Match = '' then Exit; | 
|---|
|  | 514 | ProvDx.Code := Piece(Match, U, 1); | 
|---|
|  | 515 | ProvDx.Text := Piece(Match, U, 2); | 
|---|
|  | 516 | i := Pos(' (ICD', ProvDx.Text); | 
|---|
|  | 517 | if i = 0 then i := Length(ProvDx.Text) + 1; | 
|---|
|  | 518 | if ProvDx.Text[i-1] = '*' then i := i - 2; | 
|---|
|  | 519 | ProvDx.Text := Copy(ProvDx.Text, 1, i - 1); | 
|---|
|  | 520 | txtProvDiag.Text := ProvDx.Text + ' (' + ProvDx.Code + ')'; | 
|---|
|  | 521 | {Begin BillingAware} | 
|---|
|  | 522 | if  BILLING_AWARE then BADxUpdated := TRUE; | 
|---|
|  | 523 | {End BillingAware} | 
|---|
|  | 524 | ProvDx.CodeInactive := False; | 
|---|
|  | 525 | end; | 
|---|
|  | 526 |  | 
|---|
|  | 527 | procedure TfrmEditCslt.SetProvDiagPromptingMode; | 
|---|
|  | 528 | const | 
|---|
|  | 529 | TX_USE_LEXICON = 'You must use the "Lexicon" button to select a provisional diagnosis for this service.'; | 
|---|
|  | 530 | TX_PROVDX_OPT  = 'Provisional Diagnosis'; | 
|---|
|  | 531 | TX_PROVDX_REQD = 'Provisional Dx (REQUIRED)'; | 
|---|
|  | 532 | begin | 
|---|
|  | 533 | cmdLexSearch.Enabled   := False; | 
|---|
|  | 534 | txtProvDiag.Enabled    := False; | 
|---|
|  | 535 | txtProvDiag.ReadOnly   := True; | 
|---|
|  | 536 | txtProvDiag.Color      := clBtnFace; | 
|---|
|  | 537 | txtProvDiag.Font.Color := clBtnText; | 
|---|
|  | 538 | lblProvDiag.Enabled    := False; | 
|---|
|  | 539 | txtProvDiag.Hint       := ''; | 
|---|
|  | 540 | if cboService.ItemIEN = 0 then Exit; | 
|---|
|  | 541 | GetProvDxMode(ProvDx, cboService.ItemID + CSLT_PTR); | 
|---|
|  | 542 | //  Returns:  string  A^B | 
|---|
|  | 543 | //     A = O (optional), R (required) or S (suppress) | 
|---|
|  | 544 | //     B = F (free-text) or L (lexicon) | 
|---|
|  | 545 | with ProvDx do if (Reqd = '') or (PromptMode = '') then Exit; | 
|---|
|  | 546 | if ProvDx.Reqd = 'R' then | 
|---|
|  | 547 | lblProvDiag.Caption := TX_PROVDX_REQD | 
|---|
|  | 548 | else | 
|---|
|  | 549 | lblProvDiag.Caption := TX_PROVDX_OPT; | 
|---|
|  | 550 | if ProvDx.Reqd = 'S' then | 
|---|
|  | 551 | begin | 
|---|
|  | 552 | cmdLexSearch.Enabled   := False; | 
|---|
|  | 553 | txtProvDiag.Enabled    := False; | 
|---|
|  | 554 | txtProvDiag.ReadOnly   := True; | 
|---|
|  | 555 | txtProvDiag.Color      := clBtnFace; | 
|---|
|  | 556 | txtProvDiag.Font.Color := clBtnText; | 
|---|
|  | 557 | lblProvDiag.Enabled    := False; | 
|---|
|  | 558 | end | 
|---|
|  | 559 | else | 
|---|
|  | 560 | case ProvDx.PromptMode[1] of | 
|---|
|  | 561 | 'F':  begin | 
|---|
|  | 562 | cmdLexSearch.Enabled   := False; | 
|---|
|  | 563 | txtProvDiag.Enabled    := True; | 
|---|
|  | 564 | txtProvDiag.ReadOnly   := False; | 
|---|
|  | 565 | txtProvDiag.Color      := clWindow; | 
|---|
|  | 566 | txtProvDiag.Font.Color := clWindowText; | 
|---|
|  | 567 | lblProvDiag.Enabled    := True; | 
|---|
|  | 568 | end; | 
|---|
|  | 569 | 'L':  begin | 
|---|
|  | 570 | cmdLexSearch.Enabled   := True; | 
|---|
|  | 571 | txtProvDiag.Enabled    := True; | 
|---|
|  | 572 | txtProvDiag.ReadOnly   := True; | 
|---|
|  | 573 | txtProvDiag.Color      := clInfoBk; | 
|---|
|  | 574 | txtProvDiag.Font.Color := clInfoText; | 
|---|
|  | 575 | lblProvDiag.Enabled    := True; | 
|---|
|  | 576 | txtProvDiag.Hint       := TX_USE_LEXICON; | 
|---|
|  | 577 | end; | 
|---|
|  | 578 | end; | 
|---|
|  | 579 | end; | 
|---|
|  | 580 |  | 
|---|
|  | 581 | procedure TfrmEditCslt.mnuPopProvDxDeleteClick(Sender: TObject); | 
|---|
|  | 582 | begin | 
|---|
|  | 583 | inherited; | 
|---|
|  | 584 | ProvDx.Text := ''; | 
|---|
|  | 585 | ProvDx.Code := ''; | 
|---|
|  | 586 | ProvDx.CodeInactive := False; | 
|---|
|  | 587 | txtProvDiag.Text := ''; | 
|---|
|  | 588 | ControlChange(Self); | 
|---|
|  | 589 | end; | 
|---|
|  | 590 |  | 
|---|
|  | 591 | procedure TfrmEditCslt.popReasonPopup(Sender: TObject); | 
|---|
|  | 592 | begin | 
|---|
|  | 593 | inherited; | 
|---|
|  | 594 | if PopupComponent(Sender, popReason) is TCustomEdit | 
|---|
|  | 595 | then FEditCtrl := TCustomEdit(PopupComponent(Sender, popReason)) | 
|---|
|  | 596 | else FEditCtrl := nil; | 
|---|
|  | 597 | if FEditCtrl <> nil then | 
|---|
|  | 598 | begin | 
|---|
|  | 599 | popReasonCut.Enabled      := FEditCtrl.SelLength > 0; | 
|---|
|  | 600 | popReasonCopy.Enabled     := popReasonCut.Enabled; | 
|---|
|  | 601 | popReasonPaste.Enabled    := (not TORExposedCustomEdit(FEditCtrl).ReadOnly) and | 
|---|
|  | 602 | Clipboard.HasFormat(CF_TEXT); | 
|---|
|  | 603 | end else | 
|---|
|  | 604 | begin | 
|---|
|  | 605 | popReasonCut.Enabled      := False; | 
|---|
|  | 606 | popReasonCopy.Enabled     := False; | 
|---|
|  | 607 | popReasonPaste.Enabled    := False; | 
|---|
|  | 608 | end; | 
|---|
|  | 609 | popReasonReformat.Enabled := True; | 
|---|
|  | 610 | end; | 
|---|
|  | 611 |  | 
|---|
|  | 612 | procedure TfrmEditCslt.popReasonCutClick(Sender: TObject); | 
|---|
|  | 613 | begin | 
|---|
|  | 614 | inherited; | 
|---|
|  | 615 | FEditCtrl.CutToClipboard; | 
|---|
|  | 616 | end; | 
|---|
|  | 617 |  | 
|---|
|  | 618 | procedure TfrmEditCslt.popReasonCopyClick(Sender: TObject); | 
|---|
|  | 619 | begin | 
|---|
|  | 620 | inherited; | 
|---|
|  | 621 | FEditCtrl.CopyToClipboard; | 
|---|
|  | 622 | end; | 
|---|
|  | 623 |  | 
|---|
|  | 624 | procedure TfrmEditCslt.popReasonPasteClick(Sender: TObject); | 
|---|
|  | 625 | begin | 
|---|
|  | 626 | inherited; | 
|---|
|  | 627 | FEditCtrl.SelText := Clipboard.AsText; | 
|---|
|  | 628 | end; | 
|---|
|  | 629 |  | 
|---|
|  | 630 | procedure TfrmEditCslt.popReasonReformatClick(Sender: TObject); | 
|---|
|  | 631 | begin | 
|---|
|  | 632 | inherited; | 
|---|
|  | 633 | if (Screen.ActiveControl <> memReason) and | 
|---|
|  | 634 | (Screen.ActiveControl <> memComment)then Exit; | 
|---|
|  | 635 | ReformatMemoParagraph(TCustomMemo(FEditCtrl)); | 
|---|
|  | 636 | end; | 
|---|
|  | 637 |  | 
|---|
|  | 638 | procedure TfrmEditCslt.memCommentKeyUp(Sender: TObject; var Key: Word; | 
|---|
|  | 639 | Shift: TShiftState); | 
|---|
|  | 640 | begin | 
|---|
|  | 641 | if FNavigatingTab then | 
|---|
|  | 642 | begin | 
|---|
|  | 643 | if ssShift in Shift then | 
|---|
|  | 644 | FindNextControl(Sender as TWinControl, False, True, False).SetFocus //previous control | 
|---|
|  | 645 | else if ssCtrl      in Shift then | 
|---|
|  | 646 | FindNextControl(Sender as TWinControl, True, True, False).SetFocus; //next control | 
|---|
|  | 647 | FNavigatingTab := False; | 
|---|
|  | 648 | end; | 
|---|
|  | 649 | if (key = VK_ESCAPE) then begin | 
|---|
|  | 650 | FindNextControl(Sender as TWinControl, False, True, False).SetFocus; //previous control | 
|---|
|  | 651 | key := 0; | 
|---|
|  | 652 | end; | 
|---|
|  | 653 | end; | 
|---|
|  | 654 |  | 
|---|
|  | 655 | procedure TfrmEditCslt.memCommentKeyDown(Sender: TObject; var Key: Word; | 
|---|
|  | 656 | Shift: TShiftState); | 
|---|
|  | 657 | begin | 
|---|
|  | 658 | //The navigating tab controls were inadvertantently adding tab characters | 
|---|
|  | 659 | //This should fix it | 
|---|
|  | 660 | FNavigatingTab := (Key = VK_TAB) and ([ssShift,ssCtrl] * Shift <> []); | 
|---|
|  | 661 | if FNavigatingTab then | 
|---|
|  | 662 | Key := 0; | 
|---|
|  | 663 | end; | 
|---|
|  | 664 |  | 
|---|
|  | 665 | procedure TfrmEditCslt.memCommentKeyPress(Sender: TObject; var Key: Char); | 
|---|
|  | 666 | begin | 
|---|
|  | 667 | if FNavigatingTab then | 
|---|
|  | 668 | Key := #0;  //Disable shift-tab processin | 
|---|
|  | 669 | end; | 
|---|
|  | 670 |  | 
|---|
|  | 671 | end. | 
|---|