| [453] | 1 | //kt -- Modified with SourceScanner on 8/8/2007
 | 
|---|
 | 2 | unit rODMeds;
 | 
|---|
 | 3 | 
 | 
|---|
 | 4 | interface
 | 
|---|
 | 5 | 
 | 
|---|
 | 6 | uses SysUtils, Classes, ORNet, ORFn, uCore, uConst;
 | 
|---|
 | 7 | 
 | 
|---|
 | 8 | function DEACheckFailed(AnOI: Integer; ForInpatient: Boolean): Boolean;
 | 
|---|
 | 9 | function DEACheckFailedForIVOnOutPatient(AnOI: Integer; AnOIType: Char): boolean;
 | 
|---|
 | 10 | procedure ListForOrderable(var AListIEN, ACount: Integer; const DGrpNm: string);
 | 
|---|
 | 11 | procedure SubsetOfOrderable(Dest: TStringList; Append: Boolean; ListIEN, First, Last: Integer);
 | 
|---|
 | 12 | function IndexOfOrderable(ListIEN: Integer; From: string): Integer;
 | 
|---|
 | 13 | procedure IsActivateOI(var AMsg: string; theOI: integer);
 | 
|---|
 | 14 | procedure ListForQuickOrders(var AListIEN, ACount: Integer; const DGrpNm: string);
 | 
|---|
 | 15 | procedure SubsetOfQuickOrders(Dest: TStringList; AListIEN, First, Last: Integer);
 | 
|---|
 | 16 | function IndexOfQuickOrder(AListIEN: Integer; From: string): Integer;
 | 
|---|
 | 17 | procedure LoadFormularyAltOI(AList: TStringList; AnIEN: Integer; ForInpatient: Boolean);
 | 
|---|
 | 18 | procedure LoadFormularyAltDose(AList: TStringList; DispDrug, OI: Integer; ForInpatient: Boolean);
 | 
|---|
 | 19 | procedure LoadAdminInfo(const Schedule: string; OrdItem: Integer; var StartText: string;
 | 
|---|
 | 20 |   var AdminTime: TFMDateTime; var Duration: string);
 | 
|---|
 | 21 | function GetAdminTime(const StartText, Schedule: string; OrdItem: Integer): TFMDateTime;
 | 
|---|
 | 22 | procedure LoadSchedules(Dest: TStrings; IsInptDlg: boolean = False);
 | 
|---|
 | 23 | function QtyToDays(Quantity: Double;   const UnitsPerDose, Schedule, Duration, Drug: string): Integer;
 | 
|---|
 | 24 | function DaysToQty(DaysSupply: Integer; const UnitsPerDose, Schedule, Duration, Drug: string): Integer;
 | 
|---|
 | 25 | function DurToQty(DaysSupply: Integer; const UnitStr, SchedStr: string): Integer;
 | 
|---|
 | 26 | function DefaultDays(const ADrug, UnitStr, SchedStr: string): Integer;
 | 
|---|
 | 27 | function CalcMaxRefills(const Drug: string; Days, OrdItem: Integer; Discharge: Boolean): Integer;
 | 
|---|
 | 28 | function ScheduleRequired(OrdItem: Integer; const ARoute, ADrug: string): Boolean;
 | 
|---|
 | 29 | function ODForMedsIn: TStrings;
 | 
|---|
 | 30 | function ODForMedsOut: TStrings;
 | 
|---|
 | 31 | function OIForMed(AnIEN: Integer; ForInpatient: Boolean; HavePI: boolean = True; PKIActive: Boolean = False): TStrings;
 | 
|---|
 | 32 | function GetPickupForLocation(const Loc: string): string;
 | 
|---|
 | 33 | function QOHasRouteDefined(AQOID: integer): boolean;
 | 
|---|
 | 34 | procedure CheckExistingPI(AOrderId: string; var APtI: string);
 | 
|---|
 | 35 | 
 | 
|---|
 | 36 | implementation
 | 
|---|
 | 37 | 
 | 
|---|
 | 38 | function DEACheckFailed(AnOI: Integer; ForInpatient: Boolean): Boolean;
 | 
|---|
 | 39 | var
 | 
|---|
 | 40 |   PtType: Char;
 | 
|---|
 | 41 | begin
 | 
|---|
 | 42 |   if ForInpatient then PtType := 'I' else PtType := 'O';
 | 
|---|
 | 43 |   Result := sCallV('ORWDPS1 FAILDEA', [AnOI, Encounter.Provider, PtType]) = '1';
 | 
|---|
 | 44 | end;
 | 
|---|
 | 45 | 
 | 
|---|
 | 46 | function DEACheckFailedForIVOnOutPatient(AnOI: Integer; AnOIType: Char): boolean;
 | 
|---|
 | 47 | begin
 | 
|---|
 | 48 |   Result := sCallV('ORWDPS1 IVDEA',[AnOI,AnOIType,Encounter.Provider]) = '1';
 | 
|---|
 | 49 | end;
 | 
|---|
 | 50 | 
 | 
|---|
 | 51 | procedure ListForOrderable(var AListIEN, ACount: Integer; const DGrpNm: string);
 | 
|---|
 | 52 | begin
 | 
|---|
 | 53 |   CallV('ORWUL FV4DG', [DGrpNm]);
 | 
|---|
 | 54 |   AListIEN := StrToIntDef(Piece(RPCBrokerV.Results[0], U, 1), 0);
 | 
|---|
 | 55 |   ACount   := StrToIntDef(Piece(RPCBrokerV.Results[0], U, 2), 0);
 | 
|---|
 | 56 | end;
 | 
|---|
 | 57 | 
 | 
|---|
 | 58 | procedure SubsetOfOrderable(Dest: TStringList; Append: Boolean; ListIEN, First, Last: Integer);
 | 
|---|
 | 59 | var
 | 
|---|
 | 60 |   i: Integer;
 | 
|---|
 | 61 | begin
 | 
|---|
 | 62 |   CallV('ORWUL FVSUB', [ListIEN, First+1, Last+1]);  // M side not 0-based
 | 
|---|
 | 63 |   if Append then Dest.AddStrings(RPCBrokerV.Results) else
 | 
|---|
 | 64 |   begin
 | 
|---|
 | 65 |     for i := Pred(RPCBrokerV.Results.Count) downto 0 do Dest.Insert(0, RPCBrokerV.Results[i]);
 | 
|---|
 | 66 |   end;
 | 
|---|
 | 67 | end;
 | 
|---|
 | 68 | 
 | 
|---|
 | 69 | function IndexOfOrderable(ListIEN: Integer; From: string): Integer;
 | 
|---|
 | 70 | var
 | 
|---|
 | 71 |   x: string;
 | 
|---|
 | 72 | begin
 | 
|---|
 | 73 |   Result := -1;
 | 
|---|
 | 74 |   if From = '' then Exit;
 | 
|---|
 | 75 |   // decrement last char & concat '~' for $ORDER on M side, limit string length
 | 
|---|
 | 76 |   x := UpperCase(Copy(From, 1, 220));
 | 
|---|
 | 77 |   x := Copy(x, 1, Length(x) - 1) + Pred(x[Length(x)]) + '~';
 | 
|---|
 | 78 |   x := sCallV('ORWUL FVIDX', [ListIEN, x]);
 | 
|---|
 | 79 |   // use Pred to make the index 0-based (first value = 1 on M side)
 | 
|---|
 | 80 |   if CompareText(Copy(Piece(x, U, 2), 1, Length(From)), From) = 0
 | 
|---|
 | 81 |     then Result := Pred(StrToIntDef(Piece(x, U, 1), 0));
 | 
|---|
 | 82 | end;
 | 
|---|
 | 83 | 
 | 
|---|
 | 84 | procedure IsActivateOI(var AMsg: string; theOI: integer);
 | 
|---|
 | 85 | begin
 | 
|---|
 | 86 |   AMsg := SCallV('ORWDXA ISACTOI', [theOI]);
 | 
|---|
 | 87 | end;
 | 
|---|
 | 88 | 
 | 
|---|
 | 89 | procedure ListForQuickOrders(var AListIEN, ACount: Integer; const DGrpNm: string);
 | 
|---|
 | 90 | begin
 | 
|---|
 | 91 |   CallV('ORWUL QV4DG', [DGrpNm]);
 | 
|---|
 | 92 |   AListIEN := StrToIntDef(Piece(RPCBrokerV.Results[0], U, 1), 0);
 | 
|---|
 | 93 |   ACount   := StrToIntDef(Piece(RPCBrokerV.Results[0], U, 2), 0);
 | 
|---|
 | 94 | end;
 | 
|---|
 | 95 | 
 | 
|---|
 | 96 | procedure SubsetOfQuickOrders(Dest: TStringList; AListIEN, First, Last: Integer);
 | 
|---|
 | 97 | var
 | 
|---|
 | 98 |   i: Integer;
 | 
|---|
 | 99 | begin
 | 
|---|
 | 100 |  CallV('ORWUL QVSUB', [AListIEN,'','']);
 | 
|---|
 | 101 |  for i := 0 to RPCBrokerV.Results.Count -1 do
 | 
|---|
 | 102 |    Dest.Add(RPCBrokerV.Results[i]);
 | 
|---|
 | 103 | end;
 | 
|---|
 | 104 | 
 | 
|---|
 | 105 | function IndexOfQuickOrder(AListIEN: Integer; From: string): Integer;
 | 
|---|
 | 106 | var
 | 
|---|
 | 107 |   x: string;
 | 
|---|
 | 108 | begin
 | 
|---|
 | 109 |   Result := -1;
 | 
|---|
 | 110 |   if From = '' then Exit;
 | 
|---|
 | 111 |   // decrement last char & concat '~' for $ORDER on M side, limit string length
 | 
|---|
 | 112 |   x := UpperCase(Copy(From, 1, 220));
 | 
|---|
 | 113 |   x := Copy(x, 1, Length(x) - 1) + Pred(x[Length(x)]) + '~';
 | 
|---|
 | 114 |   x := sCallV('ORWUL QVIDX', [AListIEN, x]);
 | 
|---|
 | 115 |   // use Pred to made the index 0-based (first value = 1 on M side)
 | 
|---|
 | 116 |   if CompareText(Copy(Piece(x, U, 2), 1, Length(From)), From) = 0
 | 
|---|
 | 117 |     then Result := Pred(StrToIntDef(Piece(x, U, 1), 0));
 | 
|---|
 | 118 | end;
 | 
|---|
 | 119 | 
 | 
|---|
 | 120 | procedure LoadFormularyAltOI(AList: TStringList; AnIEN: Integer; ForInpatient: Boolean);
 | 
|---|
 | 121 | var
 | 
|---|
 | 122 |   PtType: Char;
 | 
|---|
 | 123 | begin
 | 
|---|
 | 124 |   if ForInpatient then PtType := 'I' else PtType := 'O';
 | 
|---|
 | 125 |   CallV('ORWDPS1 FORMALT', [AnIEN, PtType]);
 | 
|---|
 | 126 |   AList.Assign(RPCBrokerV.Results);
 | 
|---|
 | 127 | end;
 | 
|---|
 | 128 | 
 | 
|---|
 | 129 | procedure LoadFormularyAltDose(AList: TStringList; DispDrug, OI: Integer; ForInpatient: Boolean);
 | 
|---|
 | 130 | var
 | 
|---|
 | 131 |   PtType: Char;
 | 
|---|
 | 132 | begin
 | 
|---|
 | 133 |   if ForInpatient then PtType := 'I' else PtType := 'O';
 | 
|---|
 | 134 |   CallV('ORWDPS1 DOSEALT', [DispDrug, OI, PtType]);
 | 
|---|
 | 135 |   AList.Assign(RPCBrokerV.Results);
 | 
|---|
 | 136 | end;
 | 
|---|
 | 137 | 
 | 
|---|
 | 138 | procedure LoadAdminInfo(const Schedule: string; OrdItem: Integer; var StartText: string;
 | 
|---|
 | 139 |   var AdminTime: TFMDateTime; var Duration: string);
 | 
|---|
 | 140 | var
 | 
|---|
 | 141 |   x: string;
 | 
|---|
 | 142 | begin
 | 
|---|
 | 143 |   x := sCallV('ORWDPS2 ADMIN', [Patient.DFN, Schedule, OrdItem, Encounter.Location]);
 | 
|---|
 | 144 |   StartText := Piece(x, U, 1);
 | 
|---|
 | 145 |   AdminTime := MakeFMDateTime(Piece(x, U, 4));
 | 
|---|
 | 146 |   Duration  := Piece(x, U, 3);
 | 
|---|
 | 147 | end;
 | 
|---|
 | 148 | 
 | 
|---|
 | 149 | function GetAdminTime(const StartText, Schedule: string; OrdItem: Integer): TFMDateTime;
 | 
|---|
 | 150 | var
 | 
|---|
 | 151 |   x: string;
 | 
|---|
 | 152 | begin
 | 
|---|
 | 153 |   x := sCallV('ORWDPS2 REQST', [Patient.DFN, Schedule, OrdItem, Encounter.Location, StartText]);
 | 
|---|
 | 154 |   Result := MakeFMDateTime(x);
 | 
|---|
 | 155 | end;
 | 
|---|
 | 156 | 
 | 
|---|
 | 157 | procedure LoadSchedules(Dest: TStrings; IsInptDlg: boolean);
 | 
|---|
 | 158 | begin
 | 
|---|
 | 159 |   // if uMedSchedules = nil then CallV('ORWDPS ALLSCHD', [nil]); uMedSchedules.Assign(...);
 | 
|---|
 | 160 |   CallV('ORWDPS1 SCHALL', [nil]);
 | 
|---|
 | 161 |   Dest.Assign(RPCBrokerV.Results);
 | 
|---|
 | 162 |   If (Dest.IndexOfName('OTHER') < 0) and IsInptDlg then
 | 
|---|
 | 163 |     Dest.Add('OTHER');
 | 
|---|
 | 164 | end;
 | 
|---|
 | 165 | 
 | 
|---|
 | 166 | function QtyToDays(Quantity: Double;   const UnitsPerDose, Schedule, Duration, Drug: string): Integer;
 | 
|---|
 | 167 | begin
 | 
|---|
 | 168 |   Result := StrToIntDef(sCallV('ORWDPS2 QTY2DAY',
 | 
|---|
 | 169 |     [Quantity,   UnitsPerDose, Schedule, Duration, Patient.DFN, Drug]), 0);
 | 
|---|
 | 170 | end;
 | 
|---|
 | 171 | 
 | 
|---|
 | 172 | function DaysToQty(DaysSupply: Integer; const UnitsPerDose, Schedule, Duration, Drug: string): Integer;
 | 
|---|
 | 173 | begin
 | 
|---|
 | 174 |   Result := StrToIntDef(sCallV('ORWDPS2 DAY2QTY',
 | 
|---|
 | 175 |     [DaysSupply, UnitsPerDose, Schedule, Duration, Patient.DFN, Drug]), 0);
 | 
|---|
 | 176 | end;
 | 
|---|
 | 177 | 
 | 
|---|
 | 178 | function DurToQty(DaysSupply: Integer; const UnitStr, SchedStr: string): Integer;
 | 
|---|
 | 179 | begin
 | 
|---|
 | 180 |   Result := StrToIntDef(sCallV('ORWDPS2 DAY2QTY', [DaysSupply, UnitStr, SchedStr]), 0);
 | 
|---|
 | 181 | end;
 | 
|---|
 | 182 | 
 | 
|---|
 | 183 | function DefaultDays(const ADrug, UnitStr, SchedStr: string): Integer;
 | 
|---|
 | 184 | begin
 | 
|---|
 | 185 |   Result := StrToIntDef(sCallV('ORWDPS1 DFLTSPLY', [UnitStr, SchedStr, Patient.DFN, ADrug]), 0);
 | 
|---|
 | 186 | end;
 | 
|---|
 | 187 | 
 | 
|---|
 | 188 | function CalcMaxRefills(const Drug: string; Days, OrdItem: Integer; Discharge: Boolean): Integer;
 | 
|---|
 | 189 | begin
 | 
|---|
 | 190 |   Result := StrToIntDef(sCallV('ORWDPS2 MAXREF', [Patient.DFN, Drug, Days, OrdItem, Discharge]), 0);
 | 
|---|
 | 191 | end;
 | 
|---|
 | 192 | 
 | 
|---|
 | 193 | function ScheduleRequired(OrdItem: Integer; const ARoute, ADrug: string): Boolean;
 | 
|---|
 | 194 | begin
 | 
|---|
 | 195 |   Result := sCallV('ORWDPS2 SCHREQ', [OrdItem, ARoute, ADrug]) = '1';
 | 
|---|
 | 196 | end;
 | 
|---|
 | 197 | 
 | 
|---|
 | 198 | function ODForMedsIn: TStrings;
 | 
|---|
 | 199 | { Returns init values for inpatient meds dialog.  The results must be used immediately. }
 | 
|---|
 | 200 | begin
 | 
|---|
 | 201 |   CallV('ORWDPS1 ODSLCT', [PST_UNIT_DOSE, Patient.DFN, Encounter.Location]);
 | 
|---|
 | 202 |   Result := RPCBrokerV.Results;
 | 
|---|
 | 203 | end;
 | 
|---|
 | 204 | 
 | 
|---|
 | 205 | function ODForMedsOut: TStrings;
 | 
|---|
 | 206 | { Returns init values for outpatient meds dialog.  The results must be used immediately. }
 | 
|---|
 | 207 | begin
 | 
|---|
 | 208 |   CallV('ORWDPS1 ODSLCT', [PST_OUTPATIENT, Patient.DFN, Encounter.Location]);
 | 
|---|
 | 209 |   Result := RPCBrokerV.Results;
 | 
|---|
 | 210 | end;
 | 
|---|
 | 211 | 
 | 
|---|
 | 212 | function OIForMed(AnIEN: Integer; ForInpatient: Boolean; HavePI: Boolean; PKIActive: Boolean): TStrings;
 | 
|---|
 | 213 | var
 | 
|---|
 | 214 |   PtType: Char;
 | 
|---|
 | 215 |   NeedPI: Char;
 | 
|---|
 | 216 |   IsPKIActive: Char;
 | 
|---|
 | 217 | begin
 | 
|---|
 | 218 |   if HavePI then NeedPI := 'Y' else NeedPI := 'N';
 | 
|---|
 | 219 |   if ForInpatient then PtType := 'U' else PtType := 'O';
 | 
|---|
 | 220 |   if PKIActive then IsPKIActive := 'Y' else IsPKIActive := 'N';
 | 
|---|
 | 221 |   CallV('ORWDPS2 OISLCT', [AnIEN, PtType, Patient.DFN, NeedPI, IsPKIActive]);
 | 
|---|
 | 222 |   Result := RPCBrokerV.Results;
 | 
|---|
 | 223 | end;
 | 
|---|
 | 224 | 
 | 
|---|
 | 225 | function GetPickupForLocation(const Loc: string): string;
 | 
|---|
 | 226 | begin
 | 
|---|
 | 227 |   Result := sCallV('ORWDPS1 LOCPICK',[Loc]);
 | 
|---|
 | 228 | end;
 | 
|---|
 | 229 | 
 | 
|---|
 | 230 | function QOHasRouteDefined(AQOID: integer): boolean;
 | 
|---|
 | 231 | begin
 | 
|---|
 | 232 |   Result := False;
 | 
|---|
 | 233 |   if ( sCallV('ORWDPS1 HASROUTE',[AQOID])='1' ) then
 | 
|---|
 | 234 |     Result := True;
 | 
|---|
 | 235 | end;
 | 
|---|
 | 236 | 
 | 
|---|
 | 237 | procedure CheckExistingPI(AOrderId: string; var APtI: string);
 | 
|---|
 | 238 | begin
 | 
|---|
 | 239 |   APtI := sCallV('ORWDPS2 CHKPI', [AOrderId]);
 | 
|---|
 | 240 | end;
 | 
|---|
 | 241 | 
 | 
|---|
 | 242 | end.
 | 
|---|