[613] | 1 | PXRRFDD ;ISL/PKR,ALB/Zoltan - PCE Frequency of Diagnosis report driver.;9/22/98
|
---|
| 2 | ;;1.0;PCE PATIENT CARE ENCOUNTER;**3,10,12,18,31,61**;Aug 12, 1996
|
---|
| 3 | MAIN ;
|
---|
| 4 | N PXRRFDJB,PXRRFDST,PXRRIOD,PXRROPT,PXRRQUE,PXRRXTMP
|
---|
| 5 | S PXRRXTMP=$$PXRRXTMP^PXRRWLD("PXRRFD")
|
---|
| 6 | S ^XTMP(PXRRXTMP,0)=$$FMADD^XLFDT(DT,7)_U_DT_U_"PXRR Frequency of Diagnosis"
|
---|
| 7 | ;
|
---|
| 8 | ;Establish the selection criteria.
|
---|
| 9 | FAC ;Get the facility list.
|
---|
| 10 | N NFAC,PXRRFAC,PXRRFACN
|
---|
| 11 | D FACILITY^PXRRLCSC
|
---|
| 12 | I $D(DTOUT)!$D(DUOUT) G EXIT
|
---|
| 13 | ;
|
---|
| 14 | DR ;Get the encounter date range.
|
---|
| 15 | N PXRRBDT,PXRREDT
|
---|
| 16 | D PDR^PXRRADUT(.PXRRBDT,.PXRREDT,"ENCOUNTER")
|
---|
| 17 | I $D(DTOUT) G EXIT
|
---|
| 18 | I $D(DUOUT) G FAC
|
---|
| 19 | ;
|
---|
| 20 | DIAG ;Get the diagnosis screening criteria.
|
---|
| 21 | N PXRRFDDC
|
---|
| 22 | D DIAGSC^PXRRFDSC
|
---|
| 23 | I $D(DTOUT) G EXIT
|
---|
| 24 | I $D(DUOUT) G DR
|
---|
| 25 | ;
|
---|
| 26 | EATT ;Get a list of encounter screening attributes.
|
---|
| 27 | N PXRRECAT
|
---|
| 28 | D ECAT^PXRRECSC
|
---|
| 29 | I $D(DTOUT) G EXIT
|
---|
| 30 | I $D(DUOUT) G DIAG
|
---|
| 31 | ;
|
---|
| 32 | ;Process the screening attributes
|
---|
| 33 | ;
|
---|
| 34 | SCAT ;Get the service categories.
|
---|
| 35 | N PXRRSCAT
|
---|
| 36 | I PXRRECAT["1" D
|
---|
| 37 | . D SCAT^PXRRECSC
|
---|
| 38 | E S PXRRSCAT="AI"
|
---|
| 39 | I $D(DTOUT) G EXIT
|
---|
| 40 | I $D(DUOUT) G EATT
|
---|
| 41 | ;
|
---|
| 42 | ETYPE ;Get the encounter types.
|
---|
| 43 | ;This section is commented out so it can be easily restored if encounter
|
---|
| 44 | ;types are used later. The part of ECAT^PXRRECSC relating to this should
|
---|
| 45 | ;also be restored.
|
---|
| 46 | ;N PXRRETYP
|
---|
| 47 | ;I PXRRECAT["2" D
|
---|
| 48 | ;. D ETYPE^PXRRECSC
|
---|
| 49 | ;I $D(DTOUT) G EXIT
|
---|
| 50 | ;I $D(DUOUT) G EATT
|
---|
| 51 | ;
|
---|
| 52 | LOC ;Get the locations.
|
---|
| 53 | N NCS,NHL,PXRRCS,PXRRLCHL,PXRRLCSC
|
---|
| 54 | I PXRRECAT["2" D
|
---|
| 55 | . D LOC^PXRRLCSC("Determine frequency of diagnosis for","HS")
|
---|
| 56 | I $D(DTOUT) G EXIT
|
---|
| 57 | I $D(DUOUT) G EATT
|
---|
| 58 | ;
|
---|
| 59 | PRV ;Get the provider list.
|
---|
| 60 | N NCL,NPL,PXRRPECL,PXRRPRPL,PXRRPRSC
|
---|
| 61 | I PXRRECAT["3" D
|
---|
| 62 | . D PRV^PXRRPRSC
|
---|
| 63 | I $D(DTOUT) G EXIT
|
---|
| 64 | I $D(DUOUT) G EATT
|
---|
| 65 | ;
|
---|
| 66 | DOB ;Get the patient age range.
|
---|
| 67 | N PXRRDOB,PXRRDOBE,PXRRDOBS,PXRRMAXA,PXRRMINA
|
---|
| 68 | I PXRRECAT["4" D
|
---|
| 69 | . S PXRRMINA=$$AGE^PXRRADUT("MINIMUM",1)
|
---|
| 70 | . I '$D(DTOUT)&'$D(DUOUT) D
|
---|
| 71 | .. S PXRRMAXA=$$AGE^PXRRADUT("MAXIMUM",0)
|
---|
| 72 | .;Convert the ages into dates of birth.
|
---|
| 73 | . I +$G(PXRRMAXA)>0 S PXRRDOBS=$$DOBFA^PXRRADUT(PXRRMAXA)
|
---|
| 74 | . I +$G(PXRRMINA)>0 S PXRRDOBE=$$DOBFA^PXRRADUT(PXRRMINA)
|
---|
| 75 | . I ($D(PXRRDOBS))!($D(PXRRDOBE)) S PXRRDOB=1
|
---|
| 76 | I $D(DTOUT) G EXIT
|
---|
| 77 | I $D(DUOUT) G EATT
|
---|
| 78 | ;
|
---|
| 79 | RACE ;Get the patient race.
|
---|
| 80 | N NRACE,PXRRRACE
|
---|
| 81 | I PXRRECAT["5" D
|
---|
| 82 | . D RACE^PXRRFDSC
|
---|
| 83 | I $D(DTOUT) G EXIT
|
---|
| 84 | I $D(DUOUT) G EATT
|
---|
| 85 | ;
|
---|
| 86 | PSEX ;Get the patient sex.
|
---|
| 87 | N PXRRSEX
|
---|
| 88 | I PXRRECAT["6" D
|
---|
| 89 | . D SEX^PXRRFDSC
|
---|
| 90 | I $D(DTOUT) G EXIT
|
---|
| 91 | I $D(DUOUT) G EATT
|
---|
| 92 | ;
|
---|
| 93 | MAX ;Get the maximum number of diagnosis counts to include in the report.
|
---|
| 94 | N PXRRDMAX
|
---|
| 95 | D DMAX^PXRRFDSC
|
---|
| 96 | I $D(DTOUT) G EXIT
|
---|
| 97 | I $D(DUOUT) G EATT
|
---|
| 98 | ;
|
---|
| 99 | ;Determine whether the report should be queued.
|
---|
| 100 | S %ZIS="QM"
|
---|
| 101 | W !
|
---|
| 102 | D ^%ZIS
|
---|
| 103 | I POP G EXIT
|
---|
| 104 | S PXRRIOD=ION_";"_IOST_";"_IOM_";"_IOSL
|
---|
| 105 | S PXRRQUE=$G(IO("Q"))
|
---|
| 106 | ;
|
---|
| 107 | I PXRRQUE D
|
---|
| 108 | .;Queue the report.
|
---|
| 109 | . N DESC,IODEV,ROUTINE
|
---|
| 110 | . S DESC="Frequency of Diagnosis Report - sort encounters"
|
---|
| 111 | . S IODEV=""
|
---|
| 112 | . S ROUTINE="SORT^PXRRFDSE"
|
---|
| 113 | . S ^XTMP(PXRRXTMP,"SORTEZTSK")=$$QUE^PXRRQUE(DESC,IODEV,ROUTINE,"SAVE^PXRRFDD")
|
---|
| 114 | .;
|
---|
| 115 | . S DESC="Frequency of Diagnosis Report - sort diagnosis data"
|
---|
| 116 | . S IODEV=""
|
---|
| 117 | . S ROUTINE="SORT^PXRRFDSD"
|
---|
| 118 | . S ZTDTH="@"
|
---|
| 119 | . S ^XTMP(PXRRXTMP,"SORTDZTSK")=$$QUE^PXRRQUE(DESC,IODEV,ROUTINE,"SAVE^PXRRFDD")
|
---|
| 120 | .;
|
---|
| 121 | . S DESC="Frequency of diagnosis report - print"
|
---|
| 122 | . S IODEV=PXRRIOD
|
---|
| 123 | . S ROUTINE="PXRRFDP"
|
---|
| 124 | . S ZTDTH="@"
|
---|
| 125 | . S ^XTMP(PXRRXTMP,"PRZTSK")=$$QUE^PXRRQUE(DESC,IODEV,ROUTINE,"SAVE^PXRRFDD")
|
---|
| 126 | E D SORT^PXRRFDSE
|
---|
| 127 | ;
|
---|
| 128 | Q
|
---|
| 129 | ;
|
---|
| 130 | ;=======================================================================
|
---|
| 131 | EXIT ;
|
---|
| 132 | D EXIT^PXRRGUT
|
---|
| 133 | Q
|
---|
| 134 | ;
|
---|
| 135 | ;=======================================================================
|
---|
| 136 | SAVE ;Save the variables.
|
---|
| 137 | S ZTSAVE("PXRRBDT")="",ZTSAVE("PXRREDT")=""
|
---|
| 138 | S ZTSAVE("PXRRDOB")=""
|
---|
| 139 | S ZTSAVE("PXRRDOBE")=""
|
---|
| 140 | S ZTSAVE("PXRRDOBS")=""
|
---|
| 141 | S ZTSAVE("PXRRCS(")="",ZTSAVE("NCS")=""
|
---|
| 142 | S ZTSAVE("PXRRDMAX")=""
|
---|
| 143 | S ZTSAVE("PXRRECAT")=""
|
---|
| 144 | S ZTSAVE("PXRRETYP")=""
|
---|
| 145 | S ZTSAVE("PXRRFAC(")="",ZTSAVE("NFAC")=""
|
---|
| 146 | S ZTSAVE("PXRRFACN(")=""
|
---|
| 147 | S ZTSAVE("PXRRFDDC")=""
|
---|
| 148 | S ZTSAVE("PXRRIOD")=""
|
---|
| 149 | S ZTSAVE("PXRRLCHL(")="",ZTSAVE("NHL")=""
|
---|
| 150 | S ZTSAVE("PXRRLCSC")=""
|
---|
| 151 | S ZTSAVE("PXRRMAXA")=""
|
---|
| 152 | S ZTSAVE("PXRRMINA")=""
|
---|
| 153 | S ZTSAVE("PXRRPECL(")="",ZTSAVE("NCL")=""
|
---|
| 154 | S ZTSAVE("PXRRPRPL(")="",ZTSAVE("NPL")=""
|
---|
| 155 | S ZTSAVE("PXRRPRSC")=""
|
---|
| 156 | S ZTSAVE("PXRRQUE")=""
|
---|
| 157 | S ZTSAVE("PXRRSCAT")=""
|
---|
| 158 | S ZTSAVE("PXRRRACE(")="",ZTSAVE("NRACE")=""
|
---|
| 159 | S ZTSAVE("PXRRSEX")=""
|
---|
| 160 | S ZTSAVE("PXRRXTMP")=""
|
---|
| 161 | Q
|
---|