source: cprs/branches/foia-cprs/CPRS-Chart/Consults/fEditConsult.pas@ 516

Last change on this file since 516 was 459, checked in by Kevin Toppenberg, 17 years ago

Adding foia-cprs branch

File size: 20.0 KB
RevLine 
[459]1unit fEditConsult;
2
3interface
4
5uses
6 Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
7 StdCtrls, ORCtrls, ExtCtrls, ComCtrls, ORfn, uConst, uConsults, Buttons,
8 Menus ;
9
10type
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
84function EditResubmitConsult(FontSize: Integer; ConsultIEN: integer): boolean;
85
86var
87 frmEditCslt: TfrmEditCslt;
88
89implementation
90
91{$R *.DFM}
92
93uses
94 rODBase, rConsults, uCore, rCore, fConsults, fRptBox, fPCELex, rPCE,
95 ORClasses, clipbrd, UBAGlobals, rOrders ;
96
97var
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
107const
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
121function EditResubmitConsult(FontSize: Integer; ConsultIEN: integer): boolean;
122begin
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;
164end;
165
166procedure TfrmEditCslt.InitDialog;
167var
168 i:integer;
169begin
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('');
217end;
218
219procedure 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
227begin
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);
249end;
250
251procedure TfrmEditCslt.txtAttnNeedData(Sender: TObject;
252 const StartFrom: string; Direction, InsertAt: Integer);
253begin
254 inherited;
255 txtAttn.ForDataUse(SubSetOfPersons(StartFrom, Direction));
256end;
257
258procedure TfrmEditCslt.radInpatientClick(Sender: TObject);
259begin
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);
269end;
270
271procedure TfrmEditCslt.radOutpatientClick(Sender: TObject);
272begin
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);
282end;
283
284
285procedure TfrmEditCslt.ControlChange(Sender: TObject);
286begin
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;
398end;
399
400procedure TfrmEditCslt.FormClose(Sender: TObject; var Action: TCloseAction);
401const
402 TX_ACCEPT = 'Resubmit this request?' + CRLF + CRLF;
403 TX_ACCEPT_CAP = 'Unsaved Changes';
404begin
405 if FChanged then
406 if InfoBox(TX_ACCEPT, TX_ACCEPT_CAP, MB_YESNO) = ID_YES then
407 if not ValidSave then Action := caNone;
408end;
409
410procedure TfrmEditCslt.cmdAcceptClick(Sender: TObject);
411{Begin BillingAware}
412var
413 BADiagnosis: string;
414 //newDxRec: TBADxRecord;
415 //AnOrder: TOrder;
416{End BillingAware}
417begin
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;
436end;
437
438procedure TfrmEditCslt.memReasonExit(Sender: TObject);
439var
440 AStringList: TStringList;
441begin
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;
452end;
453
454procedure TfrmEditCslt.cmdQuitClick(Sender: TObject);
455begin
456 inherited;
457 FChanged := False;
458 Close;
459end;
460
461function TfrmEditCslt.ValidSave: Boolean;
462const
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.';
466var
467 ErrMsg: string;
468begin
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);
478end;
479
480
481procedure TfrmEditCslt.OrderMessage(const AMessage: string);
482begin
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;
491end;
492
493procedure TfrmEditCslt.btnCmtCancelClick(Sender: TObject);
494begin
495 ReportBox(OldRec.DenyComments, 'Cancellation Comments', False);
496end;
497
498procedure TfrmEditCslt.btnCmtOtherClick(Sender: TObject);
499begin
500 ReportBox(OldRec.OtherComments, 'Added Comments', False);
501end;
502
503procedure TfrmEditCslt.cmdLexSearchClick(Sender: TObject);
504var
505 Match: string;
506 i: integer;
507begin
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;
525end;
526
527procedure TfrmEditCslt.SetProvDiagPromptingMode;
528const
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)';
532begin
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;
579end;
580
581procedure TfrmEditCslt.mnuPopProvDxDeleteClick(Sender: TObject);
582begin
583 inherited;
584 ProvDx.Text := '';
585 ProvDx.Code := '';
586 ProvDx.CodeInactive := False;
587 txtProvDiag.Text := '';
588 ControlChange(Self);
589end;
590
591procedure TfrmEditCslt.popReasonPopup(Sender: TObject);
592begin
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;
610end;
611
612procedure TfrmEditCslt.popReasonCutClick(Sender: TObject);
613begin
614 inherited;
615 FEditCtrl.CutToClipboard;
616end;
617
618procedure TfrmEditCslt.popReasonCopyClick(Sender: TObject);
619begin
620 inherited;
621 FEditCtrl.CopyToClipboard;
622end;
623
624procedure TfrmEditCslt.popReasonPasteClick(Sender: TObject);
625begin
626 inherited;
627 FEditCtrl.SelText := Clipboard.AsText;
628end;
629
630procedure TfrmEditCslt.popReasonReformatClick(Sender: TObject);
631begin
632 inherited;
633 if (Screen.ActiveControl <> memReason) and
634 (Screen.ActiveControl <> memComment)then Exit;
635 ReformatMemoParagraph(TCustomMemo(FEditCtrl));
636end;
637
638procedure TfrmEditCslt.memCommentKeyUp(Sender: TObject; var Key: Word;
639 Shift: TShiftState);
640begin
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;
653end;
654
655procedure TfrmEditCslt.memCommentKeyDown(Sender: TObject; var Key: Word;
656 Shift: TShiftState);
657begin
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;
663end;
664
665procedure TfrmEditCslt.memCommentKeyPress(Sender: TObject; var Key: Char);
666begin
667 if FNavigatingTab then
668 Key := #0; //Disable shift-tab processin
669end;
670
671end.
Note: See TracBrowser for help on using the repository browser.