PRPFCD ;ALTOONA/CTB PATIENT FUNDS ACCOUNT CARD GENERATOR ;11/22/96 4:33 PM
V ;;3.0;PATIENT FUNDS;**3,6**;JUNE 1, 1989
;HARD CODED OUTPUT - DOES NOT USE THE FILE MANAGER
LHDR1 W !,"REFERENCE",?12,"MASTER # SOURCE",?32,"WITHDRAWALS",?47,"DEPOSITS",?57,"DATE/TIME",?67,"DEFERRED",?86,"BALANCE",?95,"REMARKS" Q
BODY ;PRINTS THE BODY OF THE PATIENT CARD
S BAL=0,PAGE=0,END=45,GBAL=0,PBAL=0,D1=0 W !,LINE
I $D(BDATE) F D1=0:0 S D1=$O(^PRPF(470,DFN,3,D1)) Q:'D1 Q:'$D(^(D1,0)) S PTR=^(0) Q:$P(PTR,"^",2)>BDATE S BAL=BAL+$P(PTR,"^",3),GBAL=GBAL+$P(PTR,"^",5),PBAL=PBAL+$P(PTR,"^",4)
I BAL,GBAL W !,"BALCARFWD",?24,"GRAT",?45,$J(GBAL,10,2),?57,BDATE1,?83,$J(GBAL,10,2),?95,"Gratuitous Balance Carried Forward"
I BAL,PBAL W !,"BALCARFWD",?24,"PRIV",?45,$J(PBAL,10,2),?57,BDATE1,?83,$J(BAL,10,2),?95,"Private Source Balance Carried Fwd"
K GBAL,PBAL
I D1,$D(^PRPF(470,DFN,3,D1,0)) S PTR=^(0) D LINE
F S D1=$O(^PRPF(470,DFN,3,D1)) Q:'D1 Q:'$D(^(D1,0)) S PTR=^(0) D LINE
Q
LINE ;PRINTS THE TRANSACTION LINE FOR THE CARD
I PAGE>0,$Y>55 S PTRX=PTR D LINE3,PAGE,SHDR S PTR=PTRX K PTRX G LINE2
I PAGE=0,$Y>45 S PTRX=PTR D LINE3,TRAIL,PAGE,SHDR S END=58,PTR=PTRX K PTRX
LINE2 S MTR=$S($D(^PRPF(470.1,+PTR,0)):^(0),1:"")
S SOURCE=$P(MTR,U,10) S SOURCE=$S(SOURCE="P":"PRIV",SOURCE="G":"GRAT",SOURCE="B":"BOTH",1:"UNK")
S NU=$P(MTR,U),REF=$P(MTR,U,7),WI="",DE="" S:$P(MTR,U,8)="W" WI=-$P(PTR,U,3) S:$P(MTR,U,8)="D" DE=$P(PTR,U,3) S REM=$S($L($P(MTR,"^",16))>35:$E($P(MTR,U,16),1,34)_"*",1:$P(MTR,"^",16))
S X=$P(MTR,U,5) D DATE S DATE=X
S BAL=BAL+DE-WI S:DE'="" DE=$J(DE,10,2) S:WI'="" WI=$J(WI,10,2) S:BAL'="" JBAL=$J(BAL,10,2)
S X=$P(MTR,U,21) D DATE S DEF=X
W !,REF,?13,NU,?24,SOURCE,?33,WI,?45,DE,?57,DATE,?68,DEF,?83,JBAL,?95,REM K DEF,HR,MIN,NU,REF,SOURCE,WI,DE,DATE,JBAL Q
LINE3 W !,LINE
Q
EN2 S U="^" K LINE S $P(LINE,"-",131)="-" D LHDR^PRPFCD1,BODY,END,OUT Q
END W !!,"END OF CARD FOR: ",$P(DFN(0),U),?60,"ENDING BALANCE: $",$J(BAL,0,2)
F II=$Y:1:END W !
D:PAGE=0 LINE3,TRAIL
I '$D(TRAIL) F I=1:1:131 W "_"
D PAGE Q
END1 Q
OUT ;EXIT LINE
K ^PRPF(470,"AD","Y",DFN) S $P(^PRPF(470,DFN,1),"^",13)="" ;ABSV*3*8
K IOP,BAL,C1,D1,DATE,DE,DEF,DFN,DOA,DG1,DGA1,II,IND,JBAL,LINE,MONTH,MTR,PAGE,PTR,POP,NU,PDFN,SOURCE,WI,X,XREF,Y,TRAIL,END,REM Q
TRAIL ; PRINTS THE TRAILER INFO FOR PAGE ONE OF THE CARD
T1 ;
W !,"REGIONAL OFFICE: ",$S($P(PDFN(0),U,9)]"":$P(^DIC(4,$P(PDFN(0),U,9),0),U),1:""),?40,"OTHER ASSET: ",$P(PDFN(0),U,10),?65,"PRIVATE SOURCE FUNDS IN BALANCE: "
W $J($P(PDFN(1),U,5),9,2) W !!,"INCOME SOURCE",?27,"PAYEE",?52,"AMOUNT",?62,"FREQUENCY",?102,"MIN BALANCE",?120,"MAX BALANCE"
S N=0 F IX=1,3 S N=$O(^PRPF(470,DFN,6,N)) D S1
K XX,IX F IX=1:1 S N=$O(^PRPF(470,DFN,6,N)) G:'N T2 S XX=^(N,0) W !,$P(XX,U),?27,$P(XX,U,2),?49,"$",$J($P(XX,U,3),9,2) S Y="",X=$P(XX,U,4),DD=470.05,F=3 D:X]"" ^PRPFU1 W ?62,Y
T2 K IX W ! S N=0,DIWF="W",DIWL=5,DIWR=IOM-10 F I=1:1 S N=$O(^PRPF(470,DFN,7,N)) Q:N="" S X=^(N,0) S:I=1 X="GENERAL REMARKS/INFORMATION: "_X D ^DIWP
D ^DIWW K DIWF,DIWL,DIWR,X Q
Q
S1 S XX="" W ! S:N XX=^PRPF(470,DFN,6,N,0) W:N $P(XX,U),?27,$P(XX,U,2),?49,"$",$J($P(XX,U,3),9,2) S Y="",X=$P(XX,U,4) S DD=470.05,F=3 D:X]"" ^PRPFU1 W:N ?62,Y W ?102,"$",$J($P(PDFN(2),U,IX),9,2),?120,"$",$J($P(PDFN(2),U,IX+1),9,2) Q
SHDR ;PRINTS THE SHORT HEADER USED ON CONTINUATION PAGES
W @IOF,!,"BENEFICIARY:",?32,"CLAIM #:",?48,"I.D. #",?64,"WARD",?75,"MIN BALANCE",?90,"MAX BALANCE"
W !,$P(DFN(0),U),?32,"C-",$P(DFN(.31),U,3),?48,$P(DFN(0),U,9),?64,DFN(.1),?75,$J($P(PDFN(2),U),8,2),?90,$J($P(PDFN(2),U,2),8,2),!,?75,$J($P(PDFN(2),U,3),8,2),?90,$J($P(PDFN(2),U,4),8,2),!,LINE
D LHDR1 W !! Q
PAGE S PAGE=PAGE+1 F I=$Y:1:61 W !
W ?60,"PAGE ",PAGE Q
DATE ;CONVERT DATE TO SLASH FORMAT
I +X<2000000 S X="" Q
S X=$E(X,4,5)_"/"_$E(X,6,7)_"/"_$E(X,2,3) Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPRPFCD 3830 printed Dec 13, 2024@02:01:28 Page 2
PRPFCD ;ALTOONA/CTB PATIENT FUNDS ACCOUNT CARD GENERATOR ;11/22/96 4:33 PM
V ;;3.0;PATIENT FUNDS;**3,6**;JUNE 1, 1989
+1 ;HARD CODED OUTPUT - DOES NOT USE THE FILE MANAGER
LHDR1 WRITE !,"REFERENCE",?12,"MASTER # SOURCE",?32,"WITHDRAWALS",?47,"DEPOSITS",?57,"DATE/TIME",?67,"DEFERRED",?86,"BALANCE",?95,"REMARKS"
QUIT
BODY ;PRINTS THE BODY OF THE PATIENT CARD
+1 SET BAL=0
SET PAGE=0
SET END=45
SET GBAL=0
SET PBAL=0
SET D1=0
WRITE !,LINE
+2 IF $DATA(BDATE)
FOR D1=0:0
SET D1=$ORDER(^PRPF(470,DFN,3,D1))
if 'D1
QUIT
if '$DATA(^(D1,0))
QUIT
SET PTR=^(0)
if $PIECE(PTR,"^",2)>BDATE
QUIT
SET BAL=BAL+$PIECE(PTR,"^",3)
SET GBAL=GBAL+$PIECE(PTR,"^",5)
SET PBAL=PBAL+$PIECE(PTR,"^",4)
+3 IF BAL
IF GBAL
WRITE !,"BALCARFWD",?24,"GRAT",?45,$JUSTIFY(GBAL,10,2),?57,BDATE1,?83,$JUSTIFY(GBAL,10,2),?95,"Gratuitous Balance Carried Forward"
+4 IF BAL
IF PBAL
WRITE !,"BALCARFWD",?24,"PRIV",?45,$JUSTIFY(PBAL,10,2),?57,BDATE1,?83,$JUSTIFY(BAL,10,2),?95,"Private Source Balance Carried Fwd"
+5 KILL GBAL,PBAL
+6 IF D1
IF $DATA(^PRPF(470,DFN,3,D1,0))
SET PTR=^(0)
DO LINE
+7 FOR
SET D1=$ORDER(^PRPF(470,DFN,3,D1))
if 'D1
QUIT
if '$DATA(^(D1,0))
QUIT
SET PTR=^(0)
DO LINE
+8 QUIT
LINE ;PRINTS THE TRANSACTION LINE FOR THE CARD
+1 IF PAGE>0
IF $Y>55
SET PTRX=PTR
DO LINE3
DO PAGE
DO SHDR
SET PTR=PTRX
KILL PTRX
GOTO LINE2
+2 IF PAGE=0
IF $Y>45
SET PTRX=PTR
DO LINE3
DO TRAIL
DO PAGE
DO SHDR
SET END=58
SET PTR=PTRX
KILL PTRX
LINE2 SET MTR=$SELECT($DATA(^PRPF(470.1,+PTR,0)):^(0),1:"")
+1 SET SOURCE=$PIECE(MTR,U,10)
SET SOURCE=$SELECT(SOURCE="P":"PRIV",SOURCE="G":"GRAT",SOURCE="B":"BOTH",1:"UNK")
+2 SET NU=$PIECE(MTR,U)
SET REF=$PIECE(MTR,U,7)
SET WI=""
SET DE=""
if $PIECE(MTR,U,8)="W"
SET WI=-$PIECE(PTR,U,3)
if $PIECE(MTR,U,8)="D"
SET DE=$PIECE(PTR,U,3)
SET REM=$SELECT($LENGTH($PIECE(MTR,"^",16))>35:$EXTRACT($PIECE(MTR,U,16),1,34)_"*",1:$PIECE(MTR,"^",16))
+3 SET X=$PIECE(MTR,U,5)
DO DATE
SET DATE=X
+4 SET BAL=BAL+DE-WI
if DE'=""
SET DE=$JUSTIFY(DE,10,2)
if WI'=""
SET WI=$JUSTIFY(WI,10,2)
if BAL'=""
SET JBAL=$JUSTIFY(BAL,10,2)
+5 SET X=$PIECE(MTR,U,21)
DO DATE
SET DEF=X
+6 WRITE !,REF,?13,NU,?24,SOURCE,?33,WI,?45,DE,?57,DATE,?68,DEF,?83,JBAL,?95,REM
KILL DEF,HR,MIN,NU,REF,SOURCE,WI,DE,DATE,JBAL
QUIT
LINE3 WRITE !,LINE
+1 QUIT
EN2 SET U="^"
KILL LINE
SET $PIECE(LINE,"-",131)="-"
DO LHDR^PRPFCD1
DO BODY
DO END
DO OUT
QUIT
END WRITE !!,"END OF CARD FOR: ",$PIECE(DFN(0),U),?60,"ENDING BALANCE: $",$JUSTIFY(BAL,0,2)
+1 FOR II=$Y:1:END
WRITE !
+2 if PAGE=0
DO LINE3
DO TRAIL
+3 IF '$DATA(TRAIL)
FOR I=1:1:131
WRITE "_"
+4 DO PAGE
QUIT
END1 QUIT
OUT ;EXIT LINE
+1 ;ABSV*3*8
KILL ^PRPF(470,"AD","Y",DFN)
SET $PIECE(^PRPF(470,DFN,1),"^",13)=""
+2 KILL IOP,BAL,C1,D1,DATE,DE,DEF,DFN,DOA,DG1,DGA1,II,IND,JBAL,LINE,MONTH,MTR,PAGE,PTR,POP,NU,PDFN,SOURCE,WI,X,XREF,Y,TRAIL,END,REM
QUIT
TRAIL ; PRINTS THE TRAILER INFO FOR PAGE ONE OF THE CARD
T1 ;
+1 WRITE !,"REGIONAL OFFICE: ",$SELECT($PIECE(PDFN(0),U,9)]"":$PIECE(^DIC(4,$PIECE(PDFN(0),U,9),0),U),1:""),?40,"OTHER ASSET: ",$PIECE(PDFN(0),U,10),?65,"PRIVATE SOURCE FUNDS IN BALANCE: "
+2 WRITE $JUSTIFY($PIECE(PDFN(1),U,5),9,2)
WRITE !!,"INCOME SOURCE",?27,"PAYEE",?52,"AMOUNT",?62,"FREQUENCY",?102,"MIN BALANCE",?120,"MAX BALANCE"
+3 SET N=0
FOR IX=1,3
SET N=$ORDER(^PRPF(470,DFN,6,N))
DO S1
+4 KILL XX,IX
FOR IX=1:1
SET N=$ORDER(^PRPF(470,DFN,6,N))
if 'N
GOTO T2
SET XX=^(N,0)
WRITE !,$PIECE(XX,U),?27,$PIECE(XX,U,2),?49,"$",$JUSTIFY($PIECE(XX,U,3),9,2)
SET Y=""
SET X=$PIECE(XX,U,4)
SET DD=470.05
SET F=3
if X]""
DO ^PRPFU1
WRITE ?62,Y
T2 KILL IX
WRITE !
SET N=0
SET DIWF="W"
SET DIWL=5
SET DIWR=IOM-10
FOR I=1:1
SET N=$ORDER(^PRPF(470,DFN,7,N))
if N=""
QUIT
SET X=^(N,0)
if I=1
SET X="GENERAL REMARKS/INFORMATION: "_X
DO ^DIWP
+1 DO ^DIWW
KILL DIWF,DIWL,DIWR,X
QUIT
+2 QUIT
S1 SET XX=""
WRITE !
if N
SET XX=^PRPF(470,DFN,6,N,0)
if N
WRITE $PIECE(XX,U),?27,$PIECE(XX,U,2),?49,"$",$JUSTIFY($PIECE(XX,U,3),9,2)
SET Y=""
SET X=$PIECE(XX,U,4)
SET DD=470.05
SET F=3
if X]""
DO ^PRPFU1
if N
WRITE ?62,Y
WRITE ?102,"$",$JUSTIFY($PIECE(PDFN(2),U,IX),9,2),?120,"$",$JUSTIFY($PIECE(PDFN(2),U,IX+1),9,2)
QUIT
SHDR ;PRINTS THE SHORT HEADER USED ON CONTINUATION PAGES
+1 WRITE @IOF,!,"BENEFICIARY:",?32,"CLAIM #:",?48,"I.D. #",?64,"WARD",?75,"MIN BALANCE",?90,"MAX BALANCE"
+2 WRITE !,$PIECE(DFN(0),U),?32,"C-",$PIECE(DFN(.31),U,3),?48,$PIECE(DFN(0),U,9),?64,DFN(.1),?75,$JUSTIFY($PIECE(PDFN(2),U),8,2),?90,$JUSTIFY($PIECE(PDFN(2),U,2),8,2),!,?75,$JUSTIFY($PIECE(PDFN(2),U,3),8,2),?90,$JUSTIFY($PIECE(PDFN(2),U,4),8,2),!,
LINE
+3 DO LHDR1
WRITE !!
QUIT
PAGE SET PAGE=PAGE+1
FOR I=$Y:1:61
WRITE !
+1 WRITE ?60,"PAGE ",PAGE
QUIT
DATE ;CONVERT DATE TO SLASH FORMAT
+1 IF +X<2000000
SET X=""
QUIT
+2 SET X=$EXTRACT(X,4,5)_"/"_$EXTRACT(X,6,7)_"/"_$EXTRACT(X,2,3)
QUIT