[453] | 1 | //kt -- Modified with SourceScanner on 8/25/2007
|
---|
| 2 | unit fGAF;
|
---|
| 3 |
|
---|
| 4 | interface
|
---|
| 5 |
|
---|
| 6 | uses
|
---|
| 7 | Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
|
---|
| 8 | fPCEBase, StdCtrls, Buttons, ExtCtrls, Grids, ORFn, ORNet, ORCtrls,
|
---|
| 9 | ORDtTm, ComCtrls, fPCEBaseGrid, Menus, DKLang;
|
---|
| 10 |
|
---|
| 11 | type
|
---|
| 12 | TfrmGAF = class(TfrmPCEBaseGrid)
|
---|
| 13 | lblGAF: TStaticText;
|
---|
| 14 | edtScore: TCaptionEdit;
|
---|
| 15 | udScore: TUpDown;
|
---|
| 16 | dteGAF: TORDateBox;
|
---|
| 17 | lblEntry: TStaticText;
|
---|
| 18 | lblScore: TLabel;
|
---|
| 19 | lblDate: TLabel;
|
---|
| 20 | lblDeterminedBy: TLabel;
|
---|
| 21 | cboGAFProvider: TORComboBox;
|
---|
| 22 | btnURL: TButton;
|
---|
| 23 | Spacer1: TLabel;
|
---|
| 24 | Spacer2: TLabel;
|
---|
| 25 | procedure cboGAFProviderNeedData(Sender: TObject; const StartFrom: String;
|
---|
| 26 | Direction, InsertAt: Integer);
|
---|
| 27 | procedure edtScoreChange(Sender: TObject);
|
---|
| 28 | procedure dteGAFExit(Sender: TObject);
|
---|
| 29 | procedure cboGAFProviderExit(Sender: TObject);
|
---|
| 30 | procedure FormActivate(Sender: TObject);
|
---|
| 31 | procedure FormShow(Sender: TObject);
|
---|
| 32 | procedure btnURLClick(Sender: TObject);
|
---|
| 33 | procedure FormCreate(Sender: TObject);
|
---|
| 34 | private
|
---|
| 35 | FDataLoaded: boolean;
|
---|
| 36 | procedure LoadScores;
|
---|
| 37 | function BADData(ShowMessage: boolean): boolean;
|
---|
| 38 | public
|
---|
| 39 | procedure AllowTabChange(var AllowChange: boolean); override;
|
---|
| 40 | procedure GetGAFScore(var Score: integer; var Date: TFMDateTime; var Staff: Int64);
|
---|
| 41 | end;
|
---|
| 42 |
|
---|
| 43 | function ValidGAFData(Score: integer; Date: TFMDateTime; Staff: Int64): boolean;
|
---|
| 44 |
|
---|
| 45 | var
|
---|
| 46 | frmGAF: TfrmGAF;
|
---|
| 47 |
|
---|
| 48 | implementation
|
---|
| 49 |
|
---|
| 50 | uses rPCE, rCore, uCore, uPCE, fEncounterFrame;
|
---|
| 51 |
|
---|
| 52 | {$R *.DFM}
|
---|
| 53 |
|
---|
| 54 | function ValidGAFData(Score: integer; Date: TFMDateTime; Staff: Int64): boolean;
|
---|
| 55 | begin
|
---|
| 56 | if(Score < 1) or (Score > 100) or (Date <= 0) or (Staff = 0) then
|
---|
| 57 | Result := FALSE
|
---|
| 58 | else
|
---|
| 59 | Result := ((Patient.DateDied <= 0) or (Date <= Patient.DateDied));
|
---|
| 60 | end;
|
---|
| 61 |
|
---|
| 62 | procedure TfrmGAF.LoadScores;
|
---|
| 63 | var
|
---|
| 64 | i: integer;
|
---|
| 65 | tmp: string;
|
---|
| 66 |
|
---|
| 67 | begin
|
---|
| 68 | RecentGafScores(3);
|
---|
| 69 | if(RPCBrokerV.Results.Count > 0) and (RPCBrokerV.Results[0] = '[DATA]') then
|
---|
| 70 | begin
|
---|
| 71 | for i := 1 to RPCBrokerV.Results.Count-1 do
|
---|
| 72 | begin
|
---|
| 73 | tmp := RPCBrokerV.Results[i];
|
---|
| 74 | lbGrid.Items.Add(Piece(tmp,U,5) + U + Piece(Piece(tmp,U,2),NoPCEValue,1) + U +
|
---|
| 75 | Piece(tmp,U,7) + U + Piece(tmp,U,8));
|
---|
| 76 | end;
|
---|
| 77 | end;
|
---|
| 78 | if(lbGrid.Items.Count > 0) then
|
---|
| 79 | SyncGridData
|
---|
| 80 | else
|
---|
| 81 | // lbGrid.Items.Add('No GAF scores found.'); <-- original line. //kt 8/25/2007
|
---|
| 82 | lbGrid.Items.Add(DKLangConstW('fGAF_No_GAF_scores_foundx')); //kt added 8/25/2007
|
---|
| 83 | end;
|
---|
| 84 |
|
---|
| 85 | procedure TfrmGAF.cboGAFProviderNeedData(Sender: TObject;
|
---|
| 86 | const StartFrom: String; Direction, InsertAt: Integer);
|
---|
| 87 | begin
|
---|
| 88 | inherited;
|
---|
| 89 | cboGAFProvider.ForDataUse(SubSetOfPersons(StartFrom, Direction));
|
---|
| 90 | end;
|
---|
| 91 |
|
---|
| 92 | function TfrmGAF.BADData(ShowMessage: boolean): boolean;
|
---|
| 93 | var
|
---|
| 94 | PName, msg: string;
|
---|
| 95 | GAFDate: TFMDateTime;
|
---|
| 96 | UIEN: Int64;
|
---|
| 97 |
|
---|
| 98 | begin
|
---|
| 99 | GAFDate := dteGAF.FMDateTime;
|
---|
| 100 | msg := ValidateGAFDate(GAFDate);
|
---|
| 101 | if(dteGAF.FMDateTime <> GAFDate) then
|
---|
| 102 | dteGAF.FMDateTime := GAFDate;
|
---|
| 103 |
|
---|
| 104 | if(cboGAFProvider.ItemID = '') then
|
---|
| 105 | begin
|
---|
| 106 | if(msg <> '') then
|
---|
| 107 | msg := msg + CRLF;
|
---|
| 108 | // msg := msg + 'A determining party is required to enter a GAF score.'; <-- original line. //kt 8/25/2007
|
---|
| 109 | msg := msg + DKLangConstW('fGAF_A_determining_party_is_required_to_enter_a_GAF_scorex'); //kt added 8/25/2007
|
---|
| 110 | UIEN := uProviders.PCEProvider;
|
---|
| 111 | if(UIEN <> 0) then
|
---|
| 112 | begin
|
---|
| 113 | PName := uProviders.PCEProviderName;
|
---|
| 114 | // msg := msg + ' Determined By changed to ' + PName + '.'; <-- original line. //kt 8/25/2007
|
---|
| 115 | msg := msg + DKLangConstW('fGAF_Determined_By_changed_to') + PName + '.'; //kt added 8/25/2007
|
---|
| 116 | cboGAFProvider.SelectByIEN(UIEN);
|
---|
| 117 | if(cboGAFProvider.ItemID = '') then
|
---|
| 118 | begin
|
---|
| 119 | cboGAFProvider.InitLongList(PName);
|
---|
| 120 | cboGAFProvider.SelectByIEN(UIEN);
|
---|
| 121 | end;
|
---|
| 122 | end;
|
---|
| 123 | end;
|
---|
| 124 |
|
---|
| 125 | if(ShowMessage and (msg <> '')) then
|
---|
| 126 | // InfoBox(msg, 'Invalid GAF Data', MB_OK); <-- original line. //kt 8/25/2007
|
---|
| 127 | InfoBox(msg, DKLangConstW('fGAF_Invalid_GAF_Data'), MB_OK); //kt added 8/25/2007
|
---|
| 128 |
|
---|
| 129 | if(udScore.Position > udScore.Min) then
|
---|
| 130 | Result := (msg <> '')
|
---|
| 131 | else
|
---|
| 132 | Result := FALSE;
|
---|
| 133 | end;
|
---|
| 134 |
|
---|
| 135 | procedure TfrmGAF.edtScoreChange(Sender: TObject);
|
---|
| 136 | var
|
---|
| 137 | i: integer;
|
---|
| 138 |
|
---|
| 139 | begin
|
---|
| 140 | inherited;
|
---|
| 141 | i := StrToIntDef(edtScore.Text,udScore.Min);
|
---|
| 142 | if(i < udScore.Min) or (i > udScore.Max) then
|
---|
| 143 | i := udScore.Min;
|
---|
| 144 | udScore.Position := i;
|
---|
| 145 | edtScore.Text := IntToStr(i);
|
---|
| 146 | edtScore.SelStart := length(edtScore.Text);
|
---|
| 147 | end;
|
---|
| 148 |
|
---|
| 149 | procedure TfrmGAF.dteGAFExit(Sender: TObject);
|
---|
| 150 | begin
|
---|
| 151 | inherited;
|
---|
| 152 | // BadData(TRUE);
|
---|
| 153 | end;
|
---|
| 154 |
|
---|
| 155 | procedure TfrmGAF.cboGAFProviderExit(Sender: TObject);
|
---|
| 156 | begin
|
---|
| 157 | inherited;
|
---|
| 158 | BadData(TRUE);
|
---|
| 159 | end;
|
---|
| 160 |
|
---|
| 161 | procedure TfrmGAF.AllowTabChange(var AllowChange: boolean);
|
---|
| 162 | begin
|
---|
| 163 | AllowChange := (not BadData(TRUE));
|
---|
| 164 | end;
|
---|
| 165 |
|
---|
| 166 | procedure TfrmGAF.GetGAFScore(var Score: integer; var Date: TFMDateTime; var Staff: Int64);
|
---|
| 167 | begin
|
---|
| 168 | Score := udScore.Position;
|
---|
| 169 | if(Score > 0) then BadData(TRUE);
|
---|
| 170 | Date := dteGAF.FMDateTime;
|
---|
| 171 | Staff := cboGAFProvider.ItemIEN;
|
---|
| 172 | if(not ValidGAFData(Score, Date, Staff)) then
|
---|
| 173 | begin
|
---|
| 174 | Score := 0;
|
---|
| 175 | Date := 0;
|
---|
| 176 | Staff := 0
|
---|
| 177 | end;
|
---|
| 178 | end;
|
---|
| 179 |
|
---|
| 180 | procedure TfrmGAF.FormActivate(Sender: TObject);
|
---|
| 181 | begin
|
---|
| 182 | inherited;
|
---|
| 183 | if(not FDataLoaded) then
|
---|
| 184 | begin
|
---|
| 185 | FDataLoaded := TRUE;
|
---|
| 186 | LoadScores;
|
---|
| 187 | cboGAFProvider.InitLongList(Encounter.ProviderName);
|
---|
| 188 | BadData(FALSE);
|
---|
| 189 | end;
|
---|
| 190 | end;
|
---|
| 191 |
|
---|
| 192 | procedure TfrmGAF.FormShow(Sender: TObject);
|
---|
| 193 | begin
|
---|
| 194 | inherited;
|
---|
| 195 | FormActivate(Sender);
|
---|
| 196 | end;
|
---|
| 197 |
|
---|
| 198 | procedure TfrmGAF.btnURLClick(Sender: TObject);
|
---|
| 199 | begin
|
---|
| 200 | inherited;
|
---|
| 201 | GotoWebPage(GAFURL);
|
---|
| 202 | end;
|
---|
| 203 |
|
---|
| 204 | procedure TfrmGAF.FormCreate(Sender: TObject);
|
---|
| 205 | begin
|
---|
| 206 | inherited;
|
---|
| 207 | FTabName := CT_GAFNm;
|
---|
| 208 | btnURL.Visible := (User.WebAccess and (GAFURL <> ''));
|
---|
| 209 | end;
|
---|
| 210 |
|
---|
| 211 | end.
|
---|