Changeset 636 for FOIAVistA/tag/r/CLINICAL_REMINDERS-PXRM/PXRMPDR.m
- Timestamp:
- Dec 4, 2009, 8:26:01 PM (14 years ago)
- Location:
- FOIAVistA/tag/r
- Files:
-
- 1 edited
- 1 copied
Legend:
- Unmodified
- Added
- Removed
-
FOIAVistA/tag/r/CLINICAL_REMINDERS-PXRM/PXRMPDR.m
r628 r636 1 PXRMPDR ;SLC/AGP,PKR - Patient List Demographic report main routine ; 11/16/20072 ;;2.0;CLINICAL REMINDERS;**4 ,6**;Feb 04, 2005;Build 1231 PXRMPDR ;SLC/AGP,PKR - Patient List Demographic report main routine ;07/17/2006 2 ;;2.0;CLINICAL REMINDERS;**4**;Feb 04, 2005;Build 21 3 3 ; 4 4 EN(PLIEN) ; -- main entry point for PXRM PATIENT LIST DEMOGRAPHIC 5 N ARRAY,DC,DDATA,DELIM,DTOUT,DUOUT 5 N ADDDATA,APPDATA,ARRAY,BACK,CNT,DC,DEMDATA,DELIM,DIC,DIR,DTOUT,DUOUT 6 N ELIGDATA,IEN,INPDATA 7 N FINDDATA,NAME,NODE,PFACDATA,PTIEN 8 N QUIT,REMDATA 9 N X,Y,YESNO 6 10 W @IOF 7 11 K ^TMP("PXRMPLD",$J),^TMP("PXRMPLN",$J) 8 S DELIM=012 S BACK=0,DELIM=0,QUIT=0 9 13 OPTION ; 10 14 W !,"Select the items to include on the report." 11 ADDSEL D ADDSEL^PXRMPDRS(. DDATA,"ADD")15 ADDSEL D ADDSEL^PXRMPDRS(.ADDDATA) 12 16 I $D(DTOUT)!$D(DUOUT) Q 13 APPSEL D APPSEL^PXRMPDRS(. DDATA,"APP")17 APPSEL D APPSEL^PXRMPDRS(.APPDATA) 14 18 I $D(DTOUT)!$D(DUOUT) G ADDSEL 15 DEMSEL D DEMSEL^PXRMPDRS(.D DATA,"DEM")19 DEMSEL D DEMSEL^PXRMPDRS(.DEMDATA) 16 20 I $D(DTOUT)!$D(DUOUT) G APPSEL 17 PFACSEL S DDATA("PFAC",0)=$$ASKYN^PXRMEUT("N","Include the patient's preferred facility")21 PFACSEL S PFACDATA(0)=$$ASKYN^PXRMEUT("N","Include the patient's preferred facility") 18 22 I $D(DTOUT)!$D(DUOUT) G DEMSEL 19 S DDATA("PFAC","LEN")=$S(DDATA("PFAC",0)=1:1,1:0)20 ELIGSEL D ELIGSEL^PXRMPDRS(. DDATA,"ELIG")23 S PFACDATA("LEN")=$S(PFACDATA(0)=1:1,1:0) 24 ELIGSEL D ELIGSEL^PXRMPDRS(.ELIGDATA) 21 25 I $D(DTOUT)!$D(DUOUT) G PFACSEL 22 DATASEL D DATASEL^PXRMPDRS(PLIEN,. DDATA,"FIND")26 DATASEL D DATASEL^PXRMPDRS(PLIEN,.FINDDATA) 23 27 I $D(DTOUT)!$D(DUOUT) G ELIGSEL 24 INPSEL D INPSEL^PXRMPDRS(. DDATA,"INP")28 INPSEL D INPSEL^PXRMPDRS(.INPDATA) 25 29 I $D(DTOUT)!$D(DUOUT) G DATASEL 26 REMDATA D REMSEL^PXRMPDRS(PLIEN,. DDATA,"REM")30 REMDATA D REMSEL^PXRMPDRS(PLIEN,.REMDATA) 27 31 I $D(DTOUT)!$D(DUOUT) G INPSEL 28 32 S DELIM=$$ASKYN^PXRMEUT("Y","Delimited Report:") 29 33 I $D(DTOUT)!$D(DUOUT) G REMDATA 30 S DC=$S(DELIM:$$DELIMSEL^PXRMXSD,1:U)34 I DELIM S DC=$$DELIMSEL^PXRMXSD 31 35 I $D(DTOUT)!$D(DUOUT) G OPTION 32 36 DEVICE ; 33 N D ESC,DIR,PXRMQUE,RTN,SAVE,%ZIS37 N DIR,PXRMQUE,%ZIS,ZTDESC,ZTRTN,ZTSAVE 34 38 S %ZIS="M" 35 S DESC="Patient List Demographic Report"36 S RTN="GETPDATA^PXRMPDR(DELIM,DC,PLIEN,.DDATA)"37 S SAVE("DELIM")="",SAVE("DC")="",SAVE("PLIEN")=""38 S SAVE("DDATA(")=""39 S PXRMQUE=$$DEVICE^PXRMXQUE( RTN,DESC,.SAVE,.%ZIS,1)40 I PXRMQUE '=""G EXIT39 S ZTDESC="Patient List Demographic" 40 S ZTRTN="GETDATA^PXRMPDR(DELIM,PLIEN,.DEMDATA,.PFACDATA,.ADDDATA,.INPDATA,.APPDATA,.FINDDATA,.REMDATA)" 41 S ZTSAVE("*")="" 42 S PXRMQUE=0 43 S PXRMQUE=$$DEVICE^PXRMXQUE(ZTRTN,ZTDESC,.ZTSAVE,.%ZIS,.ZTSK) 44 I PXRMQUE=1 G EXIT 41 45 I $D(DTOUT)!$D(DUOUT) G EXIT 46 ; 42 47 S DIR(0)="E" D ^DIR 43 48 EXIT D KVA^VADPT … … 45 50 Q 46 51 ; 47 GET PDATA(DELIM,DC,PLIEN,DDATA) ;52 GETDATA(DELIM,PLIEN,DEMDATA,PFACDATA,ADDDATA,INPDATA,APPDATA,FINDDATA,REMDATA) ; 48 53 N DATA,DATE,DCREAT,DFN,DTYPE,ERRMSG 49 54 N GETADD,GETAPP,GETDEM,GETELIG,GETFIND,GETINP,GETREM … … 54 59 S LISTNAME=$P(^PXRMXP(810.5,PLIEN,0),U,1) 55 60 S DCREAT=$P(^PXRMXP(810.5,PLIEN,0),U,4) 56 S GETDEM=$S(D DATA("DEM","LEN")>0:1,1:0)57 S GETADD=$S( DDATA("ADD","LEN")>0:1,1:0)58 S GETINP=$S( DDATA("INP","LEN")>0:1,1:0)59 S GETELIG=$S( DDATA("ELIG","LEN")>0:1,1:0)60 S GETAPP=$S( DDATA("APP","LEN")>0:1,1:0)61 S GETFIND=$S( DDATA("FIND","LEN")>0:1,1:0)62 S GETREM=$S( DDATA("REM","LEN")>0:1,1:0)61 S GETDEM=$S(DEMDATA("LEN")>0:1,1:0) 62 S GETADD=$S(ADDDATA("LEN")>0:1,1:0) 63 S GETINP=$S(INPDATA("LEN")>0:1,1:0) 64 S GETELIG=$S(ELIGDATA("LEN")>0:1,1:0) 65 S GETAPP=$S(APPDATA("LEN")>0:1,1:0) 66 S GETFIND=$S(FINDDATA("LEN")>0:1,1:0) 67 S GETREM=$S(REMDATA("LEN")>0:1,1:0) 63 68 S IEN=0 64 69 F S IEN=+$O(^PXRMXP(810.5,PLIEN,30,IEN)) Q:IEN=0 D … … 72 77 .. N VADM 73 78 .. D DEM^VADPT 74 .. F IND=1:1:D DATA("DEM","LEN") D75 ... S JND=$P(D DATA("DEM"),",",IND)76 ... S KND=0 77 ... F S KND=$O(D DATA("DEM",JND,KND)) Q:KND="" D78 .... S PIECE=$P(D DATA("DEM",JND,KND),U,2)79 .. F IND=1:1:DEMDATA("LEN") D 80 ... S JND=$P(DEMDATA,",",IND) 81 ... S KND=0 82 ... F S KND=$O(DEMDATA(JND,KND)) Q:KND="" D 83 .... S PIECE=$P(DEMDATA(JND,KND),U,2) 79 84 .... S TDATA=$P(VADM(KND),U,PIECE) 80 85 .... S LND="" … … 82 87 ..... I TDATA'="" S TDATA=TDATA_"~" 83 88 ..... S TDATA=TDATA_$P(VADM(KND,LND),U,PIECE) 84 .... I KND=2,'D DATA("DEM","FULLSSN") S TDATA=$E(TDATA,8,11)85 .... S $P(PDATA,U,KND)=TDATA 86 .. I PDATA'="" S ^TMP("PXRMPLD",$J,DFN,"DEM ")=PDATA,PDATA=""87 . I DDATA("PFAC",0)=1 D89 .... I KND=2,'DEMDATA("FULLSSN") S TDATA=$E(TDATA,8,11) 90 .... S $P(PDATA,U,KND)=TDATA 91 .. I PDATA'="" S ^TMP("PXRMPLD",$J,DFN,"DEMDATA")=PDATA,PDATA="" 92 . I PFACDATA(0)=1 D 88 93 ..;DBIA #1850 89 94 .. S TDATA=$$GET1^DIQ(2,DFN,27.02,"E","","ERRMSG") 90 95 .. I TDATA="" S TDATA="NONE" 91 .. S ^TMP("PXRMPLD",$J,DFN,"PFAC ")=TDATA96 .. S ^TMP("PXRMPLD",$J,DFN,"PFACDATA")=TDATA 92 97 . I GETADD D 93 98 .. N VAPA 94 99 .. D ADD^VADPT 95 .. F IND=1:1: DDATA("ADD","LEN") D96 ... S JND=$P( DDATA("ADD"),",",IND)97 ... S KND=0 98 ... F S KND=$O( DDATA("ADD",JND,KND)) Q:KND="" D99 .... S PIECE=$P( DDATA("ADD",JND,KND),U,2)100 .. F IND=1:1:ADDDATA("LEN") D 101 ... S JND=$P(ADDDATA,",",IND) 102 ... S KND=0 103 ... F S KND=$O(ADDDATA(JND,KND)) Q:KND="" D 104 .... S PIECE=$P(ADDDATA(JND,KND),U,2) 100 105 .... S TDATA=$P(VAPA(KND),U,PIECE) 101 106 .... S $P(PDATA,U,KND)=TDATA 102 .. I PDATA'="" S ^TMP("PXRMPLD",$J,DFN,"ADD ")=PDATA,PDATA=""107 .. I PDATA'="" S ^TMP("PXRMPLD",$J,DFN,"ADDDATA")=PDATA,PDATA="" 103 108 . I GETINP D 104 109 .. N VAIP 105 110 .. D INP^VADPT 106 .. F IND=1:1: DDATA("INP","LEN") D107 ... S JND=$P( DDATA("INP"),",",IND)108 ... S KND=0 109 ... F S KND=$O( DDATA("INP",JND,KND)) Q:KND="" D110 .... S PIECE=$P( DDATA("INP",JND,KND),U,2)111 .. F IND=1:1:INPDATA("LEN") D 112 ... S JND=$P(INPDATA,",",IND) 113 ... S KND=0 114 ... F S KND=$O(INPDATA(JND,KND)) Q:KND="" D 115 .... S PIECE=$P(INPDATA(JND,KND),U,2) 111 116 .... S TDATA=$P(VAIN(KND),U,PIECE) 112 117 .... S $P(PDATA,U,KND)=TDATA 113 .. I PDATA'="" S ^TMP("PXRMPLD",$J,DFN,"INP ")=PDATA,PDATA=""118 .. I PDATA'="" S ^TMP("PXRMPLD",$J,DFN,"INPDATA")=PDATA,PDATA="" 114 119 . I GETELIG D 115 120 .. N VAEL 116 121 .. D ELIG^VADPT 117 .. F IND=1:1: DDATA("ELIG","LEN") D118 ... S JND=$P( DDATA("ELIG"),",",IND)119 ... S KND=0 120 ... F S KND=$O( DDATA("ELIG",JND,KND)) Q:KND="" D121 .... S PIECE=$P( DDATA("ELIG",JND,KND),U,2)122 .. F IND=1:1:ELIGDATA("LEN") D 123 ... S JND=$P(ELIGDATA,",",IND) 124 ... S KND=0 125 ... F S KND=$O(ELIGDATA(JND,KND)) Q:KND="" D 126 .... S PIECE=$P(ELIGDATA(JND,KND),U,2) 122 127 .... S TDATA=$P(VAEL(KND),U,PIECE) 123 128 .... I KND=4 S TDATA=$S(TDATA=1:"YES",1:"NO") 124 129 .... S $P(PDATA,U,KND)=TDATA 125 .. I PDATA'="" S ^TMP("PXRMPLD",$J,DFN,"ELIG ")=PDATA,PDATA=""130 .. I PDATA'="" S ^TMP("PXRMPLD",$J,DFN,"ELIGDATA")=PDATA,PDATA="" 126 131 . D KVA^VADPT 127 132 . I GETREM D 128 133 .. S IND=0 129 .. F S IND=$O( DDATA("REM","IEN",IND)) Q:IND="" D134 .. F S IND=$O(REMDATA("IEN",IND)) Q:IND="" D 130 135 ... S PDATA=$G(^PXRMXP(810.5,PLIEN,30,IEN,"REM",IND,0)) 131 136 ... I PDATA="" Q 132 137 ... S RIEN=$P(PDATA,U,1) 133 ... S ^TMP("PXRMPLD",$J,DFN,"REM ",RIEN)=PDATA,PDATA=""138 ... S ^TMP("PXRMPLD",$J,DFN,"REMDATA",RIEN)=PDATA,PDATA="" 134 139 . I GETFIND D 135 140 .. N DL 136 .. F IND=1:1: DDATA("FIND","LEN") D137 ... S JND=$P( DDATA("FIND"),",",IND)138 ... S DTYPE= DDATA("FIND",JND,JND)141 .. F IND=1:1:FINDDATA("LEN") D 142 ... S JND=$P(FINDDATA,",",IND) 143 ... S DTYPE=FINDDATA(JND,JND) 139 144 ... S KND=$O(^PXRMXP(810.5,PLIEN,30,IEN,"DATA","B",DTYPE,"")) 140 145 ... S DL=$S(KND="":0,1:$L(^PXRMXP(810.5,PLIEN,30,IEN,"DATA",KND,0),U)) 141 146 ... S DATA=$S(KND="":"",1:$P(^PXRMXP(810.5,PLIEN,30,IEN,"DATA",KND,0),U,2,DL)) 142 ... S ^TMP("PXRMPLD",$J,DFN,"FIND ",JND)=DATA147 ... S ^TMP("PXRMPLD",$J,DFN,"FINDDATA",JND)=DATA 143 148 ;Get appointment data for all patients on the list. 144 149 I GETAPP D … … 146 151 . S ARRAY(1)=DT,ARRAY(3)="I;R" 147 152 . S ARRAY(4)="^TMP($J,""PXRMPL""",ARRAY("FLDS")="" 148 . F IND=1:1: DDATA("APP","LEN") D149 .. S JND=$P( DDATA("APP"),",",IND)153 . F IND=1:1:APPDATA("LEN") D 154 .. S JND=$P(APPDATA,",",IND) 150 155 .. S KND=0 151 .. F S KND=$O( DDATA("APP",JND,KND)) Q:KND="" S ARRAY("FLDS")=ARRAY("FLDS")_KND_";"156 .. F S KND=$O(APPDATA(JND,KND)) Q:KND="" S ARRAY("FLDS")=ARRAY("FLDS")_KND_";" 152 157 . K ^TMP($J,"PXRMPL"),^TMP($J,"SDAMA301") 153 158 . S IND=0 … … 158 163 . I COUNT=-1 D Q 159 164 .. D APPERR^PXRMPDRS 160 .. S DDATA("APP","ERROR")=""165 .. S APPDATA("ERROR")="" 161 166 .. K ^TMP($J,"PXRMPL"),^TMP($J,"SDAMA301") 162 167 . F IND=1:1:COUNT D … … 172 177 ..... S TDATA=$P(TDATA,U,2),TDATA=$P(TDATA,";",2) 173 178 ..... S PDATA=PDATA_U_TDATA 174 ..... S ^TMP("PXRMPLD",$J,DFN,"APP ",KND)=PDATA179 ..... S ^TMP("PXRMPLD",$J,DFN,"APPDATA",KND)=PDATA 175 180 . K ^TMP($J,"PXRMPL"),^TMP($J,"SDAMA301") 176 I DELIM=1 D DELIMPR^PXRMPDRP(DC,PLIEN,. DDATA)177 I DELIM=0 D REGPR^PXRMPDRP(PLIEN,. DDATA)181 I DELIM=1 D DELIMPR^PXRMPDRP(DC,PLIEN,.ADDDATA,.APPDATA,.DEMDATA,.FINDDATA,.INPDATA,.PFACDATA,.REMDATA) 182 I DELIM=0 D REGPR^PXRMPDRP(PLIEN,.ADDDATA,.APPDATA,.DEMDATA,.FINDDATA,.INPDATA,.PFACDATA,.REMDATA) 178 183 Q 179 184 ; … … 184 189 ; 185 190 PAGE ; 186 I ($E(IOST ,1,2)="C-")&(IO=IO(0)) D191 I ($E(IOST)="C")&(IO=IO(0)) D 187 192 .S DIR(0)="E" 188 193 .W ! … … 191 196 W:$D(IOF) @IOF 192 197 S PAGE=PAGE+1 193 I ($E(IOST,1,2)="C-")&(IO=IO(0)) W @IOF194 Q 195 ; 198 I $E(IOST)="C",IO=IO(0) W @IOF 199 Q 200 ;
Note:
See TracChangeset
for help on using the changeset viewer.