PRC0C ;WISC/PLT-UTILITY (2) ; 1/23/98 1200
V ;;5.1;IFCAP;;Oct 20, 2000
;Per VHA Directive 10-93-142, this routine should not be modified.
QUIT ; invalid entry
;
;extrinsic function for fms document required fields
;A is ^1=record id of file 420.14 (option)
; ^2=station #, ^3=fund control pt #,
; ^4=(document) fiscal year, ^5=beginning budget fiscal year
;B=fix value of doc type in file 420.16
;C=fix value of doc data element of file 420.17
; variable=Y for yes, N or nil for no
REQ(A,B,C) ;get fund's one required field value Y/N
N D,X
S X="",B=$O(^PRCD(420.16,"AC",B,"")),C=$O(^PRCD(420.17,"AC",C,""))
I $P(A,"^",2) S D=$$ACC($P(A,"^",2),$P(A,"^",3)_"^"_$P(A,"^",4)_"^"_$P(A,"^",5)),$P(A,"^")=$P(D,"^",9)
I A,B,C D
. S X=$O(^PRCD(420.18,"UNQ",$P(A,"^"),B,C,""))
. S:X>0 X=$P($G(^PRCD(420.18,X,0)),"^",4)
. QUIT
QUIT X
;
; A=^1 fund 420.14 ri (opt), ^2 station #, ^3 control pt #,
; ^4=(document) fiscal year, ^5=beginning budget fiscal year
; B=document type fix value, C=variable name
; return value is variable name(data element fix value)="Y","N" or nil
; variable name=$$ACC^PRC0C
DOCREQ(A,B,C) ;get fund's all required fields in array
N D,E
I $P(A,"^",2) S D=$$ACC($P(A,"^",2),$P(A,"^",3)_"^"_$P(A,"^",4)_"^"_$P(A,"^",5)),@C=D,$P(A,"^",1)=$P(D,"^",9)
S B=$O(^PRCD(420.16,"AC",B,""))
I A,B D
.S D="" F S D=$O(^PRCD(420.18,"UNQ",+A,B,D)) Q:'D S E=$O(^(D,"")) D:E
.. S E=^PRCD(420.18,E,0)
.. S @(C_"($P(^PRCD(420.17,D,0),""^"",4))=$P(E,""^"",4)")
.. QUIT
. QUIT
QUIT
;
;A is station #
;B is data ^1=fund control point code, ^2= (document) fiscal 2-digit year,
; ^3=beginning budget fiscal year (4-digit)
; value ^1=a/o code, ^2=program, ^3=fcp/prj code
; ^4=object class, ^5=fund code
; ^6=bfy beginning, ^7=bfy end, ^8=fund trans allowed
; ^9=file 420.14 record id, ^10=job, ^11=fill-in-year(s) appropriation, ^12=gross/net, ^13='Y' if revolving fund
ACC(A,B) ;extrinsic function
N C,D,E,F,G,I
S (C,D,F)=""
S:$P(B,"^",2)?2N&A&B C=$$ACC^PRCSEZ(+A,$P(B,"^",2),+B)
S:$P(C,"^",4) D=$$NP^PRC0B("^PRCD(420.15,$P(C,""^"",4),",0,1)
S:$P(C,"^",5) $P(D,"^",2)=$$NP^PRC0B("^PRCD(420.13,$P(C,""^"",5),",0,1)
S:$P(C,"^",6) $P(D,"^",3)=$$NP^PRC0B("^PRCD(420.131,$P(C,""^"",6),",0,1)
S:$P(C,"^",7) $P(D,"^",4)=$$NP^PRC0B("^PRCD(420.132,$P(C,""^"",7),",0,1)
I $P(C,"^",10)]"",$P(B,"^",3) S F=$$FUND($P(C,"^",10),$P(B,"^",3))
S E="" F I=2,4,5,8,1 S E=E_$P(F,"^",I)_"^"
S $P(D,"^",5,9)=E,$P(D,"^",12)=$P(F,"^",6) S:$P(D,"^",12)="" $P(D,"^",12)="N"
S:$P(C,"^",8) $P(D,"^",10)=$$NP^PRC0B("^PRCD(420.133,$P(C,""^"",8),",0,1)
S:$P(D,"^",6) $P(D,"^",11)=$$APPF($P(C,"^",9),$P(D,"^",6),$P(D,"^",7))
I $P(D,"^",5)]"" S C=$O(^PRCD(420.3,"B",$P(D,"^",5),0)) S:C $P(D,"^",13)=$P(^PRCD(420.3,C,0),"^",8)
QUIT D
;
FUND(A,B) ;get fund, A=fund code, B=bbfy
N C
S C="" I A]"",B]"" S C=$O(^PRCD(420.14,"UNQ",A,B,"")) I C S C=$O(^(C,""))
QUIT C_"^"_$S(C:$G(^PRCD(420.14,C,0)),1:"")
;
;A=station #, B=fiscal year (2-digit), C=fcp #
;D is data ^1=appropriation code, ^2=fund code
APP(A,B,C) ;EF data ^1=app symbol, ^2=fund code, ^3=program ri
N D
S D=$G(^PRC(420,+A,1,+C,4,B,2)) S:D]"" D=$P(D,"^",9,10)_"^"_$P(D,"^",5)
S:D="" D=$P($G(^PRC(420,+A,1,+C,0)),"^",3),$P(D,"^",2,3)=$P($G(^(5)),"^",1,2)
QUIT D
;
APPF(A,B,C) ;fill-in-years appropriation, A=appropriation, B=bbfy, C=ebfy
N D
S D=$F(A,"_/_")
QUIT $S(D>1:$E(A,1,D-4)_(B#10)_"/"_(C#10)_$E(A,D,999),1:$TR(A,"_",B#10))
;
;X date
;A=I if fm date, E if external date, H if $H date
DATE(X,A) ;ext value ^1=fy (4 digits),^2=fy qtr,^3=year,^4=month (2 digits),^5=day (2 digits),^6=week day #,^7=fm date,^8=$H date, ^9=fiscal month( 2-dig)
N B,C,D,E,Y,%H,%,%DT,%T,%Y
S D=""
I A="H" S D=X,E=D-3#7,%H=X D YMD^%DTC
I A="E" S %DT="" D ^%DT S X=Y
S A=X\10000+1700,B=$E(X,4,5),C=$E(X,6,7)
I D="" D H^%DTC S D=%H,E=%Y
QUIT B>9+A_"^"_(B+2\3#4+1)_"^"_A_"^"_B_"^"_C_"^"_E_"^"_X_"^"_D_"^"_$E(B+2#12+1+100,2,3)
;
;A is 2/4 digit year
YEAR(A) ;EF value ^1=4-digit year,^2=2-digit year
N B,C,D,F,X,Y,%DT
I A>100 S B=A_"^"_$E(A,$L(A)-1,$L(A))
E S X=$E(100+A,2,3),%DT="" D ^%DT S B=$E(Y,1,3)+1700_"^"_X
QUIT B
;
;A=staiton #
SEC1(A) ;EF value=fms sec1 code
QUIT $P($G(^PRCD(420.138,+$P($G(^PRC(411,+A,9)),"^",2),0)),"^",1)
;
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPRC0C 4364 printed Sep 11, 2024@02:19:19 Page 2
PRC0C ;WISC/PLT-UTILITY (2) ; 1/23/98 1200
V ;;5.1;IFCAP;;Oct 20, 2000
+1 ;Per VHA Directive 10-93-142, this routine should not be modified.
+2 ; invalid entry
QUIT
+3 ;
+4 ;extrinsic function for fms document required fields
+5 ;A is ^1=record id of file 420.14 (option)
+6 ; ^2=station #, ^3=fund control pt #,
+7 ; ^4=(document) fiscal year, ^5=beginning budget fiscal year
+8 ;B=fix value of doc type in file 420.16
+9 ;C=fix value of doc data element of file 420.17
+10 ; variable=Y for yes, N or nil for no
REQ(A,B,C) ;get fund's one required field value Y/N
+1 NEW D,X
+2 SET X=""
SET B=$ORDER(^PRCD(420.16,"AC",B,""))
SET C=$ORDER(^PRCD(420.17,"AC",C,""))
+3 IF $PIECE(A,"^",2)
SET D=$$ACC($PIECE(A,"^",2),$PIECE(A,"^",3)_"^"_$PIECE(A,"^",4)_"^"_$PIECE(A,"^",5))
SET $PIECE(A,"^")=$PIECE(D,"^",9)
+4 IF A
IF B
IF C
Begin DoDot:1
+5 SET X=$ORDER(^PRCD(420.18,"UNQ",$PIECE(A,"^"),B,C,""))
+6 if X>0
SET X=$PIECE($GET(^PRCD(420.18,X,0)),"^",4)
+7 QUIT
End DoDot:1
+8 QUIT X
+9 ;
+10 ; A=^1 fund 420.14 ri (opt), ^2 station #, ^3 control pt #,
+11 ; ^4=(document) fiscal year, ^5=beginning budget fiscal year
+12 ; B=document type fix value, C=variable name
+13 ; return value is variable name(data element fix value)="Y","N" or nil
+14 ; variable name=$$ACC^PRC0C
DOCREQ(A,B,C) ;get fund's all required fields in array
+1 NEW D,E
+2 IF $PIECE(A,"^",2)
SET D=$$ACC($PIECE(A,"^",2),$PIECE(A,"^",3)_"^"_$PIECE(A,"^",4)_"^"_$PIECE(A,"^",5))
SET @C=D
SET $PIECE(A,"^",1)=$PIECE(D,"^",9)
+3 SET B=$ORDER(^PRCD(420.16,"AC",B,""))
+4 IF A
IF B
Begin DoDot:1
+5 SET D=""
FOR
SET D=$ORDER(^PRCD(420.18,"UNQ",+A,B,D))
if 'D
QUIT
SET E=$ORDER(^(D,""))
if E
Begin DoDot:2
+6 SET E=^PRCD(420.18,E,0)
+7 SET @(C_"($P(^PRCD(420.17,D,0),""^"",4))=$P(E,""^"",4)")
+8 QUIT
End DoDot:2
+9 QUIT
End DoDot:1
+10 QUIT
+11 ;
+12 ;A is station #
+13 ;B is data ^1=fund control point code, ^2= (document) fiscal 2-digit year,
+14 ; ^3=beginning budget fiscal year (4-digit)
+15 ; value ^1=a/o code, ^2=program, ^3=fcp/prj code
+16 ; ^4=object class, ^5=fund code
+17 ; ^6=bfy beginning, ^7=bfy end, ^8=fund trans allowed
+18 ; ^9=file 420.14 record id, ^10=job, ^11=fill-in-year(s) appropriation, ^12=gross/net, ^13='Y' if revolving fund
ACC(A,B) ;extrinsic function
+1 NEW C,D,E,F,G,I
+2 SET (C,D,F)=""
+3 if $PIECE(B,"^",2)?2N&A&B
SET C=$$ACC^PRCSEZ(+A,$PIECE(B,"^",2),+B)
+4 if $PIECE(C,"^",4)
SET D=$$NP^PRC0B("^PRCD(420.15,$P(C,""^"",4),",0,1)
+5 if $PIECE(C,"^",5)
SET $PIECE(D,"^",2)=$$NP^PRC0B("^PRCD(420.13,$P(C,""^"",5),",0,1)
+6 if $PIECE(C,"^",6)
SET $PIECE(D,"^",3)=$$NP^PRC0B("^PRCD(420.131,$P(C,""^"",6),",0,1)
+7 if $PIECE(C,"^",7)
SET $PIECE(D,"^",4)=$$NP^PRC0B("^PRCD(420.132,$P(C,""^"",7),",0,1)
+8 IF $PIECE(C,"^",10)]""
IF $PIECE(B,"^",3)
SET F=$$FUND($PIECE(C,"^",10),$PIECE(B,"^",3))
+9 SET E=""
FOR I=2,4,5,8,1
SET E=E_$PIECE(F,"^",I)_"^"
+10 SET $PIECE(D,"^",5,9)=E
SET $PIECE(D,"^",12)=$PIECE(F,"^",6)
if $PIECE(D,"^",12)=""
SET $PIECE(D,"^",12)="N"
+11 if $PIECE(C,"^",8)
SET $PIECE(D,"^",10)=$$NP^PRC0B("^PRCD(420.133,$P(C,""^"",8),",0,1)
+12 if $PIECE(D,"^",6)
SET $PIECE(D,"^",11)=$$APPF($PIECE(C,"^",9),$PIECE(D,"^",6),$PIECE(D,"^",7))
+13 IF $PIECE(D,"^",5)]""
SET C=$ORDER(^PRCD(420.3,"B",$PIECE(D,"^",5),0))
if C
SET $PIECE(D,"^",13)=$PIECE(^PRCD(420.3,C,0),"^",8)
+14 QUIT D
+15 ;
FUND(A,B) ;get fund, A=fund code, B=bbfy
+1 NEW C
+2 SET C=""
IF A]""
IF B]""
SET C=$ORDER(^PRCD(420.14,"UNQ",A,B,""))
IF C
SET C=$ORDER(^(C,""))
+3 QUIT C_"^"_$SELECT(C:$GET(^PRCD(420.14,C,0)),1:"")
+4 ;
+5 ;A=station #, B=fiscal year (2-digit), C=fcp #
+6 ;D is data ^1=appropriation code, ^2=fund code
APP(A,B,C) ;EF data ^1=app symbol, ^2=fund code, ^3=program ri
+1 NEW D
+2 SET D=$GET(^PRC(420,+A,1,+C,4,B,2))
if D]""
SET D=$PIECE(D,"^",9,10)_"^"_$PIECE(D,"^",5)
+3 if D=""
SET D=$PIECE($GET(^PRC(420,+A,1,+C,0)),"^",3)
SET $PIECE(D,"^",2,3)=$PIECE($GET(^(5)),"^",1,2)
+4 QUIT D
+5 ;
APPF(A,B,C) ;fill-in-years appropriation, A=appropriation, B=bbfy, C=ebfy
+1 NEW D
+2 SET D=$FIND(A,"_/_")
+3 QUIT $SELECT(D>1:$EXTRACT(A,1,D-4)_(B#10)_"/"_(C#10)_$EXTRACT(A,D,999),1:$TRANSLATE(A,"_",B#10))
+4 ;
+5 ;X date
+6 ;A=I if fm date, E if external date, H if $H date
DATE(X,A) ;ext value ^1=fy (4 digits),^2=fy qtr,^3=year,^4=month (2 digits),^5=day (2 digits),^6=week day #,^7=fm date,^8=$H date, ^9=fiscal month( 2-dig)
+1 NEW B,C,D,E,Y,%H,%,%DT,%T,%Y
+2 SET D=""
+3 IF A="H"
SET D=X
SET E=D-3#7
SET %H=X
DO YMD^%DTC
+4 IF A="E"
SET %DT=""
DO ^%DT
SET X=Y
+5 SET A=X\10000+1700
SET B=$EXTRACT(X,4,5)
SET C=$EXTRACT(X,6,7)
+6 IF D=""
DO H^%DTC
SET D=%H
SET E=%Y
+7 QUIT B>9+A_"^"_(B+2\3#4+1)_"^"_A_"^"_B_"^"_C_"^"_E_"^"_X_"^"_D_"^"_$EXTRACT(B+2#12+1+100,2,3)
+8 ;
+9 ;A is 2/4 digit year
YEAR(A) ;EF value ^1=4-digit year,^2=2-digit year
+1 NEW B,C,D,F,X,Y,%DT
+2 IF A>100
SET B=A_"^"_$EXTRACT(A,$LENGTH(A)-1,$LENGTH(A))
+3 IF '$TEST
SET X=$EXTRACT(100+A,2,3)
SET %DT=""
DO ^%DT
SET B=$EXTRACT(Y,1,3)+1700_"^"_X
+4 QUIT B
+5 ;
+6 ;A=staiton #
SEC1(A) ;EF value=fms sec1 code
+1 QUIT $PIECE($GET(^PRCD(420.138,+$PIECE($GET(^PRC(411,+A,9)),"^",2),0)),"^",1)
+2 ;