| 1 | unit fEditProc; | 
|---|
| 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, fAutoSz, ORDtTm, VA508AccessibilityManager, fBase508Form; | 
|---|
| 9 |  | 
|---|
| 10 | type | 
|---|
| 11 | TfrmEditProc = class(TfrmAutoSz) | 
|---|
| 12 | cmdAccept: TButton; | 
|---|
| 13 | cmdQuit: TButton; | 
|---|
| 14 | pnlMessage: TPanel; | 
|---|
| 15 | imgMessage: TImage; | 
|---|
| 16 | memMessage: TRichEdit; | 
|---|
| 17 | pnlMain: TPanel; | 
|---|
| 18 | lblProc: TLabel; | 
|---|
| 19 | lblReason: TLabel; | 
|---|
| 20 | lblService: TOROffsetLabel; | 
|---|
| 21 | lblComment: TLabel; | 
|---|
| 22 | lblComments: TLabel; | 
|---|
| 23 | lblUrgency: TStaticText; | 
|---|
| 24 | lblPlace: TStaticText; | 
|---|
| 25 | lblAttn: TStaticText; | 
|---|
| 26 | lblProvDiag: TStaticText; | 
|---|
| 27 | lblInpOutp: TStaticText; | 
|---|
| 28 | memReason: TRichEdit; | 
|---|
| 29 | cboUrgency: TORComboBox; | 
|---|
| 30 | radInpatient: TRadioButton; | 
|---|
| 31 | radOutpatient: TRadioButton; | 
|---|
| 32 | cboPlace: TORComboBox; | 
|---|
| 33 | txtProvDiag: TCaptionEdit; | 
|---|
| 34 | txtAttn: TORComboBox; | 
|---|
| 35 | cboProc: TORComboBox; | 
|---|
| 36 | cboCategory: TORComboBox; | 
|---|
| 37 | cboService: TORComboBox; | 
|---|
| 38 | memComment: TRichEdit; | 
|---|
| 39 | btnCmtCancel: TButton; | 
|---|
| 40 | btnCmtOther: TButton; | 
|---|
| 41 | cmdLexSearch: TButton; | 
|---|
| 42 | lblEarliest: TStaticText; | 
|---|
| 43 | lblLatest: TStaticText; | 
|---|
| 44 | calEarliest: TORDateBox; | 
|---|
| 45 | calLatest: TORDateBox; | 
|---|
| 46 | mnuPopProvDx: TPopupMenu; | 
|---|
| 47 | mnuPopProvDxDelete: TMenuItem; | 
|---|
| 48 | popReason: TPopupMenu; | 
|---|
| 49 | popReasonCut: TMenuItem; | 
|---|
| 50 | popReasonCopy: TMenuItem; | 
|---|
| 51 | popReasonPaste: TMenuItem; | 
|---|
| 52 | popReasonPaste2: TMenuItem; | 
|---|
| 53 | popReasonReformat: TMenuItem; | 
|---|
| 54 | pnlCombatVet: TPanel; | 
|---|
| 55 | txtCombatVet: TVA508StaticText; | 
|---|
| 56 | procedure txtAttnNeedData(Sender: TObject; const StartFrom: String; | 
|---|
| 57 | Direction, InsertAt: Integer); | 
|---|
| 58 | procedure cboProcNeedData(Sender: TObject; const StartFrom: String; | 
|---|
| 59 | Direction, InsertAt: Integer); | 
|---|
| 60 | procedure radInpatientClick(Sender: TObject); | 
|---|
| 61 | procedure radOutpatientClick(Sender: TObject); | 
|---|
| 62 | procedure ControlChange(Sender: TObject); | 
|---|
| 63 | procedure FormClose(Sender: TObject; var Action: TCloseAction); | 
|---|
| 64 | procedure cboProcSelect(Sender: TObject); | 
|---|
| 65 | procedure memReasonExit(Sender: TObject); | 
|---|
| 66 | procedure cmdAcceptClick(Sender: TObject); | 
|---|
| 67 | procedure cmdQuitClick(Sender: TObject); | 
|---|
| 68 | procedure OrderMessage(const AMessage: string); | 
|---|
| 69 | procedure btnCmtCancelClick(Sender: TObject); | 
|---|
| 70 | procedure btnCmtOtherClick(Sender: TObject); | 
|---|
| 71 | procedure cmdLexSearchClick(Sender: TObject); | 
|---|
| 72 | procedure mnuPopProvDxDeleteClick(Sender: TObject); | 
|---|
| 73 | procedure popReasonCutClick(Sender: TObject); | 
|---|
| 74 | procedure popReasonCopyClick(Sender: TObject); | 
|---|
| 75 | procedure popReasonPasteClick(Sender: TObject); | 
|---|
| 76 | procedure popReasonPopup(Sender: TObject); | 
|---|
| 77 | procedure popReasonReformatClick(Sender: TObject); | 
|---|
| 78 | procedure memCommentKeyUp(Sender: TObject; var Key: Word; | 
|---|
| 79 | Shift: TShiftState); | 
|---|
| 80 | procedure memReasonKeyDown(Sender: TObject; var Key: Word; | 
|---|
| 81 | Shift: TShiftState); | 
|---|
| 82 | procedure memReasonKeyPress(Sender: TObject; var Key: Char); | 
|---|
| 83 | procedure calEarliestExit(Sender: TObject); | 
|---|
| 84 | procedure calLatestExit(Sender: TObject); | 
|---|
| 85 | procedure memCommentExit(Sender: TObject); | 
|---|
| 86 | private | 
|---|
| 87 | FLastProcID: string; | 
|---|
| 88 | FChanged: boolean; | 
|---|
| 89 | FChanging: boolean; | 
|---|
| 90 | FEditCtrl: TCustomEdit; | 
|---|
| 91 | FNavigatingTab: boolean; | 
|---|
| 92 | FEarliestDate: TFMDateTime; | 
|---|
| 93 | //FLatestDate: TFMDateTime; | 
|---|
| 94 | procedure SetProvDiagPromptingMode; | 
|---|
| 95 | procedure SetUpCombatVet; | 
|---|
| 96 | protected | 
|---|
| 97 | procedure InitDialog; | 
|---|
| 98 | procedure Validate(var AnErrMsg: string); | 
|---|
| 99 | function  ValidSave: Boolean; | 
|---|
| 100 | end; | 
|---|
| 101 |  | 
|---|
| 102 |  | 
|---|
| 103 | function EditResubmitProcedure(FontSize: Integer; ConsultIEN: integer): boolean; | 
|---|
| 104 |  | 
|---|
| 105 | var | 
|---|
| 106 | frmEditProc: TfrmEditProc; | 
|---|
| 107 |  | 
|---|
| 108 | implementation | 
|---|
| 109 |  | 
|---|
| 110 | {$R *.DFM} | 
|---|
| 111 |  | 
|---|
| 112 | uses | 
|---|
| 113 | rConsults, uCore, rCore, fConsults, rODBase, fRptBox, fPCELex, rPCE, ORClasses, clipbrd ; | 
|---|
| 114 |  | 
|---|
| 115 | var | 
|---|
| 116 | OldRec, NewRec: TEditResubmitRec; | 
|---|
| 117 | Defaults: TStringList; | 
|---|
| 118 | uMessageVisible: DWORD; | 
|---|
| 119 | ProvDx: TProvisionalDiagnosis; | 
|---|
| 120 |  | 
|---|
| 121 | const | 
|---|
| 122 | TX_NO_PROC         = 'A procedure must be specified.'    ; | 
|---|
| 123 | TX_NO_REASON       = 'A reason for this procedure must be entered.'  ; | 
|---|
| 124 | TX_NO_SERVICE      = 'A service must be selected to perform this procedure.'; | 
|---|
| 125 | TX_NO_URGENCY      = 'An urgency must be specified.'; | 
|---|
| 126 | TX_NO_PLACE        = 'A place of consultation must be specified'; | 
|---|
| 127 | TX_NO_DIAG         = 'A provisional diagnosis must be entered for consults to this service.'; | 
|---|
| 128 | TX_SELECT_DIAG     = 'You must use the "Lexicon" button to select a diagnosis for consults to this service.'; | 
|---|
| 129 | TX_INACTIVE_CODE   = 'The provisional diagnosis code is not active as of today''s date.' + #13#10 + | 
|---|
| 130 | 'Another code must be selected'; | 
|---|
| 131 | TC_INACTIVE_CODE   = 'Inactive ICD Code'; | 
|---|
| 132 | TX_PAST_DATE       = 'Earliest appropriate date must be today or later.'; | 
|---|
| 133 | TX_BAD_DATES       = 'Latest appropriate date must be equal to or later than earliest date.'; | 
|---|
| 134 |  | 
|---|
| 135 | function EditResubmitProcedure(FontSize: Integer; ConsultIEN: integer): boolean; | 
|---|
| 136 | begin | 
|---|
| 137 | Result := False; | 
|---|
| 138 | if ConsultIEN = 0 then exit; | 
|---|
| 139 | FillChar(OldRec, SizeOf(OldRec), 0); | 
|---|
| 140 | FillChar(NewRec, SizeOf(NewRec), 0); | 
|---|
| 141 | FillChar(ProvDx, SizeOf(ProvDx), 0); | 
|---|
| 142 | OldRec := LoadConsultForEdit(ConsultIEN); | 
|---|
| 143 | NewRec.IEN := OldRec.IEN; | 
|---|
| 144 | NewRec.RequestType := OldRec.RequestType; | 
|---|
| 145 | with NewRec do | 
|---|
| 146 | begin | 
|---|
| 147 | RequestReason:= TStringList.Create ; | 
|---|
| 148 | DenyComments:= TStringList.Create ; | 
|---|
| 149 | OtherComments:= TStringList.Create ; | 
|---|
| 150 | NewComments:= TStringList.Create ; | 
|---|
| 151 | end; | 
|---|
| 152 | StatusText('Loading Procedure for Edit'); | 
|---|
| 153 | frmEditProc := TfrmEditProc.Create(Application); | 
|---|
| 154 | Defaults    := TStringList.Create; | 
|---|
| 155 | try | 
|---|
| 156 | ResizeAnchoredFormToFont(frmEditProc); | 
|---|
| 157 | with frmEditProc do | 
|---|
| 158 | begin | 
|---|
| 159 | FChanged     := False; | 
|---|
| 160 | InitDialog; | 
|---|
| 161 | ShowModal ; | 
|---|
| 162 | Result := FChanged ; | 
|---|
| 163 | end ; | 
|---|
| 164 | finally | 
|---|
| 165 | OldRec.RequestReason.Free; | 
|---|
| 166 | OldRec.DenyComments.Free; | 
|---|
| 167 | OldRec.OtherComments.Free; | 
|---|
| 168 | OldRec.NewComments.Free; | 
|---|
| 169 | NewRec.RequestReason.Free; | 
|---|
| 170 | NewRec.DenyComments.Free; | 
|---|
| 171 | NewRec.OtherComments.Free; | 
|---|
| 172 | NewRec.NewComments.Free; | 
|---|
| 173 | Defaults.Free; | 
|---|
| 174 | frmEditProc.Release; | 
|---|
| 175 | end; | 
|---|
| 176 | end; | 
|---|
| 177 |  | 
|---|
| 178 | procedure TfrmEditProc.InitDialog; | 
|---|
| 179 | var | 
|---|
| 180 | i: integer; | 
|---|
| 181 | begin | 
|---|
| 182 | if FChanging then exit; | 
|---|
| 183 | FChanging := True; | 
|---|
| 184 | Defaults := TStringList.Create; | 
|---|
| 185 | FastAssign(ODForProcedures, Defaults); | 
|---|
| 186 | FLastProcID := ''; | 
|---|
| 187 | cboProc.InitLongList(OldRec.ConsultProcName) ; | 
|---|
| 188 | cboProc.SelectByIEN(OldRec.OrderableItem); | 
|---|
| 189 | if cboProc.ItemIndex = -1 then | 
|---|
| 190 | begin | 
|---|
| 191 | cboProc.Items.Insert(0, IntToStr(OldRec.OrderableItem) + U + OldRec.ConsultProcName + | 
|---|
| 192 | U + OldRec.ConsultProcName + U + OldRec.ConsultProc); | 
|---|
| 193 | cboProc.ItemIndex := 0; | 
|---|
| 194 | end; | 
|---|
| 195 | cboProcSelect(Self); | 
|---|
| 196 | txtAttn.InitLongList(OldRec.AttnName) ; | 
|---|
| 197 | if OldRec.Attention > 0 then | 
|---|
| 198 | txtAttn.SelectByIEN(OldRec.Attention) | 
|---|
| 199 | else | 
|---|
| 200 | txtAttn.ItemIndex := -1; | 
|---|
| 201 | cboService.SelectByIEN(OldRec.ToService); | 
|---|
| 202 | if OldRec.InpOutp <> '' then | 
|---|
| 203 | case OldRec.InpOutp[1] of | 
|---|
| 204 | 'I': radInpatient.Checked  := True;                 //INPATIENT PROCEDURE | 
|---|
| 205 | 'O': radOutpatient.Checked := True;                 //OUTPATIENT PROCEDURE | 
|---|
| 206 | end | 
|---|
| 207 | else | 
|---|
| 208 | begin | 
|---|
| 209 | if Patient.Inpatient then | 
|---|
| 210 | radInpatient.Checked  := True | 
|---|
| 211 | else | 
|---|
| 212 | radOutpatient.Checked := True; | 
|---|
| 213 | end; | 
|---|
| 214 | cboPlace.SelectByID(OldRec.Place); | 
|---|
| 215 | with cboUrgency do for i := 0 to Items.Count-1 do | 
|---|
| 216 | if UpperCase(DisplayText[i]) = UpperCase(OldRec.UrgencyName) then ItemIndex := i; | 
|---|
| 217 | calEarliest.FMDateTime := OldRec.EarliestDate; | 
|---|
| 218 | FEarliestDate := OldRec.EarliestDate; | 
|---|
| 219 | //calLatest.FMDateTime := OldRec.LatestDate; | 
|---|
| 220 | //FLatestDate := OldRec.LatestDate; | 
|---|
| 221 | txtProvDiag.Text := OldRec.ProvDiagnosis; | 
|---|
| 222 | ProvDx.Code := OldRec.ProvDxCode; | 
|---|
| 223 | if OldRec.ProvDxCodeInactive then | 
|---|
| 224 | begin | 
|---|
| 225 | InfoBox(TX_INACTIVE_CODE, TC_INACTIVE_CODE, MB_ICONWARNING or MB_OK); | 
|---|
| 226 | ProvDx.CodeInactive := True; | 
|---|
| 227 | end; | 
|---|
| 228 | QuickCopy(OldRec.RequestReason, memReason); | 
|---|
| 229 | btnCmtCancel.Enabled := (OldRec.DenyComments.Count > 0); | 
|---|
| 230 | btnCmtOther.Enabled := (OldRec.OtherComments.Count > 0); | 
|---|
| 231 | memComment.Clear ; | 
|---|
| 232 | SetProvDiagPromptingMode; | 
|---|
| 233 | if (patient.CombatVet.IsEligible = True) then | 
|---|
| 234 | begin | 
|---|
| 235 | SetUpCombatVet; | 
|---|
| 236 | end | 
|---|
| 237 | else | 
|---|
| 238 | begin | 
|---|
| 239 | txtCombatVet.Enabled := False; | 
|---|
| 240 | pnlCombatVet.SendToBack; | 
|---|
| 241 | end; | 
|---|
| 242 | FChanging := False; | 
|---|
| 243 | StatusText(''); | 
|---|
| 244 | end; | 
|---|
| 245 |  | 
|---|
| 246 | procedure TfrmEditProc.Validate(var AnErrMsg: string); | 
|---|
| 247 |  | 
|---|
| 248 | procedure SetError(const x: string); | 
|---|
| 249 | begin | 
|---|
| 250 | if Length(AnErrMsg) > 0 then AnErrMsg := AnErrMsg + CRLF; | 
|---|
| 251 | AnErrMsg := AnErrMsg + x; | 
|---|
| 252 | end; | 
|---|
| 253 |  | 
|---|
| 254 | begin | 
|---|
| 255 | if cboProc.ItemIEN = 0                  then SetError(TX_NO_PROC); | 
|---|
| 256 | if memReason.Lines.Count = 0            then SetError(TX_NO_REASON); | 
|---|
| 257 | if cboService.ItemIEN = 0               then SetError(TX_NO_SERVICE); | 
|---|
| 258 | if cboUrgency.ItemIEN = 0               then SetError(TX_NO_URGENCY); | 
|---|
| 259 | if cboPlace.ItemID = ''                 then SetError(TX_NO_PLACE); | 
|---|
| 260 | if (ProvDx.Reqd = 'R') and (Length(txtProvDiag.Text) = 0) then | 
|---|
| 261 | begin | 
|---|
| 262 | if ProvDx.PromptMode = 'F' then | 
|---|
| 263 | SetError(TX_NO_DIAG) | 
|---|
| 264 | else | 
|---|
| 265 | SetError(TX_SELECT_DIAG); | 
|---|
| 266 | end; | 
|---|
| 267 | if OldRec.ProvDxCodeInactive and ProvDx.CodeInactive then | 
|---|
| 268 | SetError(TX_INACTIVE_CODE); | 
|---|
| 269 | if calEarliest.FMDateTime < FMToday     then SetError(TX_PAST_DATE); | 
|---|
| 270 | //if calLatest.FMDateTime < FMToday       then SetError(TX_PAST_DATE); | 
|---|
| 271 | //if calLatest.FMDateTime < calEarliest.FMDateTime then SetError(TX_BAD_DATES); | 
|---|
| 272 | end; | 
|---|
| 273 |  | 
|---|
| 274 | procedure TfrmEditProc.txtAttnNeedData(Sender: TObject; | 
|---|
| 275 | const StartFrom: string; Direction, InsertAt: Integer); | 
|---|
| 276 | begin | 
|---|
| 277 | inherited; | 
|---|
| 278 | txtAttn.ForDataUse(SubSetOfPersons(StartFrom, Direction)); | 
|---|
| 279 | end; | 
|---|
| 280 |  | 
|---|
| 281 | procedure TfrmEditProc.calEarliestExit(Sender: TObject); | 
|---|
| 282 | begin | 
|---|
| 283 | inherited; | 
|---|
| 284 | FEarliestDate := calEarliest.FMDateTime; | 
|---|
| 285 | ControlChange(Self); | 
|---|
| 286 | end; | 
|---|
| 287 |  | 
|---|
| 288 | procedure TfrmEditProc.calLatestExit(Sender: TObject); | 
|---|
| 289 | begin | 
|---|
| 290 | inherited; | 
|---|
| 291 | //FLatestDate := calLatest.FMDateTime; | 
|---|
| 292 | //ControlChange(Self); | 
|---|
| 293 | end; | 
|---|
| 294 |  | 
|---|
| 295 | procedure TfrmEditProc.cboProcNeedData(Sender: TObject; | 
|---|
| 296 | const StartFrom: string; Direction, InsertAt: Integer); | 
|---|
| 297 | begin | 
|---|
| 298 | inherited; | 
|---|
| 299 | cboProc.ForDataUse(SubSetOfProcedures(StartFrom, Direction)); | 
|---|
| 300 | end; | 
|---|
| 301 |  | 
|---|
| 302 | procedure TfrmEditProc.radInpatientClick(Sender: TObject); | 
|---|
| 303 | begin | 
|---|
| 304 | inherited; | 
|---|
| 305 | cboCategory.Items.Clear; | 
|---|
| 306 | cboCategory.Items.Add('I^Inpatient'); | 
|---|
| 307 | cboCategory.SelectById('I'); | 
|---|
| 308 | ExtractItems(cboPlace.Items, Defaults, 'Inpt Place'); | 
|---|
| 309 | ExtractItems(cboUrgency.Items, Defaults, 'Inpt Proc Urgencies');      //S.GMRCR | 
|---|
| 310 | ControlChange(Self); | 
|---|
| 311 | end; | 
|---|
| 312 |  | 
|---|
| 313 | procedure TfrmEditProc.radOutpatientClick(Sender: TObject); | 
|---|
| 314 | begin | 
|---|
| 315 | inherited; | 
|---|
| 316 | cboCategory.Items.Clear; | 
|---|
| 317 | cboCategory.Items.Add('O^Outpatient'); | 
|---|
| 318 | cboCategory.SelectById('O'); | 
|---|
| 319 | ExtractItems(cboPlace.Items, Defaults, 'Outpt Place'); | 
|---|
| 320 | ExtractItems(cboUrgency.Items, Defaults, 'Outpt Urgencies');     //S.GMRCO | 
|---|
| 321 | ControlChange(Self); | 
|---|
| 322 | end; | 
|---|
| 323 |  | 
|---|
| 324 | procedure TfrmEditProc.ControlChange(Sender: TObject); | 
|---|
| 325 | begin | 
|---|
| 326 | if FChanging then exit; | 
|---|
| 327 | with NewRec do | 
|---|
| 328 | begin | 
|---|
| 329 | with cboProc do if ItemIEN > 0 then | 
|---|
| 330 | if Piece(Items[ItemIndex], U, 4) <> OldRec.ConsultProc then | 
|---|
| 331 | begin | 
|---|
| 332 | ConsultProc     := Piece(Items[ItemIndex], U, 4); | 
|---|
| 333 | ConsultProcName := Text; | 
|---|
| 334 | end | 
|---|
| 335 | else | 
|---|
| 336 | begin | 
|---|
| 337 | ConsultProc     := ''; | 
|---|
| 338 | ConsultProcName := ''; | 
|---|
| 339 | end; | 
|---|
| 340 |  | 
|---|
| 341 | with cboService do if ItemIEN > 0 then | 
|---|
| 342 | if ItemIEN <> OldRec.ToService then | 
|---|
| 343 | begin | 
|---|
| 344 | ToService     := ItemIEN; | 
|---|
| 345 | ToServiceName := Text; | 
|---|
| 346 | end | 
|---|
| 347 | else | 
|---|
| 348 | begin | 
|---|
| 349 | ToService     := 0; | 
|---|
| 350 | ToServiceName := ''; | 
|---|
| 351 | end; | 
|---|
| 352 |  | 
|---|
| 353 | with cboCategory do if Length(ItemID) > 0 then | 
|---|
| 354 | if ItemID <> OldRec.InpOutP then | 
|---|
| 355 | InpOutP := ItemID | 
|---|
| 356 | else | 
|---|
| 357 | InpOutP := ''; | 
|---|
| 358 |  | 
|---|
| 359 | with cboUrgency do if ItemIEN > 0 then | 
|---|
| 360 | if StrToIntDef(Piece(Items[ItemIndex], U, 3), 0) <> OldRec.Urgency then | 
|---|
| 361 | begin | 
|---|
| 362 | Urgency     := StrToIntDef(Piece(Items[ItemIndex], U, 3), 0); | 
|---|
| 363 | UrgencyName := Text; | 
|---|
| 364 | end | 
|---|
| 365 | else | 
|---|
| 366 | begin | 
|---|
| 367 | Urgency     := 0; | 
|---|
| 368 | UrgencyName := ''; | 
|---|
| 369 | end; | 
|---|
| 370 |  | 
|---|
| 371 | if FEarliestDate > 0 then | 
|---|
| 372 | begin | 
|---|
| 373 | if FEarliestDate <> OldRec.EarliestDate then | 
|---|
| 374 | EarliestDate := FEarliestDate | 
|---|
| 375 | else | 
|---|
| 376 | EarliestDate := 0; | 
|---|
| 377 | end; | 
|---|
| 378 |  | 
|---|
| 379 | (*     if FLatestDate > 0 then | 
|---|
| 380 | begin | 
|---|
| 381 | if FLatestDate <> OldRec.LatestDate then | 
|---|
| 382 | LatestDate := FLatestDate | 
|---|
| 383 | else | 
|---|
| 384 | LatestDate := 0; | 
|---|
| 385 | end;*) | 
|---|
| 386 |  | 
|---|
| 387 | with cboPlace do if Length(ItemID) > 0 then | 
|---|
| 388 | if ItemID <> OldRec.Place then | 
|---|
| 389 | begin | 
|---|
| 390 | Place     := ItemID; | 
|---|
| 391 | PlaceName := Text; | 
|---|
| 392 | end | 
|---|
| 393 | else | 
|---|
| 394 | begin | 
|---|
| 395 | Place     := ''; | 
|---|
| 396 | PlaceName := ''; | 
|---|
| 397 | end; | 
|---|
| 398 |  | 
|---|
| 399 | with txtAttn do | 
|---|
| 400 | if ItemIEN > 0 then | 
|---|
| 401 | begin | 
|---|
| 402 | if ItemIEN <> OldRec.Attention then | 
|---|
| 403 | begin | 
|---|
| 404 | Attention := ItemIEN; | 
|---|
| 405 | AttnName  := Text; | 
|---|
| 406 | end | 
|---|
| 407 | else | 
|---|
| 408 | begin | 
|---|
| 409 | Attention := 0; | 
|---|
| 410 | AttnName  := ''; | 
|---|
| 411 | end; | 
|---|
| 412 | end | 
|---|
| 413 | else  // blank | 
|---|
| 414 | begin | 
|---|
| 415 | if OldRec.Attention > 0 then | 
|---|
| 416 | begin | 
|---|
| 417 | Attention := -1; | 
|---|
| 418 | AttnName  := ''; | 
|---|
| 419 | end | 
|---|
| 420 | else | 
|---|
| 421 | begin | 
|---|
| 422 | Attention := 0; | 
|---|
| 423 | AttnName  := ''; | 
|---|
| 424 | end; | 
|---|
| 425 | end; | 
|---|
| 426 |  | 
|---|
| 427 | with txtProvDiag do | 
|---|
| 428 | if Length(Text) > 0 then | 
|---|
| 429 | begin | 
|---|
| 430 | if Text <> OldRec.ProvDiagnosis then | 
|---|
| 431 | ProvDiagnosis := Text | 
|---|
| 432 | else | 
|---|
| 433 | ProvDiagnosis := ''; | 
|---|
| 434 |  | 
|---|
| 435 | if ProvDx.Code <> OldRec.ProvDxCode then | 
|---|
| 436 | ProvDxCode := ProvDx.Code | 
|---|
| 437 | else | 
|---|
| 438 | ProvDxCode := ''; | 
|---|
| 439 |  | 
|---|
| 440 | if OldRec.ProvDxCodeInactive then | 
|---|
| 441 | ProvDx.CodeInactive := (ProvDx.Code = OldRec.ProvDxCode); | 
|---|
| 442 | end | 
|---|
| 443 | else  //blank | 
|---|
| 444 | begin | 
|---|
| 445 | ProvDx.Code := ''; | 
|---|
| 446 | ProvDx.CodeInactive := False; | 
|---|
| 447 | if OldRec.ProvDiagnosis <> '' then | 
|---|
| 448 | ProvDiagnosis := '@' | 
|---|
| 449 | else | 
|---|
| 450 | ProvDiagnosis := ''; | 
|---|
| 451 | end; | 
|---|
| 452 |  | 
|---|
| 453 | with memReason do if Lines.Count > 0 then | 
|---|
| 454 | if Lines.Equals(OldRec.RequestReason) then | 
|---|
| 455 | RequestReason.Clear | 
|---|
| 456 | else | 
|---|
| 457 | QuickCopy(memReason, RequestReason); | 
|---|
| 458 |  | 
|---|
| 459 | with memComment do | 
|---|
| 460 | if GetTextLen > 0 then | 
|---|
| 461 | QuickCopy(memComment, NewComments) | 
|---|
| 462 | else | 
|---|
| 463 | NewComments.Clear; | 
|---|
| 464 | end; | 
|---|
| 465 | end; | 
|---|
| 466 |  | 
|---|
| 467 | procedure TfrmEditProc.FormClose(Sender: TObject; var Action: TCloseAction); | 
|---|
| 468 | const | 
|---|
| 469 | TX_ACCEPT = 'Resubmit this request?' + CRLF + CRLF; | 
|---|
| 470 | TX_ACCEPT_CAP = 'Unsaved Changes'; | 
|---|
| 471 | begin | 
|---|
| 472 | if FChanged then | 
|---|
| 473 | if InfoBox(TX_ACCEPT, TX_ACCEPT_CAP, MB_YESNO) = ID_YES then | 
|---|
| 474 | if not ValidSave then Action := caNone; | 
|---|
| 475 | end; | 
|---|
| 476 |  | 
|---|
| 477 | function TfrmEditProc.ValidSave: Boolean; | 
|---|
| 478 | const | 
|---|
| 479 | TX_NO_SAVE     = 'This request cannot be saved for the following reason(s):' + CRLF + CRLF; | 
|---|
| 480 | TX_NO_SAVE_CAP = 'Unable to Save Request'; | 
|---|
| 481 | TX_SAVE_ERR    = 'Unexpected error - it was not possible to save this request.'; | 
|---|
| 482 | var | 
|---|
| 483 | ErrMsg: string; | 
|---|
| 484 | begin | 
|---|
| 485 | Result := True; | 
|---|
| 486 | Validate(ErrMsg); | 
|---|
| 487 | if Length(ErrMsg) > 0 then | 
|---|
| 488 | begin | 
|---|
| 489 | InfoBox(TX_NO_SAVE + ErrMsg, TX_NO_SAVE_CAP, MB_OK); | 
|---|
| 490 | Result := False; | 
|---|
| 491 | end; | 
|---|
| 492 | if (ProvDx.Reqd = 'R') and (Length(txtProvDiag.Text) = 0) and (ProvDx.PromptMode = 'L') then | 
|---|
| 493 | cmdLexSearchClick(Self); | 
|---|
| 494 | end; | 
|---|
| 495 |  | 
|---|
| 496 | procedure TfrmEditProc.SetUpCombatVet; | 
|---|
| 497 | begin | 
|---|
| 498 | pnlCombatVet.BringToFront; | 
|---|
| 499 | txtCombatVet.Enabled := True; | 
|---|
| 500 | txtCombatVet.Caption := 'Combat Veteran Eligibility Expires on ' + patient.CombatVet.ExpirationDate; | 
|---|
| 501 | pnlMain.Top := pnlMain.Top + pnlCombatVet.Height; | 
|---|
| 502 | pnlMain.Anchors := [akLeft, akTop, akRight]; | 
|---|
| 503 | self.Height := self.Height + pnlCombatVet.Height; | 
|---|
| 504 | pnlMain.Anchors := [akLeft, akTop, akRight, akBottom]; | 
|---|
| 505 | ActiveControl := txtCombatVet; | 
|---|
| 506 | end; | 
|---|
| 507 |  | 
|---|
| 508 | procedure TfrmEditProc.cboProcSelect(Sender: TObject); | 
|---|
| 509 | begin | 
|---|
| 510 | inherited; | 
|---|
| 511 | with cboProc do | 
|---|
| 512 | begin | 
|---|
| 513 | if ItemIndex = -1 then Exit; | 
|---|
| 514 | if ItemID <> FLastProcID then FLastProcID := ItemID else Exit; | 
|---|
| 515 | with cboService do | 
|---|
| 516 | begin | 
|---|
| 517 | Clear; | 
|---|
| 518 | FastAssign(GetProcedureServices(cboProc.ItemIEN), cboService.Items); | 
|---|
| 519 | if Items.Count > 0 then | 
|---|
| 520 | begin | 
|---|
| 521 | ItemIndex := 0 ; | 
|---|
| 522 | NewRec.ToService := ItemIEN; | 
|---|
| 523 | NewRec.ToServiceName := Text; | 
|---|
| 524 | end | 
|---|
| 525 | else | 
|---|
| 526 | begin | 
|---|
| 527 | InfoBox('There are no services defined for this procedure.', | 
|---|
| 528 | 'Information', MB_OK or MB_ICONINFORMATION); | 
|---|
| 529 | //cboProc.ItemIndex := -1; | 
|---|
| 530 | InitDialog; | 
|---|
| 531 | Exit ; | 
|---|
| 532 | end; | 
|---|
| 533 | end; | 
|---|
| 534 | end; | 
|---|
| 535 | OrderMessage(ConsultMessage(cboProc.ItemIEN)); | 
|---|
| 536 | ControlChange(Self) ; | 
|---|
| 537 | end; | 
|---|
| 538 |  | 
|---|
| 539 | procedure TfrmEditProc.memReasonExit(Sender: TObject); | 
|---|
| 540 | var | 
|---|
| 541 | AStringList: TStringList; | 
|---|
| 542 | begin | 
|---|
| 543 | inherited; | 
|---|
| 544 | AStringList := TStringList.Create; | 
|---|
| 545 | try | 
|---|
| 546 | //QuickCopy(memReason, AStringList); | 
|---|
| 547 | AStringList.Text := memReason.Text; | 
|---|
| 548 | LimitStringLength(AStringList, 74); | 
|---|
| 549 | //QuickCopy(AstringList, memReason); | 
|---|
| 550 | memReason.Text := AStringList.Text; | 
|---|
| 551 | ControlChange(Self); | 
|---|
| 552 | finally | 
|---|
| 553 | AStringList.Free; | 
|---|
| 554 | end; | 
|---|
| 555 | end; | 
|---|
| 556 |  | 
|---|
| 557 | procedure TfrmEditProc.cmdAcceptClick(Sender: TObject); | 
|---|
| 558 | begin | 
|---|
| 559 | if ValidSave then | 
|---|
| 560 | begin | 
|---|
| 561 | FChanged := (ResubmitConsult(NewRec) = '0'); | 
|---|
| 562 | Close; | 
|---|
| 563 | end; | 
|---|
| 564 | end; | 
|---|
| 565 |  | 
|---|
| 566 | procedure TfrmEditProc.cmdQuitClick(Sender: TObject); | 
|---|
| 567 | begin | 
|---|
| 568 | inherited; | 
|---|
| 569 | FChanged := False; | 
|---|
| 570 | Close; | 
|---|
| 571 | end; | 
|---|
| 572 |  | 
|---|
| 573 | procedure TfrmEditProc.OrderMessage(const AMessage: string); | 
|---|
| 574 | begin | 
|---|
| 575 | memMessage.Lines.SetText(PChar(AMessage)); | 
|---|
| 576 | if ContainsVisibleChar(AMessage) then | 
|---|
| 577 | begin | 
|---|
| 578 | pnlMessage.Visible := True; | 
|---|
| 579 | pnlMessage.BringToFront; | 
|---|
| 580 | uMessageVisible := GetTickCount; | 
|---|
| 581 | end | 
|---|
| 582 | else pnlMessage.Visible := False; | 
|---|
| 583 | end; | 
|---|
| 584 |  | 
|---|
| 585 | procedure TfrmEditProc.btnCmtCancelClick(Sender: TObject); | 
|---|
| 586 | begin | 
|---|
| 587 | ReportBox(OldRec.DenyComments, 'Cancellation Comments', False); | 
|---|
| 588 | end; | 
|---|
| 589 |  | 
|---|
| 590 | procedure TfrmEditProc.btnCmtOtherClick(Sender: TObject); | 
|---|
| 591 | begin | 
|---|
| 592 | ReportBox(OldRec.OtherComments, 'Added Comments', False); | 
|---|
| 593 | end; | 
|---|
| 594 |  | 
|---|
| 595 |  | 
|---|
| 596 |  | 
|---|
| 597 | procedure TfrmEditProc.cmdLexSearchClick(Sender: TObject); | 
|---|
| 598 | var | 
|---|
| 599 | Match: string; | 
|---|
| 600 | i: integer; | 
|---|
| 601 | begin | 
|---|
| 602 | inherited; | 
|---|
| 603 | LexiconLookup(Match, LX_ICD); | 
|---|
| 604 | if Match = '' then Exit; | 
|---|
| 605 | ProvDx.Code := Piece(Match, U, 1); | 
|---|
| 606 | ProvDx.Text := Piece(Match, U, 2); | 
|---|
| 607 | i := Pos(' (ICD', ProvDx.Text); | 
|---|
| 608 | if i = 0 then i := Length(ProvDx.Text) + 1; | 
|---|
| 609 | if ProvDx.Text[i-1] = '*' then i := i - 2; | 
|---|
| 610 | ProvDx.Text := Copy(ProvDx.Text, 1, i - 1); | 
|---|
| 611 | txtProvDiag.Text := ProvDx.Text + ' (' + ProvDx.Code + ')'; | 
|---|
| 612 | ProvDx.CodeInactive := False; | 
|---|
| 613 | end; | 
|---|
| 614 |  | 
|---|
| 615 | procedure TfrmEditProc.SetProvDiagPromptingMode; | 
|---|
| 616 | const | 
|---|
| 617 | TX_USE_LEXICON = 'You must use the "Lexicon" button to select a provisional diagnosis for this service.'; | 
|---|
| 618 | TX_PROVDX_OPT  = 'Provisional Diagnosis'; | 
|---|
| 619 | TX_PROVDX_REQD = 'Provisional Dx (REQUIRED)'; | 
|---|
| 620 | begin | 
|---|
| 621 | cmdLexSearch.Enabled   := False; | 
|---|
| 622 | txtProvDiag.Enabled    := False; | 
|---|
| 623 | txtProvDiag.ReadOnly   := True; | 
|---|
| 624 | txtProvDiag.Color      := clBtnFace; | 
|---|
| 625 | txtProvDiag.Font.Color := clBtnText; | 
|---|
| 626 | lblProvDiag.Enabled    := False; | 
|---|
| 627 | txtProvDiag.Hint       := ''; | 
|---|
| 628 | if cboProc.ItemIEN = 0 then Exit; | 
|---|
| 629 | //GetProvDxMode(ProvDx, cboService.ItemID); | 
|---|
| 630 | GetProvDxMode(ProvDx, Piece(cboProc.Items[cboProc.ItemIndex], U, 4)); | 
|---|
| 631 | //  Returns:  string  A^B | 
|---|
| 632 | //     A = O (optional), R (required) or S (suppress) | 
|---|
| 633 | //     B = F (free-text) or L (lexicon) | 
|---|
| 634 | with ProvDx do if (Reqd = '') or (PromptMode = '') then Exit; | 
|---|
| 635 | if ProvDx.Reqd = 'R' then | 
|---|
| 636 | lblProvDiag.Caption := TX_PROVDX_REQD | 
|---|
| 637 | else | 
|---|
| 638 | lblProvDiag.Caption := TX_PROVDX_OPT; | 
|---|
| 639 | if ProvDx.Reqd = 'S' then | 
|---|
| 640 | begin | 
|---|
| 641 | cmdLexSearch.Enabled   := False; | 
|---|
| 642 | txtProvDiag.Enabled    := False; | 
|---|
| 643 | txtProvDiag.ReadOnly   := True; | 
|---|
| 644 | txtProvDiag.Color      := clBtnFace; | 
|---|
| 645 | txtProvDiag.Font.Color := clBtnText; | 
|---|
| 646 | lblProvDiag.Enabled    := False; | 
|---|
| 647 | end | 
|---|
| 648 | else | 
|---|
| 649 | case ProvDx.PromptMode[1] of | 
|---|
| 650 | 'F':  begin | 
|---|
| 651 | cmdLexSearch.Enabled   := False; | 
|---|
| 652 | txtProvDiag.Enabled    := True; | 
|---|
| 653 | txtProvDiag.ReadOnly   := False; | 
|---|
| 654 | txtProvDiag.Color      := clWindow; | 
|---|
| 655 | txtProvDiag.Font.Color := clWindowText; | 
|---|
| 656 | lblProvDiag.Enabled    := True; | 
|---|
| 657 | end; | 
|---|
| 658 | 'L':  begin | 
|---|
| 659 | cmdLexSearch.Enabled   := True; | 
|---|
| 660 | txtProvDiag.Enabled    := True; | 
|---|
| 661 | txtProvDiag.ReadOnly   := True; | 
|---|
| 662 | txtProvDiag.Color      := clInfoBk; | 
|---|
| 663 | txtProvDiag.Font.Color := clInfoText; | 
|---|
| 664 | lblProvDiag.Enabled    := True; | 
|---|
| 665 | txtProvDiag.Hint       := TX_USE_LEXICON; | 
|---|
| 666 | end; | 
|---|
| 667 | end; | 
|---|
| 668 | end; | 
|---|
| 669 |  | 
|---|
| 670 | procedure TfrmEditProc.mnuPopProvDxDeleteClick(Sender: TObject); | 
|---|
| 671 | begin | 
|---|
| 672 | inherited; | 
|---|
| 673 | ProvDx.Text := ''; | 
|---|
| 674 | ProvDx.Code := ''; | 
|---|
| 675 | ProvDx.CodeInactive := False; | 
|---|
| 676 | txtProvDiag.Text := ''; | 
|---|
| 677 | ControlChange(Self); | 
|---|
| 678 | end; | 
|---|
| 679 |  | 
|---|
| 680 | procedure TfrmEditProc.popReasonPopup(Sender: TObject); | 
|---|
| 681 | begin | 
|---|
| 682 | inherited; | 
|---|
| 683 | if PopupComponent(Sender, popReason) is TCustomEdit | 
|---|
| 684 | then FEditCtrl := TCustomEdit(PopupComponent(Sender, popReason)) | 
|---|
| 685 | else FEditCtrl := nil; | 
|---|
| 686 | if FEditCtrl <> nil then | 
|---|
| 687 | begin | 
|---|
| 688 | popReasonCut.Enabled      := FEditCtrl.SelLength > 0; | 
|---|
| 689 | popReasonCopy.Enabled     := popReasonCut.Enabled; | 
|---|
| 690 | popReasonPaste.Enabled    := (not TORExposedCustomEdit(FEditCtrl).ReadOnly) and | 
|---|
| 691 | Clipboard.HasFormat(CF_TEXT); | 
|---|
| 692 | end else | 
|---|
| 693 | begin | 
|---|
| 694 | popReasonCut.Enabled      := False; | 
|---|
| 695 | popReasonCopy.Enabled     := False; | 
|---|
| 696 | popReasonPaste.Enabled    := False; | 
|---|
| 697 | end; | 
|---|
| 698 | popReasonReformat.Enabled := True; | 
|---|
| 699 | end; | 
|---|
| 700 |  | 
|---|
| 701 | procedure TfrmEditProc.popReasonCutClick(Sender: TObject); | 
|---|
| 702 | begin | 
|---|
| 703 | inherited; | 
|---|
| 704 | FEditCtrl.CutToClipboard; | 
|---|
| 705 | end; | 
|---|
| 706 |  | 
|---|
| 707 | procedure TfrmEditProc.popReasonCopyClick(Sender: TObject); | 
|---|
| 708 | begin | 
|---|
| 709 | inherited; | 
|---|
| 710 | FEditCtrl.CopyToClipboard; | 
|---|
| 711 | end; | 
|---|
| 712 |  | 
|---|
| 713 | procedure TfrmEditProc.popReasonPasteClick(Sender: TObject); | 
|---|
| 714 | begin | 
|---|
| 715 | inherited; | 
|---|
| 716 | FEditCtrl.SelText := Clipboard.AsText; | 
|---|
| 717 | end; | 
|---|
| 718 |  | 
|---|
| 719 | procedure TfrmEditProc.popReasonReformatClick(Sender: TObject); | 
|---|
| 720 | begin | 
|---|
| 721 | if (Screen.ActiveControl <> memReason) and | 
|---|
| 722 | (Screen.ActiveControl <> memComment)then Exit; | 
|---|
| 723 | ReformatMemoParagraph(TCustomMemo(FEditCtrl)); | 
|---|
| 724 | end; | 
|---|
| 725 |  | 
|---|
| 726 |  | 
|---|
| 727 | procedure TfrmEditProc.memCommentExit(Sender: TObject); | 
|---|
| 728 | //added OnExit code for CQ17822 WAT | 
|---|
| 729 | var | 
|---|
| 730 | AStringList: TStringList; | 
|---|
| 731 | begin | 
|---|
| 732 | inherited; | 
|---|
| 733 | AStringList := TStringList.Create; | 
|---|
| 734 | try | 
|---|
| 735 | //QuickCopy(memComment, AStringList); | 
|---|
| 736 | AStringList.Text := memComment.Text; | 
|---|
| 737 | LimitStringLength(AStringList, 74); | 
|---|
| 738 | //QuickCopy(AstringList, memComment); | 
|---|
| 739 | memComment.Text := AStringList.Text; | 
|---|
| 740 | ControlChange(Self); | 
|---|
| 741 | finally | 
|---|
| 742 | AStringList.Free; | 
|---|
| 743 | end; | 
|---|
| 744 | end; | 
|---|
| 745 |  | 
|---|
| 746 | procedure TfrmEditProc.memCommentKeyUp(Sender: TObject; var Key: Word; | 
|---|
| 747 | Shift: TShiftState); | 
|---|
| 748 | begin | 
|---|
| 749 | if FNavigatingTab then | 
|---|
| 750 | begin | 
|---|
| 751 | if ssShift in Shift then | 
|---|
| 752 | FindNextControl(Sender as TWinControl, False, True, False).SetFocus //previous control | 
|---|
| 753 | else if ssCtrl      in Shift then | 
|---|
| 754 | FindNextControl(Sender as TWinControl, True, True, False).SetFocus; //next control | 
|---|
| 755 | end; | 
|---|
| 756 | if (key = VK_ESCAPE) then begin | 
|---|
| 757 | FindNextControl(Sender as TWinControl, False, True, False).SetFocus; //previous control | 
|---|
| 758 | key := 0; | 
|---|
| 759 | end; | 
|---|
| 760 | end; | 
|---|
| 761 |  | 
|---|
| 762 | procedure TfrmEditProc.memReasonKeyDown(Sender: TObject; var Key: Word; | 
|---|
| 763 | Shift: TShiftState); | 
|---|
| 764 | begin | 
|---|
| 765 | //The navigating tab controls were inadvertently adding tab characters | 
|---|
| 766 | //This should fix it | 
|---|
| 767 | FNavigatingTab := (Key = VK_TAB) and ([ssShift,ssCtrl] * Shift <> []); | 
|---|
| 768 | if FNavigatingTab then | 
|---|
| 769 | Key := 0; | 
|---|
| 770 | end; | 
|---|
| 771 |  | 
|---|
| 772 | procedure TfrmEditProc.memReasonKeyPress(Sender: TObject; var Key: Char); | 
|---|
| 773 | begin | 
|---|
| 774 | if FNavigatingTab then | 
|---|
| 775 | Key := #0;  //Disable shift-tab processing | 
|---|
| 776 | end; | 
|---|
| 777 |  | 
|---|
| 778 | end. | 
|---|
| 779 |  | 
|---|
| 780 |  | 
|---|