1 | LRCAPPH ;DALOI/FHS - PROCESS PHLEBOTOMY WORKLOAD DATA ; 5/1/99
|
---|
2 | ;;5.2;LAB SERVICE;**1,19,127,136,138,158,153,263,264**;Sep 27, 1994
|
---|
3 | ;**DBIA 1995-A Retrieve CPT codes
|
---|
4 | ;**DBIA 1995-B Retrieve CPT Modifiers
|
---|
5 | ;**DBIA 1889-A Pass PCE Encounter Data
|
---|
6 | ;**DBIA 1889-B Delete PCE Entries
|
---|
7 | ;**DBIA 1889-F Extract PCE Data
|
---|
8 | ; Reference to ^DIC(9.4, Supported by Reference 10048
|
---|
9 | ; Reference to ^SC( Supported by Reference 10040
|
---|
10 | ; Reference to ^%ZOSF("TEST") Supported by Reference #10096
|
---|
11 | ; Reference to ^DIC(40.7 Supported by Reference #923
|
---|
12 | ; Reference to ^XMB(1 Supported by Reference #10091
|
---|
13 | ; Reference to T0^%ZOSV Supported by Reference #10097
|
---|
14 | ; Reference to T1^%ZOSV Supported by Reference #10097
|
---|
15 | ; Reference to ^DIC( Supported by Reference #10006
|
---|
16 | ; Reference to EN3^SDACS Supported by DBIA #10041
|
---|
17 | ; No longer called
|
---|
18 | ; Reference to $$PKGON^VSIT Supported by DBIA #1900-E
|
---|
19 | ; Reference to $$NOW^XLFDT Supported by Reference #10103
|
---|
20 | ; Reference to $$GET^XUA4A72 Supported by Reference #1625
|
---|
21 | EN ;
|
---|
22 | I $G(^LRO(69,"AE"))'=DT D
|
---|
23 | . D EN0^LRCAPPH3
|
---|
24 | . S ^LRO(69,"AE")=DT
|
---|
25 | NP ;Not performed entry tag Called from LRCAPPNP
|
---|
26 | N LRSPEC,LR657,LR658
|
---|
27 | D
|
---|
28 | . K DIC S DIC="^LAM(",DIC(0)="ONMX"
|
---|
29 | . S X="89343.0000",LR657=657 D ^DIC I Y>1 S LR657=+Y
|
---|
30 | . S X="89341.0000",LR658=658 D ^DIC I Y>1 S LR658=+Y
|
---|
31 | K ^LRO(69,"AE",0)
|
---|
32 | I $G(LRNP) S LRNOPX=1
|
---|
33 | I $D(ZTQUEUED) S ZTREQ="@" K LRDBUG
|
---|
34 | I '$G(LRDBUG) K ^TMP("LRMOD",$J)
|
---|
35 | S LRDPRAC=+$P($G(^LAB(69.9,1,12)),U)
|
---|
36 | I LRDPRAC D
|
---|
37 | . N DIC,X
|
---|
38 | . S DIC(0)="NZ",DIC=200,X="`"_LRDPRAC
|
---|
39 | . D ^DIC S LRDPRAC=$S(Y<1:0,$P($G(Y(0)),U,11):0,1:+Y)
|
---|
40 | . I $$GET^XUA4A72(LRDPRAC)<1 S LRDPRAC=0
|
---|
41 | S LROK=+$G(^LAB(69.9,1,.8)) G:'LROK END0
|
---|
42 | I $P($G(^SC(LROK,0)),U)'["LAB DIV " G END0
|
---|
43 | K LROK
|
---|
44 | I '$G(LRNP) L +^LRO("LRCAPPH","NITE"):1 G:'$T END0
|
---|
45 | S:'$D(^LAB(69.9,1,"NITE")) ^("NITE")=""
|
---|
46 | S LRWRKL=$S($P(^LAB(69.9,1,0),U,14):1,1:0)
|
---|
47 | I $D(XRTL) S XRTN="LRCAPPH" D T0^%ZOSV
|
---|
48 | S LRPKG=$O(^DIC(9.4,"C","LR",0))
|
---|
49 | S:'LRPKG LRPKG=$O(^DIC(9.4,"B","LAB SERVICE",0))
|
---|
50 | G:'LRPKG END0
|
---|
51 | S LRVSIT=$P($G(^LAB(69.9,1,"VSIT")),U)
|
---|
52 | S X="PXAI" X ^%ZOSF("TEST") I '$T G END0
|
---|
53 | S:'$G(LRNP) $P(^LAB(69.9,1,"NITE"),U,2)=$$NOW^XLFDT
|
---|
54 | S LRPCEON=$$PKGON^VSIT("PX")
|
---|
55 | S ^TMP("LRMOD",$J)=""
|
---|
56 | SDC S SDC=$S($P(^LAB(69.9,1,"NITE"),U,3):$G(^DIC(40.7,+$P(^LAB(69.9,1,"NITE"),U,3),0)),1:"") S LRSDC=$S($P(SDC,U,2):+$P(SDC,U,2),1:108)
|
---|
57 | DSSLOC S LRDLOC=+$G(^LAB(69.9,1,.8))
|
---|
58 | S LCWT=$P($G(^LAM(LR658,0)),U,3)_U_$P($G(^LAM(LR658,0)),U,10)
|
---|
59 | S LSPWT=$P($G(^LAM(LR657,0)),U,3)_U_$P($G(^LAM(LR657,0)),U,10)
|
---|
60 | S LRCSC=+$G(^LAB(69.9,1,"VSIT"))
|
---|
61 | S LRINS=+$P($G(^XMB(1,1,"XUS")),U,17) G END0:'LRINS
|
---|
62 | HEAC ;
|
---|
63 | D
|
---|
64 | . N DIC,Y,X
|
---|
65 | . S DIC="^LRO(68,",DIC(0)="MO",X="HEM" D ^DIC
|
---|
66 | . I Y>0 S LRDAA=+Y Q
|
---|
67 | . S LRDAA=10
|
---|
68 | S LRSPEC=$P($G(^LAB(69.9,1,1)),U)
|
---|
69 | I $G(LRNP) S LRNOPX=0 Q
|
---|
70 | S (LRCEX,LRCEXV,LREND,LROA)=0 F S LRCEX=$O(^LRO(69,"AA",LRCEX)) Q:LRCEX=""!(LREND) D
|
---|
71 | . K LRXCPT
|
---|
72 | . S (LROA,LRCC)="" F S LROA=$O(^LRO(69,"AA",LRCEX,LROA)) Q:LROA="" S LRCDT=+LROA,LRSN=+$P(LROA,"|",2) D:LRCDT&(LRSN) LOOK D
|
---|
73 | . . I '$G(LRDBUG) K:'$G(^LRO(69,"AA",LRCEX,LROA)) ^(LROA)
|
---|
74 | AE ;Process NP specimens and delete CPT procedures
|
---|
75 | K LRXCPT D ^LRCAPPNP
|
---|
76 | END0 Q:$G(LRDBUG)
|
---|
77 | K I,LRAA,LRCC,LRCDT,LRLD,LRIN,LRINS,LRNT,LROA,LRSN,LRPWT,NODE,X,LREND,LRWRKL,SDC,SDIV,SDATE,SDCTYPE,SDMSG,LRSPWT,LOC,LCWT,LSPWT,LRO,LRSDTC,LSPWT,LRSDC
|
---|
78 | K LRVSIT,EDATE,^TMP("LRPXAPI",$J),LRPCEON,DFN,LRCE,LRCSQ,SDUZ,EDATE
|
---|
79 | K LRCEX,LRCEXV,CPT,LRNINS,LRCDT,LREDT,LRCNT,LRI,LRICPT,LRINA,LRNLT,LRPKG
|
---|
80 | K LRREL,LRSN,LRSTP,LRTST,LRTSTP,LRVSIT,NODE,LRPRO
|
---|
81 | K LRDLOC,LRDSSLOC,LRNOP,SDERR,PXKDONE,VSIT,DIC,LRCSC,LRDFN
|
---|
82 | K LRDPRAC,LROK,LRXCPT
|
---|
83 | K ^TMP("LRMOD",$J)
|
---|
84 | I $D(XRT0) S XRTN="END^LRCAPPH" D T1^%ZOSV
|
---|
85 | S $P(^LAB(69.9,1,"NITE"),U,2)="" L -^LRO("LRCAPPH","NITE")
|
---|
86 | Q
|
---|
87 | LOOK ;From LRCAPPNP
|
---|
88 | N LRDUZ
|
---|
89 | Q:'$D(^LRO(69,LRCDT,1,LRSN,0))#2 S NODE=^(0)
|
---|
90 | S LRDFN=+NODE Q:'$D(^LR(LRDFN,0))#2 S LRDPF=+$P(^(0),U,2),DFN=+$P(^(0),U,3)
|
---|
91 | Q:'DFN!(LRDPF'=2)
|
---|
92 | S LRDUZ=$S($P(NODE,U,2):$P(NODE,U,2),1:DUZ)
|
---|
93 | S LRCC=$S(($P(NODE,U,4)="LC"!($P(NODE,U,4)="I")):LR658,$P(NODE,U,4)="SP":LR657,1:0)
|
---|
94 | Q:'$D(^LRO(69,LRCDT,1,LRSN,1))#2 S NODE(1)=^(1) Q:$P(NODE(1),U,4)'="C" S LRNT=+NODE(1),LRIN=$S($P(NODE(1),U,8):$P(NODE(1),U,8),1:LRINS),LRCE=+$G(^(.1))
|
---|
95 | I $G(LRNP) S LRNOPX=1 Q
|
---|
96 | D:LRCSC EN3 I 'LRWRKL S:'$G(LRDBUG) $P(^LRO(69,LRCDT,1,LRSN,0),U,10)=1,LRCEXV=$G(LRCEX) Q
|
---|
97 | Q:$G(^LRO(69,"AA",LRCEX,LROA))
|
---|
98 | PHLE I $G(LRCC),LRCEX'=$G(LRCEXV) D
|
---|
99 | . S LREDT=$P($G(^LRO(69,LRCDT,1,LRSN,3)),U) Q:'LREDT
|
---|
100 | . N LRCDT,LRIN,DIC,X,Y
|
---|
101 | . S X="`"_$P(NODE,U,9),DIC="^SC(",DIC(0)="NZ" D ^DIC
|
---|
102 | . Q:Y<1
|
---|
103 | . S:Y>0 LROL=+Y,LRIN=$P(Y(0),U,4),LRRRL2=$P(Y(0),U,20),LRRRL4=$P(Y(0),U,3)
|
---|
104 | . S:'LRIN LRIN=LRINS
|
---|
105 | . S LRCDT=$P(LREDT,".")
|
---|
106 | . D:'$D(^LRO(64.1,LRIN,1,LRCDT,1,LRCC,1,0))#2 BLDIN^LRCAPV3
|
---|
107 | . D
|
---|
108 | . . S LRTST=0 F S LRTST=$O(^LRO(69,LRCDT,1,LRSN,2,LRTST)) Q:LRTST<1 Q:'$P(^(LRTST,0),U,11)
|
---|
109 | . . Q:'LRTST S LREN5=^LRO(69,LRCDT,1,LRSN,2,LRTST,0)
|
---|
110 | . . S LRAA=$S($G(^LAB(69.9,1,14,LRIN,20)):+^(20),1:LRDAA)
|
---|
111 | . . S LRCTM=$P(LREDT,".",2)
|
---|
112 | . . S LRTS=+LREN5,LRCNT=1,LRLD="CP"
|
---|
113 | . . S (LRMA,LRLSS,LRWA)=LRAA
|
---|
114 | . . S LRACC=$P($G(^LRO(68,+$P(LREN5,U,4),1,+$P(LREN5,U,3),1,+$P(LREN5,U,5),.2)),U)
|
---|
115 | . . S LRFILE=+DFN_";DPT(",LROAD=$P(LREN5,U,3)
|
---|
116 | . . S LROAD1=$P(NODE,U,5),LROAD2=LRSN
|
---|
117 | . . S:'$G(LRSPEC) LRSPEC=$P($G(^LAB(69.9,1,1)),U)
|
---|
118 | . . S LRRRL=$P(NODE,U,7)
|
---|
119 | . . S LRRRL1=$P(NODE,U,6)
|
---|
120 | . . S LRRRL3=$P(NODE,U,2)
|
---|
121 | . . S LRIDT="",LRUG=$P(LREN5,U,2)
|
---|
122 | . . S LRTEC=$P(NODE,U,2)
|
---|
123 | . . D STORE^LRCAPV3
|
---|
124 | . S LRCEXV=LRCEX
|
---|
125 | S:'$G(LRDBUG) $P(^LRO(69,LRCDT,1,LRSN,0),U,10)=1 Q
|
---|
126 | Q
|
---|
127 | EN3 ;Called from LRCAPPH
|
---|
128 | Q:'$G(LRVSIT) I $G(LRPCEON) D:$G(LRPKG) EN3^LRCAPPH1
|
---|
129 | Q ; EN3^SDACS is no longer supported
|
---|
130 | Q:$G(LRVSIT)=1
|
---|
131 | K SDERR D
|
---|
132 | . S LOC=$G(^SC(+$P(NODE,U,9),0))
|
---|
133 | . I $L(LOC),"CMZ"[$P(LOC,U,3) D
|
---|
134 | .. S SDC=LRSDC,SDMSG=$S('$D(ZTQUEUED):"S",1:0),SDCTYPE="S"
|
---|
135 | .. S SDIV=LRIN,SDATE=LRNT,SDUZ=$P(NODE,U,2) D:SDUZ EN3^SDACS
|
---|
136 | Q
|
---|
137 | XTMP ;Clean up XTMP("LRCAP" global
|
---|
138 | ; Called from LRNIGHT
|
---|
139 | S LRCSQ="" F S LRCSQ=$O(^XTMP("LRCAP",LRCSQ)) Q:LRCSQ="" D
|
---|
140 | . S LRDUZ=0 F S LRDUZ=$O(^XTMP("LRCAP",LRCSQ,LRDUZ)) Q:LRDUZ<1 D QC K ^XTMP("LRCAP",LRCSQ)
|
---|
141 | K LRDUZ
|
---|
142 | Q
|
---|
143 | QC ;
|
---|
144 | I $D(ZTQUEUED) S ZTREQ="@"
|
---|
145 | L +^XTMP("LRCAP",LRCSQ,LRDUZ):1 Q:'$T
|
---|
146 | S NODE=$G(^XTMP("LRCAP",LRCSQ,LRDUZ)) G:'$L(NODE) QUIT
|
---|
147 | S LRSTDC=+NODE,LRCQC=+$P(NODE,U,2),LRREPC=+$P(NODE,U,3),LRCDT=DT,LRIN=$S($G(DUZ(2)):DUZ(2),1:$$INSN^LRU)
|
---|
148 | S LRCC=0 F S LRCC=$O(^XTMP("LRCAP",LRCSQ,LRDUZ,LRCC)) Q:'LRCC I $D(^LAM(LRCC,0)) S LRWT=$P(^(0),U,3) D BLDIN^LRCAPV3 S:'$D(^LRO(64.1,LRIN,1,LRCDT,1,LRCC,0)) ^(0)=LRCC_U_LRWT D SET1 L
|
---|
149 | QUIT K ^XTMP("LRCAP",LRCSQ,LRDUZ),NODE,LRSTDC,LRCQC,LRREPC,LRCC,LRWT,LRCSC,LRPKG
|
---|
150 | K ^TMP("LRPXAPI",$J),^TMP("LRMOD",$J)
|
---|
151 | L -^XTMP("LRCAP",LRCSQ,LRDUZ) Q
|
---|
152 | SET1 F L +^LRO(64.1,LRIN,1,LRCDT,1,LRCC,"S"):10 Q:$T
|
---|
153 | G:'$D(LRSTDC)!('$D(LRCQC))!('$D(LRREPC)) SET2
|
---|
154 | I '$D(^LRO(64.1,LRIN,1,LRCDT,1,LRCC,"S")) S ^("S")=LRSTDC_U_LRCQC_U_LRREPC_U G SET2
|
---|
155 | S NODE=$G(^LRO(64.1,LRIN,1,LRCDT,1,LRCC,"S")) I LRSTDC S $P(NODE,U)=$P(NODE,U)+LRSTDC
|
---|
156 | I LRREPC S $P(NODE,U,3)=$P(NODE,U,3)+LRREPC
|
---|
157 | I LRCQC S $P(NODE,U,2)=$P(NODE,U,2)+LRCQC
|
---|
158 | S ^LRO(64.1,LRIN,1,LRCDT,1,LRCC,"S")=NODE
|
---|
159 | SET2 L -^LRO(64.1,LRIN,1,LRCDT,1,LRCC,"S")
|
---|
160 | Q
|
---|