VistA-cprs/CPRS-Chart/fGraphs.pas

6325 lines
206 KiB
Plaintext

unit fGraphs;
interface
uses
Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
ExtCtrls, StdCtrls, ORCtrls, Menus, TeeProcs, TeEngine, Series, Chart, Math,
ComCtrls, GanttCh, ClipBrd, StrUtils, ORFn, ORDtTmRng, DateUtils, Printers,
OleServer, Variants, Word97, Word2000, ArrowCha, ORDtTm, uGraphs;
type
TfrmGraphs = class(TForm)
btnChangeSettings: TButton;
btnClose: TButton;
btnGraphSelections: TButton;
bvlBottomLeft: TBevel;
bvlBottomRight: TBevel;
bvlTopLeft: TBevel;
bvlTopRight: TBevel;
calDateRange: TORDateRangeDlg;
cboDateRange: TORComboBox;
chartBase: TChart;
chartDatelineBottom: TChart;
chartDatelineTop: TChart;
chkDualViews: TCheckBox;
chkItemsBottom: TCheckBox;
chkItemsTop: TCheckBox;
dlgDate: TORDateTimeDlg;
lblDateRange: TLabel;
lblViewsBottom: TOROffsetLabel;
lblViewsTop: TOROffsetLabel;
lstAllTypes: TListBox;
lstCheck: TListBox;
lstData: TListBox;
lstDrugClass: TListBox;
lstItems: TListBox;
lstItemsTemp: TListBox;
lstMultiSpec: TListBox;
lstNonNumeric: TListBox;
lstScratchLab: TListBox;
lstScratchSwap: TListBox;
lstScratchTemp: TListBox;
lstSelCopyBottom: TListBox;
lstSelCopyTop: TListBox;
lstSpec1: TListBox;
lstSpec2: TListBox;
lstSpec3: TListBox;
lstSpec4: TListBox;
lstTemp: TListBox;
lstTempCheck: TListBox;
lstTestSpec: TListBox;
lstTypes: TListBox;
lstViews: TListBox;
lstZoomHistory: TListBox;
lvwItemsBottom: TListView;
lvwItemsTop: TListView;
mnumedsasgantt: TMenuItem;
mnumedsasganttvertheight: TMenuItem;
mnuPopGraph3D: TMenuItem;
mnuPopGraphClear: TMenuItem;
mnuPopGraphCopy: TMenuItem;
mnuPopGraphDates: TMenuItem;
mnuPopGraphDefineViews: TMenuItem;
mnuPopGraphDetails: TMenuItem;
mnuPopGraphDualViews: TMenuItem;
mnuPopGraphGradient: TMenuItem;
mnuPopGraphFixed: TMenuItem;
mnuPopGraphHints: TMenuItem;
mnuPopGraphHorizontal: TMenuItem;
mnuPopGraphIsolate: TMenuItem;
mnuPopGraphLegend: TMenuItem;
mnuPopGraphLines: TMenuItem;
mnuPopGraphPrint: TMenuItem;
mnuPopGraphRemove: TMenuItem;
mnuPopGraphReset: TMenuItem;
mnuPopGraphSeparate1: TMenuItem;
mnuPopGraphSort: TMenuItem;
mnuPopGraphSplit: TMenuItem;
mnuPopGraphStayOnTop: TMenuItem;
mnuPopGraphStuff: TPopupMenu;
mnuPopGraphSwap: TMenuItem;
mnuPopGraphToday: TMenuItem;
mnuPopGraphValues: TMenuItem;
mnuPopGraphVertical: TMenuItem;
mnuPopGraphZoomBack: TMenuItem;
N1: TMenuItem;
N2: TMenuItem;
N3: TMenuItem;
N4: TMenuItem;
pnlBlankBottom: TPanel;
pnlBlankTop: TPanel;
pnlBottom: TPanel;
pnlBottomRightPad: TPanel;
pnlData: TPanel;
pnlDatelineBottom: TPanel;
pnlDatelineBottomSpacer: TORAutoPanel;
pnlDatelineTop: TPanel;
pnlDatelineTopSpacer: TORAutoPanel;
pnlFooter: TPanel;
pnlHeader: TPanel;
pnlInfo: TORAutoPanel;
pnlItemsBottom: TPanel;
pnlItemsBottomInfo: TPanel;
pnlItemsTop: TPanel;
pnlItemsTopInfo: TPanel;
pnlMain: TPanel;
pnlScrollBottomBase: TPanel;
pnlScrollTopBase: TPanel;
pnlTemp: TPanel;
pnlTop: TPanel;
pnlTopRightPad: TPanel;
scrlBottom: TScrollBox;
scrlTop: TScrollBox;
serDatelineBottom: TGanttSeries;
serDatelineTop: TGanttSeries;
splGraphs: TSplitter;
splItemsBottom: TSplitter;
splItemsTop: TSplitter;
timHintPause: TTimer;
lstSelPrevTop: TListBox;
lstSelPrevBottom: TListBox;
lstComp: TListBox;
pnlViewsTopSpacer: TPanel;
cboViewsTop: TORComboBox;
pnlViewsTopSpacerRight: TPanel;
pnlViewsBottomSpacer: TPanel;
cboViewsBottom: TORComboBox;
pnlViewsBottomSpacerRight: TPanel;
testcount1: TMenuItem;
procedure FormCreate(Sender: TObject);
procedure FormShow(Sender: TObject);
procedure FormClose(Sender: TObject; var Action: TCloseAction);
procedure btnCloseClick(Sender: TObject);
procedure btnChangeSettingsClick(Sender: TObject);
procedure btnGraphSelectionsClick(Sender: TObject);
procedure chkDualViewsClick(Sender: TObject);
procedure chkItemsTopClick(Sender: TObject);
procedure chkItemsBottomClick(Sender: TObject);
procedure mnuMedsasganttClick(Sender: TObject);
procedure mnuPopGraph3DClick(Sender: TObject);
procedure mnuPopGraphClearClick(Sender: TObject);
procedure mnuPopGraphCopyClick(Sender: TObject);
procedure mnuPopGraphDatesClick(Sender: TObject);
procedure mnuPopGraphDetailsClick(Sender: TObject);
procedure mnuPopGraphDualViewsClick(Sender: TObject);
procedure mnuPopGraphFixedClick(Sender: TObject);
procedure mnuPopGraphGradientClick(Sender: TObject);
procedure mnuPopGraphHintsClick(Sender: TObject);
procedure mnuPopGraphIsolateClick(Sender: TObject);
procedure mnuPopGraphLegendClick(Sender: TObject);
procedure mnuPopGraphLinesClick(Sender: TObject);
procedure mnuPopGraphPrintClick(Sender: TObject);
procedure mnuPopGraphRemoveClick(Sender: TObject);
procedure mnuPopGraphResetClick(Sender: TObject);
procedure mnuPopGraphSeparate1Click(Sender: TObject);
procedure mnuPopGraphStayOnTopClick(Sender: TObject);
procedure mnuPopGraphSortClick(Sender: TObject);
procedure mnuPopGraphSplitClick(Sender: TObject);
procedure mnuPopGraphStuffPopup(Sender: TObject);
procedure mnuPopGraphSwapClick(Sender: TObject);
procedure mnuPopGraphTodayClick(Sender: TObject);
procedure mnuPopGraphValuesClick(Sender: TObject);
procedure mnuPopGraphHorizontalClick(Sender: TObject);
procedure mnuPopGraphVerticalClick(Sender: TObject);
procedure mnuPopGraphZoomBackClick(Sender: TObject);
procedure splGraphsMoved(Sender: TObject);
procedure splItemsBottomMoved(Sender: TObject);
procedure splItemsTopMoved(Sender: TObject);
procedure GetSize;
procedure SetSize;
procedure lvwItemsBottomClick(Sender: TObject);
procedure lvwItemsBottomColumnClick(Sender: TObject; Column: TListColumn);
procedure lvwItemsBottomCompare(Sender: TObject; Item1,
Item2: TListItem; Data: Integer; var Compare: Integer);
procedure lvwItemsTopClick(Sender: TObject);
procedure lvwItemsTopColumnClick(Sender: TObject; Column: TListColumn);
procedure lvwItemsTopCompare(Sender: TObject; Item1, Item2: TListItem;
Data: Integer; var Compare: Integer);
procedure cboDateRangeChange(Sender: TObject);
procedure cboViewsBottomChange(Sender: TObject);
procedure cboViewsTopChange(Sender: TObject);
procedure pnlScrollTopBaseResize(Sender: TObject);
procedure chartBaseClickLegend(Sender: TCustomChart;
Button: TMouseButton; Shift: TShiftState; X, Y: Integer);
procedure chartBaseClickSeries(Sender: TCustomChart; Series: TChartSeries;
ValueIndex: Integer; Button: TMouseButton; Shift: TShiftState; X, Y: Integer);
procedure chartBaseMouseDown(Sender: TObject; Button: TMouseButton;
Shift: TShiftState; X, Y: Integer);
procedure chartBaseMouseMove(Sender: TObject; Shift: TShiftState; X, Y: Integer);
procedure serDatelineTopGetMarkText(Sender: TChartSeries;
ValueIndex: Integer; var MarkText: String);
procedure ChartOnUndoZoom(Sender: TObject);
procedure ChartOnZoom(Sender: TObject);
procedure DisplayData(aSection: string);
procedure HideDates(aChart: TChart);
procedure SourcesDefault;
procedure StayOnTop;
procedure timHintPauseTimer(Sender: TObject);
procedure ZoomUpdate;
procedure ZoomUpdateInfo(SmallTime, BigTime: TDateTime);
procedure ZoomTo(SmallTime, BigTime: TDateTime);
procedure lvwItemsTopChange(Sender: TObject; Item: TListItem;
Change: TItemChange);
procedure lvwItemsTopKeyDown(Sender: TObject; var Key: Word;
Shift: TShiftState);
procedure lvwItemsBottomChange(Sender: TObject; Item: TListItem;
Change: TItemChange);
procedure testcount1Click(Sender: TObject);
procedure cboDateRangeDropDown(Sender: TObject);
procedure cboViewsTopDropDown(Sender: TObject);
procedure cboViewsTopDropDownClose(Sender: TObject);
procedure cboViewsBottomDropDown(Sender: TObject);
procedure cboViewsBottomDropDownClose(Sender: TObject);
procedure FormDestroy(Sender: TObject);
procedure lvwItemsTopEnter(Sender: TObject);
procedure lvwItemsBottomEnter(Sender: TObject);
procedure chkItemsBottomEnter(Sender: TObject);
procedure cboViewsBottomEnter(Sender: TObject);
private
{ Private declarations }
FBSortAscending: boolean;
FBSortCol: integer;
FDate1: Double;
FDate2: Double;
FSortAscending: boolean;
FSortCol: integer;
FActiveGraph: TChart;
FArrowKeys: boolean;
FBHighTime, FBLowTime: Double;
FCreate: boolean;
FFirstClick: boolean;
FFirstSwitch: boolean;
FGraphClick: TCustomChart;
FGraphSeries: TChartSeries;
FGraphValueIndex: integer;
FGraphSetting: TGraphSetting;
FGraphType: char;
FItemsSortedTop: boolean;
FItemsSortedBottom: boolean;
FMouseDown: boolean;
FMTimestamp: string;
FMToday: TFMDateTime;
FMyProfiles, FProfiles: TStringList;
FNonNumerics: boolean; // used with pnlItemsTop.Tag & pnlItemsBottom.Tag
FOnLegend: integer;
FOnSeries: integer;
FOnValue: integer;
FPrevEvent: string;
FRetainZoom: boolean;
FSources: TStrings;
FSourcesDefault: TStrings;
FTHighTime, FTLowTime: Double;
FWarning: boolean;
FX, FY: integer;
FYMinValue: Double;
FYMaxValue: Double;
procedure AdjustTimeframe;
procedure AllTypeDate(aType, aTypeName, firstline, secondline: string; aDate, aDate2: double);
procedure AllDetails(aDate1, aDate2: TFMDateTime; aTempList: TStrings);
procedure AssignProfile(aProfile, aSection: string);
procedure AutoSelect(aListView: TListView);
procedure BaseResize(aScrollBox: TScrollBox);
procedure BottomAxis(aScrollBox: TScrollBox);
procedure ChangeStyle;
procedure ChartStyle(aChart: TChart);
procedure CheckProfile(var aProfile: string; var Updated: boolean);
procedure CheckToAddData(aListView: TListView; aSection, TypeToCheck: string);
procedure CreatePatientHeader(var HeaderList: TStringList; PageTitle, Warning, DateRange: string);
procedure DateRangeItems(oldestdate, newestdate: double; filenum: string);
procedure UpdateView(filename, filenum, itemnum, aString: string; aListView: TListView);
procedure DisplayType(itemtype, displayed: string);
procedure FillViews;
procedure FilterListView(oldestdate, newestdate: double);
procedure FixedDates(var adatetime, adatetime1: TDateTime);
procedure GetData(aString: string);
procedure HideGraphs(action: boolean);
procedure HighLow(fmtime, fmtime1: string; aChart: TChart; var adatetime, adatetime1: TDateTime);
procedure InactivateHint;
procedure ItemCheck(aListView: TListView; aItemName: string;
var aNum: integer; var aTypeItem: string);
procedure ItemsClick(Sender: TObject; aListView, aOtherListView: TListView;
aCheckBox: TCheckBox; aComboBox: TORComboBox; aList: TListBox; aSection: string);
procedure ItemDateRange(Sender: TCustomChart);
procedure LabData(aItemType, aItemName, aSection: string);
procedure LoadDateRange;
procedure LoadDisplayCheck(typeofitem: string; var updated: boolean);
procedure LoadType(itemtype, displayed: string);
procedure NextPointerStyle(aSeries: TChartSeries; aSerCnt: integer);
procedure OneDayTypeDetails(aTypeItem: string);
procedure RefUnits(aItem, aSpec: string; var low, high, units: string);
procedure ResetSpec(aListBox: TListBox; aItemNum, aNewItemNum, aNewItemName, aNewString: string);
procedure TempCheck(typeitem: string; var levelseq: double);
procedure SelCopy(aListView: TListView; aListBox: TListBox);
procedure SelReset(aListbox: TListBox; aListView: TListView);
procedure SelectItem(aListView: TListView; typeitem: string);
procedure SetProfile(aProfile, aName: string; aListView: TListView);
procedure SizeDates(aChart: TChart; aSmallTime, aBigTime: TDateTime);
procedure SizeTogether(onlylines, nolines, anylines: Boolean; aScroll: TScrollBox;
aChart: TChart; aPanel, aPanelBase: TPanel; portion: Double);
procedure ViewsChange(aListView: TListView; aComboBox: TORComboBox; aSection: string);
procedure MakeDateline(section, aTitle, aFileType: string; aChart: TChart; graphtype: integer;
var bcnt, pcnt, gcnt, vcnt, acnt: integer);
procedure MakeSeparate(aScrollBox: TScrollBox; aListView: TListView; aPadPanel: TPanel; section: string);
procedure MakeTogether(aScrollBox: TScrollBox; aListView: TListView; aPadPanel: TPanel; section: string);
procedure MakeAGanttSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
procedure MakeArrowSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
procedure MakeBarSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
procedure MakeGanttSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
procedure MakeLineSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt, aNonCnt: integer; multiline: boolean);
procedure MakeManyGanttSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer); // good one
procedure MakePointSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
procedure MakeVisitGanttSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
procedure MakeWeightedArrowSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
procedure MakeWeightedGanttSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
function BPValue(aDateTime: TDateTime): string;
function DateRangeMultiItems(aOldDate, aNewDate: double; aMultiItem: string): boolean;
function DCName(aDCien: string): string;
function ExpandTax(profile: string): string;
function FileNameX(filenum: string): string;
function FMCorrectedDate(fmtime: string): string;
function GraphTypeNum(aType: string): integer;
function HSAbbrev(aType: string): boolean;
function InvVal(value: double): double;
function ItemName(filenum, itemnum: string): string;
function NextColor(aCnt: integer): TColor;
function PortionSize(lcnt, pcnt, gcnt, vcnt, bcnt, acnt: integer): double;
function SelectRef(aRef: string): string;
function StdDev(value, high, low: double): double;
function TypeIsDisplayed(itemtype: string): boolean;
function TypeIsLoaded(itemtype: string): boolean;
function Vfactor(aTitle: string): double;
function ValueText(Sender: TCustomChart; Series: TChartSeries; ValueIndex: Integer): string;
public
{ Public declarations }
procedure InitialData;
procedure Initialize;
procedure InitialRetain;
procedure LoadListView(aList: TStrings);
procedure SourceContext;
procedure ViewSelections;
procedure SetFontSize(FontSize: integer);
function FMToDateTime(FMDateTime: string): TDateTime;
end;
var
frmGraphs: TfrmGraphs;
FHintWin: THintWindow;
FHintWinActive: boolean;
FHintStop: boolean;
implementation
uses fGraphSettings, fGraphProfiles, rGraphs,
ComObj, ActiveX, ShellAPI, fFrame, uCore, rCore, fRptBox, fReports,
uFormMonitor;
{$R *.DFM}
type
TGraphItem = class
public
Values: string;
end;
procedure TfrmGraphs.FormCreate(Sender: TObject);
var
i: integer;
dfntype, listline, settings, settings1, t1, t2: string;
aList: TStrings;
begin
FMToday := DateTimeToFMDateTime(Date);
FHintWinActive := false;
FHintStop := false;
FNonNumerics := false;
FMouseDown := false;
FItemsSortedTop := false;
FItemsSortedBottom := false;
FRetainZoom := false;
FFirstClick := true;
FArrowKeys := false;
FCreate := true;
FGraphType := Char(32);
aList := TStringList.Create;
FastAssign(rpcGetGraphSettings, aList);
btnClose.Tag := 0;
if aList.Count < 1 then
begin
Screen.Cursor := crDefault;
showmessage('CPRS is not configured for graphing.');
btnClose.Tag := 1;
FreeAndNil(aList);
Close;
Exit;
end;
t1 := aList[0]; t2 := aList[1]; // hint are current, t1 are personal, t2 public settings
if length(frmFrame.mnuToolsGraphing.Hint) > 0 then settings := frmFrame.mnuToolsGraphing.Hint
else if length(t1) > 0 then settings := t1
else settings := t2;
SetPiece(settings, '|', 8, Piece(t2, '|', 8)); //??????????
frmFrame.mnuToolsGraphing.Hint := settings;
settings1 := Piece(settings, '|', 1);
FSources := TStringList.Create;
FSourcesDefault := TStringList.Create;
FMyProfiles := TStringList.Create;
FProfiles := TStringList.Create;
FYMinValue := 0;
FYMaxValue := 0;
FTHighTime := 0;
FTLowTime := BIG_NUMBER;
FBHighTime := 0;
FBLowTime := BIG_NUMBER;
pnlInfo.Caption := TXT_INFO;
FOnLegend := BIG_NUMBER;
FOnSeries := BIG_NUMBER;
FOnValue := BIG_NUMBER;
FHintWin := THintWindow.Create(self);
FHintWin.Color := clInfoBk;
FHintWin.Canvas.Font.Color := clInfoBk;
FX := 0; FY :=0;
FastAssign(rpcGetTypes('0', false), lstAllTypes.Items);
for i := 0 to lstAllTypes.Items.Count - 1 do
begin
listline := lstAllTypes.Items[i];
dfntype := UpperCase(Piece(listline, '^', 1));
SetPiece(listline, '^', 1, dfntype);
lstAllTypes.Items[i] := listline;
end;
FGraphSetting := GraphSettingsInit(settings);
for i := 0 to BIG_NUMBER do
begin
dfntype := Piece(settings1, ';', i);
if length(dfntype) = 0 then break;
listline := dfntype + '^' + FileNameX(dfntype) + '^1';
FSources.Add(listline);
FSourcesDefault.Add(listline);
end;
serDatelineTop.Active := false;
serDatelineBottom.Active := false;
chartDatelineTop.Gradient.EndColor := clGradientActiveCaption;
chartDatelineTop.Gradient.StartColor := clWindow;
chartDatelineBottom.Gradient.EndColor := clGradientActiveCaption;
chartDatelineBottom.Gradient.StartColor := clWindow;
LoadDateRange;
chkItemsTop.Checked := true;
chkItemsBottom.Checked := true;
FastAssign(rpcGetTestSpec, lstTestSpec.Items);
FillViews;
FreeAndNil(aList);
end;
procedure TfrmGraphs.SourcesDefault;
var
i: integer;
dfntype, listline, settings, settings1, t1, t2: string;
aList: TStrings;
begin
aList := TStringList.Create;
FastAssign(rpcGetGraphSettings, aList);
t1 := aList[0]; t2 := aList[1]; // t1 are personal, t2 public settings
if length(frmFrame.mnuToolsGraphing.Hint) > 0 then settings := frmFrame.mnuToolsGraphing.Hint
else if length(t1) > 0 then settings := t1
else settings := t2;
SetPiece(settings, '|', 8, Piece(t2, '|', 8));
settings1 := Piece(settings, '|', 1);
FGraphSetting := GraphSettingsInit(settings);
for i := 0 to BIG_NUMBER do
begin
dfntype := Piece(settings1, ';', i);
if length(dfntype) = 0 then break;
listline := dfntype + '^' + FileNameX(dfntype) + '^1';
FSourcesDefault.Add(listline);
end;
FreeAndNil(aList);
end;
procedure TfrmGraphs.Initialize;
var
i: integer;
rptview1, rptview2, rptviews: string;
begin
InitialData;
SourceContext;
LoadListView(lstItems.Items);
if pnlMain.Tag > 0 then
begin
rptviews := MixedCase(rpcReportParams(pnlMain.Tag));
if length(rptviews) > 1 then
begin
rptview1 := Piece(rptviews, '^', 1);
rptview2 := Piece(rptviews, '^', 2);
if length(rptview1) > 0 then
begin
for i := 0 to cboViewsTop.Items.Count - 1 do
if Piece(cboViewsTop.Items[i], '^', 2) = rptview1 then
begin
cboViewsTop.ItemIndex := i;
break;
end;
end;
if length(rptview2) > 0 then
begin
chkDualViews.Checked := true;
chkDualViewsClick(self);
for i := 0 to cboViewsBottom.Items.Count - 1 do
if Piece(cboViewsBottom.Items[i], '^', 2) = rptview2 then
begin
cboViewsBottom.ItemIndex := i;
break;
end;
end;
end;
end;
if cboViewsTop.ItemIndex > -1 then
cboViewsTopChange(self)
else
lvwItemsTopClick(self);
if cboViewsBottom.ItemIndex > -1 then
cboViewsbottomChange(self)
else
lvwItemsBottomClick(self);
if pnlMain.Tag > 0 then
begin
pnlMain.Tag := 0;
cboDateRangeChange(self);
if cboViewsTop.ItemIndex > -1 then
cboViewsTopChange(self)
else
lvwItemsTopClick(self);
if cboViewsBottom.ItemIndex > -1 then
cboViewsbottomChange(self)
else
lvwItemsBottomClick(self);
end;
end;
procedure TfrmGraphs.InitialRetain;
//var
//i: integer;
begin
{//
allview=false
fullview=false
noview=true
go thru items
if selected
if view
noview=false
else
allview=false
else
if view
allview=false
fullview=false
noview=false
else
//
if noview
//
if allview
//
if fullview
//
else //partial view
//
//}
end;
procedure TfrmGraphs.FillViews;
var
i: integer;
begin
with cboViewsTop do
begin
Items.Clear;
Sorted := false;
lstTemp.Sorted := true;
FastAssign(rpcGetGraphProfiles('1', '0', 0), lstTemp.Items);
if lstTemp.Items.Count > 0 then
begin
for i := 0 to lstTemp.Items.Count - 1 do
Items.Add('-1^' + lstTemp.Items[i] + '^');
end;
FastAssign(rpcGetGraphProfiles('1', '1', 0), lstTemp.Items);
if lstTemp.Items.Count > 0 then
begin
Items.Add(LLS_LINE);
for i := 0 to lstTemp.Items.Count - 1 do
Items.Add('-2^' + lstTemp.Items[i] + '^');
end;
Items.Insert(0, '^<clear all selections>^0');
Items.Insert(1, '^<select items>^0');
end;
FastAssign(cboViewsTop.Items, cboViewsBottom.Items);
end;
procedure TfrmGraphs.SourceContext;
begin
if frmFrame.GraphContext = '' then exit;
frmFrame.GraphContext := '';
end;
procedure TfrmGraphs.FormShow(Sender: TObject);
begin
Font := MainFont;
ChangeStyle;
StayOnTop;
mnuPopGraphResetClick(self);
if pnlFooter.Tag = 1 then // do not show footer controls on reports tab
begin
pnlFooter.Visible := false;
if FCreate then
begin
FGraphType := GRAPH_REPORT;
FCreate := false;
GetSize;
end;
end
else
begin
chkDualViews.Checked := false;
chkDualViewsClick(self);
if FCreate then
begin
FGraphType := GRAPH_FLOAT;
FCreate := false;
GetSize;
end;
end;
if cboDateRange.ItemIndex < 0 then
cboDateRange.ItemIndex := cboDateRange.Items.Count - 1;
cboDateRangeChange(self);
lvwItemsTopClick(self);
if lvwItemsTop.Items.Count = 0 then
begin
cboViewsTop.ItemIndex := 0;
cboViewsTop.Text := '';
end;
//else
// lvwItemsTop.SetFocus;
//chkItemsTop.SetFocus;
cboViewsTop.SetFocus;
//Perform(WM_NextDlgCtl, 0, 0);
end;
procedure TfrmGraphs.FormClose(Sender: TObject; var Action: TCloseAction);
begin
SetSize;
timHintPause.Enabled := false;
InactivateHint;
frmFrame.GraphFloatActive := false;
end;
procedure TfrmGraphs.GetSize;
var
i, v1, v2, v3, v4: integer;
name, settings, value: string;
aList: TStrings;
begin
aList := TStringList.Create;
FastAssign(rpcGetGraphSizing, aList);
for i := 0 to aList.Count - 1 do
begin
settings := aList[i];
name := Piece(settings, '^', 1);
value := Piece(settings, '^', 2);
if length(value) > 1 then
begin
v1 := strtointdef(Piece(value, ',', 1), 0);
v2 := strtointdef(Piece(value, ',', 2), 0);
v3 := strtointdef(Piece(value, ',', 3), 0);
v4 := strtointdef(Piece(value, ',', 4), 0);
if FGraphType = GRAPH_FLOAT then
begin
if name = 'FBOUNDS' then
begin
if value = '0,0,0,0' then
WindowState := wsMaximized
else
begin
if v1 > 0 then Left := v1;
if v2 > 0 then Top := v2;
if v3 > 0 then Width := v3;
if v4 > 0 then Height := v4;
end;
end
else if name = 'FWIDTH' then
begin
if v1 > 0 then
begin
pnlItemsTop.Width := v1;
splItemsTopMoved(self);
end;
end
else if name = 'FBOTTOM' then
begin
if v1 > 0 then
begin
chkDualViews.Checked := true;
chkDualViewsClick(self);
pnlBottom.Height := v1;
end;
end
else if name = 'FCOLUMN' then
begin
if v1 > 0 then lvwItemsTop.Column[0].Width := v1;
if v2 > 0 then lvwItemsTop.Column[1].Width := v2;
if v3 > 0 then lvwItemsTop.Column[2].Width := v3;
if v4 > 0 then lvwItemsTop.Column[3].Width := v4;
end
else if name = 'FBCOLUMN' then
begin
if v1 > 0 then lvwItemsBottom.Column[0].Width := v1;
if v2 > 0 then lvwItemsBottom.Column[1].Width := v2;
if v3 > 0 then lvwItemsBottom.Column[2].Width := v3;
if v4 > 0 then lvwItemsBottom.Column[3].Width := v4;
end;
end
else
begin
if name = 'RWIDTH' then
begin
if v1 > 0 then
begin
pnlItemsTop.Width := v1;
splItemsTopMoved(self);
end;
end
else if name = 'RBOTTOM' then
begin
if v1 > 0 then
begin
pnlBottom.Height := v1;
splGraphsMoved(splGraphs);
end;
end
else if name = 'RCOLUMN' then
begin
if v1 > 0 then lvwItemsTop.Column[0].Width := v1;
if v2 > 0 then lvwItemsTop.Column[1].Width := v2;
if v3 > 0 then lvwItemsTop.Column[2].Width := v3;
if v4 > 0 then lvwItemsTop.Column[3].Width := v4;
end
else if name = 'RBCOLUMN' then
begin
if v1 > 0 then lvwItemsBottom.Column[0].Width := v1;
if v2 > 0 then lvwItemsBottom.Column[1].Width := v2;
if v3 > 0 then lvwItemsBottom.Column[2].Width := v3;
if v4 > 0 then lvwItemsBottom.Column[3].Width := v4;
end;
end;
end;
end;
FreeAndNil(aList);
end;
procedure TfrmGraphs.SetSize;
var
name, v1, v2, v3, v4: string;
aList: TStrings;
begin
aList := TStringList.Create;
if FGraphType = GRAPH_FLOAT then
begin
name := 'FBOUNDS';
v1 := inttostr(Left);
v2 := inttostr(Top);
v3 := inttostr(Width);
v4 := inttostr(Height);
if WindowState = wsMaximized then
aList.Add(name + '^0,0,0,0')
else
aList.Add(name + '^' + v1 +',' + v2 +',' + v3 +',' + v4);
name := 'FWIDTH';
v1 := inttostr(splItemsTop.Left);
aList.Add(name + '^' + v1);
name := 'FBOTTOM';
if chkDualViews.Checked then
v1 := inttostr(pnlBottom.Height)
else
v1 := '0';
aList.Add(name + '^' + v1);
name := 'FCOLUMN';
v1 := inttostr(lvwItemsTop.Column[0].Width);
v2 := inttostr(lvwItemsTop.Column[1].Width);
v3 := inttostr(lvwItemsTop.Column[2].Width);
v4 := inttostr(lvwItemsTop.Column[3].Width);
aList.Add(name + '^' + v1 +',' + v2 +',' + v3 +',' + v4);
name := 'FBCOLUMN';
v1 := inttostr(lvwItemsBottom.Column[0].Width);
v2 := inttostr(lvwItemsBottom.Column[1].Width);
v3 := inttostr(lvwItemsBottom.Column[2].Width);
v4 := inttostr(lvwItemsBottom.Column[3].Width);
aList.Add(name + '^' + v1 +',' + v2 +',' + v3 +',' + v4);
end
else
begin
name := 'RWIDTH';
v1 := inttostr(splItemsTop.Left);
aList.Add(name + '^' + v1);
name := 'RBOTTOM';
if chkDualViews.Checked then
v1 := inttostr(pnlBottom.Height)
else
v1 := '0';
aList.Add(name + '^' + v1);
name := 'RCOLUMN';
v1 := inttostr(lvwItemsTop.Column[0].Width);
v2 := inttostr(lvwItemsTop.Column[1].Width);
v3 := inttostr(lvwItemsTop.Column[2].Width);
v4 := inttostr(lvwItemsTop.Column[3].Width);
aList.Add(name + '^' + v1 +',' + v2 +',' + v3 +',' + v4);
name := 'RBCOLUMN';
v1 := inttostr(lvwItemsBottom.Column[0].Width);
v2 := inttostr(lvwItemsBottom.Column[1].Width);
v3 := inttostr(lvwItemsBottom.Column[2].Width);
v4 := inttostr(lvwItemsBottom.Column[3].Width);
aList.Add(name + '^' + v1 +',' + v2 +',' + v3 +',' + v4);
end;
rpcSetGraphSizing(aList);
FreeAndNil(aList);
end;
procedure TfrmGraphs.btnCloseClick(Sender: TObject);
begin
Close;
end;
procedure TfrmGraphs.btnChangeSettingsClick(Sender: TObject);
var
needtoupdate, okbutton: boolean;
conv, i, preconv: integer;
PreMaxGraphs: integer;
PreMaxSelect: integer;
PreMinGraphHeight: integer;
PreSortColumn: integer;
PreFixedDateRange: boolean;
aSettings, filetype, sourcetype: string;
PreSources: TStrings;
begin
okbutton := false;
conv := btnChangeSettings.Tag;
preconv := conv;
with FGraphSetting do
begin
PreMaxGraphs := MaxGraphs;
PreMaxSelect := MaxSelect;
PreMinGraphHeight := MinGraphHeight;
PreSortColumn := SortColumn;
PreFixedDateRange := FixedDateRange;
MaxSelectMin := Max(Max(lvwItemsTop.SelCount, lvwItemsBottom.SelCount), 1);
end;
PreSources := TStringList.Create;
PreSources.Assign(FSources);
DialogGraphSettings(Font.Size, okbutton, FGraphSetting, FSources, conv, aSettings);
if not okbutton then exit;
if length(aSettings) > 0 then frmFrame.mnuToolsGraphing.Hint := aSettings;
btnChangeSettings.Tag := conv;
pnlInfo.Font.Size := lblViewsTop.Font.Size;
SetFontSize(lblViewsTop.Font.Size);
pnlInfo.Visible := conv > 0;
if conv > 0 then
begin
pnlInfo.Caption := TXT_WARNING;
pnlInfo.Color := COLOR_WARNING;
end;
pnlHeader.Visible := pnlInfo.Visible;
StayOnTop;
needtoupdate := (conv <> preconv);
for i := 0 to FSources.Count - 1 do
begin
sourcetype := FSources[i];
if Copy(sourcetype, 1, 1) = '*' then
begin
FSources[i] := Pieces(sourcetype, '^', 2, 4);
filetype := Piece(FSources[i], '^', 1);
lstItems.Items.AddStrings(rpcGetItems(filetype, Patient.DFN));
needtoupdate := true;
end;
if not needtoupdate then
if Piece(PreSources[i], '^', 3) = '0' then
needtoupdate := TypeIsDisplayed(Piece(sourcetype, '^', 1))
else
needtoupdate := not TypeIsDisplayed(Piece(sourcetype, '^', 1));
end;
if not needtoupdate then
with FGraphSetting do
if MaxGraphs <> PreMaxGraphs then
needtoupdate := true
else if MaxSelect <> PreMaxSelect then
needtoupdate := true
else if MinGraphHeight <> PreMinGraphHeight then
needtoupdate := true
else if SortColumn <> PreSortColumn then
needtoupdate := true
else if FixedDateRange <> PreFixedDateRange then
needtoupdate := true;
if needtoupdate then
begin
cboDateRangeChange(self);
end;
ChangeStyle;
if lvwItemsTop.SelCount = 0 then
begin
cboViewsTop.ItemIndex := -1;
cboViewsTop.Text := '';
end;
if lvwItemsBottom.SelCount = 0 then
begin
cboViewsBottom.ItemIndex := -1;
cboViewsBottom.Text := '';
end;
end;
procedure TfrmGraphs.chkDualViewsClick(Sender: TObject);
begin
if chkDualViews.Checked then
begin
pnlBottom.Height := pnlMain.Height div 2;
lvwItemsTopClick(self);
end
else
begin
lvwItemsBottom.ClearSelection;
lvwItemsBottomClick(self);
pnlBottom.Height := 1;
end;
mnuPopGraphDualViews.Checked := chkDualViews.Checked;
with pnlMain.Parent do
if BorderWidth <> 1 then // only do on Graph in Reports tab
frmReports.chkDualViews.Checked := chkDualViews.Checked;
end;
procedure TfrmGraphs.LoadListView(aList: TStrings);
var
i: integer;
filename, filenum, itemnum: string;
begin
lvwItemsTop.Items.Clear;
lvwItemsBottom.Items.Clear;
lvwItemsTop.SortType := stNone; // if Sorting during load then potential error
lvwItemsBottom.SortType := stNone; // if Sorting during load then potential error
with lvwItemsTop do
for i := 0 to aList.Count - 1 do
begin
filenum := Piece(aList[i], '^', 1);
filename := FileNameX(filenum); // change rpc **********
itemnum := Piece(aList[i], '^', 2);
UpdateView(filename, filenum, itemnum, aList[i], lvwItemsTop);
end;
lvwItemsBottom.Items.Assign(lvwItemsTop.Items);
lvwItemsTop.SortType := stBoth;
lvwItemsBottom.SortType := stBoth;
if not FItemsSortedTop then
begin
lvwItemsTopColumnClick(lvwItemsTop, lvwItemsTop.Column[0]);
FItemsSortedTop := true;
end;
if not FItemsSortedBottom then
begin
lvwItemsBottomColumnClick(lvwItemsBottom, lvwItemsBottom.Column[0]);
FItemsSortedBottom := true;
end;
with FGraphSetting do
if SortColumn > 0 then
begin
lvwItemsTopColumnClick(lvwItemsTop, lvwItemsTop.Column[SortColumn]);
lvwItemsBottomColumnClick(lvwItemsBottom, lvwItemsBottom.Column[SortColumn]);
FItemsSortedTop := false;
FItemsSortedBottom := false;
end;
end;
procedure TfrmGraphs.FilterListView(oldestdate, newestdate: double);
var
colnum, i: integer;
lastdate: double;
aProfile, filename, filenum, itemnum: string;
begin
lvwItemsTop.Scroll(-BIG_NUMBER, -BIG_NUMBER); //faster to set scroll at top
lvwItemsBottom.Scroll(-BIG_NUMBER, -BIG_NUMBER);
lvwItemsTop.Items.Clear;
lvwItemsBottom.Items.Clear;
lvwItemsTop.SortType := stNone; // if Sorting during load then potential error
lvwItemsBottom.SortType := stNone; // if Sorting during load then potential error
if (cboDateRange.ItemIndex > 0) and (cboDateRange.ItemIndex < 9) then
begin
with lvwItemsTop do
if TypeIsDisplayed('405') then
DateRangeItems(oldestdate, newestdate, '405'); // does not matter for all results ******************
if TypeIsDisplayed('52') then
DateRangeItems(oldestdate, newestdate, '52'); // does not matter for all results ******************
if TypeIsDisplayed('55') then
DateRangeItems(oldestdate, newestdate, '55');
if TypeIsDisplayed('55NVA') then
DateRangeItems(oldestdate, newestdate, '55NVA');
if TypeIsDisplayed('9999911') then
DateRangeItems(oldestdate, newestdate, '9999911');
for i := 0 to lstItems.Items.Count - 1 do
begin
filenum := UpperCase(Piece(lstItems.Items[i], '^', 1));
if filenum <> '405' then
if filenum <> '52' then
if filenum <> '55' then
if filenum <> '55NVA' then
if filenum <> '9999911' then
if TypeIsDisplayed(filenum) then
begin
lastdate := strtofloatdef(Piece(lstItems.Items[i], '^', 6), -BIG_NUMBER);
if (lastdate > oldestdate) and (lastdate < newestdate) then
begin
filename := FileNameX(filenum);
itemnum := Piece(lstItems.Items[i], '^', 2);
UpdateView(filename, filenum, itemnum, lstItems.Items[i], lvwItemsTop);
end;
end;
end;
end
else if (cboDateRange.ItemIndex = 0) or (cboDateRange.ItemIndex > 8) then
begin // manual date range selection
for i := 0 to lstAllTypes.Items.Count - 1 do
begin
filenum := Piece(lstAllTypes.Items[i], '^', 1);
if TypeIsDisplayed(filenum) then
begin
DateRangeItems(oldestdate, newestdate, filenum);
end;
end;
end;
lvwItemsBottom.Items.Assign(lvwItemsTop.Items);
lvwItemsTop.SortType := stBoth;
lvwItemsBottom.SortType := stBoth;
colnum := 0;
if not FItemsSortedTop then
begin
lvwItemsTopColumnClick(lvwItemsTop, lvwItemsTop.Column[0]);
FItemsSortedTop := true;
end;
if not FItemsSortedBottom then
begin
lvwItemsBottomColumnClick(lvwItemsBottom, lvwItemsBottom.Column[0]);
FItemsSortedBottom := true;
end;
with FGraphSetting do
if SortColumn > 0 then
begin
colnum := SortColumn;
lvwItemsTopColumnClick(lvwItemsTop, lvwItemsTop.Column[SortColumn]);
lvwItemsBottomColumnClick(lvwItemsBottom, lvwItemsBottom.Column[SortColumn]);
FItemsSortedTop := false;
FItemsSortedBottom := false;
end;
if cboViewsTop.ItemIndex > 1 then // sort by view
begin
aProfile := cboViewsTop.Items[cboViewsTop.ItemIndex];
AssignProfile(aProfile, 'top');
if not FItemsSortedTop then lvwItemsTopColumnClick(lvwItemsTop, lvwItemsTop.Column[colnum]);
lvwItemsTopColumnClick(lvwItemsTop, lvwItemsTop.Column[2]);
lvwItemsTopColumnClick(lvwItemsTop, lvwItemsTop.Column[2]);
FItemsSortedTop := false;
end;
if cboViewsBottom.ItemIndex > 1 then // sort by view
begin
aProfile := cboViewsBottom.Items[cboViewsBottom.ItemIndex];
AssignProfile(aProfile, 'bottom');
if not FItemsSortedBottom then lvwItemsBottomColumnClick(lvwItemsBottom, lvwItemsBottom.Column[colnum]);
lvwItemsBottomColumnClick(lvwItemsBottom, lvwItemsBottom.Column[2]);
lvwItemsBottomColumnClick(lvwItemsBottom, lvwItemsBottom.Column[2]);
FItemsSortedBottom := false;
end;
end;
procedure TfrmGraphs.DateRangeItems(oldestdate, newestdate: double; filenum: string);
var
i, j: integer;
filename, itemnum, itemstuff, mitemnum: string;
begin
FastAssign(rpcDateItem(oldestdate, newestdate, filenum, Patient.DFN), lstScratchTemp.Items);
filename := FileNameX(filenum);
with lvwItemsTop do
for i := 0 to lstScratchTemp.Items.Count - 1 do
begin
itemstuff := lstScratchTemp.Items[i];
itemnum := UpperCase(Piece(itemstuff, '^',2));
for j := 0 to lstItems.Items.Count - 1 do
if (filenum = UpperCase(Piece(lstItems.Items[j], '^', 1))) and (itemnum = UpperCase(Piece(lstItems.Items[j], '^', 2))) then
UpdateView(filename, filenum, itemnum, lstItems.Items[j], lvwItemsTop);
if filenum = '63' then
for j := 0 to lstMultiSpec.Items.Count - 1 do
begin
mitemnum := Piece(lstMultiSpec.Items[j], '^', 2);
if itemnum = Piece(mitemnum, '.', 1) then
if DateRangeMultiItems(oldestdate, newestdate, mitemnum) then //******** check specific date range
UpdateView(filename, filenum, mitemnum, lstMultiSpec.Items[j], lvwItemsTop);
end;
end;
end;
procedure TfrmGraphs.UpdateView(filename, filenum, itemnum, aString: string; aListView: TListView);
var
drugclass, itemname, itemqualifier: string;
aGraphItem: TGraphItem;
aListItem: TListItem;
begin
itemname := Piece(aString, '^', 4);
itemqualifier := Pieces(aString, '^', 5, 9);
itemqualifier := filenum + '^' + itemnum + '^' + itemqualifier;
drugclass := Piece(aString, '^', 8);
aListItem := aListView.Items.Add;
with aListItem do
begin
Caption := itemname;
SubItems.Add(filename);
SubItems.Add('');
SubItems.Add(drugclass);
aGraphItem := TGraphItem.Create;
aGraphItem.Values := itemqualifier;
SubItems.AddObject('info object', aGraphItem);
end;
end;
function TfrmGraphs.DateRangeMultiItems(aOldDate, aNewDate: double; aMultiItem: string): boolean;
var
i: integer;
checkdate: double;
fileitem: string;
begin
Result := false;
fileitem := '63^' + aMultiItem;
for i := 0 to lstData.Items.Count - 1 do
if Pieces(lstData.Items[i], '^', 1, 2) = fileitem then
begin
checkdate := strtofloatdef(Piece(lstData.Items[i], '^', 3), BIG_NUMBER);
if checkdate <> BIG_NUMBER then
if checkdate >= aOldDate then
if checkdate <= aNewDate then
begin
Result := true;
break;
end;
end;
end;
function TfrmGraphs.FileNameX(filenum: string): string;
var
i: integer;
typestring: string;
begin
Result := '';
with lstAllTypes do
for i := 0 to Items.Count - 1 do
begin
typestring := Items[i];
if Piece(typestring, '^', 1) = filenum then
begin
Result := Piece(Items[i], '^', 2);
break;
end;
end;
if Result = '' then
begin
with lstAllTypes do
for i := 0 to Items.Count - 1 do
begin
typestring := Items[i];
if lowercase(Piece(typestring, '^', 1)) = filenum then
begin
Result := Piece(Items[i], '^', 2);
break;
end;
end;
end;
end;
function TfrmGraphs.ItemName(filenum, itemnum: string): string;
var
i: integer;
typestring: string;
begin
Result := '';
filenum := UpperCase(filenum);
itemnum := UpperCase(itemnum);
with lstItems do
for i := 0 to Items.Count - 1 do
begin
typestring := UpperCase(Items[i]);
if (Piece(typestring, '^', 1) = filenum) and
(Piece(typestring, '^', 2) = itemnum) then
begin
Result := Piece(typestring, '^', 4);
break;
end;
end;
end;
procedure TfrmGraphs.InitialData;
var
i, total: integer;
dfntype, listline: string;
begin
total := pnlData.ControlCount - 1;
with pnlData do
for i:= 0 to total do
if Controls[i] is TListBox then
if Controls[i] <> lstAllTypes then
if Controls[i] <> lstTestSpec then
(Controls[i] as TListBox).Items.Clear;
SourcesDefault;
FSources.Assign(FSourcesDefault);
btnChangeSettings.Tag :=0;
btnClose.Tag := 0;
cboViewsTop.Tag :=0;
chartDatelineTop.Tag :=0;
lvwItemsBottom.Tag :=0;
lvwItemsTop.Tag :=0;
pnlFooter.Parent.Tag :=0;
pnlItemsBottom.Tag :=0;
pnlItemsTop.Tag :=0;
pnlTop.Tag :=0;
scrlTop.Tag :=0;
splGraphs.Tag :=0;
cboViewsTop.ItemIndex := -1;
cboViewsBottom.ItemIndex := -1;
FastAssign(rpcGetTypes(Patient.DFN, false), lstTypes.Items);
for i := 0 to lstTypes.Items.Count - 1 do
begin
dfntype := UpperCase(Piece(lstTypes.Items[i], '^', 1));
if TypeIsLoaded(dfntype) then
lstItems.Items.AddStrings(rpcGetItems(dfntype, Patient.DFN));
listline := lstTypes.Items[i];
dfntype := UpperCase(Piece(listline, '^', 1));
SetPiece(listline, '^', 1, dfntype);
lstTypes.Items[i] := listline;
end;
lstTypes.Hint := Patient.DFN; // use to check for patient change
FMTimestamp := floattostr(FMNow);
FPrevEvent := '';
FWarning := false;
FFirstSwitch := true;
end;
function TfrmGraphs.TypeIsLoaded(itemtype: string): boolean;
var
i: integer;
filetype: string;
begin
Result := false;
for i := 0 to FSources.Count - 1 do
begin
filetype := Piece(FSources[i], '^', 1);
if itemtype = filetype then
begin
Result := true;
break;
end;
end;
end;
function TfrmGraphs.TypeIsDisplayed(itemtype: string): boolean;
var
i: integer;
displayed, filetype: string;
begin
Result := false;
for i := 0 to FSources.Count - 1 do
begin
filetype := Piece(FSources[i], '^', 1);
displayed := Piece(FSources[i], '^', 3);
if (itemtype = filetype) then
begin
if displayed = '1' then Result := true;
break;
end;
end;
end;
procedure TfrmGraphs.LoadDateRange;
var
defaults, defaultrange: string;
begin
FastAssign(rpcGetGraphDateRange('OR_GRAPHS'), cboDateRange.Items);
with cboDateRange do
begin
defaults := Items[Items.Count - 1];
defaultrange := Piece(defaults, '^', 1);
//get report views - param 1 and param 2
lvwItemsTop.Hint := Piece(defaults,'^', 8); // top view
lvwItemsBottom.Hint := Piece(defaults,'^', 9); // bottom view
//check if default range already exists
if strtointdef(defaultrange, BIG_NUMBER) = BIG_NUMBER then
ItemIndex := Items.Count - 1;
end;
end;
procedure TfrmGraphs.LoadType(itemtype, displayed: string);
var
needtoadd: boolean;
i: integer;
filename, filetype: string;
begin
if displayed <> '1' then displayed := '';
needtoadd := true;
for i := 0 to FSources.Count - 1 do
begin
filetype := Piece(FSources[i], '^', 1);
if itemtype = filetype then
begin
needtoadd := false;
break;
end;
end;
if needtoadd then
begin
filename := FileNameX(itemtype);
FSources.Add(itemtype + '^' + filename + '^' + displayed);
lstItems.Items.AddStrings(rpcGetItems(itemtype, Patient.DFN));
end;
end;
procedure TfrmGraphs.DisplayType(itemtype, displayed: string);
var
i: integer;
filename, filetype: string;
begin
if displayed <> '1' then displayed := '';
for i := 0 to FSources.Count - 1 do
begin
filetype := Piece(FSources[i], '^', 1);
if itemtype = filetype then
begin
filename := FileNameX(itemtype);
FSources[i] := itemtype + '^' + filename + '^' + displayed;
break;
end;
end;
end;
procedure TfrmGraphs.DisplayData(aSection: string);
var
aChart: TChart;
aCheckBox: TCheckBox;
aListView, aOtherListView: TListView;
aDateline, aRightPad: TPanel;
aScrollBox: TScrollBox;
begin
FHintStop := true;
SetFontSize(lblViewsTop.Font.Size);
if aSection = 'top' then
begin
aListView := lvwItemsTop;
aOtherListView := lvwItemsBottom;
aDateline := pnlDatelineTop;
aRightPad := pnlTopRightPad;
aScrollBox := scrlTop;
aChart := chartDatelineTop;
aCheckBox := chkItemsTop;
end
else
begin
aListView := lvwItemsBottom;
aOtherListView := lvwItemsTop;
aDateline := pnlDatelineBottom;
aRightPad := pnlBottomRightPad;
aScrollBox := scrlBottom;
aChart := chartDatelineBottom;
aCheckBox := chkItemsBottom;
end;
if aListView.SelCount < 1 then
begin
if not FFirstClick then
begin
FFirstClick := true;
while aScrollBox.ControlCount > 0 do
aScrollBox.Controls[0].Free;
exit;
end;
FFirstClick := false;
aDateline.Visible := false;
while aScrollBox.ControlCount > 0 do
aScrollBox.Controls[0].Free;
if aOtherListView.SelCount > 0 then
if aOtherListView = lvwItemsTop then
ItemsClick(self, lvwItemsTop, lvwItemsBottom, chkItemsTop, cboViewsTop, lstSelCopyTop, 'top')
else
ItemsClick(self, lvwItemsBottom, lvwItemsTop, chkItemsBottom, cboViewsBottom, lstSelCopyBottom, 'bottom');
exit;
end;
aScrollBox.VertScrollBar.Visible := false;
aScrollBox.HorzScrollBar.Visible := false;
aChart.RemoveAllSeries; // this would leave bottom dateline visible on date change
//chartDatelineTop.RemoveAllSeries; // do both
//chartDatelineBottom.RemoveAllSeries; // do both
lstNonNumeric.Items.Clear;
if aCheckBox.Checked then
MakeSeparate(aScrollBox, aListView, aRightPad, aSection)
else
begin
MakeTogether(aScrollBox, aListView, aRightPad, aSection);
end;
ChangeStyle;
pnlInfo.Font.Size := lblViewsTop.Font.Size;
if ((lvwItemsTop.SelCount > MAX_ITEM_DISCLAIMER) and (not chkItemsTop.Checked))
or ((lvwItemsBottom.SelCount > MAX_ITEM_DISCLAIMER) and (not chkItemsBottom.Checked)) then
begin
pnlInfo.Caption := TXT_DISCLAIMER;
pnlInfo.Color := COLOR_WARNING;
pnlInfo.Visible := true;
end
else
pnlInfo.Visible := false;
if btnChangeSettings.Tag > 0 then
begin
pnlInfo.Caption := TXT_WARNING;
pnlInfo.Color := COLOR_WARNING;
pnlInfo.Visible := true;
end;
//if copy(pnlInfo.Caption, 1, 7) = 'Warning' then
if FWarning then
pnlInfo.Visible := true;
pnlHeader.Visible := pnlInfo.Visible;
aScrollBox.VertScrollBar.Visible := true;
aScrollBox.HorzScrollBar.Visible := false;
end;
procedure TfrmGraphs.chkItemsTopClick(Sender: TObject);
begin
Screen.Cursor := crHourGlass;
DisplayData('top');
if FFirstSwitch then // this code makes events appear better (on first click was not displaying bar)
begin
chartBaseMouseDown(chartDatelineTop, mbLeft, [], 1, 1);
DisplayData('top');
FFirstSwitch := false;
end;
Screen.Cursor := crDefault;
end;
procedure TfrmGraphs.chkItemsBottomClick(Sender: TObject);
begin
Screen.Cursor := crHourGlass;
DisplayData('bottom');
if FFirstSwitch then // this code makes events appear better (on first click was not displaying bar)
begin
chartBaseMouseDown(chartDatelineBottom, mbLeft, [], 1, 1);
DisplayData('bottom');
FFirstSwitch := false;
end;
Screen.Cursor := crDefault;
end;
procedure TfrmGraphs.BottomAxis(aScrollBox: TScrollBox);
var
i: integer;
ChildControl: TControl;
begin
for i := 0 to aScrollBox.ControlCount - 1 do
begin
ChildControl := aScrollBox.Controls[i];
with (ChildControl as TChart).BottomAxis do
begin
Automatic := false;
Minimum := 0;
Maximum := chartDatelineTop.BottomAxis.Maximum;
Minimum := chartDatelineTop.BottomAxis.Minimum;
end;
end;
end;
procedure TfrmGraphs.AdjustTimeframe;
begin
with FGraphSetting do
begin
if HighTime = 0 then exit; // no data to chart clear form ???
chartDatelineTop.BottomAxis.Minimum := 0; // avoid possible error
chartDatelineTop.BottomAxis.Maximum := HighTime;
if LowTime < HighTime then
chartDatelineTop.BottomAxis.Minimum := LowTime;
chartDatelineBottom.BottomAxis.Minimum := 0; // avoid possible error
chartDatelineBottom.BottomAxis.Maximum := HighTime;
if HighTime > FMDateTimeToDateTime(FMStopDate) then
chartDatelineTop.BottomAxis.Maximum := FMDateTimeToDateTime(FMStopDate);
if LowTime < FMDateTimeToDateTime(FMStartDate) then
chartDatelineTop.BottomAxis.Minimum := FMDateTimeToDateTime(FMStartDate); // *****
end;
BottomAxis(scrlTop);
BottomAxis(scrlBottom);
end;
procedure TfrmGraphs.ChartOnZoom(Sender: TObject);
var
i: integer;
padding: double;
datehx: string;
BigTime, SmallTime: TDateTime;
ChildControl: TControl;
begin
if not (Sender is TChart) then exit;
if not FGraphSetting.VerticalZoom then
begin
padding := 0; //(FYMaxValue - FYMinValue) * ((100 - ZOOM_PERCENT) * 0.01);
(Sender as TChart).LeftAxis.Maximum := BIG_NUMBER; // avoid min>max error
(Sender as TChart).LeftAxis.Minimum := -BIG_NUMBER;
(Sender as TChart).LeftAxis.Maximum := FYMaxValue + padding; //padding 0?
(Sender as TChart).LeftAxis.Minimum := FYMinValue - padding; //padding 0?
end;
SmallTime := (Sender as TChart).BottomAxis.Minimum;
BigTime := (Sender as TChart).BottomAxis.Maximum;
if BigTime < SmallTime then BigTime := SmallTime; // avoid min>max error
for i := 0 to scrlTop.ControlCount - 1 do
begin
ChildControl := scrlTop.Controls[i];
SizeDates((ChildControl as TChart), SmallTime, BigTime);
end;
SizeDates(chartDatelineTop, SmallTime, BigTime);
for i := 0 to scrlBottom.ControlCount - 1 do
begin
ChildControl := scrlBottom.Controls[i];
SizeDates((ChildControl as TChart), SmallTime, BigTime);
end;
SizeDates(chartDatelineBottom, SmallTime, BigTime);
if FMouseDown and (Sender as TChart).Zoomed then
begin
datehx := FloatToStr(SmallTime) + '^' + FloatToStr(BigTime);
lstZoomHistory.Items.Add(datehx);
mnuPopGraphZoomBack.Enabled := true;
FMouseDown := false;
ZoomUpdateinfo(SmallTime, BigTime);
end;
end;
procedure TfrmGraphs.ChartOnUndoZoom(Sender: TObject);
var
i: integer;
padding: double;
BigTime, SmallTime: TDateTime;
ChildControl: TControl;
begin
if not (Sender is TChart) then exit;
FRetainZoom := false;
mnuPopGraphZoomBack.Enabled := false;
lstZoomHistory.Items.Clear;
if not FGraphSetting.VerticalZoom then
begin
padding := 0; //(FYMaxValue - FYMinValue) * ((100 - ZOOM_PERCENT) * 0.01);
(Sender as TChart).LeftAxis.Maximum := BIG_NUMBER; // avoid min>max error
(Sender as TChart).LeftAxis.Minimum := -BIG_NUMBER;
(Sender as TChart).LeftAxis.Maximum := FYMaxValue + padding; //padding 0?
(Sender as TChart).LeftAxis.Minimum := FYMinValue - padding; //padding 0?
end;
SmallTime := (Sender as TChart).BottomAxis.Minimum;
BigTime := (Sender as TChart).BottomAxis.Maximum;
if BigTime < SmallTime then BigTime := SmallTime; // avoid min>max error
for i := 0 to scrlTop.ControlCount - 1 do
begin
ChildControl := scrlTop.Controls[i];
SizeDates((ChildControl as TChart), SmallTime, BigTime);
end;
SizeDates(chartDatelineTop, SmallTime, BigTime);
for i := 0 to scrlBottom.ControlCount - 1 do
begin
ChildControl := scrlBottom.Controls[i];
SizeDates((ChildControl as TChart), SmallTime, BigTime);
end;
SizeDates(chartDatelineBottom, SmallTime, BigTime);
if FMouseDown then
begin
FMouseDown := false;
pnlInfo.Caption := '';
pnlInfo.Color := COLOR_INFO;
pnlInfo.Visible := false;
pnlHeader.Visible := false;
end;
end;
procedure TfrmGraphs.SizeDates(aChart: TChart; aSmallTime, aBigTime: TDateTime);
var
datediff, yeardiff: integer;
begin
with aChart.BottomAxis do
begin
Automatic := false;
Maximum := BIG_NUMBER; // avoid min>max error
Minimum := -BIG_NUMBER;
Minimum := aSmallTime;
Maximum := aBigTime;
Increment := DateTimeStep[dtOneMinute];
datediff := DaysBetween(aBigTime, aSmallTime);
yeardiff := datediff div 365;
DateTimeFormat := '';
Labels := true;
if yeardiff > 0 then
begin
if (pnlScrollTopBase.Width div yeardiff) < DWIDTH_MDY then
DateTimeFormat := DFORMAT_MYY;
if (pnlScrollTopBase.Width div yeardiff) < DWIDTH_MYY then
DateTimeFormat := DFORMAT_YY;
if (pnlScrollTopBase.Width div yeardiff) < DWIDTH_YY then
Labels := false;
end;
end;
if datediff < 1 then
begin
if not aChart.Foot.Visible then
begin
aChart.Foot.Text.Clear;
aChart.Foot.Text.Insert(0, FormatDateTime('mmm d, yyyy', aSmallTime));
aChart.Foot.Font.Color := clBtnText;
aChart.Foot.Visible := true;
end;
end
else
aChart.Foot.Visible := false;
end;
procedure TfrmGraphs.MakeSeparate(aScrollBox: TScrollBox; aListView:
TListView; aPadPanel: TPanel; section: string);
var
acnt, bcnt, displayheight, displaynum, gcnt, graphtype, i, j, lcnt, ncnt, pcnt, vcnt: integer;
aTitle, checkdata, filetype, high, low, specimen, specnum, typeitem, units: string;
newchart: TChart;
aGraphItem: TGraphItem;
begin
FNonNumerics := false;
if section = 'top' then pnlItemsTop.Tag := 0 else pnlItemsBottom.Tag := 0;
while aScrollBox.ControlCount > 0 do
aScrollBox.Controls[0].Free;
aPadPanel.Visible := false;
if FGraphSetting.Hints then //**************
begin
chartDatelineTop.OnMouseMove := chartBaseMouseMove;
chartDatelineBottom.OnMouseMove := chartBaseMouseMove;
end
else
begin
chartDatelineTop.OnMouseMove := nil;
chartDatelineBottom.OnMouseMove := nil;
end;
pcnt := 0; gcnt := 0; vcnt := 0; lcnt := 0; ncnt := 0; bcnt := 0; acnt := 0;
for j := 0 to aListView.Items.Count - 1 do
if aListView.Items[j].Selected then
begin
aGraphItem := TGraphItem(aListView.Items.Item[j].SubItems.Objects[3]);
filetype := UpperCase(Piece(aGraphItem.Values, '^', 1));
typeitem := UpperCase(Piece(aGraphItem.Values, '^', 2));
graphtype := GraphTypeNum(filetype); //*****strtointdef(Piece(aListBox.Items[j], '^', 2), 1);
if (filetype = '63') and (lstData.Items.Count > 0) then
begin
checkdata := '';
for i := 0 to lstData.Items.Count - 1 do
begin
checkdata := lstData.Items[i];
if (Piece(checkdata, '^', 1) = '63') and (Piece(checkdata, '^', 2) = typeitem) then
break;
end;
specnum := Piece(checkdata, '^', 7);
specimen := Piece(checkdata, '^', 8);
RefUnits(typeitem, specnum, low, high, units);
units := LowerCase(units);
if units = '' then units := ' ';
end
else
begin
specimen := ''; low := ''; high := ''; units := '';
end;
aTitle := filetype + '^' + typeitem + '^' + aListView.Items[j].Caption + '^' +
specimen + '^' + low + '^' + high + '^' + units;
newchart := TChart.Create(self);
with newchart do
begin
Parent := aScrollBox;
View3D := false;
height := 170;
Align := alBottom;
Align := alTop;
AllowPanning := pmNone;
Legend.LegendStyle := lsSeries;
Legend.ShadowSize := 1;
Legend.Color := clCream;
Legend.VertMargin := 0;
Legend.Alignment := laTop;
Legend.Visible := true;
Gradient.EndColor := clGradientActiveCaption;
//SetPiece(aTitle, '^', 3, 'zzzz: ' + Piece(aTitle, '^', 3)); // test prefix
if (graphtype = 1) and (btnChangeSettings.Tag = 1) then
LeftAxis.Title.Caption := 'StdDev'
else if (graphtype = 1) and (btnChangeSettings.Tag = 2) then
begin
LeftAxis.Title.Caption := '1/' + units;
SetPiece(aTitle, '^', 3, 'Inverse ' + Piece(aTitle, '^', 3));
end
else
LeftAxis.Title.Caption := units;
if graphtype <> 1 then
begin
LeftAxis.Visible := false;
MarginLeft := round((50 / (pnlScrollTopBase.Width + 1)) * 100); // ************* marginleft is a %
end;
BottomAxis.ExactDateTime := true;
BottomAxis.Increment := DateTimeStep[dtOneMinute];
HideDates(newchart);
BevelOuter := bvNone;
OnZoom := ChartOnZoom;
OnUndoZoom := ChartOnUndoZoom;
OnClickSeries := chartBaseClickSeries;
OnClickLegend := chartBaseClickLegend;
OnDblClick := mnuPopGraphDetailsClick;
OnMouseDown := chartBaseMouseDown;
if FGraphSetting.Hints then //*****
OnMouseMove := chartBaseMouseMove
else
OnMouseMove := nil;
end;
splGraphs.Tag := 1; // show ref ranges
if graphtype = 4 then graphtype := 2; // change points to be bars
case graphtype of
1: MakeLineSeries(newchart, aTitle, filetype, lcnt, ncnt, false);
2: MakeBarSeries(newchart, aTitle, filetype, bcnt);
3: MakeVisitGanttSeries(newchart, aTitle, filetype, vcnt);
4: MakePointSeries(newchart, aTitle, filetype, pcnt);
5: MakeArrowSeries(newchart, aTitle, filetype, acnt);
6: MakeGanttSeries(newchart, aTitle, filetype, gcnt);
7: MakeAGanttSeries(newchart, aTitle, filetype, gcnt);
8: MakeManyGanttSeries(newchart, aTitle, filetype, gcnt);
9: MakeWeightedArrowSeries(newchart, aTitle, filetype, acnt);
10: MakeWeightedGanttSeries(newchart, aTitle, filetype, gcnt);
end;
end;
if section = 'top' then
begin
pnlDatelineTop.Align := alBottom;
pnlDatelineTop.Height := 30;
scrlTop.Align := alClient;
pnlDatelineTop.Visible := false;
end
else
begin
pnlDatelineBottom.Align := alBottom;
pnlDatelineBottom.Height := 30;
scrlBottom.Align := alClient;
pnlDatelineBottom.Visible := false;
end;
with aScrollBox do
begin
if ControlCount < FGraphSetting.MaxGraphs then //**** formating should be made for top & bottom
displaynum := ControlCount
else
displaynum := FGraphSetting.MaxGraphs;
if displaynum = 0 then
displaynum := 3;
if (Height div displaynum) < FGraphSetting.MinGraphHeight then
displayheight := FGraphSetting.MinGraphHeight
else
displayheight := (Height div displaynum);
for i := 0 to aScrollBox.ControlCount - 1 do
Controls[i].height := displayheight;
end;
if (FGraphSetting.HighTime = FGraphSetting.LowTime)
or (lcnt = 1) or (pcnt = 1) or (bcnt = 1) or (vcnt = 1) then
begin
FGraphSetting.HighTime := FGraphSetting.HighTime + 1;
FGraphSetting.LowTime := FGraphSetting.LowTime - 1;
end;
AdjustTimeframe;
if chartDatelineTop.Visible then chartDatelineTop.ZoomPercent(ZOOM_PERCENT);
if chartDatelineBottom.Visible then chartDatelineBottom.ZoomPercent(ZOOM_PERCENT);
if FNonNumerics then
if section = 'top' then pnlItemsTop.Tag := 1
else pnlItemsBottom.Tag := 1;
end;
procedure TfrmGraphs.MakeTogether(aScrollBox: TScrollBox; aListView:
TListView; aPadPanel: TPanel; section: string);
var
anylines, nolines, onlylines, singlelabtest: boolean;
acnt, bcnt, cnt, gcnt, graphtype, i, j, lcnt, ncnt, pcnt, vcnt: integer;
portion: double;
aTitle, checkdata, filetype, high, low, specimen, specnum, typeitem, units: string;
newchart: TChart;
aGraphItem: TGraphItem;
begin
pcnt := 0; gcnt := 0; lcnt := 0; ncnt := 0; bcnt := 0; acnt := 0;
onlylines := true;
anylines := false;
nolines := true;
FNonNumerics := false;
if section = 'top' then pnlItemsTop.Tag := 0 else pnlItemsBottom.Tag := 0;
if FGraphSetting.Hints then //******
begin
chartDatelineTop.OnMouseMove := chartBaseMouseMove;
chartDatelineBottom.OnMouseMove := chartBaseMouseMove;
end
else
begin
chartDatelineTop.OnMouseMove := nil;
chartDatelineBottom.OnMouseMove := nil;
end;
for j := 0 to aListView.Items.Count - 1 do
if aListView.Items[j].Selected then
begin
aGraphItem := TGraphItem(aListView.Items.Item[j].SubItems.Objects[3]);
filetype := UpperCase(Piece(aGraphItem.Values, '^', 1));
typeitem := UpperCase(Piece(aGraphItem.Values, '^', 2));
if aListView.SelCount = 1 then // one lab test - make separate
begin
if filetype = '63' then
begin
MakeSeparate(aScrollBox, aListView, aPadPanel, section);
exit;
end;
end;
graphtype := GraphTypeNum(filetype);
case graphtype of
1: lcnt := lcnt + 1;
2: bcnt := bcnt + 1;
3: vcnt := vcnt + 1;
4: pcnt := pcnt + 1;
5: acnt := acnt + 1;
6: gcnt := gcnt + 1;
7: gcnt := gcnt + 1;
8: gcnt := gcnt + 1;
9: acnt := acnt + 1;
end;
if graphtype = 1 then
begin
anylines := true;
nolines := false;
end
else
onlylines := false;
end;
if section = 'top' then
chkItemsTop.Checked := false
else
chkItemsBottom.Checked := false;
lstTempCheck.Items.Clear;
while aScrollBox.ControlCount > 0 do
aScrollBox.Controls[0].Free;
newchart := TChart.Create(self); // whynot use base?
with newchart do // if a single line graph do lab stuff (ref range, units) ****************************************
begin
Parent := aScrollBox;
View3D := false;
Chart3DPercent := 10;
AllowPanning := pmNone;
Align := alClient;
Gradient.EndColor := clGradientActiveCaption;
Legend.LegendStyle := lsSeries;
Legend.ShadowSize := 1;
Legend.Color := clCream;
Legend.VertMargin := 0;
Legend.Alignment := laTop;
Legend.Visible := true;
LeftAxis.Title.Caption := ' ';
BottomAxis.ExactDateTime := true;
BottomAxis.Increment := DateTimeStep[dtOneMinute];
HideDates(newchart);
BevelOuter := bvNone;
OnZoom := ChartOnZoom;
OnUndoZoom := ChartOnUndoZoom;
OnClickSeries := chartBaseClickSeries;
OnClickLegend := chartBaseClickLegend;
OnDblClick := mnuPopGraphDetailsClick;
OnMouseDown := chartBaseMouseDown;
if FGraphSetting.Hints then //******
OnMouseMove := chartBaseMouseMove
else
OnMouseMove := nil;
Visible := false;
end;
aPadPanel.Visible := true;
portion := PortionSize(lcnt, pcnt, gcnt, vcnt, bcnt, acnt);
if section = 'top' then
SizeTogether(onlylines, nolines, anylines, scrlTop, newchart,
pnlDatelineTop, pnlScrollTopBase, portion)
else
SizeTogether(onlylines, nolines, anylines, scrlBottom, newchart,
pnlDatelineBottom, pnlScrollBottomBase, portion);
if btnChangeSettings.Tag = 1 then splGraphs.Tag := 1 // show ref ranges
else splGraphs.Tag := 0;
if nolines then
begin
pcnt := 0; gcnt := 0; vcnt := 0; bcnt := 0; acnt := 0;
for j := 0 to aListView.Items.Count - 1 do
if aListView.Items[j].Selected then
begin
aGraphItem := TGraphItem(aListView.Items.Item[j].SubItems.Objects[3]);
filetype := Piece(aGraphItem.Values, '^', 1);
typeitem := Piece(aGraphItem.Values, '^', 2);
aTitle := filetype + '^' + typeitem + '^' + aListView.Items[j].Caption + '^';
graphtype := GraphTypeNum(filetype);
if section = 'top' then
MakeDateline(section, aTitle, filetype, chartDatelineTop, graphtype, bcnt, pcnt, gcnt, vcnt, acnt)
else
MakeDateline(section, aTitle, filetype, chartDatelineBottom, graphtype, bcnt, pcnt, gcnt, vcnt, acnt);
end;
if section = 'top' then
begin
scrlTop.Align := alTop;
scrlTop.Height := 1; //pnlScrollTopBase.Height div 4;
pnlDatelineTop.Align := alClient;
pnlDatelineTop.Visible := true;
end
else
begin
scrlBottom.Align := alTop;
scrlBottom.Height := 1; //pnlScrollBottomBase.Height div 4;
pnlDatelineBottom.Align := alClient;
pnlDatelineBottom.Visible := true;
end;
end
else if onlylines then
begin
lcnt := 0;
for j := 0 to aListView.Items.Count - 1 do
if aListView.Items[j].Selected then
begin
aGraphItem := TGraphItem(aListView.Items.Item[j].SubItems.Objects[3]);
filetype := Piece(aGraphItem.Values, '^', 1);
typeitem := Piece(aGraphItem.Values, '^', 2);
if (filetype = '63') and (lstData.Items.Count > 0) then //***********
begin
checkdata := '';
for i := 0 to lstData.Items.Count - 1 do
begin
checkdata := lstData.Items[i];
if (Piece(checkdata, '^', 1) = '63') and (Piece(checkdata, '^', 2) = typeitem) then
break;
end;
specnum := Piece(checkdata, '^', 7);
specimen := Piece(checkdata, '^', 8);
RefUnits(typeitem, specnum, low, high, units);
units := LowerCase(units);
if units = '' then units := ' ';
end
else
begin
specimen := ''; low := ''; high := ''; units := '';
end;
aTitle := filetype + '^' + typeitem + '^' + aListView.Items[j].Caption + '^' +
specimen + '^' + low + '^' + high + '^' + units;
MakeLineSeries(newchart, aTitle, filetype, lcnt, ncnt, true)
end;
if section = 'top' then
begin
pnlDatelineTop.Align := alBottom;
pnlDatelineTop.Height := 5;
scrlTop.Align := alClient;
pnlDatelineTop.Visible := false;
end
else
begin
pnlDatelineBottom.Align := alBottom;
pnlDatelineBottom.Height := 5;
scrlBottom.Align := alClient;
pnlDatelineBottom.Visible := false;
end;
with newchart do
begin
if btnChangeSettings.Tag = 1 then
LeftAxis.Title.Caption := 'StdDev';
Visible := true;
end;
end
else if anylines then
begin
pcnt := 0; gcnt := 0; vcnt := 0; lcnt := 0; ncnt := 0; bcnt := 0; acnt := 0;
cnt := 0;
for j := 0 to aListView.Items.Count - 1 do
if aListView.Items[j].Selected then
begin
aGraphItem := TGraphItem(aListView.Items.Item[j].SubItems.Objects[3]);
filetype := Piece(aGraphItem.Values, '^', 1);
if filetype = '120.5' then
begin
cnt := BIG_NUMBER;
break;
end;
if filetype = '63' then
cnt := cnt + 1;
if cnt > 1 then
break;
end;
singlelabtest := cnt = 1;
for j := 0 to aListView.Items.Count - 1 do
if aListView.Items[j].Selected then
begin
aGraphItem := TGraphItem(aListView.Items.Item[j].SubItems.Objects[3]);
filetype := Piece(aGraphItem.Values, '^', 1);
typeitem := Piece(aGraphItem.Values, '^', 2);
if (filetype = '63') and (lstData.Items.Count > 0) then //***********
begin
checkdata := '';
for i := 0 to lstData.Items.Count - 1 do
begin
checkdata := lstData.Items[i];
if (Piece(checkdata, '^', 1) = '63') and (Piece(checkdata, '^', 2) = typeitem) then
break;
end;
specnum := Piece(checkdata, '^', 7);
specimen := Piece(checkdata, '^', 8);
RefUnits(typeitem, specnum, low, high, units);
units := LowerCase(units);
if units = '' then units := ' ';
end
else
begin
specimen := ''; low := ''; high := ''; units := '';
end;
aTitle := filetype + '^' + typeitem + '^' + aListView.Items[j].Caption + '^' +
specimen + '^' + low + '^' + high + '^' + units;
graphtype := GraphTypeNum(filetype);
if graphtype = 1 then
begin
if btnChangeSettings.Tag = 1 then
newchart.LeftAxis.Title.Caption := 'StdDev'
else
newchart.LeftAxis.Title.Caption := units;
if singlelabtest then
splGraphs.Tag := 1
else
splGraphs.Tag := 0;
MakeLineSeries(newchart, aTitle, filetype, lcnt, ncnt, true);
end
else if section = 'top' then
MakeDateline(section, aTitle, filetype, chartDatelineTop, graphtype, bcnt, pcnt, gcnt, vcnt, acnt)
else
MakeDateline(section, aTitle, filetype, chartDatelineBottom, graphtype, bcnt, pcnt, gcnt, vcnt, acnt);
end;
if section = 'top' then
begin
scrlTop.Align := alTop;
pnlDatelineTop.Align := alBottom;
pnlDatelineTop.Height := pnlScrollTopBase.Height div 2;
scrlTop.Align := alClient;
pnlDatelineTop.Visible := true;
end
else
begin
scrlBottom.Align := alTop;
pnlDatelineBottom.Align := alBottom;
pnlDatelineBottom.Height := pnlScrollBottomBase.Height div 2;
scrlBottom.Align := alClient;
pnlDatelineBottom.Visible := true;
end;
with newchart do
begin
if btnChangeSettings.Tag = 1 then
LeftAxis.Title.Caption := 'StdDev';
Visible := true;
end;
end;
if (FGraphSetting.HighTime = FGraphSetting.LowTime)
or (lcnt = 1) or (pcnt = 1) or (bcnt = 1) or (acnt = 1) or (vcnt = 1) then
begin
FGraphSetting.HighTime := FGraphSetting.HighTime + 1;
FGraphSetting.LowTime := FGraphSetting.LowTime - 1;
chartDatelineTop.LeftAxis.Minimum := chartDatelineTop.LeftAxis.Minimum - 0.5;
chartDatelineTop.LeftAxis.Maximum := chartDatelineTop.LeftAxis.Maximum + 0.5;
chartDatelineBottom.LeftAxis.Minimum := chartDatelineBottom.LeftAxis.Minimum - 0.5;
chartDatelineBottom.LeftAxis.Maximum := chartDatelineBottom.LeftAxis.Maximum + 0.5;
end;
AdjustTimeframe;
if chartDatelineTop.Visible then chartDatelineTop.ZoomPercent(ZOOM_PERCENT);
if chartDatelineBottom.Visible then chartDatelineBottom.ZoomPercent(ZOOM_PERCENT);
if FNonNumerics then
if section = 'top' then pnlItemsTop.Tag := 1
else pnlItemsBottom.Tag := 1;
end;
function TfrmGraphs.PortionSize(lcnt, pcnt, gcnt, vcnt, bcnt, acnt: integer): double;
var
etotal, evalue, dvalue, value: double;
begin
dvalue := (gcnt + vcnt + acnt);
evalue := (pcnt + bcnt) / 2;
etotal := dvalue + evalue;
if etotal > 0 then
begin
value := lcnt / etotal;
if value > 4 then Result := 0.2
else if etotal < 5 then Result := 0.2
else if value < 0.25 then Result := 0.8
else if value < 0.4 then Result := 0.6
else Result := 0.5;
end
else
Result := 0;
end;
procedure TfrmGraphs.MakeDateline(section, aTitle, aFileType: string; aChart: TChart; graphtype: integer;
var bcnt, pcnt, gcnt, vcnt, acnt: integer);
begin
aChart.LeftAxis.Automatic := true;
aChart.LeftAxis.Visible := true;
//if graphtype = 4 then graphtype := 2; // makes all points into bars
case graphtype of
2: MakeBarSeries(aChart, aTitle, aFileType, bcnt);
3: MakeVisitGanttSeries(aChart, aTitle, aFileType, vcnt);
4: MakePointSeries(aChart, aTitle, aFileType, pcnt);
5: MakeArrowSeries(aChart, aTitle, aFileType, acnt);
6: MakeGanttSeries(aChart, aTitle, aFileType, gcnt);
7: MakeAGanttSeries(aChart, aTitle, aFileType, gcnt);
8: MakeManyGanttSeries(aChart, aTitle, aFileType, gcnt);
9: MakeWeightedArrowSeries(aChart, aTitle, aFileType, acnt);
10: MakeWeightedGanttSeries(aChart, aTitle, aFileType, gcnt);
end;
end;
procedure TfrmGraphs.SizeTogether(onlylines, nolines, anylines: Boolean; aScroll: TScrollBox;
aChart: TChart; aPanel, aPanelBase: TPanel; portion: Double);
begin
if onlylines then //top &bottom
begin
aScroll.Align := alTop;
aScroll.Height := 1;
aChart.Visible := false;
aPanel.Align := alClient;
aPanel.Visible := true;
end
else if nolines then
begin
aPanel.Align := alBottom;
aPanel.Height := 5;
aScroll.Align := alClient;
aPanel.Visible := false;
if btnChangeSettings.Tag = 1 then
aChart.LeftAxis.Title.Caption := 'StdDev';
end
else if anylines then
begin
aScroll.Align := alTop;
aPanel.Align := alBottom;
aPanel.Height := round(aPanelBase.Height * portion);
if aPanel.Height < 60 then
if aPanelBase.Height > 100 then aPanel.Height := 60; //***
aScroll.Align := alClient;
aPanel.Visible := true;
if btnChangeSettings.Tag = 1 then
aChart.LeftAxis.Title.Caption := 'StdDev';
end;
end;
function TfrmGraphs.Vfactor(aTitle: string): double; // returns first numbers in string
var
firstnum: boolean;
i: integer;
vfactor: string;
begin
vfactor := '';
firstnum := false;
for i := 0 to length(aTitle) - 1 do
if IsDelimiter('1234567890.', aTitle, i) then
begin
vfactor := vfactor + aTitle[i];
firstnum := true;
end
else
if firstnum = true then break;
Result := strtofloatdef(vfactor, 1);
end;
function TfrmGraphs.NextColor(aCnt: integer): TColor;
begin
case (aCnt mod NUM_COLORS) of
1: Result := clRed;
2: Result := clBlue;
3: Result := clYellow;
4: Result := clGreen;
5: Result := clFuchsia;
6: Result := clMoneyGreen;
7: Result := clOlive;
8: Result := clLime;
9: Result := clMedGray;
10: Result := clNavy;
11: Result := clAqua;
12: Result := clGray;
13: Result := clSkyBlue;
14: Result := clTeal;
15: Result := clBlack;
0: Result := clPurple;
16: Result := clMaroon;
17: Result := clCream;
18: Result := clSilver;
else
Result := clWhite;
end;
end;
procedure TfrmGraphs.mnuPopGraphSwapClick(Sender: TObject);
var
tempcheck: boolean;
bottomview, i, j, topview: integer;
typeitem: string;
aGraphItem: TGraphItem;
begin
FFirstClick := true;
if (lvwItemsTop.SelCount = 0) and (lvwItemsBottom.SelCount = 0) then exit;
topview := cboViewsTop.ItemIndex;
bottomview := cboViewsBottom.ItemIndex;
HideGraphs(true);
with chkDualViews do
if not Checked then
begin
Checked := true;
Click;
end;
tempcheck := chkItemsTop.Checked;
chkItemsTop.Checked := chkItemsBottom.Checked;
chkItemsBottom.Checked := tempcheck;
pnlBottom.Height := pnlMain.Height - pnlBottom.Height;
lstScratchSwap.Items.Clear;
if topview < 1 then
with lvwItemsTop do
for i := 0 to Items.Count - 1 do
if Items[i].Selected then
begin
aGraphItem := TGraphItem(Items.Item[i].SubItems.Objects[3]);
lstScratchSwap.Items.Add(aGraphItem.Values);
end;
if bottomview > 0 then
begin
cboViewsTop.ItemIndex := bottomview;
cboViewsTopChange(self);
end
else
begin
cboViewsTop.ItemIndex := -1;
cboViewsTop.Text := '';
lvwItemsTop.ClearSelection;
with lvwItemsBottom do
for i := 0 to Items.Count - 1 do
if Items[i].Selected then
begin
aGraphItem := TGraphItem(Items.Item[i].SubItems.Objects[3]);
typeitem := Pieces(aGraphItem.Values, '^', 1, 2);
for j := 0 to lvwItemsTop.Items.Count - 1 do
begin
aGraphItem := TGraphItem(lvwItemsTop.Items[j].SubItems.Objects[3]);
if typeitem = Pieces(aGraphItem.Values, '^', 1, 2) then
begin
lvwItemsTop.Items[j].Selected := true;
break;
end;
end;
end;
lvwItemsTopClick(self);
end;
if topview > 0 then
begin
cboViewsBottom.ItemIndex := topview;
cboViewsBottomChange(self);
end
else
begin
cboViewsBottom.ItemIndex := -1;
cboViewsBottom.Text := '';
lvwItemsBottom.ClearSelection;
with lstScratchSwap do
for i := 0 to Items.Count - 1 do
for j := 0 to lvwItemsBottom.Items.Count - 1 do
begin
aGraphItem := TGraphItem(lvwItemsBottom.Items.Item[j].SubItems.Objects[3]);
if aGraphItem.Values = Items[i] then
begin
lvwItemsBottom.Items[j].Selected := true;
break;
end;
end;
lvwItemsBottomClick(self);
end;
lstScratchSwap.Items.Clear;
HideGraphs(false);
end;
procedure TfrmGraphs.mnuPopGraphSplitClick(Sender: TObject);
var
i: integer;
typeitem, typenum: string;
aGraphItem: TGraphItem;
begin
FFirstClick := true;
if (lvwItemsTop.SelCount = 0) and (lvwItemsBottom.SelCount = 0) then exit;
HideGraphs(true);
with chkDualViews do
if not Checked then
begin
Checked := true;
Click;
end;
with cboViewsTop do
if ItemIndex > -1 then
begin
ItemIndex := -1;
Text := '';
end;
with cboViewsBottom do
if ItemIndex > -1 then
begin
ItemIndex := -1;
Text := '';
end;
chkItemsTop.Checked := true;
chkItemsBottom.Checked := false;
pnlBottom.Height := pnlMain.Height - pnlBottom.Height;
lstScratchSwap.Items.Clear;
with lvwItemsTop do
for i := 0 to Items.Count - 1 do
if Items[i].Selected then
begin
aGraphItem := TGraphItem(Items.Item[i].SubItems.Objects[3]);
typeitem := Pieces(aGraphItem.Values, '^', 1, 2);
lstScratchSwap.Items.Add(typeitem);
end;
with lvwItemsBottom do
for i := 0 to Items.Count - 1 do
if Items[i].Selected then
begin
aGraphItem := TGraphItem(Items.Item[i].SubItems.Objects[3]);
typeitem := Pieces(aGraphItem.Values, '^', 1, 2);
lstScratchSwap.Items.Add(typeitem);
end;
lvwItemsTop.ClearSelection;
lvwItemsBottom.ClearSelection;
with lstScratchSwap do
for i := 0 to Items.Count - 1 do
begin
typeitem := Items[i];
typenum := Piece(typeitem, '^', 1);
if (typenum = '63') or (typenum = '120.5') then
SelectItem(lvwItemsTop, typeitem)
else
SelectItem(lvwItemsBottom, typeitem);
end;
lvwItemsTopClick(self);
lvwItemsBottomClick(self);
lstScratchSwap.Items.Clear;
HideGraphs(false);
end;
procedure TfrmGraphs.SelectItem(aListView: TListView; typeitem: string);
var
i: integer;
aGraphItem: TGraphItem;
begin
with aListView do
for i := 0 to Items.Count - 1 do
begin
aGraphItem := TGraphItem(Items.Item[i].SubItems.Objects[3]);
if typeitem = Pieces(aGraphItem.Values, '^', 1, 2) then
Items[i].Selected := true;
end;
end;
procedure TfrmGraphs.mnuPopGraphLinesClick(Sender: TObject);
begin
with FGraphSetting do Lines := not Lines;
ChangeStyle;
end;
procedure TfrmGraphs.mnuPopGraph3DClick(Sender: TObject);
begin
with FGraphSetting do View3D := not View3D;
ChangeStyle;
end;
procedure TfrmGraphs.mnuPopGraphValuesClick(Sender: TObject);
begin
with FGraphSetting do Values := not Values;
ChangeStyle;
end;
procedure TfrmGraphs.mnuPopGraphSortClick(Sender: TObject);
begin
with FGraphSetting do
begin
if SortColumn = 1 then SortColumn := 0
else SortColumn := 1;
mnuPopGraphSort.Checked := SortColumn = 1;
if not FItemsSortedTop then
begin
lvwItemsTopColumnClick(lvwItemsTop, lvwItemsTop.Column[0]);
FItemsSortedTop := true;
end;
if not FItemsSortedBottom then
begin
lvwItemsBottomColumnClick(lvwItemsBottom, lvwItemsBottom.Column[0]);
FItemsSortedBottom := true;
end;
if SortColumn > 0 then
begin
lvwItemsTopColumnClick(lvwItemsTop, lvwItemsTop.Column[SortColumn]);
lvwItemsBottomColumnClick(lvwItemsBottom, lvwItemsBottom.Column[SortColumn]);
FItemsSortedTop := false;
FItemsSortedBottom := false;
end;
end;
end;
procedure TfrmGraphs.mnuPopGraphClearClick(Sender: TObject);
begin
with FGraphSetting do
begin
ClearBackground := not ClearBackground;
if ClearBackground then Gradient := false;
end;
ChangeStyle;
// redisplay if nonnumericonly graph exists
if pnlItemsTop.Tag = 1 then lvwItemsTopClick(self);
if pnlItemsBottom.Tag = 1 then lvwItemsBottomClick(self);
end;
procedure TfrmGraphs.mnuPopGraphHorizontalClick(Sender: TObject);
begin
with FGraphSetting do
begin
HorizontalZoom := not HorizontalZoom;
mnuPopGraphHorizontal.Checked := HorizontalZoom;
if not HorizontalZoom then mnuPopGraphResetClick(self);
end;
end;
procedure TfrmGraphs.mnuPopGraphVerticalClick(Sender: TObject);
begin
with FGraphSetting do
begin
VerticalZoom := not VerticalZoom;
mnuPopGraphVertical.Checked := VerticalZoom;
if not VerticalZoom then mnuPopGraphResetClick(self);
end;
end;
procedure TfrmGraphs.mnuPopGraphDatesClick(Sender: TObject);
begin
with FGraphSetting do Dates := not Dates;
ChangeStyle;
end;
procedure TfrmGraphs.mnuPopGraphDualViewsClick(Sender: TObject);
begin
chkDualViews.Checked := not chkDualViews.Checked;
chkDualViewsClick(self);
end;
procedure TfrmGraphs.mnuPopGraphSeparate1Click(Sender: TObject);
begin
with mnuPopGraphSeparate1 do
Checked := not Checked;
with chkItemsTop do
begin
Checked := mnuPopGraphSeparate1.Checked;
Click;
end;
with chkItemsBottom do
begin
Checked := mnuPopGraphSeparate1.Checked;
Click;
end;
end;
procedure TfrmGraphs.mnuPopGraphGradientClick(Sender: TObject);
begin
with FGraphSetting do
begin
Gradient := not Gradient;
if Gradient then ClearBackground := false;
end;
ChangeStyle;
end;
procedure TfrmGraphs.mnuPopGraphHintsClick(Sender: TObject);
begin
with FGraphSetting do
Hints := not Hints;
ChangeStyle;
end;
procedure TfrmGraphs.mnuPopGraphLegendClick(Sender: TObject);
begin
with FGraphSetting do Legend := not Legend;
ChangeStyle;
end;
procedure TfrmGraphs.ChartStyle(aChart: TChart);
var
j: integer;
begin
with aChart do
begin
View3D := FGraphSetting.View3D;
Chart3DPercent := 10;
AllowZoom := FGraphSetting.HorizontalZoom;
Gradient.Visible := FGraphSetting.Gradient;
Legend.Visible := FGraphSetting.Legend;
HideDates(aChart);
pnlHeader.Visible := pnlInfo.Visible;
if FGraphSetting.ClearBackground then
begin
Color := clWindow;
Legend.Color := clWindow;
pnlBlankTop.Color := clWindow;
pnlBlankBottom.Color := clWindow;
end
else
begin
Color := clBtnFace;
Legend.Color := clCream;
pnlBlankTop.Color := clBtnFace;
pnlBlankBottom.Color := clBtnFace;
end;
for j := 0 to SeriesCount - 1 do
begin
if Series[j] is TLineSeries then
with (Series[j] as TLineSeries) do
begin
Marks.Visible := FGraphSetting.Values;
LinePen.Visible := FGraphSetting.Lines;
end;
if Series[j] is TPointSeries then
with (Series[j] as TPointSeries) do
begin
Marks.Visible := FGraphSetting.Values;
LinePen.Visible := FGraphSetting.Lines;
end;
if Series[j] is TBarSeries then
with (Series[j] as TBarSeries) do
begin
Marks.Visible := FGraphSetting.Values;
end;
if Series[j] is TArrowSeries then
with (Series[j] as TArrowSeries) do
begin
Marks.Visible := FGraphSetting.Values;
end;
if Series[j] is TGanttSeries then
with (Series[j] as TGanttSeries) do
begin
Marks.Visible := FGraphSetting.Values;
LinePen.Visible := FGraphSetting.Lines;
end;
end;
end;
end;
procedure TfrmGraphs.ChangeStyle;
var
i: integer;
ChildControl: TControl;
OriginalColor, ClearColor: TColor;
begin
OriginalColor := pnlItemsTopInfo.Color;
ClearColor := clWindow;
for i := 0 to scrlTop.ControlCount - 1 do
begin
ChildControl := scrlTop.Controls[i];
ChartStyle(ChildControl as TChart);
end;
for i := 0 to scrlBottom.ControlCount - 1 do
begin
ChildControl := scrlBottom.Controls[i];
ChartStyle(ChildControl as TChart);
end;
if pnlDateLineTop.Visible then // not visible when separate graphs
ChartStyle(chartDateLineTop);
if pnlDateLineBottom.Visible then
ChartStyle(chartDateLineBottom);
if FGraphSetting.ClearBackground then
begin
chartDatelineTop.Color := ClearColor;
chartDatelineTop.Legend.Color := ClearColor;
pnlDatelineTopSpacer.Color := ClearColor;
scrlTop.Color := ClearColor;
pnlTopRightPad.Color := ClearColor;
pnlScrollTopBase.Color := ClearColor;
pnlBlankTop.Color := ClearColor;
chartDatelineBottom.Color := ClearColor;
chartDatelineBottom.Legend.Color := ClearColor;
pnlDatelineBottomSpacer.Color := ClearColor;
scrlBottom.Color := ClearColor;
pnlBottomRightPad.Color := ClearColor;
pnlScrollBottomBase.Color := ClearColor;
pnlBlankBottom.Color := ClearColor;
end
else
begin
chartDatelineTop.Color := OriginalColor;
chartDatelineTop.Legend.Color := clCream;
pnlDatelineTopSpacer.Color := OriginalColor;
scrlTop.Color := OriginalColor;
pnlTopRightPad.Color := OriginalColor;
pnlScrollTopBase.Color := OriginalColor;
pnlBlankTop.Color := OriginalColor;
chartDatelineBottom.Color := OriginalColor;
chartDatelineBottom.Legend.Color := clCream;
pnlDatelineBottomSpacer.Color := OriginalColor;
scrlBottom.Color := OriginalColor;
pnlBottomRightPad.Color := OriginalColor;
pnlScrollBottomBase.Color := OriginalColor;
pnlBlankBottom.Color := OriginalColor;
end;
mnuPopGraphLines.Checked := FGraphSetting.Lines;
mnuPopGraph3D.Checked := FGraphSetting.View3D;
mnuPopGraphValues.Checked := FGraphSetting.Values;
mnuPopGraphDates.Checked := FGraphSetting.Dates;
mnuPopGraphFixed.Checked := FGraphSetting.FixedDateRange;
mnuPopGraphGradient.Checked := FGraphSetting.Gradient;
mnuPopGraphHints.Checked := FGraphSetting.Hints;
mnuPopGraphStayOnTop.Checked := FGraphSetting.StayOnTop;
mnuPopGraphLegend.Checked := FGraphSetting.Legend;
mnuPopGraphSort.Checked := FGraphSetting.SortColumn = 1;
mnuPopGraphClear.Checked := FGraphSetting.ClearBackground;
mnuPopGraphVertical.Checked := FGraphSetting.VerticalZoom;
mnuPopGraphHorizontal.Checked := FGraphSetting.HorizontalZoom;
end;
procedure TfrmGraphs.chartBaseClickSeries(Sender: TCustomChart; Series: TChartSeries;
ValueIndex: Integer; Button: TMouseButton; Shift: TShiftState; X, Y: Integer);
var
dttm, seriestitle, textvalue, textvalue1, textvalue2, typename, typenum: string;
begin
timHintPause.Enabled := false;
InactivateHint;
FGraphClick := Sender;
FGraphSeries := Series;
FGraphValueIndex := ValueIndex;
chartDateLineTop.Tag := 1; // indicates a series click
if (Series is TGanttSeries) then
begin
FDate1 := (Series as TGanttSeries).StartValues[ValueIndex];
FDate2 := (Series as TGanttSeries).EndValues[ValueIndex];
end
else
begin
FDate1 := Series.XValue[ValueIndex];
FDate2 := FDate1;
end;
seriestitle := Series.Title;
if Button <> mbRight then
begin
textvalue := ValueText(Sender, Series, ValueIndex);
dttm := Piece(textvalue, '^', 3);
if copy(textvalue, length(textvalue) - 5, length(textvalue)) = ' 00:00' then
dttm := Pieces(dttm, ' ', 1, 3);
textvalue1 := Piece(textvalue, '^', 2) + ' ' + dttm;
textvalue2 := Piece(textvalue, '^', 4) + ' ' + Piece(textvalue, '^', 5);
typenum := trim(Piece(textvalue, '^', 1));
typename := Piece(textvalue, '^', 2);
AllTypeDate(typenum, typename, textvalue1, textvalue2, FDate1, FDate2);
end
else
begin
mnuPopGraphIsolate.Enabled := true;
if pnlTop.Tag = 1 then
mnuPopGraphIsolate.Caption := 'Move - ' + seriestitle + ' - from Top to Bottom'
else
mnuPopGraphIsolate.Caption := 'Move - ' + seriestitle + ' - from Bottom to Top';
scrlTop.Hint := 'Details - for ' + seriestitle + ' for ' +
FormatDateTime('mmm d, yyyy h:nn am/pm', FDate1);
scrlTop.Tag := ValueIndex + 1;
mnuPopGraphIsolate.Hint := seriestitle;
mnuPopGraphRemove.Enabled := true;
mnuPopGraphRemove.Caption := 'Remove - ' + seriestitle;
mnuPopGraphDetails.Caption := 'Details - ' + seriestitle;
end;
FMouseDown := false;
end;
procedure TfrmGraphs.AllTypeDate(aType, aTypeName, firstline, secondline: string; aDate, aDate2: double);
var
i: integer;
dttm, datax, datex1, datex2, fmdate1, fmdate2, newdata, newline, oldline, spacer, titlemsg: string;
dt1, dt2, dtdata, dtdata1, dtdata2: double;
tmpOtherList, templist: TStringList;
begin
Screen.Cursor := crHourGlass;
tmpOtherList := TStringList.Create;
templist := TStringList.Create;
datex1 := floattostr(DateTimeToFMDateTime(aDate));
datex1 := Piece(datex1, '.', 1);
if aDate <> aDate2 then
datex2 := Piece(floattostr(DateTimeToFMDateTime(aDate2)), '.', 1) + '.23595959'
else
datex2 := datex1 + '.23595959';
dt1 := strtofloatdef(datex1, BIG_NUMBER);
dt2 := strtofloatdef(datex2, BIG_NUMBER);
CheckToAddData(lvwItemsTop, 'top', aType); // if type is not loaded - load data
for i := 0 to lstData.Items.Count - 1 do
begin
datax := lstData.Items[i];
if Piece(datax, '^', 1) = aType then
begin
if (length(Piece(datax, '^', 4))> 0) then // date/times of episodes
begin
dtdata1 := strtofloatdef(Piece(datax, '^', 3), -1);
fmdate1 := FormatFMDateTime('mm/dd/yy hh:nn', dtdata1);
if copy(fmdate1, length(fmdate1) - 5, length(fmdate1)) = ' 00:00' then
fmdate1 := copy(fmdate1, 1, length(fmdate1) - 5) + ' ';
dtdata2 := strtofloatdef(Piece(datax, '^', 4), -1);
fmdate2 := FormatFMDateTime('mm/dd/yy hh:nn', dtdata2);
if copy(fmdate2, length(fmdate2) - 5, length(fmdate2)) = ' 00:00' then
fmdate2 := copy(fmdate2, 1, length(fmdate2) - 5) + ' ';
if (dtdata2 > dt1) and (dtdata1 < dt2) then
begin
newdata := Piece(datax, '^', 3) + '^' +
Piece(datax, '^', 2) + '^' +
fmdate1 + ' - ' +
fmdate2 + '^' +
ItemName(aType, Piece(datax, '^', 2)) + '^' +
Piece(datax, '^', 5);
tmpOtherList.Add(MixedCase(newdata));
end;
end
else
begin
dtdata := strtofloatdef(Piece(datax, '^', 3), -1);
if (dtdata >= dt1) and (dtdata < dt2) then
begin
if length(Piece(Piece(datax, '^', 3), '.', 2)) > 0 then
dttm := FormatFMDateTime('mm/dd/yy hh:nn', dtdata)
else
dttm := FormatFMDateTime('mm/dd/yy', dtdata);
newdata := Piece(datax, '^', 3) + '^' +
Piece(datax, '^', 2) + '^' +
Piece(datax, '^', 5) + '^' +
dttm + '^' +
ItemName(aType, Piece(datax, '^', 2));
tmpOtherList.Add(MixedCase(newdata));
end;
end;
end;
end;
with tmpOtherList do
begin
Sort;
for i := Count - 1 downto 0 do
begin
newline := '';
oldline := tmpOtherList[i];
newline := Piece(oldline, '^', 4) + ' ' +
Piece(oldline, '^', 5);
spacer := Copy(BIG_SPACES, 1, 40 - length(newline));
newline := newline + spacer + ' ' +
Piece(oldline, '^', 3);
templist.Add(newline);
end;
Clear;
Assign(templist);
if aDate <> aDate2 then
titlemsg := aTypeName + ' occurences for ' + FormatDateTime('mmm d, yyyy', aDate) +
' - ' + FormatDateTime('mmm d, yyyy', aDate2)
else
titlemsg := aTypeName + ' occurences for ' + FormatDateTime('mmm d, yyyy', aDate);
Insert(0, firstline);
Insert(1, secondline);
Insert(2, '');
Insert(3, 'All ' + titlemsg + ':');
Insert(4, '');
Insert(0, TXT_REPORT_DISCLAIMER);
Insert(1, '');
ReportBox(tmpOtherList, titlemsg, true);
end;
tmpOtherList.Free;
templist.Free;
Screen.Cursor := crDefault;
end;
procedure TfrmGraphs.ItemDateRange(Sender: TCustomChart);
var
bpnotdone, ok: boolean;
i, j: integer;
prevtype, results, seriestitle, seriestype, spacer, textvalue, typenum: string;
tmpOtherList: TStringList;
begin
Screen.Cursor := crHourGlass;
prevtype := '';
tmpOtherList := TStringList.Create;
with tmpOtherList do
begin
Add('Date Range: ' + cboDateRange.Text);
Add('Selected Items from ' +
FormatDateTime('mm/dd/yy', FGraphSetting.LowTime) + ' to ' +
FormatDateTime('mm/dd/yy', FGraphSetting.HighTime));
Add('');
end;
bpnotdone := true;
for i := 0 to Sender.SeriesCount - 1 do
begin
if Sender.Series[i].Count > 0 then
begin
textvalue := ValueText(Sender, Sender.Series[i], 0);
seriestype := Piece(textvalue, '^', 2);
if (seriestype <> '') and (seriestype <> prevtype) then
begin
tmpOtherList.Add(' ' + seriestype); // type
prevtype := seriestype;
end;
end;
ok := true;
seriestitle := Sender.Series[i].Title;
if seriestitle = 'Blood Pressure' then
if bpnotdone = false then ok := false;
if ok then
begin
for j := 0 to Sender.Series[i].Count - 1 do
begin
textvalue := ValueText(Sender, Sender.Series[i], j);
seriestitle := Piece(textvalue, '^', 4);
typenum := Piece(textvalue, '^', 1);
if (typenum = '120.5') and (seriestitle = 'Blood Pressure') then bpnotdone := false;
if length(typenum) > 0 then
begin
spacer := Copy(BIG_SPACES, 1, 30 - length(seriestitle));
results := seriestitle + ': ' + //spacer +
Piece(textvalue, '^', 5); //LowerCase(Piece(textvalue, '^', 5));
spacer := Copy(BIG_SPACES, 1, 40 - length(results));
results := results + ' ' + spacer + Piece(textvalue, '^', 6);
if copy(results, length(results) - 5, length(results)) = ' 00:00' then
results := copy(results, 1, length(results) - 5);
tmpOtherList.Add(results); // item occurrence
end;
end;
end;
end; // same items are not being sorted by date
if tmpOtherList.Count > 0 then
begin
tmpOtherList.Insert(0, TXT_REPORT_DISCLAIMER);
tmpOtherList.Insert(1, '');
ReportBox(tmpOtherList, 'Selected Items from Graph', true);
end;
tmpOtherList.Free;
FMouseDown := false;
Screen.Cursor := crDefault;
end;
procedure TfrmGraphs.mnuPopGraphIsolateClick(Sender: TObject);
var
i, j, selnum: integer;
aSection, aOtherSection, typeitem: string;
aGraphItem: TGraphItem;
aListView, aOtherListView: TListView;
begin
FFirstClick := true;
cboViewsTop.ItemIndex := -1;
cboViewsTop.Text := '';
cboViewsBottom.ItemIndex := -1;
cboViewsBottom.Text := '';
if pnlTop.Tag = 1 then
begin
aListView := lvwItemsTop;
aOtherListView := lvwItemsBottom;
aSection := 'top';
aOtherSection := 'bottom';
end
else
begin
aListView := lvwItemsBottom;
aOtherListView := lvwItemsTop;
aSection := 'bottom';
aOtherSection := 'top';
end;
if aListView.SelCount = 0 then exit;
if StripHotKey(mnuPopGraphIsolate.Caption) = ('Move all selections to ' + aOtherSection) then
begin
with aListView do
for i := 0 to Items.Count - 1 do
if Items[i].Selected then
begin
aGraphItem := TGraphItem(Items.Item[i].SubItems.Objects[3]);
typeitem := Pieces(aGraphItem.Values, '^', 1, 2);
for j := 0 to aOtherListView.Items.Count - 1 do
begin
aGraphItem := TGraphItem(aOtherListView.Items.Item[j].SubItems.Objects[3]);
if Pieces(aGraphItem.Values, '^', 1, 2) = typeitem then
aOtherListView.Items[j].Selected := true;
end;
Items[i].Selected := false;
end;
with chkDualViews do
if not Checked then
begin
Checked := true;
Click;
end;
ChangeStyle;
DisplayData(aSection);
DisplayData(aOtherSection);
end
else
begin
ItemCheck(lvwItemsTop, mnuPopGraphIsolate.Hint, selnum, typeitem);
if selnum = -1 then exit;
for i := 0 to aOtherListView.Items.Count - 1 do
begin
aGraphItem := TGraphItem(aOtherListView.Items.Item[i].SubItems.Objects[3]);
if Pieces(aGraphItem.Values, '^', 1, 2) = typeitem then
aOtherListView.Items[i].Selected := true;
end;
aListView.Items[selnum].Selected := false;
with chkDualViews do
if not Checked then
begin
Checked := true;
Click;
end;
ChangeStyle;
DisplayData(aSection);
DisplayData(aOtherSection);
end;
mnuPopGraphIsolate.Enabled := false;
end;
procedure TFrmGraphs.ItemCheck(aListView: TListView; aItemName: string;
var aNum: integer; var aTypeItem: string);
var
i: integer;
aGraphItem: TGraphItem;
begin
aNum := -1;
aTypeItem := '';
with aListView do
for i := 0 to Items.Count - 1 do
if Items[i].Caption = aItemName then
begin
aGraphItem := TGraphItem(Items.Item[i].SubItems.Objects[3]); //get file^ien match
aNum := i;
aTypeItem := Pieces(aGraphItem.Values, '^', 1, 2);
break;
end;
if aNum = -1 then
begin
aItemName := ReverseString(aItemName);
aItemName := Pieces(aItemName, '(', 2, DelimCount(aItemName, '(') + 1);
aItemName := Copy(aItemName, 2, length(aItemName) - 1);
aItemName := ReverseString(aItemName);
with aListView do
for i := 0 to Items.Count - 1 do
if Items[i].Caption = aItemName then // match without (specimen)
begin
aGraphItem := TGraphItem(Items.Item[i].SubItems.Objects[3]); //get file^ien match
aNum := i;
aTypeItem := Pieces(aGraphItem.Values, '^', 1, 2);
break;
end;
end;
end;
procedure TfrmGraphs.chartBaseMouseDown(Sender: TObject; Button: TMouseButton;
Shift: TShiftState; X, Y: Integer);
begin
FHintStop := true;
timHintPause.Enabled := false;
InactivateHint;
chartDatelineTop.Tag := 0; // not legend or series click
scrlTop.Hint := '';
scrlTop.Tag := 0;
FYMinValue := (Sender as TChart).MinYValue((Sender as TChart).LeftAxis);
FYMaxValue := (Sender as TChart).MaxYValue((Sender as TChart).LeftAxis);
pnlTop.Tag := 1;
if (Sender as TControl).Parent = pnlBottom then pnlTop.Tag := 0;
if ((Sender as TControl).Parent as TControl) = pnlBottom then pnlTop.Tag := 0;
if (((Sender as TControl).Parent as TControl).Parent as TControl).Parent = pnlBottom then pnlTop.Tag := 0;
if pnlTop.Tag = 1 then
begin
mnuPopGraphIsolate.Caption := 'Move all selections to bottom';
mnuPopGraphRemove.Caption := 'Remove all selections from top';
end
else
begin
mnuPopGraphIsolate.Caption := 'Move all selections to top';
mnuPopGraphRemove.Caption := 'Remove all selections from bottom';
end;
If Button = mbLeft then
FMouseDown := true;
end;
procedure TfrmGraphs.mnuPopGraphStuffPopup(Sender: TObject);
begin
if scrlTop.Tag = 0 then scrlTop.Hint := '';
if (lvwItemsTop.SelCount = 0) and (lvwItemsBottom.SelCount = 0) then scrlTop.Hint := '';
if scrlTop.Hint = '' then
begin
if Pieces(mnuPopGraphIsolate.Caption, ' ', 1, 3) = 'Move all selections' then
mnuPopGraphIsolate.Enabled := true
else
begin
mnuPopGraphIsolate.Caption := 'Move';
mnuPopGraphIsolate.Enabled := false;
end;
if Pieces(mnuPopGraphRemove.Caption, ' ', 1, 3) = 'Remove all selections' then
mnuPopGraphRemove.Enabled := true
else
begin
mnuPopGraphRemove.Caption := 'Remove';
mnuPopGraphRemove.Enabled := false;
end;
mnuPopGraphDetails.Caption := 'Details...';
mnuPopGraphDetails.Enabled := (lvwItemsTop.SelCount > 0) or (lvwItemsBottom.SelCount > 0);
end
else
begin
mnuPopGraphIsolate.Enabled := true;
mnuPopGraphRemove.Enabled := true;
mnuPopGraphDetails.Enabled := true;
end;
mnuPopGraphSwap.Enabled := (lvwItemsTop.SelCount > 0) or (lvwItemsBottom.SelCount > 0);
mnuPopGraphReset.Enabled := mnuPopGraphSwap.Enabled;
mnuPopGraphCopy.Enabled := mnuPopGraphSwap.Enabled;
mnuPopGraphPrint.Enabled := mnuPopGraphSwap.Enabled;
with pnlMain.Parent do
if BorderWidth <> 1 then // only do on float Graph
mnuPopGraphStayOnTop.Enabled :=false
else
mnuPopGraphStayOnTop.Enabled :=true;
end;
procedure TfrmGraphs.mnuPopGraphDetailsClick(Sender: TObject);
var
aGraphItem: TGraphItem;
tmpList: TStringList;
date1, date2: TFMDateTime;
teststring, typeitem, textvalue, textvalue1, textvalue2, typenum, typename: string;
i, selnum: integer;
begin
if chartDatelineTop.Tag = 1 then // series
begin
ItemCheck(lvwItemsTop, mnuPopGraphIsolate.Hint, selnum, typeitem);
if selnum < 0 then exit;
if not HSAbbrev(Piece(typeitem, '^', 1)) then
begin
if (FGraphSeries is TGanttSeries) then
begin
FDate1 := (FGraphSeries as TGanttSeries).StartValues[FGraphValueIndex];
FDate2 := (FGraphSeries as TGanttSeries).EndValues[FGraphValueIndex];
end
else
begin
FDate1 := FGraphSeries.XValue[FGraphValueIndex];
FDate2 := FDate1;
end;
textvalue := ValueText(FGraphClick, FGraphSeries, FGraphValueIndex);
textvalue1 := Piece(textvalue, '^', 2) + ' ' + Piece(textvalue, '^', 3);
textvalue2 := Piece(textvalue, '^', 4) + ' ' + Piece(textvalue, '^', 5);
typenum := trim(Piece(textvalue, '^', 1));
typename := Piece(textvalue, '^', 2);
AllTypeDate(typenum, typename, textvalue1, textvalue2, FDate1, FDate2);
exit;
end
else
OneDayTypeDetails(typeitem);
end
else // legend
begin
date1 := DateTimeToFMDateTime(FGraphSetting.HighTime);
date2 := DateTimeToFMDateTime(FGraphSetting.LowTime);
tmpList := TStringList.Create;
if pnlTop.Tag = 1 then
for i := 0 to lvwItemsTop.Items.Count - 1 do
begin
if lvwItemsTop.Items[i].Selected then
begin
aGraphItem := TGraphItem(lvwItemsTop.Items.Item[i].SubItems.Objects[3]); //get file^ien match
teststring := aGraphItem.Values;
tmpList.Add(teststring);
end;
end
else
for i := 0 to lvwItemsBottom.Items.Count - 1 do
begin
if lvwItemsBottom.Items[i].Selected then
begin
aGraphItem := TGraphItem(lvwItemsBottom.Items.Item[i].SubItems.Objects[3]); //get file^ien match
teststring := aGraphItem.Values;
tmpList.Add(teststring);
end;
end;
if tmpList.Count > 0 then
AllDetails(date1, date2, tmplist);
tmpList.Free;
end;
FMouseDown := false;
end;
procedure TfrmGraphs.AllDetails(aDate1, aDate2: TFMDateTime; aTempList: TStrings);
var
TypeList: TStringList;
i: integer;
detailsok: boolean;
testnum, teststring, testtype: string;
begin
detailsok := true;
TypeList := TStringList.Create;
for i := 0 to aTempList.Count -1 do
begin
teststring := aTempList[i];
testtype := Piece(teststring, '^', 1);
if not HSAbbrev(testtype) then
detailsok := false;
if testtype = '63' then
begin
testnum := Piece(teststring, '^', 2);
testnum := Piece(testnum, '.', 1);
TypeList.Add('63^' + testnum);
end
else
TypeList.Add(teststring);
end;
if detailsok then
ReportBox(rpcDetailSelected(Patient.DFN, aDate1, aDate2, TypeList, true), 'Graph results on ' + Patient.Name, True)
else
ItemDateRange(FGraphClick);
TypeList.Free;
end;
procedure TfrmGraphs.OneDayTypeDetails(aTypeItem: string);
var
strdate1, strdate2, titleitem, titletype: string;
date1, date2: TFMDateTime;
tmpList: TStringList;
begin
tmpList := TStringList.Create;
strdate1 := FormatDateTime('mm/dd/yyyy', FDate1);
strdate2 := FormatDateTime('mm/dd/yyyy', FDate2);
FDate1 := StrToDateTime(strdate1);
FDate2 := StrToDateTime(strdate2);
date1 := DateTimeToFMDateTime(FDate1 + 1);
date2 := DateTimeToFMDateTime(FDate2);
titletype := FileNameX(Piece(aTypeItem, '^', 1));
titleitem := ItemName(Piece(aTypeItem, '^', 1), Piece(aTypeItem, '^', 2));
rpcDetailDay(tmpList, Patient.DFN, date1, date2, aTypeItem, true);
ReportBox(tmpList, titletype + ': ' + titleitem + ' on ' + Patient.Name + ' for ' + FormatFMDateTime('mmm d, yyyy', date1), True);
tmpList.Free;
end;
procedure TfrmGraphs.mnuPopGraphCopyClick(Sender: TObject);
var
i: integer;
StrForFooter, StrForHeader, aTitle, aWarning, aDateRange: String;
aHeader: TStringList;
wrdApp, wrdDoc: Variant;
ChildControl: TControl;
begin
try
wrdApp := CreateOleObject('Word.Application');
except
raise Exception.Create('Cannot start MS Word!');
end;
Screen.Cursor := crHourGlass;
aTitle := 'CPRS Graphing';
aWarning := pnlInfo.Caption;
aDateRange := 'Date Range: ' + cboDateRange.Text + ' Selected Items from ' +
FormatDateTime('mm/dd/yy', FGraphSetting.LowTime) + ' to ' +
FormatDateTime('mm/dd/yy', FGraphSetting.HighTime);
aHeader := TStringList.Create;
CreatePatientHeader(aHeader, aTitle, aWarning, aDateRange);
StrForHeader := '';
for i := 0 to aHeader.Count -1 do
StrForHeader := StrForHeader + aHeader[i] + Chr(13);
StrForFooter := aTitle + ' - *** WORK COPY ONLY ***' + Chr(13);
wrdApp.Visible := False;
wrdApp.Documents.Add;
wrdDoc := wrdApp.Documents.Item(1);
wrdDoc := wrdDoc.Sections.Item(1);
wrdDoc := wrdDoc.Headers.Item(1).Range;
wrdDoc.Font.Name := 'Courier New';
wrdDoc.Font.Size := 9;
wrdDoc.Text := StrForHeader;
wrdDoc := wrdApp.Documents.Item(1);
wrdDoc := wrdDoc.Sections.Item(1);
wrdDoc := wrdDoc.Footers.Item(1);
wrdDoc.Range.Font.Name := 'Courier New';
wrdDoc.Range.Font.Size := 9;
wrdDoc.Range.Text := StrForFooter;
wrdDoc.PageNumbers.Add;
wrdDoc := wrdApp.Documents.Item(1);
wrdDoc.Range.Font.Name := 'Courier New';
wrdDoc.Range.Font.Size := 9;
wrdDoc.Range.Text := StrForHeader;
wrdDoc.Range.InsertParagraphAfter;
for i := 0 to scrlTop.ControlCount - 1 do // goes from top to bottom
begin
ChildControl := scrlTop.Controls[i];
if (ChildControl as TChart).Visible then
begin
(ChildControl as TChart).CopyToClipboardBitmap;
wrdDoc.Range.InsertParagraphAfter;
wrdDoc.Paragraphs.Last.Range.Paste;
end;
end;
if (chartDatelineTop.SeriesCount > 0) and (not chkItemsTop.Checked) then
begin
chartDatelineTop.CopyToClipboardBitmap;
wrdDoc.Range.InsertParagraphAfter;
wrdDoc.Paragraphs.Last.Range.Paste;
end;
wrdDoc.Range.InsertParagraphAfter;
wrdDoc.Paragraphs.Last.Range.Text := ' ';
for i := 0 to scrlBottom.ControlCount - 1 do
begin
ChildControl := scrlBottom.Controls[i];
if (ChildControl as TChart).Visible then
begin
(ChildControl as TChart).CopyToClipboardBitmap;
wrdDoc.Range.InsertParagraphAfter;
wrdDoc.Paragraphs.Last.Range.Paste;
end;
end;
if (chartDatelineBottom.SeriesCount > 0) and (chkDualViews.Checked)
and (not chkItemsBottom.Checked) then
begin
chartDatelineBottom.CopyToClipboardBitmap;
wrdDoc.Range.InsertParagraphAfter;
wrdDoc.Paragraphs.Last.Range.Paste;
end;
wrdDoc.Range.WholeStory;
wrdDoc.Range.Copy;
wrdDoc.Close(false);
wrdApp.DisplayAlerts := false;
wrdApp.Quit;
wrdApp := Unassigned; // releases variant
aHeader.Free;
Screen.Cursor := crDefault;
end;
procedure TfrmGraphs.CreatePatientHeader(var HeaderList: TStringList; PageTitle, Warning, DateRange: string);
// this procedure modified from rReports
var
tmpStr, tmpItem: string;
begin
if Warning = TXT_INFO then Warning := ' ';
with HeaderList do
begin
Add(' ');
Add(StringOfChar(' ', (74 - Length(PageTitle)) div 2) + PageTitle);
Add(' ');
tmpStr := Patient.Name + ' ' + Patient.SSN;
tmpItem := tmpStr + StringOfChar(' ', 39 - Length(tmpStr)) + Encounter.LocationName;
tmpStr := FormatFMDateTime('mmm dd, yyyy', Patient.DOB) + ' (' + IntToStr(Patient.Age) + ')';
tmpItem := tmpItem + StringOfChar(' ', 74 - (Length(tmpItem) + Length(tmpStr))) + tmpStr;
Add(tmpItem);
Add(StringOfChar('=', 74));
Add('*** WORK COPY ONLY ***' + StringOfChar(' ', 24) + 'Printed: '
+ FormatFMDateTime('mmm dd, yyyy hh:nn', FMNow));
Add(TXT_COPY_DISCLAIMER);
Add(StringOfChar(' ', (74 - Length(DateRange)) div 2) + DateRange);
Add(StringOfChar(' ', (74 - Length(Warning)) div 2) + Warning);
Add(' ');
end;
end;
procedure TfrmGraphs.GetData(aString: string);
var
i: integer;
filenum, itemdata, itemid: string;
aDate, aDate1: double;
begin
lstTemp.Items.Clear;
itemid := UpperCase(Pieces(aString, '^', 1, 2));
with lstData do
for i := Items.Count - 1 downto 0 do
if itemid = UpperCase(Pieces(Items[i], '^', 1, 2)) then
begin
itemdata := Items[i];
filenum := Piece(itemdata, '^', 1);
if (filenum = '52') or (filenum = '55') or (filenum = '55NVA')
or (filenum = '9999911') or (filenum = '405') or (filenum = '9000010') then
begin
aDate := strtofloat(FMCorrectedDate(Piece(itemdata, '^', 3)));
aDate1 := strtofloat(FMCorrectedDate(Piece(itemdata, '^', 4)));
if (aDate < FGraphSetting.FMStopDate) and (aDate > FGraphSetting.FMStartDate) then
lstTemp.Items.Add(Items[i])
else if (aDate < FGraphSetting.FMStopDate) and (aDate1 > FGraphSetting.FMStartDate) then
lstTemp.Items.Add(Items[i])
else if (aDate < FGraphSetting.FMStartDate) and (aDate1 > FGraphSetting.FMStopDate) then
lstTemp.Items.Add(Items[i]);
end
else if Piece(itemdata, '^', 3) <> '' then
begin
aDate := strtofloat(FMCorrectedDate(Piece(itemdata, '^', 3)));
if (aDate < FGraphSetting.FMStopDate) and (aDate > FGraphSetting.FMStartDate) then
if Copy(itemdata, 1, 4) = '63MI' then
lstTemp.Items.Add(Pieces(Items[i], '^', 1, 4))
else if Copy(itemdata, 1, 4) = '63AP' then
lstTemp.Items.Add(Pieces(Items[i], '^', 1, 4))
//else lstTemp.Items.Add(Pieces(Items[i], '^', 1, 5)); // add in non micro, ap
else lstTemp.Items.Add(Items[i]); // add in non micro, ap
end;
end;
end;
function TfrmGraphs.FMToDateTime(FMDateTime: string): TDateTime;
var
x, Year: string;
begin
{ Note: TDateTime cannot store month only or year only dates }
x := FMDateTime + '0000000';
if Length(x) > 12 then x := Copy(x, 1, 12);
if StrToInt(Copy(x, 9, 4)) > 2359 then x := Copy(x, 1, 7) + '.2359';
Year := IntToStr(17 + StrToInt(Copy(x, 1, 1))) + Copy(x, 2, 2);
x := Copy(x, 4, 2) + '/' + Copy(x, 6, 2) + '/' + Year + ' ' + Copy(x, 9, 2) + ':' + Copy(x, 11, 2);
Result := StrToDateTime(x);
end;
function TfrmGraphs.GraphTypeNum(aType: string): integer;
var
i: integer;
begin
Result := 4;
if (aType = '52') or (aType = '55') or (aType = '55NVA') or (aType = '9999911') then
if mnuMedsasgantt.Checked then Result := 8
else if mnuMedsasganttvertheight.Checked then Result := 3
else Result := 8
else
for i := 0 to lstAllTypes.Items.Count - 1 do
if aType = Piece(lstAllTypes.Items[i], '^', 1) then
begin
Result := strtointdef(Piece(lstAllTypes.Items[i], '^', 3), 4);
break;
end;
end;
function TfrmGraphs.HSAbbrev(aType: string): boolean;
var
i: integer;
begin
Result := false;
for i := 0 to lstTypes.Items.Count - 1 do
if Piece(lstTypes.Items[i], '^', 1) = aType then
begin
Result := length(Piece(lstTypes.Items[i], '^', 8)) > 0;
break;
end;
end;
procedure TfrmGraphs.TempCheck(typeitem: string; var levelseq: double);
var
done, previous: boolean;
j: integer;
begin
previous := false;
done := false;
j := 0;
with lstTempCheck do
while not done do
begin
if Items.Count = j then done := true
else if Items[j] = typeitem then
begin
previous := true;
levelseq := j + 1;
done := true;
end
else j := j + 1;
end;
if not previous then
begin
lstTempCheck.Items.Add(UpperCase(typeitem));
levelseq := lstTempCheck.Items.Count;
end;
end;
function TfrmGraphs.DCName(aDCien: string): string;
var
i: integer;
begin
if lstDrugClass.Items.Count < 1 then
FastAssign(rpcClass('50.605'), lstDrugClass.Items);
Result := '';
for i := 0 to lstDrugClass.Items.Count - 1 do
if Piece(lstDrugClass.Items[i], '^', 2) = aDCien then
begin
Result := 'Drug - ' + Piece(lstDrugClass.Items[i], '^', 3);
break;
end;
end;
procedure TfrmGraphs.splItemsBottomMoved(Sender: TObject);
begin
chkItemsBottom.Left := pnlItemsBottom.Width - chkItemsBottom.Width - 2;
pnlItemsTop.Width := pnlItemsBottom.Width;
chkItemsTop.Left := pnlItemsTop.Width - chkItemsTop.Width - 2;
end;
procedure TfrmGraphs.splItemsTopMoved(Sender: TObject);
begin
chkItemsTop.Left := pnlItemsTop.Width - chkItemsTop.Width - 2;
pnlItemsBottom.Width := pnlItemsTop.Width;
chkItemsBottom.Left := pnlItemsBottom.Width - chkItemsBottom.Width - 2;
end;
procedure TfrmGraphs.cboDateRangeChange(Sender: TObject);
var
datetag: integer;
endofday: double;
dateranges, manualstart, manualstop: string;
begin
endofday := FMDateTimeOffsetBy(FMToday, 1);
SelCopy(lvwItemsTop, lstSelCopyTop);
SelCopy(lvwItemsBottom, lstSelCopyBottom);
dateranges := '';
if (cboDateRange.ItemID = 'S') then
begin
with calDateRange do
begin
if Execute then
if Length(TextOfStart) > 0 then
if Length(TextOfStop) > 0 then
begin
dateranges :=
'^' + UpperCase(TextOfStart) + ' to ' + UpperCase(TextOfStop) +
'^^^' + RelativeStart + ';' + RelativeStop +
'^' + floattostr(FMDateStart) + '^' + floattostr(FMDateStop);
cboDateRange.Items.Append(dateranges);
cboDateRange.ItemIndex := cboDateRange.Items.Count - 1;
end
else
cboDateRange.ItemIndex := -1
else
cboDateRange.ItemIndex := -1
else
cboDateRange.ItemIndex := -1;
end;
end;
HideGraphs(true);
datetag := cboDateRange.ItemIEN;
with FGraphSetting do
case datetag of
0: begin
if cboDateRange.ItemIndex > 8 then // selected date range
begin
if dateranges = '' then dateranges := cboDateRange.Items[cboDateRange.ItemIndex];
manualstart := Piece(dateranges, '^' , 6);
manualstop := Piece(dateranges, '^' , 7);
if (manualstop <> '') and (length(Piece(manualstop, '.', 2)) = 0) then
manualstop := manualstop + '.2359';
FMStartDate := MakeFMDateTime(manualstart);
FMStopDate := MakeFMDateTime(manualstop);
if (manualstart <> '') and (length(Piece(manualstart, '.', 2)) = 0) then
begin
FMStartDate := FMDateTimeOffsetBy(FMStartDate, -1);
manualstart := floattostr(FMStartDate) + '.2359';
FMStartDate := MakeFMDateTime(manualstart);
end;
end;
end;
1: begin
FMStartDate := FMToday;
FMStopDate := endofday;
end;
2: begin
FMStartDate := FMDateTimeOffsetBy(FMToday, -7);
FMStopDate := endofday;
end;
3: begin
FMStartDate := FMDateTimeOffsetBy(FMToday, -14);
FMStopDate := endofday;
end;
4: begin
FMStartDate := FMDateTimeOffsetBy(FMToday, -30);
FMStopDate := endofday;
end;
5: begin
FMStartDate := FMDateTimeOffsetBy(FMToday, -183);
FMStopDate := endofday;
end;
6: begin
FMStartDate := FMDateTimeOffsetBy(FMToday, -365);
FMStopDate := endofday;
end;
7: begin
FMStartDate := FMDateTimeOffsetBy(FMToday, -730);
FMStopDate := endofday;
end;
8: begin
FMStartDate := FM_START_DATE; // earliest recorded values
FMStopDate := endofday;
end;
else
begin
if dateranges = '' then dateranges := cboDateRange.Items[cboDateRange.ItemIndex];
manualstart := Piece(dateranges, '^' , 6);
manualstop := Piece(dateranges, '^' , 7);
if (manualstop <> '') and (length(Piece(manualstop, '.', 2)) = 0) then manualstop := manualstop + '.2359';
FMStartDate := MakeFMDateTime(manualstart);
FMStopDate := MakeFMDateTime(manualstop);
if (manualstart <> '') and (length(Piece(manualstart, '.', 2)) = 0) then
begin
FMStartDate := FMDateTimeOffsetBy(FMStartDate, -1);
manualstart := floattostr(FMStartDate) + '.2359';
FMStartDate := MakeFMDateTime(manualstart);
end;
end;
end;
FilterListView(FGraphSetting.FMStartDate, FGraphSetting.FMStopDate);
SelReset(lstSelCopyTop, lvwItemsTop);
SelReset(lstSelCopyBottom, lvwItemsBottom);
DisplayData('top');
DisplayData('bottom');
if cboViewsTop.ItemIndex > 1 then cboViewsTopChange(self);
if cboViewsBottom.ItemIndex > 1 then cboViewsBottomChange(self);
HideGraphs(false);
end;
function TfrmGraphs.StdDev(value, high, low: double): double;
begin
if high - low <> 0 then
begin
Result := (value - (low + ((high - low) / 2)))/((high - low) / 4);
Result := RoundTo(Result, -2);
end
else
Result := 0;
end;
function TfrmGraphs.InvVal(value: double): double;
begin
if value = 0 then value := 0.0001;
Result := 1 / value;
Result := RoundTo(Result, -2);
end;
procedure TfrmGraphs.lvwItemsTopCompare(Sender: TObject; Item1,
Item2: TListItem; Data: Integer; var Compare: Integer);
begin
if not(Sender is TListView) then exit;
if FsortAscending then
begin
if FSortCol = 0 then
Compare := CompareStr(Item1.Caption, Item2.Caption)
else
Compare := CompareStr(Item1.SubItems[FsortCol - 1],
Item2.SubItems[FsortCol - 1]);
end
else
begin
if FSortCol = 0 then
Compare := CompareStr(Item2.Caption, Item1.Caption)
else
Compare := CompareStr(Item2.SubItems[FsortCol - 1],
Item1.SubItems[FsortCol - 1]);
end;
end;
procedure TfrmGraphs.lvwItemsTopColumnClick(Sender: TObject;
Column: TListColumn);
begin
if FSortCol = Column.Index then
FSortAscending := not FSortAscending
else
FSortAscending := true;
FSortCol := Column.Index;
(Sender as TListView).AlphaSort;
end;
procedure TfrmGraphs.lvwItemsBottomCompare(Sender: TObject; Item1,
Item2: TListItem; Data: Integer; var Compare: Integer);
begin
if not(Sender is TListView) then exit;
if FBSortAscending then
begin
if FBSortCol = 0 then
Compare := CompareStr(Item1.Caption, Item2.Caption)
else
Compare := CompareStr(Item1.SubItems[FBSortCol - 1],
Item2.SubItems[FBSortCol - 1]);
end
else
begin
if FBSortCol = 0 then
Compare := CompareStr(Item2.Caption, Item1.Caption)
else
Compare := CompareStr(Item2.SubItems[FBSortCol - 1],
Item1.SubItems[FBSortCol - 1]);
end;
end;
procedure TfrmGraphs.lvwItemsBottomColumnClick(Sender: TObject;
Column: TListColumn);
begin
if FBSortCol = Column.Index then
FBSortAscending := not FBSortAscending
else
FBSortAscending := true;
FBSortCol := Column.Index;
(Sender as TListView).AlphaSort;
end;
procedure TfrmGraphs.btnGraphSelectionsClick(Sender: TObject);
var
actionOK, checkaction: boolean;
counter, i, listnum: integer;
profile, profilestring, section, selections, specnum, typeitem: string;
aGraphItem: TGraphItem;
begin
selections := '';
for i := 0 to lvwItemsTop.Items.Count - 1 do
if lvwItemsTop.Items[i].Selected then
begin
aGraphItem := TGraphItem(lvwItemsTop.Items.Item[i].SubItems.Objects[3]);
typeitem := UpperCase(aGraphItem.Values);
if Piece(typeitem, '^', 1) = '63' then
begin
specnum := Piece(Piece(typeitem, '^', 2), '.', 2);
if length(specnum) > 0 then // mulispecimen
if specnum = '1' then typeitem := Piece(typeitem, '.', 1)
else typeitem := '';
end;
if length(typeitem) > 0 then
selections := selections + Piece(typeitem, '^', 1) + '~' + Piece(typeitem, '^', 2) +'~|';
end;
checkaction := chkDualViews.Checked;
actionOK := false;
profile := '*';
counter := cboViewsTop.Tag;
// load lstItems with all patient items and pass to Define View ????
DialogGraphProfiles(Font.Size, actionOK, checkaction, FGraphSetting,
profile, profilestring, section, Patient.DFN, counter, selections);
if (not actionOK) then exit;
FillViews;
if (section = 'niether') then exit;
cboViewsTop.Tag := counter;
lstViews.Items.Add(profilestring);
listnum := lstViews.Items.Count + 1;
for i := 0 to lstViews.Items.Count - 1 do
begin
profilestring := lstViews.Items[i];
cboViewsTop.Items.Insert(i + 2, profilestring);
cboViewsBottom.Items.Insert(i + 2, profilestring);
end;
if (section = 'bottom') or (section = 'both') then
lvwItemsBottom.Tag := listnum;
if (section = 'top') or (section = 'both') then
lvwItemsTop.Tag := listnum;
ViewSelections;
end;
procedure TfrmGraphs.ViewSelections;
var
i: integer;
begin // uses lvwItems... Tag as index for view selection
with lvwItemsBottom do
begin
if (Tag = 0) and (length(lvwItemsBottom.Hint) > 0) then
begin
for i := 0 to cboViewsBottom.Items.Count - 1 do
begin
showmessage(cboViewsBottom.Items[i]);
if lvwItemsBottom.Hint = Piece(cboViewsBottom.Items[i], '^', 2) then
begin
Tag := i;
break;
end;
end;
end;
if Tag > 0 then
begin
if not chkDualViews.Checked then
begin
chkDualViews.Checked := true;
chkDualViewsClick(self);
end;
ClearSelection;
cboViewsBottom.ItemIndex := Tag;
Tag := 0;
Hint := '';
cboViewsBottomChange(self);
end;
end;
with lvwItemsTop do
begin
if (Tag = 0) and (length(lvwItemsTop.Hint) > 0) then
begin
for i := 0 to cboViewsTop.Items.Count - 1 do
begin
if lvwItemsTop.Hint = Piece(cboViewsTop.Items[i], '^', 2) then
begin
Tag := i;
break;
end;
end;
end;
if Tag > 0 then
begin
ClearSelection;
cboViewsTop.ItemIndex := Tag;
Tag := 0;
Hint := '';
cboViewsTopChange(self);
end;
end;
end;
procedure TfrmGraphs.ItemsClick(Sender: TObject; aListView, aOtherListView: TListView;
aCheckBox: TCheckBox; aComboBox: TORComboBox; aList: TListBox; aSection: string);
begin
FRetainZoom := (lstZoomHistory.Count > 0);
FWarning := false;
Screen.Cursor := crHourGlass;
HideGraphs(true);
if Sender = aListView then
begin
aComboBox.ItemIndex := -1;
aComboBox.Text := '';
end;
if (Sender is TListView) then // clear out selcopy list
aList.Items.Clear;
if aOtherListView.SelCount < 1 then
begin
FGraphSetting.HighTime := 0;
FGraphSetting.LowTime := BIG_NUMBER;
end
else if (FBHighTime <> 0) and (aSection = 'top') then
begin
if FBHighTime < FTHighTime then FGraphSetting.HighTime := FBHighTime;
if FBLowTime > FTLowTime then FGraphSetting.LowTime := FBLowTime;
end
else if (FTHighTime <> 0) and (aSection = 'bottom') then
begin
if FTHighTime < FBHighTime then FGraphSetting.HighTime := FTHighTime;
if FTLowTime > FBLowTime then FGraphSetting.LowTime := FTLowTime;
end;
if aSection = 'top' then
begin
FTHighTime := 0;
FTLowTime := BIG_NUMBER;
end
else if aSection = 'bottom' then
begin
FBHighTime := 0;
FBLowTime := BIG_NUMBER;
end;
CheckToAddData(aListView, aSection, 'SELECT');
DisplayData(aSection);
if (aListView.SelCount = 1) and (aOtherListView.SelCount = 0) then
begin
lstZoomHistory.Items.Clear;
FRetainZoom := false;
mnuPopGraphZoomBack.Enabled := false;
end
else if FRetainZoom and (lstZoomHistory.Count > 0) then
ZoomUpdate;
HideGraphs(false);
if FWarning then
FWarning := false;
Screen.Cursor := crDefault;
end;
procedure TfrmGraphs.CheckToAddData(aListView: TListView; aSection, TypeToCheck: string);
var
done, ok, previous, singletype: boolean;
i, j: integer;
itemname, typeitem: string;
aGraphItem: TGraphItem;
begin
TypeToCheck := UpperCase(TypeToCheck);
if (TypeToCheck = 'SELECT') and (lvwItemsTop.SelCount = 0)
and (lvwItemsBottom.SelCount = 0) then exit;
singletype := length(Piece(TypeToCheck, '^', 2)) = 0;
for i := 0 to aListView.Items.Count - 1 do
begin
ok := false;
if (TypeToCheck = 'ALL') then ok := true;
if (TypeToCheck = 'SELECT') and aListView.Items[i].Selected then ok := true;
aGraphItem := TGraphItem(aListView.Items.Item[i].SubItems.Objects[3]);
typeitem := UpperCase(Pieces(aGraphItem.Values, '^', 1, 2));
if not ok then
if TypeToCheck = typeitem then ok := true
else if (TypeToCheck = Piece(typeitem, '^', 1)) and
singletype then ok := true;
if ok then
begin
previous := false;
done := false;
j := 0;
with lstCheck do
while not done do
begin
if Items.Count = j then done := true
else if lstCheck.Items[j] = typeitem then
begin
previous := true;
done := true;
end
else j := j + 1;
end;
if not previous then
begin
lstCheck.Items.Add(typeitem);
itemname := aListView.Items[i].Caption;
if Piece(typeitem, '^', 1) = '63' then
LabData(typeitem, itemname, aSection)
else
lstData.Items.AddStrings(rpcGetItemData(typeitem, FMTimeStamp, Patient.DFN));
end;
end;
end;
end;
procedure TfrmGraphs.lvwItemsTopClick(Sender: TObject);
var
i: integer;
begin
FFirstClick := true;
with FGraphSetting do
if lvwItemsTop.SelCount > MaxSelect then
begin
pnlItemsTopInfo.Tag := 1;
lvwItemsTop.ClearSelection;
showmessage('Too many items to graph');
for i := 0 to lstSelPrevTop.Items.Count - 1 do
lvwItemsTop.Items[strtoint(lstSelPrevTop.Items[i])].Selected := true;
pnlItemsTopInfo.Tag := 0;
end
else
begin
lstSelPrevTop.Clear;
for i := 0 to lvwItemsTop.Items.Count - 1 do
if lvwItemsTop.Items[i].Selected then lstSelPrevTop.Items.Add(inttostr(i));
ItemsClick(Sender, lvwItemsTop, lvwItemsBottom, chkItemsTop, cboViewsTop, lstSelCopyTop, 'top');
end;
end;
procedure TfrmGraphs.lvwItemsBottomClick(Sender: TObject);
var
i: integer;
begin
FFirstClick := true;
with FGraphSetting do
if lvwItemsBottom.SelCount > MaxSelect then
begin
pnlItemsBottomInfo.Tag := 1;
lvwItemsBottom.ClearSelection;
showmessage('Too many items to graph');
for i := 0 to lstSelPrevBottom.Items.Count - 1 do
lvwItemsBottom.Items[strtoint(lstSelPrevBottom.Items[i])].Selected := true;
pnlItemsBottomInfo.Tag := 0;
end
else
begin
lstSelPrevBottom.Clear;
for i := 0 to lvwItemsBottom.Items.Count - 1 do
if lvwItemsBottom.Items[i].Selected then lstSelPrevBottom.Items.Add(inttostr(i));
ItemsClick(Sender, lvwItemsBottom, lvwItemsTop, chkItemsBottom, cboViewsBottom, lstSelCopyBottom, 'bottom');
end;
end;
procedure TfrmGraphs.SelCopy(aListView: TListView; aListBox: TListBox);
var
i: integer;
aGraphItem: TGraphItem;
begin
if aListView.Items.Count > 0 then
begin
for i := 0 to aListView.Items.Count - 1 do
if aListView.Items[i].Selected then
begin
aGraphItem := TGraphItem(aListView.Items.Item[i].SubItems.Objects[3]); //get file^ien match
aListBox.Items.Add(aGraphItem.Values);
end;
end;
end;
procedure TfrmGraphs.SelReset(aListbox: TListBox; aListView: TListView);
var
i, j: integer;
typeitem, itemtype: string;
aGraphItem: TGraphItem;
begin
for i := 0 to aListView.Items.Count - 1 do
begin
aGraphItem := TGraphItem(aListView.Items.Item[i].SubItems.Objects[3]); //get file^ien match
typeitem := UpperCase(Pieces(aGraphItem.Values, '^', 1, 3));
for j := 0 to aListBox.Items.Count - 1 do
begin
itemtype := UpperCase(Pieces(aListBox.Items[j], '^', 1, 3));
if itemtype = typeitem then
begin
aListView.Items[i].Selected := true;
break;
end;
end
end;
end;
procedure TfrmGraphs.ViewsChange(aListView: TListView; aComboBox: TORComboBox; aSection: string);
var
Updated: boolean;
aProfile: string;
begin
timHintPause.Enabled := false;
InactivateHint;
if aComboBox.ItemIndex = -1 then exit; // or clear graph ***************************
if aComboBox.ItemIndex = 0 then // <clear all selections>
begin
aComboBox.Text := '';
aListView.ClearSelection;
if aSection = 'top' then
begin
FTHighTime := 0;
FTLowTime := BIG_NUMBER;
end
else
begin
FBHighTime := 0;
FBLowTime := BIG_NUMBER;
end;
DisplayData(aSection);
exit;
end;
if aComboBox.ItemIndex = 1 then // <make selections>
begin
btnGraphSelectionsClick(self);
if aComboBox.ItemIndex = -1 then
aComboBox.Text := '';
exit;
end; // view selected
aListView.ClearSelection;
Updated := false;
aProfile := aComboBox.Items[aComboBox.ItemIndex];
if (length(Piece(aProfile, '^', 3)) = 0) or (length(Piece(aProfile, '^', 1)) = 0) then //or <custom>
CheckProfile(aProfile, Updated);
aComboBox.Text := Piece(aProfile, '^', 2);
if Updated then
cboDateRangeChange(self);
if aSection = 'top' then
begin
AssignProfile(aProfile, 'top');
if not FItemsSortedTop then
lvwItemsTopColumnClick(lvwItemsTop, lvwItemsTop.Column[0]);
if FGraphSetting.SortColumn > 0 then
lvwItemsTopColumnClick(lvwItemsTop, lvwItemsTop.Column[FGraphSetting.SortColumn]);
lvwItemsTopColumnClick(lvwItemsTop, lvwItemsTop.Column[2]);
lvwItemsTopColumnClick(lvwItemsTop, lvwItemsTop.Column[2]);
FItemsSortedTop := false;
end
else
begin
AssignProfile(aProfile, 'bottom');
if not FItemsSortedBottom then
lvwItemsBottomColumnClick(lvwItemsBottom, lvwItemsBottom.Column[0]);
if FGraphSetting.SortColumn > 0 then
lvwItemsBottomColumnClick(lvwItemsBottom, lvwItemsBottom.Column[FGraphSetting.SortColumn]);
lvwItemsBottomColumnClick(lvwItemsBottom, lvwItemsBottom.Column[2]);
lvwItemsBottomColumnClick(lvwItemsBottom, lvwItemsBottom.Column[2]);
FItemsSortedBottom := false;
end;
aListView.ClearSelection;
AutoSelect(aListView);
DisplayData(aSection);
end;
procedure TfrmGraphs.cboViewsTopChange(Sender: TObject);
begin
ViewsChange(lvwItemsTop, cboViewsTop, 'top');
end;
procedure TfrmGraphs.cboViewsBottomChange(Sender: TObject);
begin
ViewsChange(lvwItemsBottom, cboViewsBottom, 'bottom');
end;
procedure TfrmGraphs.AssignProfile(aProfile, aSection: string);
var
profilename: string;
begin
profilename := Piece(aProfile, '^', 2);
aProfile := UpperCase(Piece(aProfile, '^', 3));
if length(aProfile) = 0 then exit;
if aSection = 'top' then
SetProfile(aProfile, profilename, lvwItemsTop)
else
SetProfile(aProfile, profilename, lvwItemsBottom);
end;
procedure TfrmGraphs.SetProfile(aProfile, aName: string; aListView: TListView);
var
i, j: integer;
dcnm, itemdrugclass, itempart, itempart1, itempart2, itemnums: string;
itemstring, itemstring1, itemstringnums, profname: string;
aGraphItem: TGraphItem;
begin
if aProfile = '0' then
for i := 0 to aListView.Items.Count - 1 do
aListView.Items[i].SubItems[1] := ''
else
for i := 0 to aListView.Items.Count - 1 do
begin
profname := '';
aGraphItem := TGraphItem(aListView.Items.Item[i].SubItems.Objects[3]); //get file^ien match
itemstring := aGraphItem.Values;
itemstring1 := UpperCase(Piece(itemstring, '^', 1));
itemdrugclass := Piece(itemstring, '^', 6);
itemstringnums := UpperCase(Pieces(itemstring, '^', 1, 2));
for j := 1 to BIG_NUMBER do
begin
itempart := Piece(aProfile, '|', j);
if itempart = '' then break;
itempart1 := Piece(itempart, '~', 1);
itempart2 := Piece(itempart, '~', 2);
itemnums := itempart1 + '^' + itempart2;
if (itempart1 = '50.605') and (length(itemdrugclass) > 0) then
begin
dcnm := DCName(itempart2);
if dcnm = itemdrugclass then
begin
profname := aName;
break;
end;
end
else if itempart1 = '63' then
begin
if itemnums = Piece(itemstringnums, '.', 1) then
begin
profname := aName;
break;
end;
end
else
begin
if itemnums = itemstringnums then
begin
profname := aName;
break;
end;
end;
if (itempart1 = '0') and (itempart2 = itemstring1) then
begin
profname := aName;
break;
end
else if (itempart1 = '0') and (length(Piece(itempart2, ';', 2)) > 0) then // subtypes
if copy(itempart2, 1, length(itemstring1)) = Piece(itempart2, ';', 1) then
if Piece(itempart2, ';', 2) = UpperCase(Piece(Piece(itemstring, '^', 2), ';', 2)) then
begin
profname := aName;
break;
end;
end;
aListView.Items[i].SubItems[1] := profname;
end;
end;
function TfrmGraphs.ExpandTax(profile: string): string;
var
i: integer;
itempart, itempart1, itempart2, newprofile: string;
taxonomies: TStrings;
expandedcodes: TStrings;
taxonomycodes: TStrings;
begin // '811.2~123~|0~63~|' or '55~12~|0~811.2~|0~63~|'
Result := profile;
if Pos('811.2~', profile) = 0 then exit;
taxonomies := TStringList.Create;
expandedcodes := TStringList.Create;
taxonomycodes := TStringList.Create;
newprofile := '';
for i := 1 to BIG_NUMBER do
begin
itempart := Piece(profile, '|', i);
if length(itempart) = 0 then break;
if Pos('811.2~', itempart) = 0 then
newprofile := newprofile + '|'
else
taxonomies.Add(itempart);
end;
for i := 0 to taxonomies.Count -1 do
begin
itempart := taxonomies[i];
if (Piece(itempart, '~', 1) = '0') and (Piece(itempart, '~', 2) = '811.2') then
begin
// this is Reminder Taxonomy <any> and would bring back a ton of codes
//FastAssign(rpcTaxonomy(true, nil), expandedcodes);
break;
end
else if Piece(itempart, '~', 1) = '811.2' then
taxonomycodes.Add(Piece(itempart, '~', 2));
end;
if taxonomycodes.Count > 0 then
FastAssign(rpcTaxonomy(false, taxonomycodes), expandedcodes);
for i := 1 to expandedcodes.Count -1 do
begin
itempart := expandedcodes[i];
itempart1 := Piece(itempart, ';', 1);
itempart2 := Piece(itempart, ';', 2);
newprofile := newprofile + itempart1 + '~' + itempart2 + '~|'
end;
Result := newprofile;
end;
procedure TfrmGraphs.CheckProfile(var aProfile: string; var Updated: boolean);
var
i, j: integer;
itempart, itempart1, itempart2, profile, profilename, profiletype, xprofile: string;
begin
profiletype := Piece(aProfile, '^', 1);
profilename := Piece(aProfile, '^', 2);
if profiletype = '-2' then
FastAssign(rpcGetGraphProfiles(UpperCase(profilename), '1', 0), lstTemp.Items)
else if profiletype = '-1' then
FastAssign(rpcGetGraphProfiles(UpperCase(profilename), '0', 0), lstTemp.Items);
if profiletype <> '' then
begin
for i := 0 to lstTemp.Items.Count - 1 do
aProfile := aProfile + lstTemp.Items[i];
lstTemp.Items.Clear;
end;
Updated := false;
profile := UpperCase(Piece(aProfile, '^', 3));
xprofile := ExpandTax(profile);
if xprofile <> profile then
begin // taxonomies
profile := xprofile;
LoadDisplayCheck('45DX', Updated);
LoadDisplayCheck('45OP', Updated);
LoadDisplayCheck('9000010.07', Updated);
LoadDisplayCheck('9000010.18', Updated);
LoadDisplayCheck('9000011', Updated);
//LoadDisplayCheck('9999911', Updated); // problems as durations not being used
end;
aProfile := Pieces(aProfile, '^', 1, 2) + '^' + profile;
for j := 1 to BIG_NUMBER do
begin
itempart := Piece(profile, '|', j);
if itempart = '' then break;
itempart1 := Piece(itempart, '~', 1);
itempart2 := Piece(itempart, '~', 2);
if itempart1 = '0' then // <any> type
LoadDisplayCheck(itempart2, Updated)
else if itempart1 = '50.605' then // drug class
begin
LoadDisplayCheck('52', Updated);
LoadDisplayCheck('55', Updated);
//LoadDisplayCheck('55NVAE', Updated); // nonvameds as events are not being used
LoadDisplayCheck('55NVA', Updated);
LoadDisplayCheck('53.79', Updated);
end
else if itempart1 <> '0' then // all others
LoadDisplayCheck(itempart1, Updated);
end;
end;
procedure TfrmGraphs.LoadDisplayCheck(typeofitem: string; var Updated: boolean);
begin
if not TypeIsLoaded(typeofitem) then
begin
LoadType(typeofitem, '1');
Updated := true;
end;
if not TypeIsDisplayed(typeofitem) then
begin
DisplayType(typeofitem, '1');
Updated := true;
end;
end;
procedure TfrmGraphs.AutoSelect(aListView: TListView);
var
counter, i: integer;
begin
counter := 0;
for i := 0 to aListView.Items.Count - 1 do
begin
if length(aListView.Items[i].SubItems[1]) > 0 then
counter := counter + 1;
end;
if counter <= FGraphSetting.MaxSelect then
for i := 0 to aListView.Items.Count - 1 do
begin
if length(aListView.Items[i].SubItems[1]) > 0 then
aListView.Items[i].Selected := true;
end
else
begin
if aListView = lvwItemsTop then
lvwItemsTop.ClearSelection
else if aListView = lvwItemsBottom then
lvwItemsBottom.ClearSelection;
end;
if aListView = lvwItemsTop then
lvwItemsTopClick(self)
else if aListView = lvwItemsBottom then
lvwItemsBottomClick(self);
end;
procedure TfrmGraphs.LabData(aItemType, aItemName, aSection: string);
var
singlespec: boolean;
i, oldlisting: integer;
checkitem, checkstring, datastring, filename, itemnum, newitemname, newitemnum, newstring: string;
spec1, spec2, spec3, spec4: string;
aGraphItem: TGraphItem;
aListItem: TListItem;
begin
singlespec := true;
spec1 := ''; spec2 := ''; spec3 := ''; spec4 := '';
lstSpec1.Items.Clear; lstSpec2.Items.Clear; lstSpec3.Items.Clear; lstSpec4.Items.Clear;
FastAssign(rpcGetItemData(aItemType, FMTimeStamp, Patient.DFN), lstScratchLab.Items);
for i := 0 to lstScratchLab.Items.Count - 1 do
begin
datastring := lstScratchLab.Items[i];
checkstring := Pieces(datastring, '^', 1, 2) + '^' + Pieces(datastring, '^', 7, 8);
if length(spec1) = 0 then
begin
spec1 := checkstring;
lstSpec1.Items.Add(datastring)
end
else if spec1 = checkstring then
lstSpec1.Items.Add(datastring)
else if length(spec2) = 0 then
begin
singlespec := false;
spec2 := checkstring;
lstSpec2.Items.Add(datastring)
end
else if spec2 = checkstring then
lstSpec2.Items.Add(datastring)
else if length(spec3) = 0 then
begin
spec3 := checkstring;
lstSpec3.Items.Add(datastring)
end
else if spec3 = checkstring then
lstSpec3.Items.Add(datastring)
else
begin
spec4 := checkstring;
lstSpec4.Items.Add(datastring)
end;
end;
if singlespec then
lstData.Items.AddStrings(lstScratchLab.Items)
else
begin
lstMultiSpec.Items.Clear;
itemnum := Piece(aItemType, '^', 2);
if length(spec1) > 0 then
begin
newitemnum := itemnum + '.1';
newitemname := aItemName + ' (' + LowerCase(Piece(spec1, '^', 4)) + ')';
for i := 0 to lstItems.Items.Count - 1 do
if aItemType = Pieces(lstItems.Items[i], '^', 1, 2) then
begin
newstring := lstItems.Items[i];
lstItems.Items.Delete(i);
break;
end;
for i := 0 to lstData.Items.Count - 1 do
if aItemType = Pieces(lstData.Items[i], '^', 1, 2) then
lstData.Items.Delete(i);
ResetSpec(lstSpec1, itemnum, newitemnum, newitemname, newstring);
end;
if length(spec2) > 0 then
begin
newitemnum := itemnum + '.2';
newitemname := aItemName + ' (' + LowerCase(Piece(spec2, '^', 4)) + ')';
ResetSpec(lstSpec2, itemnum, newitemnum, newitemname, newstring);
end;
if length(spec3) > 0 then
begin
newitemnum := itemnum + '.3';
newitemname := aItemName + ' (' + LowerCase(Piece(spec3, '^', 4)) + ')';
ResetSpec(lstSpec3, itemnum, newitemnum, newitemname, newstring);
end;
if length(spec4) > 0 then
begin
newitemnum := itemnum + '.4';
newitemname := aItemName + ' (other)'; // not specific after 3 specimens (from same time)
ResetSpec(lstSpec4, itemnum, newitemnum, newitemname, newstring);
end;
oldlisting := 0;
lvwItemsTop.SortType := stNone; // avoids out of bounds error
for i := 0 to lvwItemsTop.Items.Count - 1 do
begin
aGraphItem := TGraphItem(lvwItemsTop.Items.Item[i].SubItems.Objects[3]); //get file^ien match
checkitem := Pieces(aGraphItem.Values, '^', 1, 2);
if aItemType = checkitem then
begin
oldlisting := i;
lvwItemsTop.Items.Delete(i);
break;
end;
end;
filename := FileNameX('63');
for i := 0 to lstMultiSpec.Items.Count - 1 do
begin
lstCheck.Items.Add(UpperCase(Pieces(lstMultiSpec.Items[i], '^', 1, 2)));
if (FGraphSetting.FMStartDate = FM_START_DATE)
or DateRangeMultiItems(FGraphSetting.FMStartDate, FGraphSetting.FMStopDate, Piece(lstMultiSpec.Items[i], '^', 2)) then
begin
with lvwItemsTop do
aListItem := Items.Insert(oldlisting);
aListItem.Caption := Piece(lstMultiSpec.Items[i], '^', 4);
aListItem.SubItems.Add(filename);
aListItem.SubItems.Add('');
aListItem.SubItems.Add('');
aGraphItem := TGraphItem.Create;
aGraphItem.Values := lstMultiSpec.Items[i];
aListItem.SubItems.AddObject('info object', aGraphItem);
if aSection = 'top' then lvwItemsTop.Items[oldlisting].Selected := true;
end;
end;
lvwItemsTop.SortType := stBoth;
oldlisting := 0;
lvwItemsBottom.SortType := stNone; // avoids out of bounds error
for i := 0 to lvwItemsBottom.Items.Count - 1 do
begin
aGraphItem := TGraphItem(lvwItemsBottom.Items.Item[i].SubItems.Objects[3]); //get file^ien match
checkitem := Pieces(aGraphItem.Values, '^', 1, 2);
if aItemType = checkitem then
begin
oldlisting := i;
lvwItemsBottom.Items.Delete(i);
break;
end;
end;
for i := 0 to lstMultiSpec.Items.Count - 1 do
begin
aListItem := lvwItemsBottom.Items.Insert(oldlisting);
aListItem.Caption := Piece(lstMultiSpec.Items[i], '^', 4);
aListItem.SubItems.Add(filename);
aListItem.SubItems.Add('');
aListItem.SubItems.Add('');
aGraphItem := TGraphItem.Create;
aGraphItem.Values := lstMultiSpec.Items[i];
aListItem.SubItems.AddObject('info object', aGraphItem);
if aSection = 'bottom' then lvwItemsBottom.Items[oldlisting].Selected := true;
end;
lvwItemsBottom.SortType := stBoth;
end;
end;
procedure TfrmGraphs.RefUnits(aItem, aSpec: string; var low, high, units: string);
var
i: integer;
item2: double;
itemspec, specstring: string;
begin
item2 := strtofloatdef(aItem, -BIG_NUMBER);
if item2 <> -BIG_NUMBER then
begin
item2 := round(item2);
aItem := floattostr(item2);
end;
itemspec := aItem + '^' + aSpec;
for i := 0 to lstTestSpec.Items.Count - 1 do
if itemspec = Pieces(lstTestSpec.Items[i], '^', 1, 2) then
begin
specstring := lstTestSpec.Items[i];
low := Piece(specstring, '^', 3);
high := Piece(specstring, '^', 4);
units := Piece(specstring, '^', 8);
if (Copy(low, 1, 3) = '$S(') then low := SelectRef(low);
if (Copy(high, 1, 3) = '$S(') then high := SelectRef(high);
break;
end;
end;
function TfrmGraphs.SelectRef(aRef: string): string;
// check ref range for AGE and SEX variables in $S statement
procedure CheckRef(selection: string; var value: string; var ok: boolean);
var
age: integer;
part1, part2, part3: string;
begin
value := '';
ok := false;
if pos('$S', selection) > 0 then exit;
if pos(':', selection) = 0 then exit;
part1 := Piece(selection, ':', 1);
part2 := Piece(selection, ':', 2);
part3 := Piece(selection, ':', 3);
if length(part1) = 0 then exit;
if length(part2) = 0 then exit;
if length(part3) <> 0 then exit;
ok := true;
value := part2;
if part1 = '1' then exit;
if copy(part1, 1, 4) = 'SEX=' then
begin
if (part1 = 'SEX="M"') and (Patient.Sex = 'M') then exit;
if (part1 = 'SEX="F"') and (Patient.Sex = 'F') then exit; //?? check for '= '> '< ??
value := '';
end
else if copy(part1, 1, 3) = 'AGE' then
begin
part3 := copy(part1, 5, length(part1));
age := strtointdef(part3, BIG_NUMBER);
if age <> BIG_NUMBER then
begin
part3 := copy(part1, 1, 4);
if (part3 = 'AGE>') and (Patient.Age > age) then exit;
if (part3 = 'AGE<') and (Patient.Age < age) then exit;
if (part3 = 'AGE=') and (Patient.Age = age) then exit;
end;
value := '';
end
else
value:= '';
end;
var
ok: boolean;
i: integer;
selection, selections: string;
begin
Result := '';
if copy(aRef, length(aRef), 1) = ')' then
begin
selections := copy(aRef, 4, length(aRef) - 4);
for i := 1 to BIG_NUMBER do
begin
selection := Piece(selections, ',', i);
if selection = '' then break;
ok := true;
CheckRef(selection, Result, ok);
if not ok then break;
if length(Result) > 0 then break;
end;
end;
end;
procedure TfrmGraphs.ResetSpec(aListBox: TListBox; aItemNum, aNewItemNum, aNewItemName, aNewString: string);
var //also add itemx
i: integer;
checkdate, newdate: double;
newestdate, newstring: string;
begin
lstTemp.Items.Clear;
newdate := 0;
for i := 0 to aListBox.Items.Count - 1 do
begin
newstring := aListBox.Items[i];
newestdate := FMCorrectedDate(Piece(newstring, '^', 3));
checkdate := strtofloatdef(newestdate, -BIG_NUMBER);
if checkdate > newdate then newdate := checkdate;
SetPiece(newstring, '^', 2, aNewItemNum);
lstTemp.Items.Add(newstring);
end;
lstData.Items.AddStrings(lstTemp.Items);
newestdate := floattostr(newdate);
SetPiece(aNewString, '^', 2, aNewItemNum);
SetPiece(aNewString, '^', 4, aNewItemName);
SetPiece(aNewString, '^', 6, newestdate);
lstItems.Items.Add(aNewString);
lstMultiSpec.Items.Add(aNewString);
end;
procedure TfrmGraphs.chartBaseClickLegend(Sender: TCustomChart;
Button: TMouseButton; Shift: TShiftState; X, Y: Integer);
var
seriestitle: string;
begin
FGraphClick := Sender;
chartDatelineTop.Tag := -1; // indicates a legend click
if Button <> mbRight then
ItemDateRange(Sender)
else
begin
mnuPopGraphIsolate.Enabled := true;
if pnlTop.Tag = 1 then
begin
if chkItemsTop.Checked then
begin
seriestitle := Sender.SeriesTitleLegend(0);
scrlTop.Hint := 'Details - for ' + seriestitle;
scrlTop.Tag := 1;
mnuPopGraphIsolate.Caption := 'Move - ' + seriestitle + ' - from Top to Bottom';
mnuPopGraphIsolate.Hint := seriestitle;
mnuPopGraphRemove.Enabled := true;
mnuPopGraphRemove.Caption := 'Remove - ' + seriestitle;
mnuPopGraphDetails.Caption := 'Details - ' + seriestitle;
end
else
begin
mnuPopGraphIsolate.Caption := 'Move all selections to bottom';
mnuPopGraphRemove.Caption := 'Remove all selections from top';
end;
end
else
begin
if chkItemsBottom.Checked then
begin
seriestitle := Sender.SeriesTitleLegend(0);
scrlTop.Hint := 'Details - for ' + seriestitle;
scrlTop.Tag := 1;
mnuPopGraphIsolate.Caption := 'Move - ' + seriestitle + ' - from Bottom to Top';
mnuPopGraphIsolate.Hint := seriestitle;
mnuPopGraphRemove.Enabled := true;
mnuPopGraphRemove.Caption := 'Remove - ' + seriestitle;
mnuPopGraphDetails.Caption := 'Details - ' + seriestitle;
end
else
begin
mnuPopGraphIsolate.Caption := 'Move all selections to top';
mnuPopGraphRemove.Caption := 'Remove all selections from bottom';
end;
end;
end;
end;
function TfrmGraphs.BPValue(aDateTime: TDateTime): string;
var
i: integer;
fmdatetime: double;
datastring, datecheck, fmstring: string;
begin
Result := '';
fmdatetime := datetimetofmdatetime(aDateTime);
fmstring := floattostr(fmdatetime);
for i := 0 to lstData.Items.Count - 1 do
begin
datastring := lstData.Items[i];
if Pieces(datastring, '^', 1, 2) = '120.5^1' then //********** get item # for bp instead of 1
begin
datecheck := Piece(datastring, '^', 3);
if length(Piece(datecheck, '.', 2)) > 0 then
datecheck := Piece(datecheck, '.', 1) + '.' + copy(Piece(datecheck, '.', 2), 1, 4);
if fmstring = datecheck then
begin
Result := Piece(datastring, '^', 5);
break;
end;
end;
end;
end;
procedure TfrmGraphs.mnuMedsasganttClick(Sender: TObject);
begin
(Sender as TMenuItem).Checked := true;
lvwItemsTopClick(self);
lvwItemsBottomClick(self);
end;
procedure TfrmGraphs.mnuPopGraphResetClick(Sender: TObject);
begin
FFirstClick := true;
lstZoomHistory.Items.Clear;
FRetainZoom := false;
mnuPopGraphZoomBack.Enabled := false;
lvwItemsTopClick(self);
end;
procedure TfrmGraphs.serDatelineTopGetMarkText(Sender: TChartSeries;
ValueIndex: Integer; var MarkText: String);
var
cnt, i: integer;
checktag, nonstring: string;
begin // ********* listing one series' values is ok but no multiple ???
MarkText := Sender.Title;
if Copy(MarkText, 1, 4) = 'Ref ' then
MarkText := '';
if Sender.Title = '(non-numeric)' then
begin
if Sender.Tag > 0 then
begin
checktag := inttostr(Sender.Tag);
cnt := -1;
for i := 0 to lstNonNumeric.Items.Count - 1 do
begin
nonstring := lstNonNumeric.Items[i];
if checktag = Piece(nonstring, '^', 3) then
begin
cnt := cnt + 1;
if cnt = ValueIndex then
begin
MarkText := Piece(nonstring, '^', 2);
break;
end;
end;
end;
if MarkText = '(non-numeric)' then
beep;
end;
end;
end;
procedure TfrmGraphs.mnuPopGraphRemoveClick(Sender: TObject);
var
i, selnum: integer;
aSection, typeitem: string;
aComboBox: TORComboBox;
aListView: TListView;
begin
FFirstClick := true;
if pnlTop.Tag = 1 then
begin
aComboBox := cboViewsTop;
aListView := lvwItemsTop;
aSection := 'top';
end
else
begin
aComboBox := cboViewsBottom;
aListView := lvwItemsBottom;
aSection := 'bottom';
end;
aComboBox.ItemIndex := -1;
aComboBox.Text := '';
if aListView.SelCount = 0 then exit;
if StripHotKey(mnuPopGraphRemove.Caption) = ('Remove all selections from ' + aSection) then
begin
with aListView do
for i := 0 to Items.Count - 1 do
if Items[i].Selected then
begin
Items[i].Selected := false;
end;
DisplayData('top');
DisplayData('bottom');
end
else
begin
ItemCheck(aListView, mnuPopGraphIsolate.Hint, selnum, typeitem);
if selnum = -1 then exit;
aListView.Items[selnum].Selected := false;
DisplayData('top');
DisplayData('bottom');
end;
mnuPopGraphRemove.Enabled := false;
mnuPopGraphResetClick(self);
end;
procedure TfrmGraphs.mnuPopGraphTodayClick(Sender: TObject);
begin
with dlgDate do
begin
FMDateTime := FMToday;
if Execute then FMToday := FMDateTime;
end;
end;
procedure TfrmGraphs.BaseResize(aScrollBox: TScrollBox);
var
displayheight, displaynum, i: integer;
begin
ChartOnZoom(chartDatelineTop);
with aScrollBox do
begin
if ControlCount < FGraphSetting.MaxGraphs then
displaynum := ControlCount
else
displaynum := FGraphSetting.MaxGraphs;
displayheight := FGraphSetting.MinGraphHeight;
if displaynum > 0 then
if (Height div displaynum) < FGraphSetting.MinGraphHeight then
displayheight := FGraphSetting.MinGraphHeight
else
displayheight := (Height div displaynum);
for i := 0 to aScrollBox.ControlCount - 1 do
Controls[i].height := displayheight;
end;
end;
procedure TfrmGraphs.pnlScrollTopBaseResize(Sender: TObject);
begin
ChartOnZoom(chartDatelineTop);
BaseResize(scrlTop);
BaseResize(scrlBottom);
end;
procedure TfrmGraphs.NextPointerStyle(aSeries: TChartSeries; aSerCnt: integer);
var
colors1, colors2, colors3, colors4, colors5, colors6: integer;
begin
colors1 := NUM_COLORS + 1;
colors2 := NUM_COLORS * 2 + 1;
colors3 := NUM_COLORS * 3 + 1;
colors4 := NUM_COLORS * 4 + 1;
colors5 := NUM_COLORS * 5 + 1;
colors6 := NUM_COLORS * 6 + 1;
if aSeries is TLineSeries then
begin
with (aSeries as TLineSeries) do
if aSerCnt < colors1 then
Pointer.Style := psCircle
else if aSerCnt < colors2 then
Pointer.Style := psTriangle
else if aSerCnt < colors3 then
Pointer.Style := psRectangle
else if aSerCnt < colors4 then
Pointer.Style := psStar
else if aSerCnt < colors5 then
Pointer.Style := psDownTriangle
else if aSerCnt < colors6 then
Pointer.Style := psCross
else
Pointer.Style := psDiagCross;
end
else if aSeries is TBarSeries then
begin
with (aSeries as TBarSeries) do
if aSerCnt < colors1 then
BarStyle := bsPyramid
else if aSerCnt < colors2 then
BarStyle := bsInvPyramid
else if aSerCnt < colors3 then
BarStyle := bsArrow
else if aSerCnt < colors4 then
BarStyle := bsEllipse
else
BarStyle := bsRectangle;
end
else if aSeries is TPointSeries then
begin
with (aSeries as TPointSeries) do
if aSerCnt < colors1 then
Pointer.Style := psRectangle
else if aSerCnt < colors2 then
Pointer.Style := psTriangle
else if aSerCnt < colors3 then
Pointer.Style := psCircle
else if aSerCnt < colors4 then
Pointer.Style := psStar
else if aSerCnt < colors5 then
Pointer.Style := psDownTriangle
else if aSerCnt < colors6 then
Pointer.Style := psCross
else
Pointer.Style := psDiagCross;
end;
end;
function TfrmGraphs.FMCorrectedDate(fmtime: string): string;
begin
if Copy(fmtime, 4, 4) = '0000' then Result := Copy(fmtime, 1, 3) + '0101'
else if Copy(fmtime, 6, 2) = '00' then Result := Copy(fmtime, 1, 5) + '01'
else Result := fmtime;
end;
procedure TfrmGraphs.FixedDates(var adatetime, adatetime1: TDateTime);
begin
if FGraphSetting.FMStartDate <> FM_START_DATE then
begin // do not use when All Results
adatetime := FMDateTimeToDateTime(FGraphSetting.FMStopDate);
adatetime1 := FMDateTimeToDateTime(FGraphSetting.FMStartDate);
FGraphSetting.HighTime := adatetime;
FGraphSetting.LowTime := adatetime1;
FTHighTime := adatetime;
FTLowTime := adatetime1;
FBHighTime := adatetime;
FBLowTime := adatetime1;
end;
end;
procedure TfrmGraphs.HighLow(fmtime, fmtime1: string; aChart: TChart; var adatetime, adatetime1: TDateTime);
begin
adatetime1 := 0;
adatetime := FMToDateTime(fmtime);
if adatetime > FGraphSetting.HighTime then FGraphSetting.HighTime := adatetime;
if adatetime < FGraphSetting.LowTime then FGraphSetting.LowTime := adatetime;
if aChart = chartDatelineTop then
begin
if adatetime > FTHighTime then FTHighTime := adatetime;
if adatetime < FTLowTime then FTLowTime := adatetime;
end
else
begin
if adatetime > FBHighTime then FBHighTime := adatetime;
if adatetime < FBLowTime then FBLowTime := adatetime;
end;
if fmtime1 <> '' then
begin
adatetime1 := FMToDateTime(fmtime1);
if adatetime1 > FGraphSetting.HighTime then FGraphSetting.HighTime := adatetime1;
if adatetime1 < FGraphSetting.LowTime then FGraphSetting.LowTime := adatetime1;
if aChart = chartDatelineTop then
begin
if adatetime1 > FTHighTime then FTHighTime := adatetime1;
if adatetime1 < FTLowTime then FTLowTime := adatetime1;
end
else
begin
if adatetime1 > FBHighTime then FBHighTime := adatetime1;
if adatetime1 < FBLowTime then FBLowTime := adatetime1;
end;
end;
end;
procedure TfrmGraphs.HideGraphs(action: boolean);
begin
pnlTop.Color := chartDatelineTop.Color;
pnlBottom.Color := chartDatelineTop.Color;
if action then
begin
pnlScrollTopBase.Visible := false;
pnlScrollBottomBase.Visible := false;
end
else
begin
pnlScrollTopBase.Visible := true;
pnlScrollBottomBase.Visible := true;
chartDatelineTop.Refresh;
end;
end;
//****************************************************************************
procedure TfrmGraphs.MakeLineSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt, aNonCnt: integer; multiline: boolean);
procedure BorderValue(var bordervalue: double; value: double);
begin
if FGraphSetting.FixedDateRange then
if bordervalue = -BIG_NUMBER then
bordervalue := value;
end;
var
estimate, firstcnt, i, noncnt: integer;
value, fixeddatevalue, hi, highestvalue, highvalue, lo, nonvalue: double;
checkdata, fmtime, itemvalue, valueD, valueM, valueS: string;
high, low, specimen: string;
adatetime, adatetime1: TDateTime;
afixeddate, afixeddate1: TDateTime;
ser1, ser2, ser3, serLow, serHigh: TLineSeries;
serBlank, serPoint: TPointSeries;
begin
fixeddatevalue := -BIG_NUMBER;
highestvalue := aChart.MaxYValue(aChart.LeftAxis);
if highestvalue < 1 then highestvalue := 1;
firstcnt := lstNonNumeric.Items.Count;
noncnt := firstcnt;
aChart.LeftAxis.LabelsFont.Color := aChart.BottomAxis.LabelsFont.Color;
aSerCnt := aSerCnt + 1;
ser1 := TLineSeries.Create(aChart);
ser2 := TLineSeries.Create(aChart);
ser3 := TLineSeries.Create(aChart);
serPoint := TPointSeries.Create(aChart);
serBlank := TPointSeries.Create(aChart);
serLow := TLineSeries.Create(aChart);
serHigh := TLineSeries.Create(aChart);
specimen := LowerCase(Piece(aTitle, '^', 4));
low := Piece(aTitle, '^', 5); // collect non numeric - graph as events
high := Piece(aTitle, '^', 6);
lo := strtofloatdef(low, -BIG_NUMBER);
hi := strtofloatdef(high, -BIG_NUMBER);
serLow.Active := false;
serHigh.Active := false;
serPoint.Active := false;
serBlank.Active := false;
with ser1 do
begin
LinePen.Visible := FGraphSetting.Lines;
ParentChart := aChart;
Title := Piece(aTitle, '^', 3);
if (length(specimen) > 0) and (not ansicontainsstr(Title, specimen)) then
Title := Title + ' (' + specimen + ')';
XValues.DateTime := True;
NextPointerStyle(ser1, aSerCnt);
Identifier := aFileType;
Pointer.Visible := true;
Pointer.InflateMargins := true;
GetData(aTitle);
ColorEachPoint := false;
SeriesColor := NextColor(aSerCnt);
Marks.BackColor := clInfoBk;
if ser1.Title = 'Blood Pressure' then
begin
ser1.Title := 'Blood Pressure';
with ser2 do
begin
ParentChart := aChart;
Title := 'Blood Pressure';
XValues.DateTime := true;
Pointer.Style := ser1.Pointer.Style;
ShowInLegend := false; //****
Identifier := aFileType;
Pointer.Visible := true;
Pointer.InflateMargins := true;
ColorEachPoint := false;
SeriesColor := ser1.SeriesColor;
Marks.BackColor := clInfoBk;
Active := true;
end;
with ser3 do
begin
ParentChart := aChart;
Title := 'Blood Pressure';
XValues.DateTime := true;
Pointer.Style := ser1.Pointer.Style;
ShowInLegend := false; //****
Identifier := aFileType;
Pointer.Visible := true;
Pointer.InflateMargins := true;
ColorEachPoint := false;
SeriesColor := ser1.SeriesColor;
Marks.BackColor := clInfoBk;
Active := false;
end;
end
else
begin
ser2.Active := false;
ser3.Active := false;
end;
highvalue := 0;
with lstTemp do
for i:= 0 to Items.Count - 1 do
begin
checkdata := lstTemp.Items[i];
fmtime := FMCorrectedDate(Piece(Items[i], '^', 3));
if IsFMDateTime(fmtime) then
begin
HighLow(fmtime, '', aChart, adatetime, adatetime1);
itemvalue := Piece(Items[i], '^', 5);
itemvalue := trim(itemvalue);
itemvalue := StringReplace(itemvalue, ',', '', [rfReplaceAll]);
if ser1.Title = 'Blood Pressure' then
begin
valueS := Piece(itemvalue, '/', 1);
valueD := Piece(itemvalue, '/', 2);
valueM := Piece(itemvalue, '/', 3);
value := strtofloatdef(valueS, -BIG_NUMBER);
if value <> -BIG_NUMBER then
ser1.AddXY(adatetime, value, '', clTeeColor);
value := strtofloatdef(valueD, -BIG_NUMBER);
if value <> -BIG_NUMBER then
ser2.AddXY(adatetime, value, '', clTeeColor);
value := strtofloatdef(valueM, -BIG_NUMBER);
if value <> -BIG_NUMBER then
begin
ser3.AddXY(adatetime, value, '', clTeeColor);
ser3.Active := true;
end;
BorderValue(fixeddatevalue, 100);
end
else
begin
value := strtofloatdef(itemvalue, -BIG_NUMBER);
if value <> -BIG_NUMBER then
begin
if (btnChangeSettings.Tag = 1) and (hi <> -BIG_NUMBER) and (lo <> -BIG_NUMBER) then
begin
value := StdDev(value, hi, lo);
ser1.AddXY(adatetime, value, '', clTeeColor);
high := '2'; low := '-2';
BorderValue(fixeddatevalue, 0);
//splGraphs.Tag := 1; // show ref range
end
else if btnChangeSettings.Tag = 2 then
begin
value := InvVal(value);
ser1.AddXY(adatetime, value, '', clTeeColor);
high := '2'; low := '0';
BorderValue(fixeddatevalue, 0);
splGraphs.Tag := 0; // do not show ref range
end
else
begin
ser1.AddXY(adatetime, value, '', clTeeColor);
if value > highvalue then
highvalue := value;
BorderValue(fixeddatevalue, value);
end;
end
else
begin
noncnt := noncnt + 1;
lstNonNumeric.Items.Add(floattostr(adatetime) + '^' +
itemvalue + '^' + inttostr(aNonCnt + 1));
end;
end;
end;
end;
if (length(low) > 0) and (splGraphs.Tag = 1) then
begin
with serLow do
begin
Active := true;
ParentChart := aChart;
XValues.DateTime := True;
Pointer.Visible := false;
Pointer.InflateMargins := true;
OnGetMarkText := serDatelineTop.OnGetMarkText;
ColorEachPoint := false;
Title := 'Ref Low ' + low;
Pointer.Style := psCircle;
SeriesColor := ser1.SeriesColor; //clBtnShadow ; //clTeeColor;
Marks.Visible := false;
LinePen.Visible := true;
LinePen.Width := 2;
LinePen.Style := psDash; //does not show when width <> 1
end;
value := strtofloatdef(low, -BIG_NUMBER);
if value <> -BIG_NUMBER then
begin
serLow.AddXY(IncDay(FGraphSetting.LowTime, -1), value, '', clTeeColor);
serLow.AddXY(IncDay(FGraphSetting.HighTime, 1), value, '', clTeeColor);
BorderValue(fixeddatevalue, value);
end;
end;
if (length(high) > 0) and (splGraphs.Tag = 1) then
begin
with serHigh do
begin
Active := true;
ParentChart := aChart;
XValues.DateTime := True;
Pointer.Visible := false;
Pointer.InflateMargins := true;
OnGetMarkText := serDatelineTop.OnGetMarkText;
ColorEachPoint := false;
Title := 'Ref High ' + high;
Pointer.Style := psCircle;
SeriesColor := ser1.SeriesColor; // clBtnShadow; //clTeeColor;
Marks.Visible := false;
LinePen.Visible := true;
LinePen.Width := 2;
LinePen.Style := psDash; //does not show when width <> 1
end;
value := strtofloatdef(high, -BIG_NUMBER);
if value <> -BIG_NUMBER then
begin
serHigh.AddXY(IncDay(FGraphSetting.LowTime, -1), value, '', clTeeColor);
serHigh.AddXY(IncDay(FGraphSetting.HighTime, 1), value, '', clTeeColor);
BorderValue(fixeddatevalue, value);
end;
end;
splGraphs.Tag := 0;
if noncnt > firstcnt then
begin
if aChart.Height < 10 then estimate := pnlMain.Height div 2
else estimate := aChart.Height;
aNonCnt := aNonCnt + 1; // use nonnumeric count to offset position
nonvalue := (aNonCnt * (10 / (estimate + 1)) * highestvalue);
with serBlank do
begin
Active := true;
ParentChart := aChart;
XValues.DateTime := True;
Pointer.Visible := true;
Pointer.InflateMargins := true;
OnGetMarkText := serDatelineTop.OnGetMarkText;
ColorEachPoint := false;
Title := '';
Pointer.Style := psSmallDot;
SeriesColor := aChart.Color;
Marks.Visible := false;
ShowInLegend := false;
end;
with serPoint do
begin
Active := true;
ParentChart := aChart;
XValues.DateTime := True;
Pointer.Visible := true;
Pointer.InflateMargins := true;
OnGetMarkText := serDatelineTop.OnGetMarkText;
ColorEachPoint := false;
Title := '(non-numeric)';
Hint := aTitle;
Tag := aNonCnt;
Pointer.Style := ser1.Pointer.Style;
SeriesColor := ser1.SeriesColor;
Marks.BackColor := clInfoBk;
ShowInLegend := false;
end;
for i := 0 to lstNonNumeric.Items.Count - 1 do
begin
if Piece(lstNonNumeric.Items[i], '^',3) = inttostr(aNonCnt) then
if highvalue = 0 then
begin
adatetime := strtofloatdef(Piece(lstNonNumeric.Items[i], '^', 1), -BIG_NUMBER);
if adatetime <> -BIG_NUMBER then
begin
serBlank.Pointer.Pen.Visible := false;
serBlank.AddXY(adatetime, 1, '', pnlScrollTopBase.Color);
break;
end;
end;
end;
for i := 0 to lstNonNumeric.Items.Count - 1 do
if Piece(lstNonNumeric.Items[i], '^',3) = inttostr(aNonCnt) then
begin
adatetime := strtofloatdef(Piece(lstNonNumeric.Items[i], '^', 1), -BIG_NUMBER);
if adatetime <> -BIG_NUMBER then
begin
serPoint.Pointer.Pen.Visible := true;
serPoint.AddXY(adatetime, nonvalue, '', ser1.SeriesColor);
BorderValue(fixeddatevalue, nonvalue);
end;
end;
if highvalue = 0 then
begin
aChart.LeftAxis.LabelsFont.Color := pnlScrollTopBase.Color;
FNonNumerics := true;
end;
end;
if ser1.Title = 'Pain' then
begin
if not serBlank.Active then
with serBlank do
begin
Active := true;
ParentChart := aChart;
XValues.DateTime := True;
Pointer.Visible := true;
Pointer.InflateMargins := true;
OnGetMarkText := serDatelineTop.OnGetMarkText;
ColorEachPoint := false;
Title := '';
Pointer.Style := psSmallDot;
SeriesColor := aChart.Color;
Marks.Visible := false;
ShowInLegend := false;
end;
serBlank.Pointer.Pen.Visible := false;
serBlank.AddXY(IncDay(FGraphSetting.LowTime, -1), 0, '', pnlScrollTopBase.Color);
serBlank.AddXY(IncDay(FGraphSetting.LowTime, -1), 10, '', pnlScrollTopBase.Color);
end;
if multiline then
begin
// do nothing for now
end;
if fixeddatevalue <> -BIG_NUMBER then
begin
if not serBlank.Active then
with serBlank do
begin
Active := true;
ParentChart := aChart;
XValues.DateTime := True;
Pointer.Visible := true;
Pointer.InflateMargins := true;
OnGetMarkText := serDatelineTop.OnGetMarkText;
ColorEachPoint := false;
Title := '';
Pointer.Style := psSmallDot;
SeriesColor := aChart.Color;
Marks.Visible := false;
ShowInLegend := false;
end;
FixedDates(afixeddate, afixeddate1);
serBlank.Pointer.Pen.Visible := false;
serBlank.AddXY(afixeddate, fixeddatevalue, '', aChart.Color);
serBlank.AddXY(afixeddate1, fixeddatevalue, '', aChart.Color);
end;
GetHorizAxis.ExactDateTime := True;
GetHorizAxis.Increment := DateTimeStep[dtOneMinute];
end;
end;
procedure TfrmGraphs.MakePointSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
var
i: integer;
value: double;
fmtime: string;
adatetime, adatetime1: TDateTime;
ser1: TPointSeries;
begin
aSerCnt := aSerCnt + 1;
ser1 := TPointSeries.Create(aChart);
with ser1 do
begin
ParentChart := aChart;
Title := Piece(aTitle, '^', 3);
OnGetMarkText := serDatelineTop.OnGetMarkText;
XValues.DateTime := True;
NextPointerStyle(ser1, aSerCnt);
Pointer.VertSize := 10;
Pointer.HorizSize := 2;
Identifier := aFileType;
Pointer.Visible := true;
GetData(aTitle);
ColorEachPoint := false;
SeriesColor := NextColor(aSerCnt);
Marks.BackColor := clInfoBk;
with lstTemp do
for i := 0 to lstTemp.Items.Count - 1 do
begin
fmtime := FMCorrectedDate(Piece(Items[i], '^', 3));
if IsFMDateTime(fmtime) then
begin
HighLow(fmtime, '', aChart, adatetime, adatetime1);
value := strtofloatdef(Piece(Items[i], '^', 5), -BIG_NUMBER);
if value = -BIG_NUMBER then
begin
value := aSerCnt;
TempCheck(Pieces(Items[i], '^', 1, 2), value);
end;
ser1.AddXY(adatetime, value, '', clTeeColor);
end;
end;
GetHorizAxis.ExactDateTime := True;
GetHorizAxis.Increment := DateTimeStep[dtOneMinute];
end;
end;
procedure TfrmGraphs.MakeBarSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
var
i: integer;
value: double;
fmtime: string;
adatetime, adatetime1: TDateTime;
afixeddate, afixeddate1: TDateTime;
ser1: TBarSeries;
serBlank: TPointSeries;
begin
aSerCnt := aSerCnt + 1;
ser1 := TBarSeries.Create(aChart);
serBlank := TPointSeries.Create(aChart);
with serBlank do
begin
Active := true;
ParentChart := aChart;
XValues.DateTime := True;
Pointer.Visible := true;
Pointer.InflateMargins := false;
ColorEachPoint := false;
Title := '';
Pointer.Style := psSmallDot;
OnGetMarkText := serDatelineTop.OnGetMarkText;
SeriesColor := aChart.Color;
Marks.BackColor := clInfoBk;
ShowInLegend := false;
end;
with ser1 do
begin
ParentChart := aChart;
Title := Piece(aTitle, '^', 3);
XValues.DateTime := True;
YOrigin := 0;
Identifier := aFileType;
Marks.Visible := false;
OnGetMarkText := serDatelineTop.OnGetMarkText;
CustomBarWidth := 7;
Marks.Style := smsLabel;
GetData(aTitle);
ColorEachPoint := false;
SeriesColor := NextColor(aSerCnt);
Marks.BackColor := clInfoBk;
NextPointerStyle(ser1, aSerCnt);
with lstTemp do
for i:= 0 to Items.Count - 1 do
begin
fmtime := FMCorrectedDate(Piece(Items[i], '^', 3));
if IsFMDateTime(fmtime) then
begin
HighLow(fmtime, '', aChart, adatetime, adatetime1);
value := 25 - (aSerCnt mod NUM_COLORS);
if FPrevEvent = copy(fmtime, 1, 10) then
if copy((FPrevEvent + '00'), 1, 12) = copy(fmtime, 1, 12) then // same time occurrence
begin
pnlInfo.Caption := TXT_WARNING_SAME_TIME;
pnlInfo.Color := COLOR_WARNING;
pnlInfo.Visible := true;
pnlHeader.Visible := true;
FWarning := true;
end;
if value <> -BIG_NUMBER then
ser1.AddXY(adatetime, value, '', clTeeColor);
FPrevEvent := copy(fmtime, 1, 10);
if i = 0 then
begin
serBlank.Pointer.Pen.Visible := false;
serBlank.AddXY(adatetime, 100, '', aChart.Color);
if FGraphSetting.FixedDateRange then
begin
FixedDates(afixeddate, afixeddate1);
serBlank.AddXY(afixeddate, 100, '', aChart.Color);
serBlank.AddXY(afixeddate1, 100, '', aChart.Color);
end;
end;
end;
end;
GetHorizAxis.ExactDateTime := True;
GetHorizAxis.Increment := DateTimeStep[dtOneMinute];
end;
end;
procedure TfrmGraphs.MakeManyGanttSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
var
i, value: integer;
fmtime, fmtime1: string;
adatetime, adatetime1: TDateTime;
afixeddate, afixeddate1: TDateTime;
gantt: TGanttSeries;
serBlank: TPointSeries;
begin
aSerCnt := aSerCnt + 1;
gantt := TGanttSeries.Create(aChart);
serBlank := TPointSeries.Create(aChart);
with serBlank do
begin
Active := true;
ParentChart := aChart;
XValues.DateTime := True;
Pointer.Visible := true;
Pointer.InflateMargins := false;
ColorEachPoint := false;
Title := '';
Pointer.Style := psSmallDot;
OnGetMarkText := serDatelineTop.OnGetMarkText;
SeriesColor := aChart.Color;
Marks.BackColor := clInfoBk;
ShowInLegend := false;
end;
with gantt do
begin
ParentChart := aChart;
Title := Piece(aTitle, '^', 3);
Marks.Style := smsLabel;
OnGetMarkText := serDatelineTop.OnGetMarkText;
if Piece(aTitle, '^', 1) = '55' then // make inpatient meds smaller to identify
Pointer.VertSize := RX_HEIGHT_IN
else if Piece(aTitle, '^', 1) = '55NVA' then // make nonva meds smaller to identify
Pointer.VertSize := RX_HEIGHT_NVA
else if Piece(aTitle, '^', 1) = '9999911' then // make problems smaller to identify
Pointer.VertSize := PROB_HEIGHT
else
Pointer.VertSize := RX_HEIGHT_OUT;
GetData(aTitle);
ColorEachPoint := false;
SeriesColor := NextColor(aSerCnt);
Identifier := aFileType;
Marks.BackColor := clInfoBk;
value := round(((aSerCnt mod NUM_COLORS) / NUM_COLORS) * 80) + 20 + aSerCnt;
if aFileType <> '9999911' then
if aChart <> chartDatelineTop then
if aChart <> chartDatelineBottom then
value := value - 26;
with lstTemp do
for i := 0 to lstTemp.Items.Count - 1 do
begin
fmtime := FMCorrectedDate(Piece(Items[i], '^', 3));
fmtime1 := FMCorrectedDate(Piece(Items[i], '^', 4));
if IsFMDateTime(fmtime) and IsFMDateTime(fmtime1) then
begin
HighLow(fmtime, fmtime1, aChart, adatetime, adatetime1);
AddGantt(adatetime, adatetime1, value, '');
if i = 0 then
begin
serBlank.Pointer.Pen.Visible := false;
serBlank.AddXY(adatetime, 100, '', aChart.Color);
if aFileType = '9999911' then
serBlank.AddXY(adatetime, 0, '', aChart.Color);
if FGraphSetting.FixedDateRange then
begin
FixedDates(afixeddate, afixeddate1);
serBlank.AddXY(afixeddate, 100, '', aChart.Color);
serBlank.AddXY(afixeddate1, 100, '', aChart.Color);
end;
end;
end;
end;
GetHorizAxis.ExactDateTime := True;
GetHorizAxis.Increment := DateTimeStep[dtOneMinute];
end;
end;
procedure TfrmGraphs.MakeVisitGanttSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
var
i: integer;
value: double;
fmtime, fmtime1: string;
adatetime, adatetime1: TDateTime;
afixeddate, afixeddate1: TDateTime;
gantt: TGanttSeries;
serBlank: TPointSeries;
begin
aSerCnt := aSerCnt + 1;
gantt := TGanttSeries.Create(aChart);
serBlank := TPointSeries.Create(aChart);
with serBlank do
begin
Active := true;
ParentChart := aChart;
XValues.DateTime := True;
Pointer.Visible := true;
Pointer.InflateMargins := false;
ColorEachPoint := false;
Title := '';
Pointer.Style := psSmallDot;
OnGetMarkText := serDatelineTop.OnGetMarkText;
SeriesColor := aChart.Color;
Marks.Visible := false;
ShowInLegend := false;
end;
with gantt do
begin
ParentChart := aChart;
Title := Piece(aTitle, '^', 3);
Marks.Style := smsLabel;
OnGetMarkText := serDatelineTop.OnGetMarkText;
if Piece(aTitle, '^', 1) = '405' then // make admit smaller to identify
Pointer.VertSize := NUM_COLORS + 3
else if Piece(aTitle, '^', 1) = '9999911' then // make problems smaller to identify
Pointer.VertSize := PROB_HEIGHT
else
Pointer.VertSize := NUM_COLORS + (aSerCnt mod NUM_COLORS) + 10;
GetData(aTitle);
ColorEachPoint := false;
SeriesColor := NextColor(aSerCnt);
Identifier := aFileType;
Marks.BackColor := clInfoBk;
value := aSerCnt div NUM_COLORS;
with lstTemp do
for i:= 0 to Items.Count - 1 do
begin
fmtime := FMCorrectedDate(Piece(Items[i], '^', 3));
fmtime1 := FMCorrectedDate(Piece(Items[i], '^', 4));
if IsFMDateTime(fmtime) and IsFMDateTime(fmtime1) then
begin
HighLow(fmtime, fmtime1, aChart, adatetime, adatetime1);
AddGantt(adatetime, adatetime1, value, '');
if i = 0 then
begin
serBlank.Pointer.Pen.Visible := false;
serBlank.AddXY(adatetime, 100, '', aChart.Color);
if FGraphSetting.FixedDateRange then
begin
FixedDates(afixeddate, afixeddate1);
serBlank.AddXY(afixeddate, 100, '', aChart.Color);
serBlank.AddXY(afixeddate1, 100, '', aChart.Color);
end;
end;
end;
end;
GetHorizAxis.ExactDateTime := True;
GetHorizAxis.Increment := DateTimeStep[dtOneMinute];
end;
end;
procedure TfrmGraphs.MakeWeightedGanttSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
var
i: integer;
value: double;
fmtime, fmtime1: string;
gantt: TGanttSeries;
adatetime, adatetime1: TDateTime;
begin
aSerCnt := aSerCnt + 1;
gantt := TGanttSeries.Create(aChart);
with gantt do
begin
ParentChart := aChart;
Title := Piece(aTitle, '^', 3);
Marks.Style := smsLabel;
OnGetMarkText := serDatelineTop.OnGetMarkText;
value := NUM_COLORS;
GetData(aTitle);
ColorEachPoint := false;
SeriesColor := NextColor(aSerCnt);
Identifier := aFileType;
Marks.BackColor := clInfoBk;
with lstTemp do
for i:= 0 to Items.Count - 1 do
begin
fmtime := FMCorrectedDate(Piece(Items[i], '^', 3));
fmtime1 := FMCorrectedDate(Piece(Items[i], '^', 4));
if IsFMDateTime(fmtime) and IsFMDateTime(fmtime1) then
begin
HighLow(fmtime, fmtime1, aChart, adatetime, adatetime1);
value := Vfactor(Piece(aTitle, '^', 3));
AddGantt(adatetime, adatetime1, 1, '');
value := value + (value / 2);
end;
end;
Pointer.VertSize := round(value);
GetHorizAxis.ExactDateTime := True;
GetHorizAxis.Increment := DateTimeStep[dtOneMinute];
end;
end;
procedure TfrmGraphs.MakeArrowSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
var
i: integer;
value: double;
fmtime, fmtime1: string;
arrows: TArrowSeries;
adatetime, adatetime1: TDateTime;
begin
aSerCnt := aSerCnt + 1;
arrows := TArrowSeries.Create(aChart);
with arrows do
begin
ParentChart := aChart;
Title := Piece(aTitle, '^', 3);
Clear;
ArrowWidth := 12;
ArrowHeight := 9;
StartXValues.DateTime := true;
EndXValues.DateTime := true;
Marks.Style := smsLabel;
OnGetMarkText := serDatelineTop.OnGetMarkText;
Pointer.Visible := false;
Pointer.VertSize := 17; //pnlTop.Height; //******* for meds
Pointer.HorizSize := 24;
Pointer.InflateMargins := true;
GetData(aTitle);
ColorEachPoint := false;
SeriesColor := NextColor(aSerCnt);
Identifier := aFileType;
Marks.BackColor := clInfoBk;
with lstTemp do
for i:= 0 to Items.Count - 1 do
begin
fmtime := FMCorrectedDate(Piece(Items[i], '^', 3));
fmtime1 := FMCorrectedDate(Piece(Items[i], '^', 4));
if IsFMDateTime(fmtime) and IsFMDateTime(fmtime1) then
begin
HighLow(fmtime, fmtime1, aChart, adatetime, adatetime1);
value := strtofloatdef(Piece(Items[i], '^', 5), -BIG_NUMBER);
if value = -BIG_NUMBER then
TempCheck(Pieces(Items[i], '^', 1, 2), value);
AddArrow(adatetime, value, adatetime1, value, '', SeriesColor);
end;
end;
GetHorizAxis.ExactDateTime := True;
GetHorizAxis.Increment := DateTimeStep[dtOneMinute];
end;
end;
procedure TfrmGraphs.MakeWeightedArrowSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
var
i: integer;
value: double;
fmtime, fmtime1: string;
adatetime, adatetime1: TDateTime;
arrows: TArrowSeries;
begin
aSerCnt := aSerCnt + 1;
arrows := TArrowSeries.Create(aChart);
with arrows do
begin
ParentChart := aChart;
Title := Piece(aTitle, '^', 3);
Clear;
ArrowWidth := 12;
ArrowHeight := 9;
StartXValues.DateTime := true;
EndXValues.DateTime := true;
Marks.Style := smsLabel;
OnGetMarkText := serDatelineTop.OnGetMarkText;
Pointer.Visible := false;
Pointer.VertSize := 17; //pnlTop.Height; //******* for meds
Pointer.HorizSize := 24;
Pointer.InflateMargins := true;
GetData(aTitle);
ColorEachPoint := false;
SeriesColor := NextColor(aSerCnt);
Identifier := aFileType;
Marks.BackColor := clInfoBk;
with lstTemp do
for i:= 0 to Items.Count - 1 do
begin
fmtime := FMCorrectedDate(Piece(Items[i], '^', 3));
fmtime1 := FMCorrectedDate(Piece(Items[i], '^', 4));
if IsFMDateTime(fmtime) and IsFMDateTime(fmtime1) then
begin
HighLow(fmtime, fmtime1, aChart, adatetime, adatetime1);
value := strtofloatdef(Piece(Items[i], '^', 5), -BIG_NUMBER);
if value = -BIG_NUMBER then
TempCheck(Pieces(Items[i], '^', 1, 2), value);
AddArrow(adatetime, value, adatetime1, value, '', SeriesColor);
end;
end;
value := Vfactor(Piece(aTitle, '^', 3));
if value < 1 then value := 1;
Pointer.HorizSize := round(value);
GetHorizAxis.ExactDateTime := True;
GetHorizAxis.Increment := DateTimeStep[dtOneMinute];
end;
end;
procedure TfrmGraphs.MakeGanttSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
var
i: integer;
value: double;
fmtime, fmtime1: string;
adatetime, adatetime1: TDateTime;
gantt: TGanttSeries;
begin
aSerCnt := aSerCnt + 1;
gantt := TGanttSeries.Create(aChart);
with gantt do
begin
ParentChart := aChart;
Title := Piece(aTitle, '^', 3);
Marks.Style := smsLabel;
OnGetMarkText := serDatelineTop.OnGetMarkText;
Pointer.VertSize := pnlTop.Height; //******* like vertical bars
GetData(aTitle);
ColorEachPoint := false;
SeriesColor := NextColor(aSerCnt);
Identifier := aFileType;
Marks.BackColor := clInfoBk;
with lstTemp do
for i:= 0 to Items.Count - 1 do
begin
fmtime := FMCorrectedDate(Piece(Items[i], '^', 3));
fmtime1 := FMCorrectedDate(Piece(Items[i], '^', 4));
if IsFMDateTime(fmtime) and IsFMDateTime(fmtime1) then
begin
HighLow(fmtime, fmtime1, aChart, adatetime, adatetime1);
value := strtofloatdef(Piece(Items[i], '^', 5), -BIG_NUMBER);
if value = -BIG_NUMBER then
TempCheck(Pieces(Items[i], '^', 1, 2), value);
AddGantt(adatetime, adatetime1, 1, '');
end;
end;
GetHorizAxis.ExactDateTime := True;
GetHorizAxis.Increment := DateTimeStep[dtOneMinute];
end;
end;
procedure TfrmGraphs.MakeAGanttSeries(aChart: TChart; aTitle, aFileType: string; var aSerCnt: integer);
var
i: integer;
value: double;
fmtime, fmtime1: string;
gantt: TGanttSeries;
adatetime, adatetime1: TDateTime;
begin
aSerCnt := aSerCnt + 1;
if aChart = chartDatelineTop then
gantt := serDatelineTop
else
gantt := serDatelineBottom;
with gantt do
begin
ParentChart := aChart;
Active := true;
Title := Piece(aTitle, '^', 3);
Marks.Style := smsLabel;
OnGetMarkText := serDatelineTop.OnGetMarkText;
//Pointer.VertSize := pnlTop.Height; //******* for meds
GetData(aTitle);
Identifier := aFileType;
ColorEachPoint := True;
with lstTemp do
for i:= 0 to Items.Count - 1 do
begin
fmtime := FMCorrectedDate(Piece(Items[i], '^', 3));
fmtime1 := FMCorrectedDate(Piece(Items[i], '^', 4));
if IsFMDateTime(fmtime) and IsFMDateTime(fmtime1) then
begin
HighLow(fmtime, fmtime1, aChart, adatetime, adatetime1);
value := strtofloatdef(Piece(Items[i], '^', 5), -BIG_NUMBER);
if value = -BIG_NUMBER then
TempCheck(Pieces(Items[i], '^', 1, 2), value);
AddGantt(adatetime, adatetime1, aSerCnt, '');
end;
end;
GetHorizAxis.ExactDateTime := True;
GetHorizAxis.Increment := DateTimeStep[dtOneMinute];
end;
end;
procedure TfrmGraphs.splGraphsMoved(Sender: TObject);
begin
if Sender = splGraphs then
chkDualViews.Checked := pnlBottom.Height > 3;
end;
function TfrmGraphs.ValueText(Sender: TCustomChart; Series: TChartSeries; ValueIndex: Integer): string;
var // type#^typename^formatdate^itemname^result^date
i, offset, SeriesNum, selnum: integer;
dateend, datestart: double;
astring, datecheck, filetype, fmdatecheck, item, otherdate, partitem: string;
resultdate, results, seriestitle, typeitem, typename, typenum: string;
begin
SeriesNum := -1;
for i := 0 to Sender.SeriesCount -1 do
if Sender.Series[i] = Series then
begin
SeriesNum := i;
filetype := Sender.Series[i].Identifier;
break;
end;
seriestitle := Sender.Series[SeriesNum].Title;
if (seriestitle = '') and (SeriesNum < (Series.Count - 1)) then
if Sender.Series[SeriesNum + 1].Title = '(non-numeric)' then
begin
SeriesNum := SeriesNum + 1;
seriestitle := '(non-numeric)';
end;
Result := '';
if seriestitle <> '(non-numeric)' then
begin
ItemCheck(lvwItemsTop, seriestitle, selnum, typeitem);
typeitem := UpperCase(typeitem);
end
else
begin
selnum := 1;
typeitem := '63';
offset := 2; // 2 series before
if (copy(Sender.Series[SeriesNum - offset].Title, 1, 4) = 'Ref ') then
if SeriesNum - 4 > -1 then
offset := 4 // if ref ranges
else if SeriesNum - 3 > -1 then
offset := 3; // if ref ranges
seriestitle := Sender.Series[SeriesNum - offset].Title + ' ' + seriestitle;
end;
if selnum < 0 then
begin
Result := '^^^' + seriestitle;
exit;
end;
typenum := Piece(typeitem, '^', 1);
if (typenum <> filetype) and (filetype <> '') then
begin
typenum := filetype;
typeitem := typenum + '^' + Piece(typeitem, '^', 2);
end;
if typenum = '55' then
begin
if Series is TGanttSeries then
if (Series as TGanttSeries).Pointer.VertSize <> RX_HEIGHT_IN then
if (Series as TGanttSeries).Pointer.VertSize <> RX_HEIGHT_NVA then
typenum := '52'
else typenum := '55NVA';
end
else if typenum = '55NVA' then
begin
if Series is TGanttSeries then
if (Series as TGanttSeries).Pointer.VertSize <> RX_HEIGHT_NVA then
if (Series as TGanttSeries).Pointer.VertSize <> RX_HEIGHT_OUT then
typenum := '55'
else typenum := '52';
end
else if typenum = '52' then
begin
if Series is TGanttSeries then
if (Series as TGanttSeries).Pointer.VertSize <> RX_HEIGHT_OUT then
if (Series as TGanttSeries).Pointer.VertSize <> RX_HEIGHT_NVA then
typenum := '55'
else typenum := '55NVA';
end;
typename := FileNameX(typenum);
if ValueIndex < 0 then
begin
Result := typenum + '^' + typename + '^^' + seriestitle;
exit;
end;
if Copy(typename, length(typename) - 2, 3) = 'ies' then
typename := Copy(typename, 1, length(typename) - 3) + 'y'
else if Copy(typename, length(typename), 1) = 's' then
typename := Copy(typename, 1, length(typename) - 1);
if (Series is TGanttSeries) then
begin
datestart := (Series as TGanttSeries).StartValues[ValueIndex];
dateend := (Series as TGanttSeries).EndValues[ValueIndex];
end
else
begin
datestart := Series.XValue[ValueIndex];
dateend := datestart;
end;
if datestart <> dateend then
begin
resultdate := FormatDateTime('mmm d, yyyy h:nn am/pm', datestart) +
' - ' + FormatDateTime('mmm d, yyyy h:nn am/pm', dateend);
otherdate := FormatDateTime('mm/dd/yy hh:nn', datestart) +
' - ' + FormatDateTime('mm/dd/yy hh:nn', dateend);
end
else
begin
resultdate := FormatDateTime('mmm d, yyyy h:nn am/pm', datestart);
otherdate := FormatDateTime('mm/dd/yy hh:nn', datestart);
end;
results := '';
if typenum = '63' then
begin
if Series is TLineSeries then
if (Series as TLineSeries).LinePen.Style = psDash then
exit; // serHigh or serLow
if Series is TPointSeries then
if (Series as TPointSeries).Pointer.Style = psSmallDot then
exit; // serBlank
if copy(seriestitle, length(seriestitle) - 12, length(seriestitle)) = '(non-numeric)' then
begin
seriestitle := copy(seriestitle, 1, length(seriestitle) - 13);
serDatelineTopGetMarkText(Sender.Series[SeriesNum], ValueIndex, results);
end
else
results := floattostr(Series.YValue[ValueIndex]);
end
else if typenum <> '120.5' then
begin
item := Piece(typeitem, '^', 2);
partitem := copy(item, 1, 4);
//if (partitem = 'M;A;') then //or (partitem = 'M;T;') then tb antibiotic on 1st piece
begin
fmdatecheck := floattostr(DateTimeToFMDateTime(Series.XValue[ValueIndex]));
for i := 0 to lstData.Items.Count - 1 do
begin
astring := lstData.Items[i];
if item = Piece(astring, '^', 2) then
begin
datecheck := Piece(astring, '^', 3);
if length(Piece(datecheck, '.', 2)) > 0 then
datecheck := Piece(datecheck, '.', 1) + '.' + copy(Piece(datecheck, '.', 2), 1, 4);
if datecheck = fmdatecheck then
begin
results := MixedCase(Piece(astring, '^', 5));
break;
end;
end;
end;
end;
end
else if typenum = '120.5' then
begin
if seriestitle = 'Blood Pressure' then
results := BPValue(Series.XValue[ValueIndex])
else
results := floattostr(Series.YValue[ValueIndex]);
end;
Result := typenum + ' ^' + typename + '^' + resultdate + '^' +
seriestitle + '^' + results + '^' + otherdate;
end;
procedure TfrmGraphs.chartBaseMouseMove(Sender: TObject; Shift: TShiftState; X, Y: Integer);
var
ClickedLegend, ClickedValue, j: Integer;
itemname: string;
NewPt: TPoint;
begin
//if not FGraphSetting.Hints then exit; //*****
FX := x;
FY := y;
FActiveGraph := (Sender as TChart);
NewPt := Mouse.CursorPos;
ClickedValue := -1;
ClickedLegend := -1;
if FHintWinActive then exit;
with FActiveGraph do
begin
for j := 0 to SeriesCount - 1 do
with (Series[j] as TChartSeries) do
begin
itemname := Series[j].Title;
if (Copy(itemname, 1, 7) <> 'Ref Low') and (Copy(itemname, 1, 8) <> 'Ref High') then
begin
ClickedValue := Clicked(FX, FY);
if ClickedValue > -1 then break;
ClickedLegend := Legend.Clicked(FX, FY);
if ClickedLegend > -1 then break;
end;
end;
if ClickedValue > -1 then
begin
FHintStop := false;
Screen.Cursor := crHandPoint;
timHintPause.Enabled := true;
end
else if ClickedLegend > -1 then
begin
timHintPause.Enabled := false;
InactivateHint;
Screen.Cursor := crHandPoint;
end
else
begin
timHintPause.Enabled := false;
InactivateHint;
Screen.Cursor := crDefault;
end;
end;
end;
procedure TfrmGraphs.timHintPauseTimer(Sender: TObject);
var
ClickedValue, j: Integer;
dttm, itemname, textvalue: string;
Rct: TRect;
begin
with FActiveGraph do
begin
ClickedValue := -1;
for j := 0 to SeriesCount - 1 do
with (Series[j] as TChartSeries) do
begin
if FHintStop then break;
ClickedValue := Clicked(FX, FY);
if ClickedValue > -1 then break;
end;
if FHintStop then // stop when clicked
begin
timHintPause.Enabled := false;
InactivateHint;
FHintStop := false;
exit;
end;
if (ClickedValue > -1) and ((FOnValue <> ClickedValue) or (FOnSeries <> j)) then
begin // on a value but not the same value or series
if FHintWinActive then
InactivateHint;
itemname := Series[j].Title;
if Copy(itemname, 1, 7)= 'Ref Low' then exit;
if Copy(itemname, 1, 8)= 'Ref High' then exit;
FOnSeries := j;
FOnValue := ClickedValue;
textvalue := ValueText(FActiveGraph, Series[j], ClickedValue);
dttm := Piece(textvalue, '^', 3);
//if copy(textvalue, length(textvalue) - 5, length(textvalue)) = ' 00:00' then
// dttm := Pieces(dttm, ' ', 1, 3);
textvalue := Piece(textvalue, '^', 2) + ' ' + dttm +
#13 + Piece(textvalue, '^', 4) + ' ' + Piece(textvalue, '^', 5);
Rct := FHintWin.CalcHintRect(Screen.Width, textvalue, nil);
OffsetRect(Rct, FX, FY + 20);
Rct.Right := Rct.Right + 3;
Rct.TopLeft := ClientToScreen(Rct.TopLeft);
Rct.BottomRight := ClientToScreen(Rct.BottomRight);
FHintWin.ActivateHint(Rct, textvalue);
FHintWinActive := true;
end
else if (ClickedValue = -1) and ((FOnValue <> BIG_NUMBER) and (FOnSeries <> BIG_NUMBER)) then
begin // not on a value anymore (used to be on a value and series)
FOnSeries := BIG_NUMBER;
FOnValue := BIG_NUMBER;
timHintPause.Enabled := false;
InactivateHint;
end;
end;
end;
procedure TfrmGraphs.InactivateHint;
begin
FHintWin.ReleaseHandle;
FHintWinActive := false;
end;
procedure TfrmGraphs.mnuPopGraphStayOnTopClick(Sender: TObject);
begin
mnuPopGraphStayOnTop.Checked := not mnuPopGraphStayOnTop.Checked;
if mnuPopGraphStayOnTop.Checked then
begin
MarkFormAsStayOnTop(Self, true);
FGraphSetting.StayOnTop := true;
end
else
begin
MarkFormAsStayOnTop(Self, false);
FGraphSetting.StayOnTop := false;
end;
end;
procedure TfrmGraphs.StayOnTop;
begin
with pnlMain.Parent do
if BorderWidth <> 1 then
begin
mnuPopGraphStayOnTop.Enabled :=false;
mnuPopGraphStayOnTop.Checked := false;
end
else
begin // only use on float Graph
mnuPopGraphStayOnTop.Enabled :=true;
mnuPopGraphStayOnTop.Checked := not FGraphSetting.StayOnTop;
mnuPopGraphStayOnTopClick(self);
end;
end;
procedure TfrmGraphs.HideDates(aChart: TChart);
var
hidedates: boolean;
begin
with aChart do // dateline charts always have dates
begin
if (aChart = chartDatelineTop) then
hidedates := false
else if (aChart = chartDatelineBottom) then
hidedates := false
else
hidedates := not FGraphSetting.Dates;
if hidedates then
begin
MarginBottom := 0;
BottomAxis.LabelsFont.Color := chartDatelineTop.Color;
BottomAxis.LabelsSize := 1;
LeftAxis.LabelsFont.Color := chartDatelineTop.LeftAxis.LabelsFont.Color;
end
else
begin
MarginBottom := chartDatelineTop.MarginBottom;
BottomAxis.LabelsFont.Color := chartDatelineTop.BottomAxis.LabelsFont.Color;
BottomAxis.LabelsSize := chartDatelineTop.BottomAxis.LabelsSize;
LeftAxis.LabelsFont.Color := chartDatelineTop.LeftAxis.LabelsFont.Color;
end;
end;
end;
procedure TfrmGraphs.mnuPopGraphZoomBackClick(Sender: TObject);
begin
FFirstClick := true;
with lstZoomHistory do
begin
Items.Delete(Count - 1);
if Count = 0 then mnuPopGraphResetClick(self)
else ZoomUpdate;
end;
end;
procedure TfrmGraphs.ZoomUpdate;
var
lastzoom: string;
BigTime, SmallTime: TDateTime;
begin
lastzoom := lstZoomHistory.Items[lstZoomHistory.Count - 1];
SmallTime := StrToFloat(Piece(lastzoom, '^', 1));
BigTime := StrToFloat(Piece(lastzoom, '^', 2));
ZoomTo(SmallTime, BigTime);
ZoomUpdateInfo(SmallTime, BigTime);
end;
procedure TfrmGraphs.ZoomUpdateInfo(SmallTime, BigTime: TDateTime);
begin
pnlInfo.Caption := TXT_ZOOMED;
pnlInfo.Color := COLOR_ZOOM;
pnlInfo.Caption := pnlInfo.Caption + FormatDateTime('mmm d, yyyy h:nn am/pm', SmallTime);
pnlInfo.Caption := pnlInfo.Caption + ' to ' + FormatDateTime('mmm d, yyyy h:nn am/pm', BigTime) + '.';
pnlInfo.Visible := true;
pnlHeader.Visible := true;
end;
procedure TfrmGraphs.ZoomTo(SmallTime, BigTime: TDateTime);
var
i: integer;
ChildControl: TControl;
begin
for i := 0 to scrlTop.ControlCount - 1 do
begin
ChildControl := scrlTop.Controls[i];
SizeDates((ChildControl as TChart), SmallTime, BigTime);
end;
SizeDates(chartDatelineTop, SmallTime, BigTime);
for i := 0 to scrlBottom.ControlCount - 1 do
begin
ChildControl := scrlBottom.Controls[i];
SizeDates((ChildControl as TChart), SmallTime, BigTime);
end;
SizeDates(chartDatelineBottom, SmallTime, BigTime);
end;
procedure TfrmGraphs.mnuPopGraphPrintClick(Sender: TObject);
var
topflag: boolean;
i, count: integer;
StrForFooter, StrForHeader, aTitle, aWarning, aDateRange: String;
aHeader: TStringList;
wrdApp, wrdDoc, wrdPrintDlg: Variant;
ChildControl: TControl;
begin
topflag := mnuPopGraphStayOnTop.Checked and mnuPopGraphStayOnTop.Enabled;
try
wrdApp := CreateOleObject('Word.Application');
except
raise Exception.Create('Cannot start MS Word!');
end;
Screen.Cursor := crDefault;
aTitle := 'CPRS Graphing';
aWarning := pnlInfo.Caption;
aDateRange := 'Date Range: ' + cboDateRange.Text + ' Selected Items from ' +
FormatDateTime('mm/dd/yy', FGraphSetting.LowTime) + ' to ' +
FormatDateTime('mm/dd/yy', FGraphSetting.HighTime);
aHeader := TStringList.Create;
CreatePatientHeader(aHeader, aTitle, aWarning, aDateRange);
StrForHeader := '';
for i := 0 to aHeader.Count -1 do
StrForHeader := StrForHeader + aHeader[i] + Chr(13);
StrForFooter := aTitle + ' - *** WORK COPY ONLY ***' + Chr(13);
wrdApp.Visible := False;
wrdApp.Documents.Add;
wrdDoc := wrdApp.Documents.Item(1);
wrdDoc := wrdDoc.Sections.Item(1);
wrdDoc := wrdDoc.Headers.Item(1).Range;
wrdDoc.Font.Name := 'Courier New';
wrdDoc.Font.Size := 9;
wrdDoc.Text := StrForHeader;
wrdDoc := wrdApp.Documents.Item(1);
wrdDoc := wrdDoc.Sections.Item(1);
wrdDoc := wrdDoc.Footers.Item(1);
wrdDoc.Range.Font.Name := 'Courier New';
wrdDoc.Range.Font.Size := 9;
wrdDoc.Range.Text := StrForFooter;
wrdDoc.PageNumbers.Add;
wrdDoc := wrdApp.Documents.Item(1);
wrdDoc.Range.InsertParagraphAfter;
for i := 0 to scrlTop.ControlCount - 1 do // goes from top to bottom
begin
ChildControl := scrlTop.Controls[i];
if (ChildControl as TChart).Visible then
begin
(ChildControl as TChart).CopyToClipboardBitmap;
wrdDoc.Range.InsertParagraphAfter;
wrdDoc.Paragraphs.Last.Range.Paste;
end;
end;
if (chartDatelineTop.SeriesCount > 0) and (not chkItemsTop.Checked) then
begin
chartDatelineTop.CopyToClipboardBitmap;
wrdDoc.Range.InsertParagraphAfter;
wrdDoc.Paragraphs.Last.Range.Paste;
end;
wrdDoc.Range.InsertParagraphAfter;
wrdDoc.Paragraphs.Last.Range.Text := ' ';
for i := 0 to scrlBottom.ControlCount - 1 do
begin
ChildControl := scrlBottom.Controls[i];
if (ChildControl as TChart).Visible then
begin
(ChildControl as TChart).CopyToClipboardBitmap;
wrdDoc.Range.InsertParagraphAfter;
wrdDoc.Paragraphs.Last.Range.Paste;
end;
end;
if (chartDatelineBottom.SeriesCount > 0) and (chkDualViews.Checked)
and (not chkItemsBottom.Checked) then
begin
chartDatelineBottom.CopyToClipboardBitmap;
wrdDoc.Range.InsertParagraphAfter;
wrdDoc.Paragraphs.Last.Range.Paste;
end;
wrdPrintDlg := wrdApp.Dialogs.item(wdDialogFilePrint);
Screen.Cursor := crDefault;
Application.ProcessMessages;
if topflag then
mnuPopGraphStayOnTopClick(self);
wrdPrintDlg.Show;
wrdApp.Visible := false;
Screen.Cursor := crHourGlass;
Application.ProcessMessages;
Sleep(5000);
count := 0;
while (wrdApp.Application.BackgroundPrintingStatus > 0) do
begin
Sleep(1000);
Application.ProcessMessages;
count := count + 1;
if count > 3 then break;
end;
wrdApp.DisplayAlerts := false;
wrdDoc.Close(false);
wrdApp.Quit;
wrdApp := Unassigned; // releases variant
aHeader.Free;
Application.ProcessMessages;
if topflag then
mnuPopGraphStayOnTopClick(self);
Screen.Cursor := crDefault;
end;
procedure TfrmGraphs.lvwItemsTopChange(Sender: TObject; Item: TListItem;
Change: TItemChange);
begin
if FArrowKeys and (lvwItemsTop.SelCount > 0) then
begin
if pnlItemsTopInfo.Tag <> 1 then
lvwItemsTopClick(self);
FArrowKeys := false;
end;
end;
procedure TfrmGraphs.lvwItemsBottomChange(Sender: TObject; Item: TListItem;
Change: TItemChange);
begin
if FArrowKeys and (lvwItemsBottom.SelCount > 0) then
begin
if pnlItemsBottomInfo.Tag <> 1 then
lvwItemsBottomClick(self);
FArrowKeys := false;
end;
end;
procedure TfrmGraphs.lvwItemsTopKeyDown(Sender: TObject; var Key: Word;
Shift: TShiftState);
begin
if Key in [VK_PRIOR, VK_NEXT, VK_UP, VK_DOWN] then
FArrowKeys := true;
end;
procedure TfrmGraphs.testcount1Click(Sender: TObject);
function boxcount(aListBox: TListBox): string;
var
i, ccnt: integer;
begin
Result := '';
ccnt := 0;
for i := 0 to aListBox.Items.Count - 1 do
ccnt := ccnt + length(aListBox.Items[i]);
Result := inttostr(aListBox.Items.Count) + ';' + inttostr(ccnt);
end;
var
i, lines, total: integer;
aString: string;
begin
lines := 0;
total := 0;
with pnlData do
for i:= 0 to pnlData.ControlCount - 1 do
if Controls[i] is TListBox then
begin
aString := boxcount(Controls[i] as TListBox);
lines := lines + strtointdef(Piece(aString, ';', 1), 0);
total := total + strtointdef(Piece(aString, ';', 2), 0);
end;
aString := boxcount(lstTypes) + '^' + boxcount(lstItems) + '^' + boxcount(lstData)
+ ' lines: ' + inttostr(lines) + ' total: ' + inttostr(total);
showmessage(aString);
end;
procedure TfrmGraphs.cboDateRangeDropDown(Sender: TObject);
begin
if (Top + Height) > (Screen.Height - 100) then
cboDateRange.DropDownCount := 3
else
cboDateRange.DropDownCount := 9;
end;
procedure TfrmGraphs.mnuPopGraphFixedClick(Sender: TObject);
begin
with FGraphSetting do FixedDateRange := not FixedDateRange;
ChangeStyle;
end;
//***************** these are used to fix dropdown when large fonts
procedure TfrmGraphs.cboViewsTopDropDown(Sender: TObject);
begin
cboViewsTop.Align := alNone;
end;
procedure TfrmGraphs.cboViewsTopDropDownClose(Sender: TObject);
begin
cboViewsTop.Align := alClient;
end;
procedure TfrmGraphs.cboViewsBottomDropDown(Sender: TObject);
begin
cboViewsBottom.Align := alNone;
end;
procedure TfrmGraphs.cboViewsBottomDropDownClose(Sender: TObject);
begin
cboViewsBottom.Align := alClient;
end;
//*********************
procedure TfrmGraphs.FormDestroy(Sender: TObject);
begin
SetSize;
end;
procedure TfrmGraphs.SetFontSize(FontSize: integer);
begin // for now, ignore changing chart font size
with chartDatelineTop do
begin
LeftAxis.LabelsFont.Size := 8;
BottomAxis.LabelsFont.Size := 8;
Foot.Font.Size := 8;
Legend.Font.Size := 8;
Title.Font.Size := 8;
end;
with chartDatelineBottom do
begin
LeftAxis.LabelsFont.Size := 8;
BottomAxis.LabelsFont.Size := 8;
Foot.Font.Size := 8;
Legend.Font.Size := 8;
Title.Font.Size := 8;
end;
end;
procedure TfrmGraphs.lvwItemsTopEnter(Sender: TObject);
begin
if lvwItemsTop.SelCount = 0 then
if lvwItemsTop.Items.Count > 0 then
lvwItemsTop.Items[0].Focused := true;
end;
procedure TfrmGraphs.chkItemsBottomEnter(Sender: TObject);
begin
if not chkDualViews.Checked then
if pnlFooter.Visible then
cboDateRange.SetFocus
else
SelectNext(ActiveControl as TWinControl, True, True);
end;
procedure TfrmGraphs.cboViewsBottomEnter(Sender: TObject);
begin
if not chkDualViews.Checked then
SelectNext(ActiveControl as TWinControl, True, True);
end;
procedure TfrmGraphs.lvwItemsBottomEnter(Sender: TObject);
begin
if lvwItemsBottom.SelCount = 0 then
if lvwItemsBottom.Items.Count > 0 then
lvwItemsBottom.Items[0].Focused := true;
if not chkDualViews.Checked then
SelectNext(ActiveControl as TWinControl, True, True);
end;
initialization
CoInitialize (nil);
end.