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

PXRRADUT.m

Go to the documentation of this file.
  1. PXRRADUT ;ISL/PKR - Age and date utilities for PCE reports. ;6/26/97
  1. ;;1.0;PCE PATIENT CARE ENCOUNTER;**10,18**;Aug 12, 1996
  1. ;
  1. ;=======================================================================
  1. AGE(TYPE,NEWLINE) ;Get a patient age.
  1. N X,Y
  1. K DIRUT,DTOUT,DUOUT
  1. S DIR(0)="NO"
  1. S DIR("A")="Enter "_TYPE_" AGE"
  1. S DIR("?")="Enter an age in years"
  1. S DIR("??")=U_"D AGEHELP^PXRRADUT(TYPE)"
  1. I NEWLINE W !
  1. D ^DIR K DIR
  1. I $D(DIROUT) S DTOUT=1
  1. I $D(DTOUT)!($D(DUOUT)) Q -1
  1. Q Y
  1. ;
  1. ;
  1. AGEHELP(TYPE) ;Write the age selection help.
  1. W !!,"This is the ",TYPE," patient age for selecting encounters."
  1. Q
  1. ;
  1. ;=======================================================================
  1. BDHELP(HTEXT,TYPE) ;Write the beginning date help.
  1. I $D(HTEXT) D HELP^PXRRADUT(.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^PXRRADUT(.BDHTEXT)
  1. Q
  1. ;
  1. ;=======================================================================
  1. DOBFA(AGE) ;Given an age in years return the corresponding date of birth.
  1. N DOB
  1. I (AGE=0)!(AGE="") Q 0
  1. S DOB=DT-(AGE*10000)
  1. Q DOB
  1. ;
  1. ;=======================================================================
  1. EDHELP(HTEXT,TYPE) ;Write the ending date help.
  1. I $D(HTEXT) D HELP^PXRRADUT(.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^PXRRADUT(.EDHTEXT)
  1. Q
  1. ;
  1. ;=======================================================================
  1. FDR(BDATE,EDATE,TYPE,BHTEXT,EHTEXT) ;Get a future date range.
  1. FBDATE ;Select the beginning date.
  1. N X,Y
  1. K DIROUT,DIRUT,DTOUT,DUOUT
  1. S DIR(0)="DA^"_DT_"::EFTX"
  1. S DIR("A")="Enter "_TYPE_" BEGINNING DATE: "
  1. S DIR("B")=$$FMTE^XLFDT($$DT^XLFDT,"D")
  1. S DIR("?")="This must be a future date. For detailed help type ??"
  1. S DIR("??")=U_"D BDHELP^PXRRADUT(.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: "
  1. S DIR("?")="This must be a future date and not before "_$$FMTE^XLFDT(BDATE,"D")_". For detailed help type ??"
  1. S DIR("??")=U_"D EDHELP^PXRRADUT(.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 $E(Y,6,7)="00" W $C(7)," ?? Enter exact date" G FEDATE
  1. K DIROUT,DIRUT,DTOUT,DUOUT
  1. Q
  1. ;
  1. ;=======================================================================
  1. GDR(BDATE,EDATE,TYPE,BHTEXT,EHTEXT) ;Get a general date range.
  1. GBDATE ;Select the beginning date.
  1. N X,Y
  1. K DIROUT,DIRUT,DTOUT,DUOUT
  1. S DIR(0)="DA^::ETX"
  1. S DIR("A")="Enter "_TYPE_" BEGINNING DATE: "
  1. S DIR("?")="This must be a date. For detailed help type ??"
  1. S DIR("??")=U_"D BDHELP^PXRRADUT(.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 GBDATE
  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("?")="This must be a date and not before "_$$FMTE^XLFDT(BDATE,"D")_". For detailed help type ??"
  1. S DIR("??")=U_"D EDHELP^PXRRADUT(.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. ;=======================================================================
  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. D HELP^%DTC
  1. Q
  1. ;
  1. ;=======================================================================
  1. PDR(BDATE,EDATE,TYPE,BHTEXT,EXTEXT) ;Get a past date range.
  1. PBDATE ;Select the beginning date.
  1. N X,Y
  1. K DIROUT,DIRUT,DTOUT,DUOUT
  1. S DIR(0)="D^:"_DT_":EPTX"
  1. S DIR("A")="Enter "_TYPE_" BEGINNING DATE"
  1. S DIR("?")="This must be a past date. For detailed help type ??"
  1. S DIR("??")=U_"D BDHELP^PXRRADUT(.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 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("?")="This must be a past date, but not before "_$$FMTE^XLFDT(BDATE,"D")_". For detailed help type ??"
  1. S DIR("??")=U_"D EDHELP^PXRRADUT(.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 $E(Y,6,7)="00" W $C(7)," ?? Enter exact date" G PEDATE
  1. K DIROUT,DIRUT,DTOUT,DUOUT
  1. Q
  1. ;