[623] | 1 | PXRMLPP ; SLC/PKR/PJH - Reminder Patient List Patients ;01/06/2006
|
---|
| 2 | ;;2.0;CLINICAL REMINDERS;**4**;Feb 04, 2005;Build 21
|
---|
| 3 | ;
|
---|
| 4 | ;Main entry point for PXRM PATIENT LIST
|
---|
| 5 | START(IEN) ;
|
---|
| 6 | N CDATE,CLASS,CREATOR,LDATA,LNAME,PXRMVIEW,SNAME,SOURCE,TYPE
|
---|
| 7 | N VALMBCK,VALMBG,VALMCNT,VALMSG,X,XMZ,XQORM,XQORNOD
|
---|
| 8 | ;Get Patient List record and associated data.
|
---|
| 9 | S LDATA=$G(^PXRMXP(810.5,IEN,0))
|
---|
| 10 | S LNAME=$P(LDATA,U,1)
|
---|
| 11 | S CDATE=$P(LDATA,U,4)
|
---|
| 12 | S SOURCE=$P(LDATA,U,5),SNAME=""
|
---|
| 13 | ;Check if generated from #810.2
|
---|
| 14 | I SOURCE S SNAME="Extract Parameter - "_$P($G(^PXRM(810.2,SOURCE,0)),U)
|
---|
| 15 | ;If not check if generated from #810.4
|
---|
| 16 | I SNAME="" D
|
---|
| 17 | . S SOURCE=$P(LDATA,U,6)
|
---|
| 18 | . I SOURCE'="" S SNAME="List Rule - "_$P($G(^PXRM(810.4,SOURCE,0)),U)
|
---|
| 19 | ;If still no source check for created from Reminder Due Report.
|
---|
| 20 | I SNAME="" D
|
---|
| 21 | . S SOURCE=$P(LDATA,U,9)
|
---|
| 22 | . I SOURCE'="" S SNAME="Reminder Due Report"
|
---|
| 23 | ;If there still is no source then assume it was generated in the
|
---|
| 24 | ;past by a Reminder Due Report.
|
---|
| 25 | I SNAME="" S SNAME="Reminder Due Report"
|
---|
| 26 | ;Creator
|
---|
| 27 | S CREATOR=+$P(LDATA,U,7)
|
---|
| 28 | S CREATOR=$S(CREATOR>0:$$GET1^DIQ(200,CREATOR,.01),1:"None")
|
---|
| 29 | ;Type
|
---|
| 30 | S TYPE=$P(LDATA,U,8)
|
---|
| 31 | S TYPE=$$EXTERNAL^DILFD(810.5,.08,"",TYPE,.EM)
|
---|
| 32 | ;Class
|
---|
| 33 | S CLASS=$P($G(^PXRMXP(810.5,IEN,100)),U)
|
---|
| 34 | S CLASS=$S(CLASS="N":"National",CLASS="V":"VISN",1:"Local")
|
---|
| 35 | ;Default view by name.
|
---|
| 36 | S PXRMVIEW="N"
|
---|
| 37 | S VALMCNT=0
|
---|
| 38 | D EN^VALM("PXRM PATIENT LIST PATIENTS")
|
---|
| 39 | Q
|
---|
| 40 | ;
|
---|
| 41 | BLDLIST(IEN) ;Build a list of all patients
|
---|
| 42 | N IND,INCINST
|
---|
| 43 | S INCINST=+$P(^PXRMXP(810.5,IEN,0),U,10)
|
---|
| 44 | I 'INCINST D CHGCAP^VALM("HEADER3","")
|
---|
| 45 | K ^TMP("PXRMLPP",$J),^TMP("PXRMLPPA",$J),^TMP("PXRMLPPI",$J)
|
---|
| 46 | D LIST(.VALMCNT,.IEN,INCINST)
|
---|
| 47 | F IND=1:1:VALMCNT D
|
---|
| 48 | .S ^TMP("PXRMLPP",$J,"IDX",IND,IND)=^TMP("PXRMLPPI",$J,IND)
|
---|
| 49 | K ^TMP("PXRMLPPI",$J)
|
---|
| 50 | Q
|
---|
| 51 | DEM ;
|
---|
| 52 | D FULL^VALM1
|
---|
| 53 | D EN^PXRMPDR(IEN)
|
---|
| 54 | S VALMBCK="R"
|
---|
| 55 | Q
|
---|
| 56 | ;
|
---|
| 57 | EDIT ;Edit selected patient list fields.
|
---|
| 58 | N DA,DIE,DR,TEMP
|
---|
| 59 | S DA=IEN,DIE="^PXRMXP(810.5,"
|
---|
| 60 | S DR=".01;.08"
|
---|
| 61 | I $D(^XUSEC("PXRM MANAGER",DUZ)) S DR=DR_";.07"
|
---|
| 62 | D ^DIE
|
---|
| 63 | S TEMP=^PXRMXP(810.5,IEN,0)
|
---|
| 64 | S LNAME=$P(TEMP,U,1),CREATOR=$P(TEMP,U,7),TYPE=$P(TEMP,U,8)
|
---|
| 65 | S CREATOR=$P(^VA(200,CREATOR,0),U,1)
|
---|
| 66 | D HDR^PXRMLPP
|
---|
| 67 | S VALMBCK="R"
|
---|
| 68 | Q
|
---|
| 69 | ;
|
---|
| 70 | EDITOK(IEN) ;Screen for protocol PXRM PATIENT LIST EDIT, return true if
|
---|
| 71 | ;the user is permitted to edit the selected patient list.
|
---|
| 72 | I $D(^XUSEC("PXRM MANAGER",DUZ)) Q 1
|
---|
| 73 | N CREATOR
|
---|
| 74 | S CREATOR=$P(^PXRMXP(810.5,IEN,0),U,7)
|
---|
| 75 | Q $S(CREATOR=DUZ:1,1:0)
|
---|
| 76 | ;
|
---|
| 77 | ENTRY ;Entry code
|
---|
| 78 | D BLDLIST(IEN)
|
---|
| 79 | D XQORM
|
---|
| 80 | Q
|
---|
| 81 | ;
|
---|
| 82 | EXIT ;Exit code
|
---|
| 83 | K ^TMP("PXRMLPP",$J)
|
---|
| 84 | K ^TMP("PXRMLPPH",$J)
|
---|
| 85 | D CLEAN^VALM10
|
---|
| 86 | D FULL^VALM1
|
---|
| 87 | S VALMBCK="R"
|
---|
| 88 | Q
|
---|
| 89 | ;
|
---|
| 90 | FRE(NUMBER,NAME,INST,DFN) ;Format entry number, name and primary station
|
---|
| 91 | N TEMP,TNAME,TSOURCE
|
---|
| 92 | S TEMP=$$RJ^XLFSTR(NUMBER,5," ")
|
---|
| 93 | S TNAME=$E(NAME,1,30)
|
---|
| 94 | S TEMP=TEMP_" "_$$LJ^XLFSTR(TNAME,32," ")
|
---|
| 95 | S TEMP=TEMP_" "_$$LJ^XLFSTR(DFN,15," ")
|
---|
| 96 | I INST'="" S TEMP=TEMP_" "_INST
|
---|
| 97 | Q TEMP
|
---|
| 98 | ;
|
---|
| 99 | HDR ; Header code
|
---|
| 100 | S VALMHDR(1)="List Name: "_LNAME_" ("_VALMCNT_" patients)"
|
---|
| 101 | S VALMHDR(2)=" Created: "_$$FMTE^XLFDT(CDATE,"5Z")
|
---|
| 102 | S VALMHDR(2)=$$LJ^XLFSTR(VALMHDR(2),40)_"Creator: "_CREATOR
|
---|
| 103 | S VALMHDR(3)=" Class: "_CLASS
|
---|
| 104 | S VALMHDR(3)=$$LJ^XLFSTR(VALMHDR(3),40)_"Type: "_TYPE
|
---|
| 105 | S VALMHDR(4)=" Source: "_SNAME
|
---|
| 106 | S VALMSG="+ Next Screen - Prev Screen ?? More Actions"
|
---|
| 107 | Q
|
---|
| 108 | ;
|
---|
| 109 | HLP ;Help code
|
---|
| 110 | N ORU,ORUPRMT,SUB,XQORM
|
---|
| 111 | S SUB="PXRMLPPH"
|
---|
| 112 | D EN^VALM("PXRM PATIENT LIST HELP")
|
---|
| 113 | Q
|
---|
| 114 | HSA ;Print Health Summary for all patients on list
|
---|
| 115 | D HSA^PXRMLPHS(IEN)
|
---|
| 116 | S VALMBCK="R"
|
---|
| 117 | Q
|
---|
| 118 | ;
|
---|
| 119 | HSI ;Print Health Summary for selected patients.
|
---|
| 120 | ;Full Screen
|
---|
| 121 | W IORESET
|
---|
| 122 | N IND,DFN,PLNODE,PNAME,VALMY
|
---|
| 123 | D EN^VALM2(XQORNOD(0))
|
---|
| 124 | ;If there is no list quit.
|
---|
| 125 | I '$D(VALMY) Q
|
---|
| 126 | S PLNODE="PXRMLPHS"_$J_$$NOW^XLFDT
|
---|
| 127 | K ^XTMP(PLNODE)
|
---|
| 128 | S ^XTMP(PLNODE,0)=$$FMADD^XLFDT(DT,2)_U_DT_"HSI LIST"
|
---|
| 129 | S IND="",PXRMDONE=0
|
---|
| 130 | F S IND=$O(VALMY(IND)) Q:(+IND=0)!(PXRMDONE) D
|
---|
| 131 | .;Get the patient list ien.
|
---|
| 132 | .S DFN=^TMP("PXRMLPP",$J,"IDX",IND,IND)
|
---|
| 133 | .;DBIA #10035
|
---|
| 134 | .S PNAME=$P(^DPT(DFN,0),U,1)
|
---|
| 135 | .S ^XTMP(PLNODE,PNAME)=DFN
|
---|
| 136 | D HSI^PXRMLPHS(PLNODE)
|
---|
| 137 | S VALMBCK="R"
|
---|
| 138 | Q
|
---|
| 139 | ;
|
---|
| 140 | INIT ;Init
|
---|
| 141 | S VALMCNT=0
|
---|
| 142 | Q
|
---|
| 143 | ;
|
---|
| 144 | LIST(VALMCNT,IEN,INCINST) ;Build a list of patients.
|
---|
| 145 | N DATA,DFN,IND,INST,NEXT,PNAME,SUB
|
---|
| 146 | ;Build the ordered list.
|
---|
| 147 | S IND=0,SUB="NAME"
|
---|
| 148 | F S IND=$O(^PXRMXP(810.5,IEN,30,IND)) Q:'IND D
|
---|
| 149 | .S DATA=$G(^PXRMXP(810.5,IEN,30,IND,0)) Q:DATA=""
|
---|
| 150 | .S DFN=$P(DATA,U) Q:'DFN
|
---|
| 151 | .;#DBIA 10035
|
---|
| 152 | .S PNAME=$P($G(^DPT(DFN,0)),U,1)
|
---|
| 153 | .S INSTNUM=$P(DATA,U,2) S:INSTNUM="" INSTNUM="NONE"
|
---|
| 154 | .S INST=$P(DATA,U,3)
|
---|
| 155 | .;Lists built before PXRM*2*4 will only have the Institution ien.
|
---|
| 156 | .I INST="" S INST=$P(DATA,U,2)
|
---|
| 157 | .I INST="" S INST="NONE"
|
---|
| 158 | .I PXRMVIEW="I" S SUB=INST
|
---|
| 159 | .S ^TMP("PXRMLPPA",$J,SUB,PNAME,DFN)=INST
|
---|
| 160 | ;Transfer to list manager array
|
---|
| 161 | S SUB="",VALMCNT=0
|
---|
| 162 | F S SUB=$O(^TMP("PXRMLPPA",$J,SUB)) Q:SUB="" D
|
---|
| 163 | .S (INST,PNAME)=""
|
---|
| 164 | .F S PNAME=$O(^TMP("PXRMLPPA",$J,SUB,PNAME)) Q:PNAME="" D
|
---|
| 165 | ..S DFN=""
|
---|
| 166 | ..F S DFN=$O(^TMP("PXRMLPPA",$J,SUB,PNAME,DFN)) Q:DFN="" D
|
---|
| 167 | ...I INCINST S INST=^TMP("PXRMLPPA",$J,SUB,PNAME,DFN)
|
---|
| 168 | ...S VALMCNT=VALMCNT+1
|
---|
| 169 | ...S ^TMP("PXRMLPP",$J,VALMCNT,0)=$$FRE(VALMCNT,PNAME,INST,DFN)
|
---|
| 170 | ...S ^TMP("PXRMLPPI",$J,VALMCNT)=DFN
|
---|
| 171 | K ^TMP("PXRMLPPA",$J)
|
---|
| 172 | Q
|
---|
| 173 | ;
|
---|
| 174 | PEXIT ;PXRM PATIENT LIST PATIENTS MENU protocol exit code
|
---|
| 175 | S VALMSG="+ Next Screen - Prev Screen ?? More Actions"
|
---|
| 176 | D XQORM
|
---|
| 177 | Q
|
---|
| 178 | ;
|
---|
| 179 | USER ;
|
---|
| 180 | I $P($G(^PXRMXP(810.5,IEN,0)),U,8)="PUB" D FULL^VALM1 W !,"This option is locked for Public Lists." H 2 Q
|
---|
| 181 | D FULL^VALM1
|
---|
| 182 | D START^PXRMLPAU(IEN)
|
---|
| 183 | S VALMBCK="R"
|
---|
| 184 | Q
|
---|
| 185 | ;
|
---|
| 186 | USR(IEN) ;Screen for protocol PXRM PATIENT LIST AUTH USER
|
---|
| 187 | N TYPE
|
---|
| 188 | S TYPE=$P(^PXRMXP(810.5,IEN,0),U,8)
|
---|
| 189 | ;Public lists cannot have individual user access.
|
---|
| 190 | I TYPE="PUB" Q "N"
|
---|
| 191 | Q $$ACCESS^PXRMLPU(IEN)
|
---|
| 192 | ;
|
---|
| 193 | VIEW ;Select view
|
---|
| 194 | W IORESET
|
---|
| 195 | S VALMBCK="R",VALMBG=1
|
---|
| 196 | N X,Y,CODE,DIR
|
---|
| 197 | K DIROUT,DIRUT,DTOUT,DUOUT
|
---|
| 198 | S DIR(0)="S"_U_"I:Sort by Institution and Name;"
|
---|
| 199 | S DIR(0)=DIR(0)_"N:Sort by Name;"
|
---|
| 200 | S DIR("A")="TYPE OF VIEW"
|
---|
| 201 | S DIR("B")=$S(PXRMVIEW="N":"I",1:"N")
|
---|
| 202 | S DIR("?")="Select from the codes displayed."
|
---|
| 203 | D ^DIR K DIR
|
---|
| 204 | I $D(DIROUT) S DTOUT=1
|
---|
| 205 | I $D(DTOUT)!($D(DUOUT)) Q
|
---|
| 206 | ;Change display type
|
---|
| 207 | S PXRMVIEW=Y
|
---|
| 208 | ;Rebuild Workfile
|
---|
| 209 | D BLDLIST^PXRMLPP(IEN),HDR
|
---|
| 210 | Q
|
---|
| 211 | ;
|
---|
| 212 | XSEL ;PXRM PATIENT LIST PATIENT SELECT validation
|
---|
| 213 | N EPIEN,DFN,SEL
|
---|
| 214 | S SEL=$P(XQORNOD(0),"=",2)
|
---|
| 215 | ;Remove trailing ,
|
---|
| 216 | I $E(SEL,$L(SEL))="," S SEL=$E(SEL,1,$L(SEL)-1)
|
---|
| 217 | ;Invalid selection
|
---|
| 218 | I SEL["," D Q
|
---|
| 219 | .W $C(7),!,"Only one item number allowed." H 2
|
---|
| 220 | .S VALMBCK="R"
|
---|
| 221 | I ('SEL)!(SEL>VALMCNT)!('$D(@VALMAR@("IDX",SEL))) D Q
|
---|
| 222 | .W $C(7),!,SEL_" is not a valid item number." H 2
|
---|
| 223 | .S VALMBCK="R"
|
---|
| 224 | ;
|
---|
| 225 | ;Get the patient list ien
|
---|
| 226 | S DFN=^TMP("PXRMLPP",$J,"IDX",SEL,SEL)
|
---|
| 227 | ;Full screen mode
|
---|
| 228 | D FULL^VALM1
|
---|
| 229 | ;Print individual Health Summary
|
---|
| 230 | D HSI^PXRMLPHS(DFN)
|
---|
| 231 | S VALMBCK="R"
|
---|
| 232 | Q
|
---|
| 233 | ;
|
---|
| 234 | XQORM S XQORM("#")=$O(^ORD(101,"B","PXRM PATIENT LIST PATIENT SELECT",0))_U_"1:"_VALMCNT
|
---|
| 235 | S XQORM("A")="Select Item: "
|
---|
| 236 | Q
|
---|
| 237 | ;
|
---|