1 | SROACC3 ;BIR/MAM - CPT ACCURACY 1 CODE, ALL SPECIALTIES ;05/14/99 11:33 AM
|
---|
2 | ;;3.0; Surgery ;**37,50,88,127,142**;24 Jun 93
|
---|
3 | ;
|
---|
4 | ; Reference to ^ECC(723 supported by DBIA #205
|
---|
5 | ;
|
---|
6 | S SRSDT=SDATE1 F S SRSDT=$O(^SRF("AC",SRSDT)) Q:SRSDT>EDATE1!('SRSDT) S SRTN=0 F S SRTN=$O(^SRF("AC",SRSDT,SRTN)) Q:'SRTN I $D(^SRF(SRTN,0)),$P($G(^SRF(SRTN,30)),"^")="",$$DIV^SROUTL0(SRTN) D UTIL
|
---|
7 | S (SRSS,SRHDR)=0 F S SRSS=$O(^TMP("SR",$J,SRSS)) Q:SRSS=""!(SRSOUT) D HDR^SROACC0 Q:SRSOUT S SRHDR=1 D MORE
|
---|
8 | I '$D(^TMP("SR",$J)) D HDR^SROACC0,LINE W $$NODATA^SROUTL0()
|
---|
9 | Q
|
---|
10 | MORE ; print CPT description and get cases
|
---|
11 | I $Y+12>IOSL D HDR^SROACC0 I SRSOUT Q
|
---|
12 | S TYPE=0,X=$$CPT^ICPTCOD(SRCPT,EDATE),CPT1=$P(X,"^",2)_" "_$P(X,"^",3)
|
---|
13 | F S TYPE=$O(^TMP("SR",$J,SRSS,TYPE)) Q:TYPE="" D DESC S SRSDT=0 F S SRSDT=$O(^TMP("SR",$J,SRSS,TYPE,SRSDT)) Q:'SRSDT!(SRSOUT) D SRTN
|
---|
14 | Q
|
---|
15 | SRTN S SRTN=0 F S SRTN=$O(^TMP("SR",$J,SRSS,TYPE,SRSDT,SRTN)) Q:'SRTN!(SRSOUT) D PRINT
|
---|
16 | Q
|
---|
17 | LOOP ; break procedure greater than 50 characters
|
---|
18 | S SROP(M)="" F LOOP=1:1 S MM=$P(SROPER," "),MMM=$P(SROPER," ",2,200) Q:MMM="" Q:$L(SROP(M))+$L(MM)'<50 S SROP(M)=SROP(M)_MM_" ",SROPER=MMM
|
---|
19 | Q
|
---|
20 | DESC ; print description
|
---|
21 | Q:SRSOUT I '$O(^TMP("SR",$J,SRSS,TYPE,0)) Q
|
---|
22 | D LINE W !!,?(132-$L(CPT1)\2),CPT1
|
---|
23 | I TYPE=1 W !,?50,"PRINCIPAL PROCEDURES"
|
---|
24 | I TYPE=2 W !,?54,"OTHER PROCEDURES"
|
---|
25 | K SRDESC S X=$$CPTD^ICPTCOD(SRCPT,"SRDESC",,EDATE) F I=1:1:X S Y=$S(I=1:"DESCRIPTION: "_SRDESC(I),1:SRDESC(I)) W !,?(132-$L(Y)\2),Y
|
---|
26 | W !! F LINE=1:1:132 W "-"
|
---|
27 | Q
|
---|
28 | PRINT ; print each case
|
---|
29 | I $Y+5>IOSL D HDR^SROACC0 Q:SRSOUT D DESC
|
---|
30 | S SRNON=0 I $P($G(^SRF(SRTN,"NON")),"^")="Y" S SRNON=1
|
---|
31 | S DFN=$P(^SRF(SRTN,0),"^"),Y=SRSDT D D^DIQ S SRDT=Y
|
---|
32 | S Y=$P(SRDT,"@",2),SRDT=$E(SRSDT,4,5)_"/"_$E(SRSDT,6,7)_"/"_$E(SRSDT,2,3)_" "_Y
|
---|
33 | D DEM^VADPT S SRNAME=VADM(1),SSN=VA("PID"),SR(.1)=$S($D(^SRF(SRTN,.1)):^(.1),1:""),SRSUR=$S(SRNON:$P(^SRF(SRTN,"NON"),"^",6),1:$P(SR(.1),"^",4)),SRATT=$S(SRNON:$P(^SRF(SRTN,"NON"),"^",7),1:$P(SR(.1),"^",13))
|
---|
34 | I SRSUR S SRSUR=$P(^VA(200,SRSUR,0),"^") I $L(SRSUR)>20 S SRSUR=$P(SRSUR,",")_", "_$E($P(SRSUR,",",2))
|
---|
35 | I SRATT S SRATT=$P(^VA(200,SRATT,0),"^") I $L(SRATT)>20 S SRATT=$P(SRATT,",")_", "_$E($P(SRATT,",",2))
|
---|
36 | D OPER^SROACC0
|
---|
37 | K SROP,SROPT,MM,MMM S:$L(SROPER)<51 SROP(1)=SROPER I $L(SROPER)>50 S SROPER=SROPER_" " F M=1:1 D LOOP Q:MMM=""
|
---|
38 | W !,SRDT,?20,SRNAME,?60,SROP(1),?111,SRSUR,!,?3,SRTN,?20,VA("PID") W:$D(SROP(2)) ?60,SROP(2) W ?111,SRATT,! W:SRFLG=3&(SRNON) "NON-O.R." I $D(SROP(3)) W ?60,SROP(3) I $D(SROP(4)) W !,?60,SROP(4) I $D(SROP(5)) W !,?60,SROP(5)
|
---|
39 | I $D(SRCPTT) S:$L(SRCPTT)<51 SROPT(1)=SRCPTT I $L(SRCPTT)>50 S SRCPTT=SRCPTT_" " F M=1:1 D LOOP^SROACC0 Q:MMM=""
|
---|
40 | I $D(SRCPTT) F LOOP=1:1 Q:'$D(SROPT(LOOP)) W !,?60,SROPT(LOOP)
|
---|
41 | W ! Q
|
---|
42 | UTIL ; set ^TMP("SR")
|
---|
43 | S SRNON=0 I $P($G(^SRF(SRTN,"NON")),"^")="Y" S SRNON=1
|
---|
44 | I SRFLG=1!(SRFLG=3&('SRNON)) Q:$P($G(^SRF(SRTN,.2)),"^",12)=""
|
---|
45 | I SRFLG=2 Q:'SRNON
|
---|
46 | S CPT=$P($G(^SRO(136,SRTN,0)),"^",2)
|
---|
47 | I 'SRNON S X=$P(^SRF(SRTN,0),"^",4),SRSS=$S('X:"SPECIALTY NOT ENTERED",1:$P(^SRO(137.45,X,0),"^"))
|
---|
48 | I SRNON S X=$P(^SRF(SRTN,"NON"),"^",8),SRSS=$S(X:$P(^ECC(723,X,0),"^"),1:"SPECIALTY NOT ENTERED")
|
---|
49 | I CPT=SRCPT S ^TMP("SR",$J,SRSS,1,SRSDT,SRTN)=""
|
---|
50 | S OP=0 F S OP=$O(^SRO(136,SRTN,3,OP)) Q:'OP S CPT=$P($G(^SRO(136,SRTN,3,OP,0)),"^") I CPT=SRCPT S ^TMP("SR",$J,SRSS,2,SRSDT,SRTN)=""
|
---|
51 | Q
|
---|
52 | LINE W ! F LINE=1:1:132 W "="
|
---|
53 | Q
|
---|