Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: ACHSDSU

ACHSDSU.m

Go to the documentation of this file.
  1. ACHSDSU ; IHS/ITSC/PMF - DOCUMENT SUMMARY REPORT ; [ 10/16/2001 8:16 AM ]
  1. ;;3.1;CONTRACT HEALTH MGMT SYSTEM;;JUN 11, 2001
  1. ;
  1. TITLE ;;CHS DOCUMENT SUMMARY
  1. ;
  1. BDT ;
  1. S ACHSBDT=$$DATE^ACHS("B",$P($T(TITLE),";",3))
  1. I $D(DTOUT)!$D(DUOUT)!(ACHSBDT<1) D K Q
  1. EDT ;
  1. S ACHSEDT=$$DATE^ACHS("E",$P($T(TITLE),";",3))
  1. I $D(DTOUT)!(ACHSEDT<1) D K Q
  1. G BDT:$D(DUOUT)
  1. G:$$EBB^ACHS(ACHSBDT,ACHSEDT) BDT
  1. S ACHSIO=IO
  1. DEV ;
  1. S %=$$PB^ACHS
  1. I %=U!$D(DTOUT)!$D(DUOUT) D K Q
  1. I %="B" D VIEWR^XBLM("START^ACHSDSU"),EN^XBVK("VALM"),K Q
  1. S %ZIS="OPQ"
  1. D ^%ZIS
  1. I POP D HOME^%ZIS G K
  1. G:'$D(IO("Q")) START
  1. K IO("Q")
  1. I $D(IO("S"))!($E(IOST)'="P") W *7,!,"Please queue to system printers." D ^%ZISC G DEV
  1. S ZTRTN="START^ACHSDSU",ZTIO="",ZTDESC=$P($T(TITLE),";",3)_", "_$$FMTE^XLFDT(ACHSBDT)_" to "_$$FMTE^XLFDT(ACHSEDT)_".",ACHSQIO=ION_";"_IOST_";"_IOM_";"_IOSL
  1. F ACHS="ACHSQIO","ACHSBDT","ACHSEDT" S ZTSAVE(ACHS)=""
  1. D ^%ZTLOAD
  1. G:'$D(ZTSK) DEV
  1. K ;
  1. D ^%ZISC
  1. K DTOUT,DUOUT,ZTIO,ZTSK
  1. D EN^XBVK("ACHS"),^ACHSVAR
  1. Q
  1. ;
  1. START ;EP - TaskMan.
  1. K ^TMP($J,"ACHSDSU")
  1. S ACHSCHS=""
  1. D ^ACHSUF
  1. S ^TMP($J,"ACHSDSU","TRAN")=0,^TMP($J,"ACHSDSU","TOTAL")=0,ACHSTRDT=ACHSBDT-1,ACHSTY=""
  1. A1 ;
  1. S ACHSTRDT=$O(^ACHSF(DUZ(2),"TB",ACHSTRDT))
  1. I ACHSTRDT>ACHSEDT D END Q
  1. I ACHSTRDT="" D END Q
  1. S ACHSACT=""
  1. A2 ;
  1. S ACHSACT=$O(^ACHSF(DUZ(2),"TB",ACHSTRDT,ACHSACT))
  1. G A1:ACHSACT=""
  1. S ACHSDIEN=""
  1. A3 ;
  1. S ACHSDIEN=$O(^ACHSF(DUZ(2),"TB",ACHSTRDT,ACHSACT,ACHSDIEN))
  1. G A2:ACHSDIEN=""
  1. G A3:'$D(^ACHSF(DUZ(2),"D",ACHSDIEN,0))
  1. S ACHSDOCR=$G(^ACHSF(DUZ(2),"D",ACHSDIEN,0)),ACHSACN=""
  1. S N=$P(ACHSDOCR,U,6),O=$P(ACHSDOCR,U,7),ACHSDEST=$S($P(ACHSDOCR,U,17)="I":"IHS",$P(ACHSDOCR,U,17)="":"IHS",1:"FISCAL AGENT")
  1. K ACHSBLKF
  1. I $D(^ACHSF(DUZ(2),"D",ACHSDIEN,"BT")) S ACHSBLKF=""
  1. S R=$P(ACHSDOCR,U,19),ACHSADS=ACHSTRDT_U_$P(ACHSDIEN,U)_U_R_U_$P(ACHSDOCR,U,8)_U
  1. S ACHSX=$P(ACHSDOCR,U,14)
  1. D FYCVT^ACHSFU
  1. S ACHSACFY=ACHSY
  1. A4 ;
  1. S ACHSACN=$O(^ACHSF(DUZ(2),"TB",ACHSTRDT,ACHSACT,ACHSDIEN,ACHSACN))
  1. G A3:ACHSACN=""
  1. G A4:'$D(^ACHSF(DUZ(2),"D",ACHSDIEN,"T",ACHSACN,0))
  1. S ACHSTRAN=$G(^ACHSF(DUZ(2),"D",ACHSDIEN,"T",ACHSACN,0))
  1. S:$D(^ACHSF(DUZ(2),"D",ACHSDIEN,0)) ACHSACD=$P($G(^ACHSF(DUZ(2),"D",ACHSDIEN,0)),U)
  1. S ACHSSET=0,X=$P(ACHSTRAN,U,2),DFN=$P(ACHSTRAN,U,3),Y=$P(ACHSTRAN,U,5),A=$P(ACHSTRAN,U,4),T=X,O=A
  1. I X="C"&(Y="P") S T="D"
  1. I T'="P" S A=0 G A5
  1. G A6:'$D(^ACHSF(DUZ(2),"D",ACHSDIEN,"PA")) S O=$G(^ACHSF(DUZ(2),"D",ACHSDIEN,"PA")),A=$P(O,U),O=$P(O,U,2)
  1. I 'O G A6
  1. A5 ;
  1. S ACHSTS=DFN_U_T_U_O_U_A_U_$P(ACHSTRAN,U,10),ACHSSET=1
  1. A6 ;
  1. I ACHSSET S ^TMP($J,"ACHSDSU",ACHSACFY,ACHSACD,ACHSDIEN,ACHSACN)=ACHSADS_ACHSTS,ACHSTY=ACHSACT S:ACHSTY="C" O="-"_O
  1. I ACHSSET S ^TMP($J,"ACHSDSU","TRAN")=$G(^TMP($J,"ACHSDSU","TRAN"))+1,^TMP($J,"ACHSDSU","TOTAL")=$G(^TMP($J,"ACHSDSU","TOTAL"))+O
  1. ;
  1. ;WHY IS "ZA" TYPE IGNORED?????
  1. S ACHSTY=$S(ACHSTY="I":"INITIAL",ACHSTY="P":"PAYMENT",ACHSTY="S":"SUPPLEMENTAL",ACHSTY="IP":"INTERIM PAYMENT",1:"CANCEL")
  1. ;
  1. I ACHSSET,$D(ACHSTY) S:'$D(^TMP($J,"ACHSDSU",ACHSTY)) ^TMP($J,"ACHSDSU",ACHSTY)=0 S X=$G(^TMP($J,"ACHSDSU",ACHSTY)),$P(X,U)=$P(X,U)+1,$P(X,U,2)=$P(X,U,2)+O,^TMP($J,"ACHSDSU",ACHSTY)=X
  1. S:'$D(^TMP($J,"ACHSDSU",ACHSDEST)) ^TMP($J,"ACHSDSU",ACHSDEST)=0
  1. S ^TMP($J,"ACHSDSU",ACHSDEST)=$G(^TMP($J,"ACHSDSU",ACHSDEST))+1
  1. G A4
  1. ;
  1. END ; Kill routine vars, print.
  1. K ACHSDEST,ACHSDOCR,ACHSTRAN,ACHSTRDT,ACHSTS,ACHSX,ACHSY
  1. D BRPT^ACHSFU ;
  1. S (ACHSACFY,ACHSPG)=0,ACHS=""
  1. D ^ACHSUF ;CHECK DATA INTEGRITY HE,HE,HE
  1. S ACHSLOC=$$C^XBFUNC($$LOC^ACHS,80),ACHST1=$$C^XBFUNC($$FMTE^XLFDT(ACHSBDT)_" Thru "_$$FMTE^XLFDT(ACHSEDT))
  1. K ACHSSUM
  1. F ACHS=1:1:7 S ACHSSUM(ACHS)=""
  1. S ACHSACFY=0
  1. U IO
  1. FY ;
  1. S ACHSACFY=$O(^TMP($J,"ACHSDSU",ACHSACFY))
  1. I ACHSACFY<1 D HDR,SUM,RGSTRS G KILL
  1. D HDR,HDR1^ACHSODP
  1. S ACHSACD="",ACHSDIEN=0,ACHSDPFX=$E(ACHSACFY,4)_"-"_ACHSFC_"-"
  1. CODE ;
  1. S ACHSACD=$O(^TMP($J,"ACHSDSU",ACHSACFY,ACHSACD))
  1. I ACHSACD="" D RTRN^ACHS G KILL:$D(DUOUT)!$D(DTOUT),FY
  1. S ACHSDIEN=0
  1. DOC ;
  1. S ACHSDIEN=$O(^TMP($J,"ACHSDSU",ACHSACFY,ACHSACD,ACHSDIEN))
  1. G CODE:ACHSDIEN<1
  1. S ACHSTN=0
  1. TRANS ;
  1. S ACHSTN=$O(^TMP($J,"ACHSDSU",ACHSACFY,ACHSACD,ACHSDIEN,ACHSTN)) G DOC:ACHSTN<1 S ACHSACS=$G(^TMP($J,"ACHSDSU",ACHSACFY,ACHSACD,ACHSDIEN,ACHSTN))
  1. I $Y>ACHSBM D RTRN^ACHS G KILL:$D(DUOUT)!$D(DTOUT) D HDR,HDR1^ACHSODP
  1. D ^ACHSODP1
  1. G TRANS
  1. ;
  1. KILL ;
  1. W @IOF
  1. K ZTSK
  1. D ERPT^ACHS
  1. K B,C,DFN,L,N,O,S,T
  1. D EN^XBVK("ACHS"),^ACHSVAR:'$D(ZTQUEUED)
  1. Q
  1. ;
  1. HDR ;
  1. S ACHSPG=ACHSPG+1
  1. W @IOF,!,ACHSLOC,!?26,"CHS DOCUMENT SUMMARY REPORT",?71,"Page",$J(ACHSPG,4),!,ACHSTIME,!,ACHST1,!!
  1. Q
  1. ;
  1. SUM ;
  1. D HDR2^ACHSODP
  1. S ACHSCT=0,X2="2$",X3=15
  1. F ACHSTYPE="INITIAL","SUPPLEMENTAL","CANCEL","PAYMENT","INTERIM PAYMENT" D
  1. . W !?5,ACHSTYPE," DOCUMENTS"
  1. . I $D(^TMP($J,"ACHSDSU",ACHSTYPE)) S X=$P(^(ACHSTYPE),U,2),ACHSCT=ACHSCT+X D COMMA^%DTC W ?43,$J($P(^TMP($J,"ACHSDSU",ACHSTYPE),U),6),?60,X
  1. .Q
  1. S X=ACHSCT
  1. D COMMA^%DTC
  1. W !?43,"________",?62,"_____________",!!?5,"TOTALS",?44,$J(^TMP($J,"ACHSDSU","TRAN"),5),?60,X
  1. W !!!?5,"FISCAL AGENT DOCUMENTS:",$S($D(^TMP($J,"ACHSDSU","FISCAL AGENT")):$J(^("FISCAL AGENT"),5),1:" 0"),!?14,"IHS DOCUMENTS:",$S($D(^TMP($J,"ACHSDSU","IHS")):$J(^("IHS"),5),1:" 0"),!
  1. D RTRN^ACHS
  1. Q
  1. ;
  1. RGSTRS ;
  1. D HDR,SB2^ACHSODP2
  1. S ACHSACTN=$S($D(^ACHS(9,DUZ(2),"RN")):^("RN"),1:""),X2=2,X3=12
  1. F ACHS=1:1:7 S $P(ACHSSUM(ACHS),U,3)=$P(ACHSSUM(ACHS),U)-$P(ACHSSUM(ACHS),U,2)
  1. F ACHSX1=1:1:7 W !,$E($P(ACHSACTN,U,ACHSX1),1,20),?30 D SB1 W:ACHSX1<7 !
  1. W !
  1. D S21^ACHSODP2
  1. W !,"TOTAL",?30
  1. S X=0
  1. F ACHSX=1,2,3 F ACHS=1:1:7 S X=X+$P(ACHSSUM(ACHS),U,ACHSX) I ACHS=7 W $J($FN(X,",",2),12) S ACHSACTO=X,X=0
  1. W $J($FN(ACHSACTO,",",2),12),!!!?1,"Obligated Balance For Period: ",$J("$"_$FN(ACHSACTO,",",2),14)
  1. K ACHSX1,X2
  1. D RTRN^ACHS
  1. Q
  1. ;
  1. SB1 ;
  1. F ACHSX=1,2,3,3 W $J($FN($P(ACHSSUM(ACHSX1),U,ACHSX),",",2),12)
  1. Q
  1. ;