| 1 | SCUTBK11 ;ALB/SCK - Scheduling Broker Utilities; 2/2/96 ;9/7/96  17:28
 | 
|---|
| 2 |  ;;5.3;Scheduling;**41,54,86,148,177,205,209,255,297**;AUG 13, 1993
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 |  Q
 | 
|---|
| 5 | PARSE(SC) ;
 | 
|---|
| 6 |  S SCDFN=$G(SC("DFN"),"")
 | 
|---|
| 7 |  S SCPIEN=$G(SC("PIEN"),"")
 | 
|---|
| 8 |  S:$D(SC("TEAM")) SCTM=$G(SC("TEAM"))
 | 
|---|
| 9 |  S:$D(SC("BEGIN")) SCDT("BEGIN")=$G(SC("BEGIN"))
 | 
|---|
| 10 |  S:$D(SC("END")) SCDT("END")=$G(SC("END"))
 | 
|---|
| 11 |  I $D(SC("END")) S SCDT("INCL")=0
 | 
|---|
| 12 |  S SCFILE=$G(SC("FILE"))
 | 
|---|
| 13 |  S SCIEN=$G(SC("IEN"))
 | 
|---|
| 14 |  S SCFIELD=$G(SC("FIELD"))
 | 
|---|
| 15 |  S SCVAL=$G(SC("VALUE"))
 | 
|---|
| 16 |  Q
 | 
|---|
| 17 |  ;
 | 
|---|
| 18 | TMLST(SCDATA,SC) ;
 | 
|---|
| 19 |  ;  -- Return a list of teams for a patient.  Pass in the DFN and
 | 
|---|
| 20 |  ;     optionally a date range and/or a team purpose to restrict the
 | 
|---|
| 21 |  ;     team look up.  Return only the team entry, strip out any other
 | 
|---|
| 22 |  ;     array items.
 | 
|---|
| 23 |  ;
 | 
|---|
| 24 |  N DFN,SCDT,SCPURP,SCLIST,SCER1,SCOK,SCD
 | 
|---|
| 25 |  ;
 | 
|---|
| 26 |  D CHK^SCUTBK
 | 
|---|
| 27 |  D TMP^SCUTBK
 | 
|---|
| 28 |  ;
 | 
|---|
| 29 |  S DFN=$G(SC("DFN"))
 | 
|---|
| 30 |  S SCDT("BEGIN")=$G(SC("BEGIN"),"")
 | 
|---|
| 31 |  I $L(SCDT("BEGIN"))>2 S SCDT("INCL")=$G(SC("INCL"),0)
 | 
|---|
| 32 |  S SCDT("END")=$G(SC("END"),"")
 | 
|---|
| 33 |  S SCPURP=$G(SC("PURP"),"")
 | 
|---|
| 34 |  ;
 | 
|---|
| 35 |  S SCOK=$$TMPT^SCAPMC3(DFN,"SCDT","","SCD","SCER1")
 | 
|---|
| 36 |  ;
 | 
|---|
| 37 |  S I=0 F  S I=$O(SCD(I)) Q:'I  S SCDATA(I)=SCD(I)
 | 
|---|
| 38 | TMQ Q
 | 
|---|
| 39 |  ;
 | 
|---|
| 40 | FINDP(SCOUT,SCIN) ; patient lookup used by SC PATIENT LOOKUP rpc
 | 
|---|
| 41 |  ; input:
 | 
|---|
| 42 |  ;   SCIN("VALUE") = value to lookup
 | 
|---|
| 43 |  ;     Lookup uses multiple index lookup of File #2
 | 
|---|
| 44 |  ; output:
 | 
|---|
| 45 |  ;   SCOUT = location of data = ^TMP("DILIST",$J,i,0)
 | 
|---|
| 46 |  ;   for i=1:number of records returned: 
 | 
|---|
| 47 |  ;    DFN^patient name^DOB^PID^DOD
 | 
|---|
| 48 |  ;     1        2       3   4   5
 | 
|---|
| 49 |  ;
 | 
|---|
| 50 |  ;bp/cmf 205 original code next line
 | 
|---|
| 51 |  ;D FIND^DIC(2,,".01;.03;.363;.09","MPS",SCIN("VALUE"),500)
 | 
|---|
| 52 |  ;bp/cmf 205 change code next line
 | 
|---|
| 53 |  ;oifo/swo 297 added .351 for DOD warning new functionality
 | 
|---|
| 54 |  D FIND^DIC(2,,".01;.03;.363;.09;.351","PS",SCIN("VALUE"),300,"B^BS^BS5^SSN")
 | 
|---|
| 55 |  I $G(DIERR) D CLEAN^DILF Q
 | 
|---|
| 56 |  N SCOUNT S SCOUNT=+^TMP("DILIST",$J,0)
 | 
|---|
| 57 |  N SC F SC=1:1:SCOUNT D
 | 
|---|
| 58 |  . N NODE,SSN,DSSN,PLID
 | 
|---|
| 59 |  . S NODE=^TMP("DILIST",$J,SC,0)
 | 
|---|
| 60 |  . ;Apply DOB screen
 | 
|---|
| 61 |  . S $P(NODE,U,3)=$$DOB^DPTLK1(+NODE)
 | 
|---|
| 62 |  . ;Apply SSN screen
 | 
|---|
| 63 |  . S SSN=$$SSN^DPTLK1(+NODE)
 | 
|---|
| 64 |  . S DSSN=$E(SSN,1,3)_"-"_$E(SSN,4,5)_"-"_$E(SSN,6,11)
 | 
|---|
| 65 |  . S PLID=$P(NODE,U,4)
 | 
|---|
| 66 |  . I $E(SSN,1,9)'?9N S (DSSN,PLID)=SSN
 | 
|---|
| 67 |  . S $P(NODE,U,4)=$S($L(PLID)>5:PLID,1:DSSN)
 | 
|---|
| 68 |  . ;Move screened data back into output global
 | 
|---|
| 69 |  . ;oifo/swo 297 piece 6 is DOD field. Added for DOD warning
 | 
|---|
| 70 |  . S ^TMP("DILIST",$J,SC,0)=$P(NODE,U,1,4)_U_$P(NODE,U,6)
 | 
|---|
| 71 |  K ^TMP("DILIST",$J,0)
 | 
|---|
| 72 |  K SCOUT S SCOUT="^TMP(""DILIST"","_$J_")"
 | 
|---|
| 73 |  Q
 | 
|---|
| 74 | PSLST(SCDATA,SC) ;
 | 
|---|
| 75 |  ;
 | 
|---|
| 76 |  ;  - Returns a array of positions that show the person currently
 | 
|---|
| 77 |  ;    assigned to the position, the preceptor for that position,
 | 
|---|
| 78 |  ;    for the patient is assigned to.
 | 
|---|
| 79 |  ;
 | 
|---|
| 80 |  ;    Pass in the Patient's DFN
 | 
|---|
| 81 |  ;    To restrict to specific entries, pass in the following:
 | 
|---|
| 82 |  ;      Beginning and Ending Date Range 
 | 
|---|
| 83 |  ;      A specific Team Position
 | 
|---|
| 84 |  ;      A Specific User entry (8930)
 | 
|---|
| 85 |  ;      A specific Team Purpose.  (Read SCAPMC23 for how it exclude
 | 
|---|
| 86 |  ;        a specific team purpose.
 | 
|---|
| 87 |  ;      A specific role
 | 
|---|
| 88 |  ;      Flag whether to include patients associated by enrollement
 | 
|---|
| 89 |  ;    
 | 
|---|
| 90 |  N SCDT,SCD,SCER1,SCDFN,SCPRP,SCPST,SCRLE,SCIND,SCUSR,SCTM,SCDTE
 | 
|---|
| 91 |  ;
 | 
|---|
| 92 |  D CHK^SCUTBK
 | 
|---|
| 93 |  D TMP^SCUTBK
 | 
|---|
| 94 |  ;
 | 
|---|
| 95 |  D PARSE(.SC)
 | 
|---|
| 96 |  S SCDTE=$G(SCDT("BEGIN"))
 | 
|---|
| 97 |  ;
 | 
|---|
| 98 |  S CNT=0
 | 
|---|
| 99 |  K ^TMP($J,"PSLST")
 | 
|---|
| 100 |  S SCOK=$$TPPT^SCAPMC(SCDFN,.SCDT,"","","","","","SCD","SCER1")
 | 
|---|
| 101 |  S I=0 F  S I=$O(SCD(I)) Q:'I  D
 | 
|---|
| 102 |  . I $D(SCTM) D
 | 
|---|
| 103 |  .. Q:$P(SCD(I),U,3)'=SCTM
 | 
|---|
| 104 |  .. S ^TMP($J,"PSLST",I)=$P($G(SCD(I)),U,3)_U_$P($G(SCD(I)),U,4)_U_$P($G(SCD(I)),U,1,2)_U_$P($G(SCD(I)),U,7,8)
 | 
|---|
| 105 |  . ;
 | 
|---|
| 106 |  . I '$D(SCTM) D
 | 
|---|
| 107 |  .. S ^TMP($J,"PSLST",I)=$P($G(SCD(I)),U,3)_U_$P($G(SCD(I)),U,4)_U_$P($G(SCD(I)),U,1,2)_U_$P($G(SCD(I)),U,7,8)
 | 
|---|
| 108 |  ;
 | 
|---|
| 109 |  S CNT=0
 | 
|---|
| 110 |  S I=""
 | 
|---|
| 111 |  F  S I=$O(^TMP($J,"PSLST",I)) Q:'I  D
 | 
|---|
| 112 |  . S:'$D(SCDTE) SCDTE=DT
 | 
|---|
| 113 |  . S SCPIEN=$P($G(^TMP($J,"PSLST",I)),U,3)
 | 
|---|
| 114 |  . S SCDATA(CNT)=^TMP($J,"PSLST",I)_U_$$PSMBR(SCPIEN,SCDTE)_U_+$P($G(^SCPT(404.43,$P($G(^TMP($J,"PSLST",I)),U,2),0)),U,5)_U_+$P($G(^SCTM(404.57,SCPIEN,0)),U,4)
 | 
|---|
| 115 |  . S CNT=CNT+1
 | 
|---|
| 116 |  K ^TMP($J,"PSLST")
 | 
|---|
| 117 |  ;
 | 
|---|
| 118 | PSLTQ Q
 | 
|---|
| 119 |  ;
 | 
|---|
| 120 | PSMBR(SCPIEN,SCPDT) ;
 | 
|---|
| 121 |  ;
 | 
|---|
| 122 |  N SCPRCP,SCMBR,SCPP
 | 
|---|
| 123 |  ;
 | 
|---|
| 124 |  S SCMBR=$$GETPRTP^SCAPMCU2(SCPIEN,SCPDT)
 | 
|---|
| 125 |  S SCMBR=$S(+SCMBR>0:SCMBR,1:U)
 | 
|---|
| 126 |  S SCPP=$$OKPREC2^SCMCLK(SCPIEN,SCPDT)
 | 
|---|
| 127 |  S SCPRCP=$S(+SCPP>0:SCPP,1:U)
 | 
|---|
| 128 |  Q SCMBR_U_SCPRCP
 | 
|---|
| 129 |  ;
 | 
|---|
| 130 | VFILE(SCOK,SC) ;
 | 
|---|
| 131 |  N SCFILE,SCIEN,SCFIELD,SCVAL,SCFDA,SCMSG
 | 
|---|
| 132 |  ;
 | 
|---|
| 133 |  D CHK^SCUTBK
 | 
|---|
| 134 |  D TMP^SCUTBK
 | 
|---|
| 135 |  ;
 | 
|---|
| 136 |  S SCOK=1
 | 
|---|
| 137 |  D PARSE(.SC)
 | 
|---|
| 138 |  S SCFDA(SCFILE,""_SCIEN_","_"",SCFIELD)=SCVAL
 | 
|---|
| 139 |  ;
 | 
|---|
| 140 |  D FILE^DIE("K","SCFDA","SCMSG")
 | 
|---|
| 141 |  ;
 | 
|---|
| 142 |  I $D(SCMSG("DIERR")) D
 | 
|---|
| 143 |  . S SCOK=0
 | 
|---|
| 144 |  Q
 | 
|---|
| 145 |  ;
 | 
|---|
| 146 | SECKEY(SCOK,SCKEY) ;
 | 
|---|
| 147 |  ;
 | 
|---|
| 148 |  D CHK^SCUTBK
 | 
|---|
| 149 |  ;
 | 
|---|
| 150 |  S SCOK=$D(^XUSEC(SCKEY,DUZ))
 | 
|---|
| 151 |  Q
 | 
|---|
| 152 |  ;
 | 
|---|
| 153 | PSALST(SCDATA,SC) ;
 | 
|---|
| 154 |  ;
 | 
|---|
| 155 |  ;  - Returns a array of positions that show the person currently
 | 
|---|
| 156 |  ;    assigned to the position, the preceptor for that position,
 | 
|---|
| 157 |  ;    for the patient is assigned to.
 | 
|---|
| 158 |  ;
 | 
|---|
| 159 |  ;    Pass in the Patient's DFN
 | 
|---|
| 160 |  ;    To restrict to specific entries, pass in the following:
 | 
|---|
| 161 |  ;      Beginning and Ending Date Range 
 | 
|---|
| 162 |  ;      A specific Team Position
 | 
|---|
| 163 |  ;      A Specific User entry (8930)
 | 
|---|
| 164 |  ;      A specific Team Purpose.  (Read SCAPMC23 for how it exclude
 | 
|---|
| 165 |  ;        a specific team purpose.
 | 
|---|
| 166 |  ;      A specific role
 | 
|---|
| 167 |  ;      Flag whether to include patients associated by enrollement
 | 
|---|
| 168 |  ;    
 | 
|---|
| 169 |  N SCDT,SCD,SCER1,SCDFN,SCPRP,SCPST,SCRLE,SCIND,SCUSR,SCTM,SCDTE,SCPTTMA
 | 
|---|
| 170 |  ;
 | 
|---|
| 171 |  D CHK^SCUTBK
 | 
|---|
| 172 |  D TMP^SCUTBK
 | 
|---|
| 173 |  ;
 | 
|---|
| 174 |  D PARSE(.SC)
 | 
|---|
| 175 |  S SCPTTMA=$G(SC("TEAMASSIGN")) ;NEW JLU
 | 
|---|
| 176 |  S SCDTE=$G(SCDT("BEGIN"),DT)   ;bp/cmf 177 added DT for gui
 | 
|---|
| 177 |  ;
 | 
|---|
| 178 |  S CNT=0
 | 
|---|
| 179 |  K ^TMP($J,"PSLST")
 | 
|---|
| 180 |  S SCOK=$$TPPT^SCAPMC(SCDFN,.SCDT,"","","","","","SCD","SCER1")
 | 
|---|
| 181 |  S I=0 F  S I=$O(SCD(I)) Q:'I  D
 | 
|---|
| 182 |  .Q:$P(SCD(I),U,11)'=SCPTTMA
 | 
|---|
| 183 |  .S ^TMP($J,"PSLST",I)=$P($G(SCD(I)),U,3)_U_$P($G(SCD(I)),U,4)_U_$P($G(SCD(I)),U,1,2)_U_$P($G(SCD(I)),U,7,8)
 | 
|---|
| 184 |  ;
 | 
|---|
| 185 |  S CNT=0
 | 
|---|
| 186 |  S I=""
 | 
|---|
| 187 |  F  S I=$O(^TMP($J,"PSLST",I)) Q:'I  D
 | 
|---|
| 188 |  . S:'$D(SCDTE) SCDTE=DT
 | 
|---|
| 189 |  . S SCPIEN=$P($G(^TMP($J,"PSLST",I)),U,3)
 | 
|---|
| 190 |  . S SCDATA(CNT)=^TMP($J,"PSLST",I)_U_$$PSMBR(SCPIEN,SCDTE)_U_+$P($G(^SCPT(404.43,$P($G(^TMP($J,"PSLST",I)),U,2),0)),U,5)_U_+$P($G(^SCTM(404.57,SCPIEN,0)),U,4)
 | 
|---|
| 191 |  . S CNT=CNT+1
 | 
|---|
| 192 |  K ^TMP($J,"PSLST")
 | 
|---|
| 193 |  ;
 | 
|---|
| 194 | PSALSTQ Q
 | 
|---|