Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: PXRMXDUT

PXRMXDUT.m

Go to the documentation of this file.
  1. PXRMXDUT ; SLC/PJH - Date utilities for reminder reports. ;05/05/2006
  1. ;;2.0;CLINICAL REMINDERS;**4**;Feb 04, 2005;Build 21
  1. ;
  1. BDHELP(HTEXT,TYPE) ;Write the beginning date help.
  1. I $D(HTEXT) D HELP(.HTEXT)
  1. I '$D(HTEXT) D
  1. . N BDHTEXT
  1. . S BDHTEXT(1)="This is the beginning date for "_TYPE_" to be included in the creation of"
  1. . S BDHTEXT(2)="this report."
  1. . D HELP^PXRMXDUT(.BDHTEXT)
  1. Q
  1. ;
  1. EDHELP(HTEXT,TYPE) ;Write the ending date help.
  1. I $D(HTEXT) D HELP(.HTEXT)
  1. I '$D(HTEXT) D
  1. . N EDHTEXT
  1. . S EDHTEXT(1)="This is the ending date for "_TYPE_" to be included in the creation"
  1. . S EDHTEXT(2)="of this report."
  1. . D HELP^PXRMXDUT(.EDHTEXT)
  1. Q
  1. ;
  1. SDHELP(HTEXT) ;Write the single date help.
  1. I $D(HTEXT) D HELP(.HTEXT)
  1. I '$D(HTEXT) D
  1. . N SDHTEXT
  1. . S SDHTEXT(1)="This is the date of reminder evaluation for the report"
  1. . D HELP^PXRMXDUT(.SDHTEXT)
  1. Q
  1. ;
  1. FDR(BDATE,EDATE,TYPE,BHTEXT,EHTEXT) ;Get a future date range.
  1. FBDATE ;Select the beginning date.
  1. N X,Y,DIR
  1. K DIROUT,DIRUT,DTOUT,DUOUT
  1. S DIR(0)="DA^"_DT_"::EFTX"
  1. S DIR("A")="Enter "_TYPE_" BEGINNING DATE AND TIME: "
  1. S DIR("B")=$$FMTE^XLFDT($$DT^XLFDT,"D")
  1. S DIR("PRE")="S X=$$DCHECK^PXRMDATE(X) K:X=-1 X"
  1. S DIR("?")="This must be a future date. For detailed help type ??"
  1. S DIR("??")=U_"D BDHELP^PXRMXDUT(.BHTEXT,TYPE)"
  1. W !
  1. D ^DIR K DIR
  1. I $D(DIROUT) S DTOUT=1
  1. I $D(DTOUT)!($D(DUOUT)) Q
  1. S BDATE=Y
  1. I $E(Y,6,7)="00" W $C(7)," ?? Enter exact date" G FBDATE
  1. ;
  1. FEDATE ;Select the ending date.
  1. S DIR(0)="DA^"_BDATE_"::ETFX"
  1. S DIR("A")="Enter "_TYPE_" ENDING DATE AND TIME: "
  1. S DIR("PRE")="S X=$$DCHECK^PXRMDATE(X) K:X=-1 X"
  1. S DIR("?")="This must be a future date and not before "_$$FMTE^XLFDT(BDATE,"P")_". For detailed help type ??"
  1. S DIR("??")=U_"D EDHELP^PXRMXDUT(.EHTEXT,TYPE)"
  1. D ^DIR K DIR
  1. I $D(DIROUT) S DTOUT=1
  1. I $D(DTOUT) Q
  1. I $D(DUOUT) G FBDATE
  1. S EDATE=Y
  1. I EDATE<DT W !,"This must be a past date. For detailed help type ??" G FEDATE
  1. I EDATE<BDATE W !,"The ending date cannot be before the beginning date" G FEDATE
  1. I $E(Y,6,7)="00" W $C(7)," ?? Enter exact date" G FEDATE
  1. K DIROUT,DIRUT,DTOUT,DUOUT
  1. Q
  1. ;
  1. GDR(BDATE,EDATE,TYPE,BHTEXT,EHTEXT) ;Get a general date range.
  1. GBDATE ;Select the beginning date.
  1. N X,Y,DIR
  1. K DIROUT,DIRUT,DTOUT,DUOUT
  1. S DIR(0)="DA^::ETX"
  1. S DIR("A")="Enter "_TYPE_" BEGINNING DATE: "
  1. S DIR("PRE")="S X=$$DCHECK^PXRMDATE(X) K:X=-1 X"
  1. S DIR("?")="This must be a date. For detailed help type ??"
  1. S DIR("??")=U_"D BDHELP^PXRMXDUT(.BHTEXT,TYPE)"
  1. W !
  1. D ^DIR K DIR
  1. I $D(DIROUT) S DTOUT=1
  1. I $D(DTOUT)!($D(DUOUT)) Q
  1. S BDATE=Y
  1. I BDATE<DT W !,"This must be a past date. For detailed help type ??" G FBDATE
  1. ;
  1. GEDATE ;Select the ending date.
  1. S DIR(0)="DA^"_BDATE_"::ETX"
  1. S DIR("A")="Enter "_TYPE_" ENDING DATE: "
  1. S DIR("PRE")="S X=$$DCHECK^PXRMDATE(X) K:X=-1 X"
  1. S DIR("?")="This must be a date and not before "_$$FMTE^XLFDT(BDATE,"D")_". For detailed help type ??"
  1. S DIR("??")=U_"D EDHELP^PXRMXDUT(.EHTEXT,TYPE)"
  1. D ^DIR K DIR
  1. I $D(DIROUT) S DTOUT=1
  1. I $D(DTOUT) Q
  1. I $D(DUOUT) G GBDATE
  1. S EDATE=Y
  1. I $E(Y,6,7)="00" W $C(7)," ?? Enter exact date" G GEDATE
  1. K DIROUT,DIRUT,DTOUT,DUOUT
  1. Q
  1. ;
  1. HELP(HTEXT) ;General help text routine. Write out the text in the HTEXT
  1. ;array.
  1. N DIWF,DIWL,DIWR,IC
  1. S DIWF="C70",DIWL=0,DIWR=70
  1. K ^UTILITY($J,"W")
  1. S IC=""
  1. F S IC=$O(HTEXT(IC)) Q:IC="" D
  1. . S X=HTEXT(IC)
  1. . D ^DIWP
  1. W !
  1. S IC=0
  1. F S IC=$O(^UTILITY($J,"W",0,IC)) Q:IC="" D
  1. . W !,^UTILITY($J,"W",0,IC,0)
  1. K ^UTILITY($J,"W")
  1. W !
  1. N %DT,MODE
  1. S MODE=$G(TYPE),%DT="F",%DT(0)=DT
  1. I (MODE="ADMISSION")!(MODE="ENCOUNTER") S %DT="P",%DT(0)=-DT
  1. D HELP^%DTC
  1. Q
  1. ;
  1. PDR(BDATE,EDATE,TYPE,BHTEXT,EXTEXT) ;Get a past date range.
  1. PBDATE ;Select the beginning date.
  1. N X,Y,DIR
  1. K DIROUT,DIRUT,DTOUT,DUOUT
  1. S DIR(0)="D^:"_DT_":EPTX"
  1. S DIR("A")="Enter "_TYPE_" BEGINNING DATE"
  1. S DIR("PRE")="S X=$$DCHECK^PXRMDATE(X) K:X=-1 X"
  1. S DIR("?")="This must be a past date. For detailed help type ??"
  1. S DIR("??")=U_"D BDHELP^PXRMXDUT(.BHTEXT,TYPE)"
  1. W !
  1. D ^DIR K DIR
  1. I $D(DIROUT) S DTOUT=1
  1. I $D(DTOUT)!($D(DUOUT)) Q
  1. S BDATE=Y
  1. I $P(BDATE,".")>DT W !,"This must be a past date. For detailed help type ??" G PBDATE
  1. I $E(Y,6,7)="00" W $C(7)," ?? Enter exact date" G PBDATE
  1. ;
  1. PEDATE ;Select the ending date.
  1. S DIR(0)="DA^"_BDATE_":"_DT_":EPTX"
  1. S DIR("A")="Enter "_TYPE_" ENDING DATE: "
  1. S DIR("PRE")="S X=$$DCHECK^PXRMDATE(X) K:X=-1 X"
  1. S DIR("?")="This must be a past date, but not before "_$$FMTE^XLFDT(BDATE,"D")_". For detailed help type ??"
  1. S DIR("??")=U_"D EDHELP^PXRMXDUT(.EHTEXT,TYPE)"
  1. D ^DIR K DIR
  1. I $D(DIROUT) S DTOUT=1
  1. I $D(DTOUT) Q
  1. I $D(DUOUT) G PBDATE
  1. S EDATE=Y
  1. I $P(EDATE,".")>DT W !,"This must be a past date. For detailed help type ??" G PEDATE
  1. I $E(Y,6,7)="00" W $C(7)," ?? Enter exact date" G PEDATE
  1. I EDATE<BDATE W !,"The ending date cannot be less then the beginning date." G PEDATE
  1. K DIROUT,DIRUT,DTOUT,DUOUT
  1. Q
  1. ;
  1. SDR(SDATE,BHTEXT,EHTEXT) ;Get a date.
  1. SBDATE ;Select the date.
  1. N X,Y,DIR
  1. K DIROUT,DIRUT,DTOUT,DUOUT
  1. S DIR(0)="DA^::ETX"
  1. S DIR("A")="Enter EFFECTIVE DUE DATE: "
  1. S DIR("B")=$$FMTE^XLFDT($$DT^XLFDT,"D")
  1. S DIR("PRE")="S X=$$DCHECK^PXRMDATE(X) K:X=-1 X"
  1. S DIR("?")="Enter date for reminder evaluation. For detailed help type ??"
  1. S DIR("??")=U_"D SDHELP^PXRMXDUT(.BHTEXT)"
  1. W !
  1. D ^DIR K DIR
  1. I $D(DIROUT) S DTOUT=1
  1. I $D(DTOUT)!($D(DUOUT)) Q
  1. I $E(Y,6,7)="00" W $C(7)," ?? Enter exact date" G SBDATE
  1. S SDATE=Y
  1. K DIROUT,DIRUT,DTOUT,DUOUT
  1. Q
  1. ;