| 1 | unit fOrdersCopy; | 
|---|
| 2 |  | 
|---|
| 3 | interface | 
|---|
| 4 |  | 
|---|
| 5 | uses | 
|---|
| 6 | Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, | 
|---|
| 7 | StdCtrls, ORCtrls, ExtCtrls, mEvntDelay, uCore, fODBase, UConst, fAutoSz; | 
|---|
| 8 |  | 
|---|
| 9 | type | 
|---|
| 10 | TfrmCopyOrders = class(TForm) | 
|---|
| 11 | pnlInfo: TPanel; | 
|---|
| 12 | fraEvntDelayList: TfraEvntDelayList; | 
|---|
| 13 | pnlRadio: TPanel; | 
|---|
| 14 | GroupBox1: TGroupBox; | 
|---|
| 15 | radRelease: TRadioButton; | 
|---|
| 16 | radEvtDelay: TRadioButton; | 
|---|
| 17 | Image1: TImage; | 
|---|
| 18 | Label2: TStaticText; | 
|---|
| 19 | Label1: TStaticText; | 
|---|
| 20 | pnlTop: TPanel; | 
|---|
| 21 | lblPtInfo: TStaticText; | 
|---|
| 22 | pnlBtns: TPanel; | 
|---|
| 23 | gbBtns: TGroupBox; | 
|---|
| 24 | cmdOK: TButton; | 
|---|
| 25 | cmdCancel: TButton; | 
|---|
| 26 | procedure cmdOKClick(Sender: TObject); | 
|---|
| 27 | procedure cmdCancelClick(Sender: TObject); | 
|---|
| 28 | procedure FormCreate(Sender: TObject); | 
|---|
| 29 | procedure radEvtDelayClick(Sender: TObject); | 
|---|
| 30 | procedure radReleaseClick(Sender: TObject); | 
|---|
| 31 | procedure fraEvntDelayListcboEvntListChange(Sender: TObject); | 
|---|
| 32 | procedure UMStillDelay(var message: TMessage); message UM_STILLDELAY; | 
|---|
| 33 | procedure fraEvntDelayListmlstEventsDblClick(Sender: TObject); | 
|---|
| 34 | procedure fraEvntDelayListmlstEventsChange(Sender: TObject); | 
|---|
| 35 | procedure FormKeyDown(Sender: TObject; var Key: Word; | 
|---|
| 36 | Shift: TShiftState); | 
|---|
| 37 | private | 
|---|
| 38 | OKPressed: Boolean; | 
|---|
| 39 | public | 
|---|
| 40 | end; | 
|---|
| 41 |  | 
|---|
| 42 | function SetViewForCopy(var IsNewEvent: boolean; var DoesDestEvtOccur: boolean; | 
|---|
| 43 | var DestPtEvtID: integer; var DestPtEvtName: string): Boolean; | 
|---|
| 44 |  | 
|---|
| 45 | var | 
|---|
| 46 | frmCopyOrders: TfrmCopyOrders; | 
|---|
| 47 |  | 
|---|
| 48 | implementation | 
|---|
| 49 | {$R *.DFM} | 
|---|
| 50 |  | 
|---|
| 51 | uses fOrders, fOrdersTS, ORFn, rOrders; | 
|---|
| 52 |  | 
|---|
| 53 | function SetViewForCopy(var IsNewEvent: boolean; var DoesDestEvtOccur: boolean; | 
|---|
| 54 | var DestPtEvtID: integer; var DestPtEvtName: string): Boolean; | 
|---|
| 55 | var | 
|---|
| 56 | EvtInfo,APtEvtID, AnEvtDlg: string; | 
|---|
| 57 | AnEvent: TOrderDelayEvent; | 
|---|
| 58 | SpeCap, CurrTS: string; | 
|---|
| 59 | ExistedPtEvtID: integer; | 
|---|
| 60 |  | 
|---|
| 61 | procedure Highlight(APtEvtID: string); | 
|---|
| 62 | var | 
|---|
| 63 | j: integer; | 
|---|
| 64 | begin | 
|---|
| 65 | frmOrders.InitOrderSheetsForEvtDelay; | 
|---|
| 66 | for j := 0 to frmOrders.lstSheets.Items.Count - 1 do | 
|---|
| 67 | begin | 
|---|
| 68 | if Piece(frmOrders.lstSheets.Items[j],'^',1)=APtEvtID then | 
|---|
| 69 | begin | 
|---|
| 70 | frmOrders.lstSheets.ItemIndex := j; | 
|---|
| 71 | break; | 
|---|
| 72 | end; | 
|---|
| 73 | end; | 
|---|
| 74 | end; | 
|---|
| 75 |  | 
|---|
| 76 | function DisplayEvntDialog(AEvtDlg: String; AnEvent: TOrderDelayEvent): boolean; | 
|---|
| 77 | var | 
|---|
| 78 | DlgData: string; | 
|---|
| 79 | begin | 
|---|
| 80 | DlgData := GetDlgData(AEvtDlg); | 
|---|
| 81 | frmOrders.NeedShowModal := True; | 
|---|
| 82 | frmOrders.IsDefaultDlg := True; | 
|---|
| 83 | Result := frmOrders.PlaceOrderForDefaultDialog(DlgData, True, AnEvent); | 
|---|
| 84 | frmOrders.IsDefaultDlg := False; | 
|---|
| 85 | frmOrders.NeedShowModal := False; | 
|---|
| 86 | end; | 
|---|
| 87 |  | 
|---|
| 88 | function FindMatchedPtEvtID(EventName: string): integer; | 
|---|
| 89 | var | 
|---|
| 90 | cnt: integer; | 
|---|
| 91 | viewName: string; | 
|---|
| 92 | begin | 
|---|
| 93 | Result := 0; | 
|---|
| 94 | for cnt := 0 to frmOrders.lstSheets.Items.Count - 1 do | 
|---|
| 95 | begin | 
|---|
| 96 | viewName := Piece(frmOrders.lstSheets.Items[cnt],'^',2); | 
|---|
| 97 | if AnsiCompareText(EventName,viewName)=0 then | 
|---|
| 98 | begin | 
|---|
| 99 | Result := StrToIntDef(Piece(frmOrders.lstSheets.Items[cnt],'^',1),0); | 
|---|
| 100 | break; | 
|---|
| 101 | end; | 
|---|
| 102 | end; | 
|---|
| 103 | end; | 
|---|
| 104 |  | 
|---|
| 105 | begin | 
|---|
| 106 | Result := False; | 
|---|
| 107 | AnEvent.EventType := #0; | 
|---|
| 108 | AnEvent.EventIFN  := 0; | 
|---|
| 109 | AnEvent.EventName := ''; | 
|---|
| 110 | AnEvent.Specialty := 0; | 
|---|
| 111 | AnEvent.Effective := 0; | 
|---|
| 112 | AnEvent.PtEventIFN := 0; | 
|---|
| 113 | AnEvent.TheParent := TParentEvent.Create; | 
|---|
| 114 | AnEvent.IsNewEvent := False; | 
|---|
| 115 |  | 
|---|
| 116 | frmCopyOrders := TfrmCopyOrders.Create(Application); | 
|---|
| 117 | try | 
|---|
| 118 | ResizeFormToFont(TForm(frmCopyOrders)); | 
|---|
| 119 | CurrTS := Piece(GetCurrentSpec(Patient.DFN),'^',1); | 
|---|
| 120 | if Length(CurrTS)>0 then | 
|---|
| 121 | SpeCap := #13 + 'The current treating specialty is ' + CurrTS | 
|---|
| 122 | else | 
|---|
| 123 | SpeCap := #13 + 'No treating specialty is available.'; | 
|---|
| 124 | //ResizeFormToFont(TForm(frmCopyOrders)); | 
|---|
| 125 | if Patient.Inpatient then | 
|---|
| 126 | frmCopyOrders.lblPtInfo.Caption := Patient.Name + ' is currently admitted to ' + Encounter.LocationName + SpeCap | 
|---|
| 127 | else | 
|---|
| 128 | begin | 
|---|
| 129 | if (Encounter.Location > 0) then | 
|---|
| 130 | frmCopyOrders.lblPtInfo.Caption := Patient.Name + ' is currently at ' + Encounter.LocationName + SpeCap | 
|---|
| 131 | else | 
|---|
| 132 | frmCopyOrders.lblPtInfo.Caption := Patient.Name + ' currently is an outpatient.'  + SpeCap; | 
|---|
| 133 | end; | 
|---|
| 134 | frmCopyOrders.ShowModal; | 
|---|
| 135 | if (frmCopyOrders.OKPressed) and (frmCopyOrders.radRelease.Checked) then | 
|---|
| 136 | begin | 
|---|
| 137 | frmOrders.lstSheets.ItemIndex := 0; | 
|---|
| 138 | frmOrders.lstSheetsClick(Nil); | 
|---|
| 139 | Result := True; | 
|---|
| 140 | end; | 
|---|
| 141 | if (frmCopyOrders.OKPressed) and (frmCopyOrders.radEvtDelay.Checked) then | 
|---|
| 142 | begin | 
|---|
| 143 | EvtInfo := frmCopyOrders.fraEvntDelayList.mlstEvents.Items[frmCopyOrders.fraEvntDelayList.mlstEvents.ItemIndex]; | 
|---|
| 144 | AnEvent.EventType := CharAt(Piece(EvtInfo,'^',3),1); | 
|---|
| 145 | AnEvent.EventIFN  := StrToInt64Def(Piece(EvtInfo,'^',1),0); | 
|---|
| 146 | if StrToInt64Def(Piece(EvtInfo,'^',13),0) > 0 then | 
|---|
| 147 | begin | 
|---|
| 148 | AnEvent.TheParent.Assign(Piece(EvtInfo,'^',13)); | 
|---|
| 149 | AnEvent.EventType := AnEvent.TheParent.ParentType; | 
|---|
| 150 | end; | 
|---|
| 151 | AnEvent.EventName := frmCopyOrders.fraEvntDelayList.mlstEvents.DisplayText[frmCopyOrders.fraEvntDelayList.mlstEvents.ItemIndex]; | 
|---|
| 152 | AnEvent.Specialty := 0; | 
|---|
| 153 | if frmCopyOrders.fraEvntDelayList.orDateBox.Visible then | 
|---|
| 154 | AnEvent.Effective := frmCopyOrders.fraEvntDelayList.orDateBox.FMDateTime | 
|---|
| 155 | else | 
|---|
| 156 | AnEvent.Effective := 0; | 
|---|
| 157 | ExistedPtEvtID := FindMatchedPtEvtID('Delayed ' + AnEvent.EventName + ' Orders'); | 
|---|
| 158 | if (ExistedPtEvtId>0) and IsCompletedPtEvt(ExistedPtEvtId) then | 
|---|
| 159 | begin | 
|---|
| 160 | DoesDestEvtOccur := True; | 
|---|
| 161 | DestPtEvtId := ExistedPtEvtId; | 
|---|
| 162 | DestPtEvtName := AnEvent.EventName; | 
|---|
| 163 | IsNewEvent := False; | 
|---|
| 164 | Result := True; | 
|---|
| 165 | Exit; | 
|---|
| 166 | end; | 
|---|
| 167 | IsNewEvent := False; | 
|---|
| 168 | if TypeOfExistedEvent(Patient.DFN,AnEvent.EventIFN) = 0 then | 
|---|
| 169 | begin | 
|---|
| 170 | IsNewEvent := True; | 
|---|
| 171 | if AnEvent.TheParent.ParentIFN > 0 then | 
|---|
| 172 | begin | 
|---|
| 173 | if StrToIntDef(AnEvent.TheParent.ParentDlg,0)>0 then | 
|---|
| 174 | AnEvtDlg := AnEvent.TheParent.ParentDlg; | 
|---|
| 175 | end | 
|---|
| 176 | else | 
|---|
| 177 | AnEvtDlg := Piece(EvtInfo,'^',5); | 
|---|
| 178 | end; | 
|---|
| 179 | if (StrToIntDef(AnEvtDlg,0)>0) and (IsNewEvent) then | 
|---|
| 180 | if not DisplayEvntDialog(AnEvtDlg, AnEvent) then | 
|---|
| 181 | begin | 
|---|
| 182 | frmOrders.lstSheets.ItemIndex := 0; | 
|---|
| 183 | frmOrders.lstSheetsClick(nil); | 
|---|
| 184 | Result := False; | 
|---|
| 185 | Exit; | 
|---|
| 186 | end; | 
|---|
| 187 | if not isExistedEvent(Patient.DFN, IntToStr(AnEvent.EventIFN), APtEvtID) then | 
|---|
| 188 | begin | 
|---|
| 189 | IsNewEvent := True; | 
|---|
| 190 | if (AnEvent.TheParent.ParentIFN > 0) and (TypeOfExistedEvent(Patient.DFN,AnEvent.EventIFN) = 0) then | 
|---|
| 191 | SaveEvtForOrder(Patient.DFN,AnEvent.TheParent.ParentIFN,''); | 
|---|
| 192 | SaveEvtForOrder(Patient.DFN,AnEvent.EventIFN,''); | 
|---|
| 193 | if isExistedEvent(Patient.DFN, IntToStr(AnEvent.EventIFN),APtEvtID) then | 
|---|
| 194 | begin | 
|---|
| 195 | Highlight(APtEvtID); | 
|---|
| 196 | AnEvent.IsNewEvent := False; | 
|---|
| 197 | AnEvent.PtEventIFN := StrToIntDef(APtEvtID,0); | 
|---|
| 198 | end; | 
|---|
| 199 | end else | 
|---|
| 200 | begin | 
|---|
| 201 | Highlight(APtEvtID); | 
|---|
| 202 | AnEvent.PtEventIFN := StrToIntDef(APtEvtID,0); | 
|---|
| 203 | AnEvent.IsNewEvent := False; | 
|---|
| 204 | end; | 
|---|
| 205 | DestPtEvtId := AnEvent.PtEventIFN; | 
|---|
| 206 | DestPtEvtName := AnEvent.EventName; | 
|---|
| 207 | if (AnEvent.PtEventIFN >0) and IsCompletedPtEvt(AnEvent.PtEventIFN) then | 
|---|
| 208 | begin | 
|---|
| 209 | DoesDestEvtOccur := True; | 
|---|
| 210 | IsNewEvent := False; | 
|---|
| 211 | Result := True; | 
|---|
| 212 | Exit; | 
|---|
| 213 | end; | 
|---|
| 214 | if frmOrders.lstSheets.ItemIndex > -1 then | 
|---|
| 215 | begin | 
|---|
| 216 | frmOrders.AskForCancel := False; | 
|---|
| 217 | frmOrders.lstSheetsClick(nil); | 
|---|
| 218 | frmOrders.AskForCancel := True; | 
|---|
| 219 | end; | 
|---|
| 220 | Result := True; | 
|---|
| 221 | end; | 
|---|
| 222 | finally | 
|---|
| 223 | frmCopyOrders.fraEvntDelayList.ResetProperty; | 
|---|
| 224 | frmCopyOrders.Release; | 
|---|
| 225 | end; | 
|---|
| 226 | end; | 
|---|
| 227 |  | 
|---|
| 228 | procedure TfrmCopyOrders.FormCreate(Sender: TObject); | 
|---|
| 229 | begin | 
|---|
| 230 | inherited; | 
|---|
| 231 | radRelease.Checked := True; | 
|---|
| 232 | OKPressed := False; | 
|---|
| 233 | if not Patient.Inpatient then | 
|---|
| 234 | begin | 
|---|
| 235 | pnlInfo.Visible := False; | 
|---|
| 236 | pnlBtns.Top := pnlRadio.Top; | 
|---|
| 237 | end; | 
|---|
| 238 | if not radEvtDelay.Checked then | 
|---|
| 239 | begin | 
|---|
| 240 | if not pnlInfo.Visible then | 
|---|
| 241 | Height := Height - fraEvntDelayList.Height - pnlInfo.Height | 
|---|
| 242 | else | 
|---|
| 243 | Height := Height - fraEvntDelayList.Height; | 
|---|
| 244 | end; | 
|---|
| 245 | end; | 
|---|
| 246 |  | 
|---|
| 247 | procedure TfrmCopyOrders.cmdOKClick(Sender: TObject); | 
|---|
| 248 | begin | 
|---|
| 249 | inherited; | 
|---|
| 250 | if (radEvtDelay.Checked) and (fraEvntDelayList.mlstEvents.ItemIndex < 0 ) then | 
|---|
| 251 | begin | 
|---|
| 252 | InfoBox('A release event must be selected.', 'No Selection Made', MB_OK); | 
|---|
| 253 | Exit; | 
|---|
| 254 | end; | 
|---|
| 255 | if radRelease.Checked then | 
|---|
| 256 | begin | 
|---|
| 257 | ImmdCopyAct := True; | 
|---|
| 258 | frmOrders.lstSheets.ItemIndex := 0; | 
|---|
| 259 | frmOrders.lstSheetsClick(Self); | 
|---|
| 260 | end; | 
|---|
| 261 | OKPressed := True; | 
|---|
| 262 | Close; | 
|---|
| 263 | end; | 
|---|
| 264 |  | 
|---|
| 265 | procedure TfrmCopyOrders.cmdCancelClick(Sender: TObject); | 
|---|
| 266 | begin | 
|---|
| 267 | inherited; | 
|---|
| 268 | Close; | 
|---|
| 269 | end; | 
|---|
| 270 |  | 
|---|
| 271 | procedure TfrmCopyOrders.radEvtDelayClick(Sender: TObject); | 
|---|
| 272 | begin | 
|---|
| 273 | inherited; | 
|---|
| 274 | if radRelease.Checked then | 
|---|
| 275 | radRelease.Checked  := False; | 
|---|
| 276 | radEvtDelay.Checked := True; | 
|---|
| 277 | Height := Height + fraEvntDelayList.Height; | 
|---|
| 278 | fraEvntDelayList.Visible := True; | 
|---|
| 279 | frmCopyOrders.fraEvntDelayList.UserDefaultEvent := StrToIntDef(GetDefaultEvt(IntToStr(User.DUZ)),0); | 
|---|
| 280 | fraEvntDelayList.DisplayEvntDelayList; | 
|---|
| 281 | end; | 
|---|
| 282 |  | 
|---|
| 283 | procedure TfrmCopyOrders.radReleaseClick(Sender: TObject); | 
|---|
| 284 | begin | 
|---|
| 285 | inherited; | 
|---|
| 286 | if radEvtDelay.Checked then | 
|---|
| 287 | radEvtDelay.Checked := False; | 
|---|
| 288 | radRelease.Checked  := True; | 
|---|
| 289 | fraEvntDelayList.Visible := False; | 
|---|
| 290 | Height := Height - fraEvntDelayList.Height; | 
|---|
| 291 | end; | 
|---|
| 292 |  | 
|---|
| 293 | procedure TfrmCopyOrders.fraEvntDelayListcboEvntListChange( | 
|---|
| 294 | Sender: TObject); | 
|---|
| 295 | begin | 
|---|
| 296 | inherited; | 
|---|
| 297 | fraEvntDelayList.IsForCpXfer := True; | 
|---|
| 298 | fraEvntDelayList.mlstEventsChange(Sender); | 
|---|
| 299 | if fraEvntDelayList.MatchedCancel then Close | 
|---|
| 300 | end; | 
|---|
| 301 |  | 
|---|
| 302 | procedure TfrmCopyOrders.UMStillDelay(var message: TMessage); | 
|---|
| 303 | begin | 
|---|
| 304 | CmdOKClick(Application); | 
|---|
| 305 | end; | 
|---|
| 306 |  | 
|---|
| 307 | procedure TfrmCopyOrders.fraEvntDelayListmlstEventsDblClick( | 
|---|
| 308 | Sender: TObject); | 
|---|
| 309 | begin | 
|---|
| 310 | inherited; | 
|---|
| 311 | if fraEvntDelayList.mlstEvents.ItemID > 0 then | 
|---|
| 312 | cmdOKClick(Self); | 
|---|
| 313 | end; | 
|---|
| 314 |  | 
|---|
| 315 | procedure TfrmCopyOrders.fraEvntDelayListmlstEventsChange(Sender: TObject); | 
|---|
| 316 | begin | 
|---|
| 317 | fraEvntDelayList.mlstEventsChange(Sender); | 
|---|
| 318 | if fraEvntDelayList.MatchedCancel then | 
|---|
| 319 | begin | 
|---|
| 320 | OKPressed := False; | 
|---|
| 321 | Close; | 
|---|
| 322 | Exit; | 
|---|
| 323 | end; | 
|---|
| 324 | end; | 
|---|
| 325 |  | 
|---|
| 326 | procedure TfrmCopyOrders.FormKeyDown(Sender: TObject; var Key: Word; | 
|---|
| 327 | Shift: TShiftState); | 
|---|
| 328 | begin | 
|---|
| 329 | if Key = VK_RETURN then | 
|---|
| 330 | cmdOKClick(Self); | 
|---|
| 331 | end; | 
|---|
| 332 |  | 
|---|
| 333 | end. | 
|---|