| 1 | PRCOER1 ;WISC/DJM-EDI REPORTS USING LIST MANAGER ; [8/31/98 2:26pm] | 
|---|
| 2 | V ;;5.1;IFCAP;;Oct 20, 2000 | 
|---|
| 3 | ;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
| 4 | ; | 
|---|
| 5 | REPORTS ;  COME HERE TO ENTER THE REPORTS GENERATOR. | 
|---|
| 6 | ; | 
|---|
| 7 | N DIR,X,Y,LIST,Q1,Q2,PRCA,PRCB,PRCSA,I,PRCPOS,PRCLST,PRCBLST | 
|---|
| 8 | N POSI,POS,PRCC,%DT,DTOUT,START,END,FIRST,LAST,A | 
|---|
| 9 | D CLEAR^VALM1 | 
|---|
| 10 | ; | 
|---|
| 11 | R0 S LIST="" | 
|---|
| 12 | D LF | 
|---|
| 13 | S DIR("A")="Select PHA, RFQ or All: " | 
|---|
| 14 | S DIR("?")="^D WRONG^PRCOER1()" | 
|---|
| 15 | S DIR(0)="FAO^1:30" | 
|---|
| 16 | D ^DIR K DIR | 
|---|
| 17 | G R4:$D(DUOUT),R4:$D(DTOUT) | 
|---|
| 18 | I X="" D  G R4:X["^",R0 | 
|---|
| 19 | . D LF | 
|---|
| 20 | . D PAUSE | 
|---|
| 21 | . D LF | 
|---|
| 22 | I X["-" G R2 | 
|---|
| 23 | I X["," G R3 | 
|---|
| 24 | I $L(X)>3 D WRONG(X) D PAUSE G R4:X["^",R0 | 
|---|
| 25 | ; | 
|---|
| 26 | R1 ; IS THIS ONE OF THE CORRECT INPUTS? | 
|---|
| 27 | S Y="" | 
|---|
| 28 | D CHECK(X,.Y) | 
|---|
| 29 | I Y>3,Y<7 D WRONG(X),PAUSE G R0 | 
|---|
| 30 | I Y>0 S LIST=Y_"," G DATE | 
|---|
| 31 | D WRONG(X) | 
|---|
| 32 | D PAUSE | 
|---|
| 33 | G R4:X["^",R0 | 
|---|
| 34 | ; | 
|---|
| 35 | R2 K Q1,Q2 | 
|---|
| 36 | S PRCA=$P(X,"-",1) | 
|---|
| 37 | S PRCB=$P(X,"-",2) | 
|---|
| 38 | I PRCA["," D  G:LIST["0" P2 G R2B | 
|---|
| 39 | .  S PRCSA=X | 
|---|
| 40 | .  S X=PRCA | 
|---|
| 41 | .  D P3 | 
|---|
| 42 | .  S X=PRCSA | 
|---|
| 43 | .  I LIST["0" Q | 
|---|
| 44 | .  S I=1 | 
|---|
| 45 | .  F  S:$P(LIST,",",I)]"" PRCPOS=$P(LIST,",",I) Q:$P(LIST,",",I)=""  S I=I+1 | 
|---|
| 46 | .  S Q1=$E(LIST,PRCPOS) | 
|---|
| 47 | .  S PRCLST=LIST | 
|---|
| 48 | .  Q | 
|---|
| 49 | S Y="" | 
|---|
| 50 | D CHECK(PRCA,.Y) | 
|---|
| 51 | I Y>3,Y<7 D WRONG(X),PAUSE G R0 | 
|---|
| 52 | I $G(Q1)="" S PRCLST=Y | 
|---|
| 53 | S Q1=Y | 
|---|
| 54 | R2B S PRCBLST=PRCB | 
|---|
| 55 | I PRCB["," D  G:LIST["0" P2 G R2C | 
|---|
| 56 | .  S PRCSA=X | 
|---|
| 57 | .  S X=PRCB | 
|---|
| 58 | .  D P3 | 
|---|
| 59 | .  S X=PRCSA | 
|---|
| 60 | .  I LIST["0" Q | 
|---|
| 61 | .  S Q2=$P(LIST,",") | 
|---|
| 62 | .  S PRCBLST=LIST | 
|---|
| 63 | .  Q | 
|---|
| 64 | D CHECK(PRCB,.Y) | 
|---|
| 65 | I Y>3,Y<7 D WRONG(X),PAUSE G R0 | 
|---|
| 66 | I $G(Q2)="" S PRCBLST=Y | 
|---|
| 67 | S Q2=Y | 
|---|
| 68 | I Q1=0 D WRONG(PRCA) G P2 | 
|---|
| 69 | I Q2=0 D WRONG(PRCB) G P2 | 
|---|
| 70 | ; | 
|---|
| 71 | R2C I $G(PRCLST)[7!($G(PRCBLST)[7) S LIST=7_"," G DATE | 
|---|
| 72 | S LIST="" | 
|---|
| 73 | I Q1>Q2 F I=Q2:1:Q1 S LIST=LIST_I_"," | 
|---|
| 74 | I Q2>Q1 F I=Q1:1:Q2 S LIST=LIST_I_"," | 
|---|
| 75 | S:$G(PRCLST)]"" LIST=LIST_PRCLST | 
|---|
| 76 | S:$G(PRCBLST)]"" LIST=LIST_PRCBLST | 
|---|
| 77 | F I=1:1 S POSI=$P(LIST,",",I) Q:POSI=""  S POS(POSI)=POSI | 
|---|
| 78 | S LIST="" | 
|---|
| 79 | F I=1:1:3 S:$G(POS(I))]"" LIST=LIST_POS(I)_"," | 
|---|
| 80 | K POS | 
|---|
| 81 | G DATE | 
|---|
| 82 | ; | 
|---|
| 83 | P2 D PAUSE | 
|---|
| 84 | G R4:X["^",R0 | 
|---|
| 85 | P3 S LIST="" | 
|---|
| 86 | F I=1:1 S PRCC=$P(X,",",I) Q:PRCC=""  D  Q:"70"[LIST | 
|---|
| 87 | .  S Y="" | 
|---|
| 88 | .  D CHECK(PRCC,.Y) | 
|---|
| 89 | .  I Y>3,Y<7 D WRONG(X) S LIST=0 Q | 
|---|
| 90 | .  I Y=0 D WRONG(PRCC) S LIST=0 Q | 
|---|
| 91 | .  I Y=7 S LIST=7_"," Q | 
|---|
| 92 | .  S LIST=LIST_Y_"," | 
|---|
| 93 | .  Q | 
|---|
| 94 | Q | 
|---|
| 95 | ; | 
|---|
| 96 | R3 D P3 | 
|---|
| 97 | I LIST'["0" G DATE | 
|---|
| 98 | D PAUSE | 
|---|
| 99 | G R4:X["^",R0 | 
|---|
| 100 | ; | 
|---|
| 101 | R4 S VALMBCK="R" | 
|---|
| 102 | S VALMBG=1 | 
|---|
| 103 | Q | 
|---|
| 104 | ; | 
|---|
| 105 | DATE D RT  ; prompt user for from and to date range | 
|---|
| 106 | I $S('$G(PRCOBEG):1,'$G(PRCOSTOP):1,1:0) G RT1 | 
|---|
| 107 | I LIST="" G P2 | 
|---|
| 108 | G ^PRCOER3 | 
|---|
| 109 | ; | 
|---|
| 110 | IT ; SELECT ACCEPTED, REJECTED OR INCOMMING TRANSACTIONS WITH PROBLEMS. | 
|---|
| 111 | Q | 
|---|
| 112 | ; | 
|---|
| 113 | RT1 D:$G(X)'="^" PAUSE | 
|---|
| 114 | G R4:X["^",R0 | 
|---|
| 115 | ; | 
|---|
| 116 | PO ; FIND OUT IF USER WANTS TO DISPLAY 'POA' RECORDS | 
|---|
| 117 | Q | 
|---|
| 118 | ; | 
|---|
| 119 | WRONG(X) ; COME HERE IF THE USER'S INPUT IS WRONG. | 
|---|
| 120 | S A(1)=$S($G(X)]"":X_" ?? "_$C(7),1:"") | 
|---|
| 121 | S A(2)="  " | 
|---|
| 122 | S A(3)="Enter a selection, more than one selection separated with a ','" | 
|---|
| 123 | S A(4)="a range of selections seperated with a '-' or exclude an entry with a '." | 
|---|
| 124 | S A(5)="  " | 
|---|
| 125 | D EN^DDIOL(.A) | 
|---|
| 126 | Q | 
|---|
| 127 | ; | 
|---|
| 128 | CHECK(X,Y) ;  COME HERE TO SEE IF INPUT IS ONE OF THE CORRECT ENTRIES. | 
|---|
| 129 | ; | 
|---|
| 130 | ;  RETURN A NUMBER THAT REPRESENTS THE INPUT. | 
|---|
| 131 | ; | 
|---|
| 132 | ;      PHA      1 | 
|---|
| 133 | ;      RFQ      2 | 
|---|
| 134 | ;      TXT      3 | 
|---|
| 135 | ;      ACT      4 | 
|---|
| 136 | ;      PRJ      5 | 
|---|
| 137 | ;      POA      6 | 
|---|
| 138 | ;      ALL      7 | 
|---|
| 139 | ;     WRONG     0 | 
|---|
| 140 | ; | 
|---|
| 141 | ;  THE RETURNED VALUE OF "0" MEANS THAT THE USER DID NOT ENTER ANY | 
|---|
| 142 | ;  CORRECT ENTRY. | 
|---|
| 143 | ; | 
|---|
| 144 | S X=$S(X["P":"PHA",X["R":"RFQ",X["A":"ALL",1:X) | 
|---|
| 145 | S Y=$S(X="PHA":1,X="RFQ":2,X="TXT":3,X="ACT":4,X="PRJ":5,X="POA":6,X="ALL":7,1:0) | 
|---|
| 146 | Q | 
|---|
| 147 | ; | 
|---|
| 148 | RT ; Ask user from date.  Must be less than "NOW". | 
|---|
| 149 | ; returns PRCOBEG | 
|---|
| 150 | N AA | 
|---|
| 151 | K PRCOBEG,PRCOSTOP | 
|---|
| 152 | D LF | 
|---|
| 153 | D NOW^%DTC | 
|---|
| 154 | S AA=$E(X,1,3)-1 | 
|---|
| 155 | S Y=AA_$E(X,4,7) | 
|---|
| 156 | D DD^%DT | 
|---|
| 157 | S DIR(0)="D^:-NOW:AET" | 
|---|
| 158 | S DIR("A")="Enter the DATE/TIME CREATED starting date" | 
|---|
| 159 | S DIR("B")=Y | 
|---|
| 160 | D ^DIR K DIR | 
|---|
| 161 | Q:$D(DIRUT) | 
|---|
| 162 | S PRCOBEG=$S(Y[".":Y,1:Y_".000001") | 
|---|
| 163 | ; | 
|---|
| 164 | RT0 ; Ask user end date.  Date must be > BEG date and less | 
|---|
| 165 | ; than "NOW". | 
|---|
| 166 | ; returns PRCOSTOP | 
|---|
| 167 | Q:'$G(PRCOBEG) | 
|---|
| 168 | S DIR(0)="D^"_PRCOBEG_":-NOW:AET" | 
|---|
| 169 | S DIR("A")="Enter the DATE/TIME CREATED ending date" | 
|---|
| 170 | S DIR("B")="NOW" | 
|---|
| 171 | D LF | 
|---|
| 172 | D ^DIR K DIR | 
|---|
| 173 | Q:$D(DIRUT) | 
|---|
| 174 | S PRCOSTOP=Y | 
|---|
| 175 | I PRCOSTOP'["." D  ;if no time entered by user | 
|---|
| 176 | .  ; | 
|---|
| 177 | .  ; set end date to "NOW" if end date is "TODAY". | 
|---|
| 178 | .  ; | 
|---|
| 179 | .  I PRCOSTOP=$G(DT) S PRCOSTOP=$$NOW^XLFDT Q | 
|---|
| 180 | .  S PRCOSTOP=PRCOSTOP_".235959"  ;attach time for end of day | 
|---|
| 181 | ; | 
|---|
| 182 | K DUOUT,DIRUT,DTOUT | 
|---|
| 183 | Q | 
|---|
| 184 | ; | 
|---|
| 185 | PAUSE ; Come here to allow user to read screen before continuing. | 
|---|
| 186 | N DIR,DIRUT,DUOUT,DTOUT | 
|---|
| 187 | S DIR(0)="E" | 
|---|
| 188 | D ^DIR | 
|---|
| 189 | Q | 
|---|
| 190 | LF ; Line feed | 
|---|
| 191 | D EN^DDIOL("","","!") | 
|---|
| 192 | Q | 
|---|