[613] | 1 | PXRMETT ; SLC/PJH - Extract Summary Display ;04/09/2007
|
---|
| 2 | ;;2.0;CLINICAL REMINDERS;**4,6**;Feb 04, 2005;Build 123
|
---|
| 3 | ;
|
---|
| 4 | ;Main entry point for PXRM EXTRACT SUMMARY
|
---|
| 5 | START(IEN) N TOGGLE,TOGGLE1,VALMBCK,VALMBG,VALMCNT,VALMSG,X,XMZ,XQORM,XQORNOD
|
---|
| 6 | S X="IORESET"
|
---|
| 7 | D ENDR^%ZISS
|
---|
| 8 | S VALMCNT=0,TOGGLE=0,TOGGLE1=0
|
---|
| 9 | D EN^VALM("PXRM EXTRACT SUMMARY")
|
---|
| 10 | Q
|
---|
| 11 | ;
|
---|
| 12 | BLDLIST(IEN,FINDINGS,PATIENT) ;Build workfile.
|
---|
| 13 | ;FINDINGS=1 means display finding totals
|
---|
| 14 | K ^TMP("PXRMETT",$J)
|
---|
| 15 | ;Build a list of extract summary totals.
|
---|
| 16 | N APPL,DATA,DUE,IND,LIST,NDUE,NAPPL,OLIST
|
---|
| 17 | N PLCNT,PLIST,RIEN,RNAME,SARRAY,SEQ,SNAME,STATION,TOT
|
---|
| 18 | ;Build the list in alphabetical order.
|
---|
| 19 | S VALMCNT=0,OLIST="",PLCNT=0
|
---|
| 20 | S IND=0 F S IND=$O(^PXRMXT(810.3,IEN,3,IND)) Q:IND'>0 D
|
---|
| 21 | .S DATA=$G(^PXRMXT(810.3,IEN,3,IND,0)) Q:DATA=""
|
---|
| 22 | .S RIEN=$P(DATA,U,2) Q:'RIEN
|
---|
| 23 | .S RNAME=$P(^PXD(811.9,RIEN,0),U,3)
|
---|
| 24 | .I RNAME="" S RNAME=$P(^PXD(811.9,RIEN,0),U,1)
|
---|
| 25 | .S STATION=$P(DATA,U,3),SARRAY=""
|
---|
| 26 | .D GETS^DIQ(4,STATION,99,"E","SARRAY")
|
---|
| 27 | .S SNAME=$G(SARRAY(4,STATION_",",99,"E"))
|
---|
| 28 | .I SNAME="" S SNAME=STATION
|
---|
| 29 | .S TOT=+$P(DATA,U,5),APPL=+$P(DATA,U,6),NAPPL=+$P(DATA,U,7)
|
---|
| 30 | .S DUE=+$P(DATA,U,8),NDUE=+$P(DATA,U,9)
|
---|
| 31 | .S PLIST=$P(DATA,U,4)
|
---|
| 32 | .I PLIST,PLIST'=OLIST D
|
---|
| 33 | ..I PLCNT>0 D
|
---|
| 34 | ...S VALMCNT=VALMCNT+1
|
---|
| 35 | ...S ^TMP("PXRMETT",$J,VALMCNT,0)=""
|
---|
| 36 | ...S ^TMP("PXRMETT",$J,"IDX",VALMCNT,PLCNT)=""
|
---|
| 37 | ..S PLNAME=$P($G(^PXRMXP(810.5,PLIST,0)),U),OLIST=PLIST Q:PLNAME=""
|
---|
| 38 | ..S VALMCNT=VALMCNT+1,PLCNT=PLCNT+1
|
---|
| 39 | ..S ^TMP("PXRMETT",$J,"IDX",VALMCNT,PLCNT)=""
|
---|
| 40 | ..S ^TMP("PXRMETT",$J,"SEL",PLCNT)=PLIST
|
---|
| 41 | ..S ^TMP("PXRMETT",$J,VALMCNT,0)=$$RJ^XLFSTR(PLCNT,4," ")_" "_PLNAME
|
---|
| 42 | .S VALMCNT=VALMCNT+1
|
---|
| 43 | .S ^TMP("PXRMETT",$J,VALMCNT,0)=$$FRE(VALMCNT,RNAME,SNAME,TOT,APPL,NAPPL,DUE,NDUE)
|
---|
| 44 | .S ^TMP("PXRMETT",$J,"IDX",VALMCNT,PLCNT)=""
|
---|
| 45 | .;Finding totals
|
---|
| 46 | .I +FINDINGS>0 D FBLD(PATIENT)
|
---|
| 47 | ;
|
---|
| 48 | S ^TMP("PXRMETT",$J,"VALMCNT")=VALMCNT
|
---|
| 49 | Q
|
---|
| 50 | ;
|
---|
| 51 | ENTRY ;Entry code
|
---|
| 52 | D BLDLIST(IEN,TOGGLE,TOGGLE1),XQORM
|
---|
| 53 | Q
|
---|
| 54 | ;
|
---|
| 55 | EXIT ;Exit code
|
---|
| 56 | K ^TMP("PXRMETT",$J)
|
---|
| 57 | K ^TMP("PXRMETTH",$J)
|
---|
| 58 | D CLEAN^VALM10
|
---|
| 59 | D FULL^VALM1
|
---|
| 60 | S VALMBCK="Q"
|
---|
| 61 | Q
|
---|
| 62 | ;
|
---|
| 63 | FBLD(PATIENT) ;Build finding list
|
---|
| 64 | N APPL,DATA,DUE,ETYP,EVAL,GNAM,GTYP
|
---|
| 65 | N NAPPL,NDUE,OGNAM,SEQ,SUB,TIEN,TNAME,TOTAL
|
---|
| 66 | S SUB=0,OGNAM=""
|
---|
| 67 | F S SUB=$O(^PXRMXT(810.3,IEN,3,IND,1,SUB)) Q:'SUB D
|
---|
| 68 | .S DATA=$G(^PXRMXT(810.3,IEN,3,IND,1,SUB,0)) Q:DATA=""
|
---|
| 69 | .S TIEN=$P(DATA,U,2) Q:'TIEN
|
---|
| 70 | .S TNAME=$P($G(^PXRMD(811.5,TIEN,0)),U)
|
---|
| 71 | .S SEQ=$P(DATA,U),ETYP=$P(DATA,U,3),GNAM=$P(DATA,U,9),GTYP=$P(DATA,U,10)
|
---|
| 72 | .S TOT=+$P(DATA,U,4),APPL=+$P(DATA,U,5),NAPPL=+$P(DATA,U,6)
|
---|
| 73 | .S DUE=+$P(DATA,U,7),NDUE=+$P(DATA,U,8)
|
---|
| 74 | .I OGNAM'=GNAM D
|
---|
| 75 | ..I OGNAM'="" D
|
---|
| 76 | ...S VALMCNT=VALMCNT+1
|
---|
| 77 | ...S ^TMP("PXRMETT",$J,VALMCNT,0)=""
|
---|
| 78 | ...S ^TMP("PXRMETT",$J,"IDX",VALMCNT,PLCNT)=""
|
---|
| 79 | ..S OGNAM=GNAM,VALMCNT=VALMCNT+1
|
---|
| 80 | ..S ^TMP("PXRMETT",$J,VALMCNT,0)=$$RJ^XLFSTR("Counting Group: ",21)_GNAM
|
---|
| 81 | ..S ^TMP("PXRMETT",$J,"IDX",VALMCNT,PLCNT)="",VALMCNT=VALMCNT+1
|
---|
| 82 | ..S ^TMP("PXRMETT",$J,VALMCNT,0)=$J("",6)_$$LJ^XLFSTR($$TXT^PXRMEPM(ETYP,GTYP),49)
|
---|
| 83 | ..S ^TMP("PXRMETT",$J,"IDX",VALMCNT,PLCNT)=""
|
---|
| 84 | .S VALMCNT=VALMCNT+1
|
---|
| 85 | .S ^TMP("PXRMETT",$J,VALMCNT,0)=$$FREF(VALMCNT,TNAME,SEQ,TOT,APPL,NAPPL,DUE,NDUE,ETYP)
|
---|
| 86 | .S ^TMP("PXRMETT",$J,"IDX",VALMCNT,PLCNT)=""
|
---|
| 87 | .I +PATIENT>0 D PBLD(IEN,IND,SUB)
|
---|
| 88 | S VALMCNT=VALMCNT+1
|
---|
| 89 | S ^TMP("PXRMETT",$J,VALMCNT,0)=""
|
---|
| 90 | S ^TMP("PXRMETT",$J,"IDX",VALMCNT,PLCNT)=""
|
---|
| 91 | Q
|
---|
| 92 | ;
|
---|
| 93 | FLIST ;Toggle list with/without finding totals
|
---|
| 94 | S TOGGLE=(TOGGLE+1)#2
|
---|
| 95 | I TOGGLE=0 S TOGGLE1=0
|
---|
| 96 | ;Rebuild Workfile
|
---|
| 97 | D BLDLIST(IEN,TOGGLE,TOGGLE1)
|
---|
| 98 | ;Refresh
|
---|
| 99 | S VALMBCK="R",VALMBG=1
|
---|
| 100 | Q
|
---|
| 101 | ;
|
---|
| 102 | FRE(NUMBER,NAME,SNAME,TOT,APPL,NAPPL,DUE,NDUE) ;Format reminder entry
|
---|
| 103 | N TEMP,TNAME,TSOURCE
|
---|
| 104 | S TEMP=" "
|
---|
| 105 | S TNAME=SNAME_"/"_$E(NAME,1,35-$L(SNAME))
|
---|
| 106 | S TEMP=TEMP_$$LJ^XLFSTR(TNAME,36," ")
|
---|
| 107 | S TEMP=TEMP_$$RJ^XLFSTR(TOT,8," ")
|
---|
| 108 | S TEMP=TEMP_$$RJ^XLFSTR(APPL,8," ")
|
---|
| 109 | S TEMP=TEMP_$$RJ^XLFSTR(NAPPL,7," ")
|
---|
| 110 | S TEMP=TEMP_$$RJ^XLFSTR(DUE,7," ")
|
---|
| 111 | S TEMP=TEMP_$$RJ^XLFSTR(NDUE,7," ")
|
---|
| 112 | Q TEMP
|
---|
| 113 | ;
|
---|
| 114 | FREF(NUMBER,NAME,SNAME,TOT,APPL,NAPPL,DUE,NDUE,ETYP) ;Format finding entry
|
---|
| 115 | N TEMP,TNAME,TSOURCE
|
---|
| 116 | S TEMP=" "
|
---|
| 117 | S TNAME=$E(NAME,1,31)
|
---|
| 118 | S TEMP=TEMP_" "_$$LJ^XLFSTR(TNAME,31," ")
|
---|
| 119 | S TEMP=TEMP_" "_$$RJ^XLFSTR(TOT,8," ")
|
---|
| 120 | I ETYP'="FC" D
|
---|
| 121 | .S TEMP=TEMP_$$RJ^XLFSTR(APPL,8," ")
|
---|
| 122 | .S TEMP=TEMP_$$RJ^XLFSTR(NAPPL,7," ")
|
---|
| 123 | .S TEMP=TEMP_$$RJ^XLFSTR(DUE,7," ")
|
---|
| 124 | .S TEMP=TEMP_$$RJ^XLFSTR(NDUE,7," ")
|
---|
| 125 | Q TEMP
|
---|
| 126 | ;
|
---|
| 127 | HDR ; Header code
|
---|
| 128 | S VALMHDR(1)="Extract Summary Name: "_$P($G(^PXRMXT(810.3,IEN,0)),U)
|
---|
| 129 | S VALMHDR(2)=" Extract Period: "_$$FMTE^XLFDT($P($G(^PXRMXT(810.3,IEN,0)),U,2),"5Z")_" - "_$$FMTE^XLFDT($P($G(^PXRMXT(810.3,IEN,0)),U,3),"5Z")
|
---|
| 130 | S VALMHDR(2)=VALMHDR(2)_" Created: "_$$FMTE^XLFDT($P($G(^PXRMXT(810.3,IEN,0)),U,6),"5Z")
|
---|
| 131 | S VALMSG="+ Next Screen - Prev Screen ?? More Actions"
|
---|
| 132 | Q
|
---|
| 133 | ;
|
---|
| 134 | HLP ;Help code
|
---|
| 135 | N ORU,ORUPRMT,XQORM
|
---|
| 136 | S SUB="PXRMETTH"
|
---|
| 137 | D EN^VALM("PXRM EXTRACT HELP")
|
---|
| 138 | Q
|
---|
| 139 | ;
|
---|
| 140 | INIT ;Init
|
---|
| 141 | S VALMCNT=0
|
---|
| 142 | Q
|
---|
| 143 | ;
|
---|
| 144 | PBLD(IEN,IND,SUB) ;
|
---|
| 145 | N ARRAY,NAME,LEN,PCNT,DFN,CNT,USTR
|
---|
| 146 | S VALMCNT=VALMCNT+1,CNT=0
|
---|
| 147 | S PCNT=0 F S PCNT=$O(^PXRMXT(810.3,IEN,3,IND,1,SUB,1,PCNT)) Q:PCNT'>0 D
|
---|
| 148 | .S DFN=$P($G(^PXRMXT(810.3,IEN,3,IND,1,SUB,1,PCNT,0)),U) Q:DFN'>0
|
---|
| 149 | .S NAME=$P($G(^DPT(DFN,0)),U)
|
---|
| 150 | .S CNT=CNT+1,ARRAY(NAME)=""
|
---|
| 151 | S ^TMP("PXRMETT",$J,VALMCNT,0)=" "_$$RJ^XLFSTR("Unique Applicable Patients ("_CNT_")",36," ")
|
---|
| 152 | S USTR=$P($G(^TMP("PXRMETT",$J,VALMCNT,0)),"U"),LEN=$L(USTR)
|
---|
| 153 | S ^TMP("PXRMETT",$J,"IDX",VALMCNT,PLCNT)=""
|
---|
| 154 | S NAME="" F S NAME=$O(ARRAY(NAME)) Q:NAME="" D
|
---|
| 155 | .S VALMCNT=VALMCNT+1
|
---|
| 156 | .S ^TMP("PXRMETT",$J,VALMCNT,0)=USTR_$$LJ^XLFSTR(NAME,36," ")
|
---|
| 157 | .S ^TMP("PXRMETT",$J,"IDX",VALMCNT,PLCNT)=""
|
---|
| 158 | S VALMCNT=VALMCNT+1
|
---|
| 159 | S ^TMP("PXRMETT",$J,VALMCNT,0)=" "
|
---|
| 160 | S ^TMP("PXRMETT",$J,"IDX",VALMCNT,PLCNT)=""
|
---|
| 161 | Q
|
---|
| 162 | ;
|
---|
| 163 | PEXIT ;Protocol exit code
|
---|
| 164 | S VALMSG="+ Next Screen - Prev Screen ?? More Actions"
|
---|
| 165 | D XQORM
|
---|
| 166 | Q
|
---|
| 167 | ;
|
---|
| 168 | PLIST(IEN) ;Patient list display
|
---|
| 169 | N IND,PLIEN,VALMY
|
---|
| 170 | D EN^VALM2(XQORNOD(0))
|
---|
| 171 | ;If there is no list quit.
|
---|
| 172 | I '$D(VALMY) Q
|
---|
| 173 | ;PXRMDONE is newed in PXRMLPM
|
---|
| 174 | S PXRMDONE=0
|
---|
| 175 | S IND=""
|
---|
| 176 | F S IND=$O(VALMY(IND)) Q:(+IND=0)!(PXRMDONE) D
|
---|
| 177 | .;Get the ien.
|
---|
| 178 | .S PLIEN=^TMP("PXRMETT",$J,"SEL",IND)
|
---|
| 179 | .D START^PXRMLPP(PLIEN)
|
---|
| 180 | S VALMBCK="R"
|
---|
| 181 | Q
|
---|
| 182 | ;
|
---|
| 183 | PLIST1 ;Toggle list with/without finding totals
|
---|
| 184 | S TOGGLE1=(TOGGLE1+1)#2
|
---|
| 185 | ;Rebuild Workfile
|
---|
| 186 | D BLDLIST(IEN,TOGGLE,TOGGLE1)
|
---|
| 187 | ;Refresh
|
---|
| 188 | S VALMBCK="R",VALMBG=1
|
---|
| 189 | Q
|
---|
| 190 | ;
|
---|
| 191 | XQORM S XQORM("#")=$O(^ORD(101,"B","PXRM EXTRACT SUMMARY SELECT ENTRY",0))_U_"1:"_VALMCNT
|
---|
| 192 | S XQORM("A")="Select Item: "
|
---|
| 193 | Q
|
---|
| 194 | ;
|
---|
| 195 | XSEL ;PXRM EXTRACT TOTALS SELECT ENTRY validation
|
---|
| 196 | N SEL,PLIEN
|
---|
| 197 | S SEL=$P(XQORNOD(0),"=",2)
|
---|
| 198 | ;Remove trailing ,
|
---|
| 199 | I $E(SEL,$L(SEL))="," S SEL=$E(SEL,1,$L(SEL)-1)
|
---|
| 200 | ;Invalid selection
|
---|
| 201 | I SEL["," D Q
|
---|
| 202 | .W $C(7),!,"Only one item number allowed." H 2
|
---|
| 203 | .S VALMBCK="R"
|
---|
| 204 | I ('SEL)!(SEL>VALMCNT)!('$D(@VALMAR@("SEL",SEL))) D Q
|
---|
| 205 | .W $C(7),!,SEL_" is not a valid item number." H 2
|
---|
| 206 | .S VALMBCK="R"
|
---|
| 207 | ;Get the list ien.
|
---|
| 208 | S PLIEN=^TMP("PXRMETT",$J,"SEL",SEL)
|
---|
| 209 | D START^PXRMLPP(PLIEN)
|
---|
| 210 | S VALMBCK="R"
|
---|
| 211 | Q
|
---|
| 212 | ;
|
---|