| 1 | SDAMODO2 ;ALB/SCK - PROVIDER DIAGNOSTICS REPORT, SET-UP DATA ; 05 Oct 98  8:43 PM
 | 
|---|
| 2 |  ;;5.3;Scheduling;**11,25,49,132,159**;Aug 13, 1993
 | 
|---|
| 3 | START ;
 | 
|---|
| 4 |  U IO
 | 
|---|
| 5 |  K ^TMP("SDRPT",$J),SDT,SDOE,DOE
 | 
|---|
| 6 |  S SDT=SDBEG F  S SDT=$O(^SCE("B",SDT)) Q:'SDT!(SDT>SDEND)  D
 | 
|---|
| 7 |  . S SDOE=0 F  S SDOE=$O(^SCE("B",SDT,SDOE)) Q:'SDOE  D
 | 
|---|
| 8 |  .. K SDPRX,SDOE0
 | 
|---|
| 9 |  .. Q:'$D(^SCE(SDOE,0))  S SDOE0=$G(^SCE(SDOE,0))
 | 
|---|
| 10 |  .. Q:'$P(SDOE0,U,7)
 | 
|---|
| 11 |  .. Q:$P(SDOE0,U,6)  ;ignore "child" encounters
 | 
|---|
| 12 |  .. I '$$OKDIV(+$P(SDOE0,U,11)) Q
 | 
|---|
| 13 |  .. I '$$CHECK(SORT1,SDOE0,SDOE) Q
 | 
|---|
| 14 |  .. I '$$CHECK(SORT2,SDOE0,SDOE) Q
 | 
|---|
| 15 |  .. S SDPRX("DFN")=+$P(SDOE0,U,2)
 | 
|---|
| 16 |  .. S SDPRX("OED")=$P(SDOE0,U)
 | 
|---|
| 17 |  .. S SDPRX("CL NAME")=$S(+$P($G(SDOE0),U,4)>0:$P(^SC(+$P(SDOE0,U,4),0),U),1:"UNSPECIFIED")
 | 
|---|
| 18 |  .. S SDPRX("DIV NAME")=+$P(SDOE0,U,11)
 | 
|---|
| 19 |  .. S SDPRX("PRV")=$$PRV1($S($P($G(SDOE0),U,6)']"":SDOE,1:$P($G(SDOE0),U,6)))
 | 
|---|
| 20 |  .. S SDPRX("DX")=$$DX1($S($P($G(SDOE0),U,6)']"":SDOE,1:$P($G(SDOE0),U,6)))
 | 
|---|
| 21 |  .. S SDPRX("SCODE")=+$P(SDOE0,U,3)
 | 
|---|
| 22 |  .. D BLD(.SDPRX,SORT1,SORT2)
 | 
|---|
| 23 |  D REPORT^SDAMODO3
 | 
|---|
| 24 | EXIT ;
 | 
|---|
| 25 |  K DOE,SDOE,SDT,OEDIV,DXD,PD,SD,OEN,SRT,VAR1,DFN,P1,XPR,XPX,XDN,XPT,XDX,DXCDE,SDPRX,VA,VAERR,SDOE0,ZTDESC,%ZIS,ZTSAVE,ZTRTN,ZTSK,ZTQUEUED
 | 
|---|
| 26 |  Q
 | 
|---|
| 27 |  ;
 | 
|---|
| 28 | BLD(SDPRX,SORT1,SORT2) ;
 | 
|---|
| 29 |  N Y,SUB1,SUB2,PRV
 | 
|---|
| 30 |  S Y=0
 | 
|---|
| 31 |  S SUB1=$S(SORT1=1:$$PRSUB($P(SDPRX("PRV"),U)),SORT1=2:$P(SDPRX("DX"),U),SORT1=3:$$PTSUB(SDPRX("DFN")),SORT1=4:SDPRX("CL NAME"),SORT1=5:SDPRX("SCODE"))
 | 
|---|
| 32 |  S SUB2=$S(SORT2=1:$$PRSUB($P(SDPRX("PRV"),U)),SORT2=2:$P(SDPRX("DX"),U),SORT2=3:$$PTSUB(SDPRX("DFN")),SORT2=4:SDPRX("CL NAME"),SORT2=5:SDPRX("SCODE"))
 | 
|---|
| 33 |  F I=1:1 I '$D(^TMP("SDRPT",$J,SDPRX("DIV NAME"),SUB1,SUB2,SDPRX("OED"),I)) D  Q
 | 
|---|
| 34 |  . S PRV=$P(SDPRX("PRV"),U),DXCDE=$P(SDPRX("DX"),U)
 | 
|---|
| 35 |  . D BLDTMP ; build first line
 | 
|---|
| 36 |  . I SORT1=1 D  Q
 | 
|---|
| 37 |  .. F XX=2:1 S PRV=$P(SDPRX("PRV"),U,XX)  Q:PRV']""  D
 | 
|---|
| 38 |  ... S SUB1=$$PRSUB($P(SDPRX("PRV"),U,XX)) D BLDTMP
 | 
|---|
| 39 |  . I SORT1=2 D  Q
 | 
|---|
| 40 |  .. F XX=2:1 S DXCDE=$P(SDPRX("DX"),U,XX) Q:DXCDE']""  D
 | 
|---|
| 41 |  ... S SUB1=DXCDE D BLDTMP
 | 
|---|
| 42 |  Q
 | 
|---|
| 43 |  ;
 | 
|---|
| 44 | BLDTMP ;
 | 
|---|
| 45 |  N X1
 | 
|---|
| 46 |  S ^TMP("SDRPT",$J,SDPRX("DIV NAME"),SUB1,SUB2,SDPRX("OED"),I,0)=SDPRX("DFN")_"^"_$$PDATA(SDPRX("DFN"))_"^"_SDPRX("CL NAME")_"^"_SDPRX("SCODE")_"^"_PRV_"^"_DXCDE
 | 
|---|
| 47 |  F X1=1:1 Q:'$P($G(SDPRX("PRV")),U,X1)  D
 | 
|---|
| 48 |  . Q:$P($G(SDPRX("PRV")),U,X1)=PRV
 | 
|---|
| 49 |  . S ^TMP("SDRPT",$J,SDPRX("DIV NAME"),SUB1,SUB2,SDPRX("OED"),I,"PRV",$P($G(SDPRX("PRV")),U,X1))=""
 | 
|---|
| 50 |  I SORT1'=2 F X1=1:1 Q:$P($G(SDPRX("DX")),U,X1)=""  D
 | 
|---|
| 51 |  . Q:$P($G(SDPRX("DX")),U,X1)=DXCDE
 | 
|---|
| 52 |  . S ^TMP("SDRPT",$J,SDPRX("DIV NAME"),SUB1,SUB2,SDPRX("OED"),I,"DX",$P($G(SDPRX("DX")),U,X1))=""
 | 
|---|
| 53 |  Q
 | 
|---|
| 54 |  ;
 | 
|---|
| 55 | PRSUB(PRX) ;
 | 
|---|
| 56 |  S XPR="UNKNOWN^0"
 | 
|---|
| 57 |  I +PRX>0 S XPR=$E($P(^VA(200,+PRX,0),U),1,29-$L(+PRX))_"^"_PRX
 | 
|---|
| 58 |  Q (XPR)
 | 
|---|
| 59 |  ;
 | 
|---|
| 60 | PTSUB(PDFN) ;
 | 
|---|
| 61 |  S XPT=$E($P(^DPT(+PDFN,0),U),1,29-$L(PDFN))_"^"_PDFN
 | 
|---|
| 62 |  Q (XPT)
 | 
|---|
| 63 |  ;
 | 
|---|
| 64 | PDATA(DFN) ;
 | 
|---|
| 65 |  D PID^VADPT6
 | 
|---|
| 66 |  Q (VA("PID"))
 | 
|---|
| 67 |  ;
 | 
|---|
| 68 | OKDIV(OEDIV)    ;   check for divisions
 | 
|---|
| 69 |  N Y
 | 
|---|
| 70 |  S Y=0
 | 
|---|
| 71 |  I OEDIV>0,VAUTD!($D(VAUTD(OEDIV))) S Y=1
 | 
|---|
| 72 | OKDIVQ Q (Y)
 | 
|---|
| 73 |  ;
 | 
|---|
| 74 | CHECK(SRT,SDOE0,OEN) ;
 | 
|---|
| 75 |  N Y
 | 
|---|
| 76 |  S Y=0
 | 
|---|
| 77 |  I SRT=1 S Y=$$PRV(OEN) G CHECKQ
 | 
|---|
| 78 |  I SRT=2 S Y=$$DX(OEN) G CHECKQ
 | 
|---|
| 79 |  I SRT=3,$P($G(SDOE0),U,2),PATN!($D(PATN(+$P($G(SDOE0),U,2)))) S Y=1 G CHECKQ
 | 
|---|
| 80 |  I SRT=4,$P($G(SDOE0),U,4),CLINIC!($D(CLINIC(+$P($G(SDOE0),U,4)))) S Y=1 G CHECKQ
 | 
|---|
| 81 |  I SRT=5,$P($G(SDOE0),U,3),STOPC!($D(STOPC(+$P($G(SDOE0),U,3)))) S Y=1 G CHECKQ
 | 
|---|
| 82 | CHECKQ Q (Y)
 | 
|---|
| 83 |  ;
 | 
|---|
| 84 | PRV(OEN) ; -- is there at least one provider from selected list
 | 
|---|
| 85 |  N Y,SD,PD,SDVPRV,SDVPRVS
 | 
|---|
| 86 |  S Y=0
 | 
|---|
| 87 |  D GETPRV^SDOE(OEN,"SDVPRVS")
 | 
|---|
| 88 |  S SDVPRV=0
 | 
|---|
| 89 |  F  S SDVPRV=$O(SDVPRVS(SDVPRV)) Q:'SDVPRV  D  Q:Y
 | 
|---|
| 90 |  . S PD=+SDVPRVS(SDVPRV)
 | 
|---|
| 91 |  . I PROVDR!($D(PROVDR(PD))) S Y=1  Q
 | 
|---|
| 92 |  Q Y
 | 
|---|
| 93 |  ;
 | 
|---|
| 94 | DX(OEN) ; -- is there at least one dx from selected list
 | 
|---|
| 95 |  N Y,SD,DXD,SDVPOV,SDVPOVS
 | 
|---|
| 96 |  S Y=0
 | 
|---|
| 97 |  D GETDX^SDOE(OEN,"SDVPOVS")
 | 
|---|
| 98 |  S SDVPOV=0
 | 
|---|
| 99 |  F  S SDVPOV=$O(SDVPOVS(SDVPOV)) Q:'SDVPOV  D  Q:Y
 | 
|---|
| 100 |  . S DXD=+SDVPOVS(SDVPOV)
 | 
|---|
| 101 |  . I PDIAG!($D(PDIAG(DXD))) S Y=1 Q
 | 
|---|
| 102 |  Q Y
 | 
|---|
| 103 |  ;
 | 
|---|
| 104 | PRV1(OEN) ; -- get list of providers for encounter
 | 
|---|
| 105 |  N PROV,SD,Y,XX,PIFN,PRX,QFLAG,SDVPRV,SDVPRVS
 | 
|---|
| 106 |  S Y=0,PRX="",QFLAG=0
 | 
|---|
| 107 |  D GETPRV^SDOE(OEN,"SDVPRVS")
 | 
|---|
| 108 |  S SDVPRV=0
 | 
|---|
| 109 |  F  S SDVPRV=$O(SDVPRVS(SDVPRV)) Q:'SDVPRV  D  Q:QFLAG
 | 
|---|
| 110 |  . S PIFN=+SDVPRVS(SDVPRV)
 | 
|---|
| 111 |  . IF $D(PROVDR),'PROVDR,'$D(PROVDR(PIFN)) Q
 | 
|---|
| 112 |  . S PRX=PRX_$S($G(^VA(200,PIFN,0))]"":PIFN,1:"UNKNOWN")_"^"
 | 
|---|
| 113 |  . S:$L(PRX)>250 QFLAG=1
 | 
|---|
| 114 |  I PRX']"" S PRX="UNKNOWN"
 | 
|---|
| 115 |  Q PRX
 | 
|---|
| 116 |  ;
 | 
|---|
| 117 | DX1(OEN) ; -- get list of dxs for encounter
 | 
|---|
| 118 |  N SD,Y,XX,XDX,XDN,QFLAG,SDVPOV,SDVPOVS
 | 
|---|
| 119 |  S XX=0,XDN="",QFLAG=0
 | 
|---|
| 120 |  D GETDX^SDOE(OEN,"SDVPOVS")
 | 
|---|
| 121 |  S SDVPOV=0
 | 
|---|
| 122 |  F  S SDVPOV=$O(SDVPOVS(SDVPOV)) Q:'SDVPOV  D  Q:QFLAG
 | 
|---|
| 123 |  . S XX=+SDVPOVS(SDVPOV)
 | 
|---|
| 124 |  . I $D(PDIAG),'PDIAG,'$D(PDIAG(XX)) Q
 | 
|---|
| 125 |  . S XDN=XDN_$S($D(^ICD9(XX,0)):$P(^(0),U)_U,1:"NOT SPECIFIED^")
 | 
|---|
| 126 |  . S:$L(XDN)>250 QFLAG=1
 | 
|---|
| 127 |  S:XDN']"" XDN="NOT SPECIFIED"
 | 
|---|
| 128 |  Q XDN
 | 
|---|