PRCFFM1M ;WISC/SJG-ROUTINE TO PROCESS AMENDMENT OBLIGATIONS CON'T ;4/26/94 16:40
V ;;5.1;IFCAP;;Oct 20, 2000
;Per VHA Directive 10-93-142, this routine should not be modified.
;
NEWVAR ; Refresh variables from 442
K DIC
S DIC("S")="I +^(0)=PRC(""SITE"")"
S DIC=442,DIC(0)="NZ",X=PRCFA("PODA")
D ^DIC K DIC G:+Y<0 OUT1
S PO(0)=Y(0),PO=Y
S PRCFA("REF")=$P(PO(0),U)
; the following line was commented out in PRC*5*179
; S PRCFA("SFC")=$P(PO(0),U,19)
S PRCFA("MP")=$P(PO(0),U,2)
S PRCFA("BBFY")=$$BBFY^PRCFFU5(+PO)
D GENDIQ^PRCFFU7(442,+PO,".1;.07;.03;17","IEN","")
;
EDIT ; Check fund/year table to determine fields required for FMS
D EDIT^PRCFFU ; sets up PRCFMO array for req'd fields
;
; if amendment requires re-establishing the FMS document
I $D(PRCFA("CANCEL")),PRCFA("CANCEL")]"" S PRCFA("MOD")="E^0^Original Entry (Amended)"
I PRCFA("TT")="AR",$D(PRCFA("CANCEL")),PRCFA("CANCEL")]"",XRBLD'=2 D
. S PRCFA("TT")="SO"
. D STACK ; set up the SO first
. S PRCFA("TT")="AR"
. S X1=PRCFA("OBLDATE"),X2=1
. D C^%DTC
. S PRCFA("OBLDATE")=X ; SO must be on FMS 1st, thus AR needs future date
. S %DT="FX",X="T+1"
. D ^%DT
. I $P(Y,".",1)>PRCFA("OBLDATE") S PRCFA("OBLDATE")=$P(Y,".",1)
D STACK ; build the appropriate FMS transaction
;
D ;adj fcp committed/obligated balance
. ; the next several lines were omitted by patch 172
. ; N TRDA,Z,AMT,DEL,X,TIME,DA
. ; S TRDA=$P(^PRC(442,PRCFA("PODA"),0),"^",12),AMT=$P(^(0),"^",$P(PRCFMO,"^",12)="N"+15),DEL=$P(^(0),"^",10)
. ; D NOW^%DTC S TIME=X
. ; I TRDA="" D QUIT
. ; . N A
. ; . S A=$$DATE^PRC0C($P(PRCOAMT,"^",3),"I"),$P(PRCOAMT,"^",3,4)=$E(A,3,4)_"^"_$P(A,"^",2)
. ; . D EBAL^PRCSEZ(PRCOAMT,"C"),EBAL^PRCSEZ(PRCOAMT,"O")
. ; . ;S A=$P($G(^PRC(442,PRCFA("PODA"),1)),"^",15) QUIT:A=""
. ; . QUIT:PRC("RBDT") S A=$$DATE^PRC0C(PRC("RBDT"),"I")
. ; . S A=+PO(0)_"^"_$P(PO(0),"^",3)_"^"_$E(A,3,4)_"^"_$P(A,"^",2)_"^"_AMT
. ; . D EBAL^PRCSEZ(A,"C"),EBAL^PRCSEZ(A,"O")
. ; . QUIT
. N TRDA,DEL,DA,MESSAGE
. S TRDA=$P(^PRC(442,PRCFA("PODA"),0),"^",12),DEL=$P(^(0),"^",10)
. I TRDA="" Q
. I '$D(^PRCS(410,TRDA,4)) Q
. S DA=TRDA,$P(^PRCS(410,TRDA,9),"^",2)=DEL
. D REMOVE^PRCSC2(DA),ENCODE^PRCSC2(DA,DUZ,.MESSAGE)
. QUIT
;
FISCST ; Post to Fiscal Status of Funds Tracker
I $P(PRC("PARAM"),U,17)["Y" D FISC^PRCFFU4
;
PRINT ; Print out copy of Purchase Order Amendment
G:'FLG OUT1
S PRCHQ="^PRCHPAM"
S PRCHQ("DEST")="S8"
S D0=PRCFA("PODA")
S D1=PRCFA("AMEND#")
D ^PRCHQUE
;
OUT1 K FLG,%,%Y,DIC,I,J,K,P,PRCFAA,PRCFPODA,X,Y,Z
K BBFY,SUB,TAG,PRCFMO,PRCCCC,PRCCSCC
K PO,PAT,PARAM1,NEW,LOOPVAL,LOOP,LOOP1,LOOP2,LOOP3,LOOP4,GECSFMS
K OLD,OLDVAL,FMSMOD,FMSNO,FMSVENID,PODATE,NUMB,MOD,ERFLAG,STR2
W !!
Q
;
STACK ; Create entry in GECS Stack File
D STACK^PRCFFU(1) ; pass 1 to force batch generation, set up CTL,BAT,DOC
;
SEGS ; Create entry into TMP($J for remaining segments
K ^TMP($J,"PRCMO")
N FMSINT S FMSINT=+PO
S FMSMOD=$P(PRCFA("MOD"),U,1)
D NEW^PRCFFU1(FMSINT,PRCFA("TT"),FMSMOD)
;
TRANSF ; Transfer nodes from TMP($J, into GECS Stack File
N LOOP S LOOP=0 F S LOOP=$O(^TMP($J,"PRCMO",GECSFMS("DA"),LOOP)) Q:'LOOP D SETCS^GECSSTAA(GECSFMS("DA"),^(LOOP))
K ^TMP($J,"PRCMO")
;
TRANSM ; Mark the document as queued for transmission
D SETSTAT^GECSSTAA(GECSFMS("DA"),"Q")
N P2 S P2=+PO_"/"_PRCFA("AMEND#"),$P(P2,"/",5)=$P($G(PRCFA("ACCPD")),U),$P(P2,"/",6)=PRCFA("OBLDATE")
D SETPARAM^GECSSDCT(GECSFMS("DA"),P2)
;
POBAL ; Enter Obligation Data into Purchase Order Record
I '$D(POESIG) I $D(PRCFA("PODA")),+PRCFA("PODA")>0 S POESIG=1
N FMSDOCT S FMSDOCT=$P(PRCFA("REF"),"-",2)
D EN7^PRCFFU41(PRCFA("TT"),FMSMOD,PRCFA("OBLDATE"),FMSDOCT) ; txn log
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPRCFFM1M 3760 printed Dec 13, 2024@02:03:25 Page 2
PRCFFM1M ;WISC/SJG-ROUTINE TO PROCESS AMENDMENT OBLIGATIONS CON'T ;4/26/94 16:40
V ;;5.1;IFCAP;;Oct 20, 2000
+1 ;Per VHA Directive 10-93-142, this routine should not be modified.
+2 ;
NEWVAR ; Refresh variables from 442
+1 KILL DIC
+2 SET DIC("S")="I +^(0)=PRC(""SITE"")"
+3 SET DIC=442
SET DIC(0)="NZ"
SET X=PRCFA("PODA")
+4 DO ^DIC
KILL DIC
if +Y<0
GOTO OUT1
+5 SET PO(0)=Y(0)
SET PO=Y
+6 SET PRCFA("REF")=$PIECE(PO(0),U)
+7 ; the following line was commented out in PRC*5*179
+8 ; S PRCFA("SFC")=$P(PO(0),U,19)
+9 SET PRCFA("MP")=$PIECE(PO(0),U,2)
+10 SET PRCFA("BBFY")=$$BBFY^PRCFFU5(+PO)
+11 DO GENDIQ^PRCFFU7(442,+PO,".1;.07;.03;17","IEN","")
+12 ;
EDIT ; Check fund/year table to determine fields required for FMS
+1 ; sets up PRCFMO array for req'd fields
DO EDIT^PRCFFU
+2 ;
+3 ; if amendment requires re-establishing the FMS document
+4 IF $DATA(PRCFA("CANCEL"))
IF PRCFA("CANCEL")]""
SET PRCFA("MOD")="E^0^Original Entry (Amended)"
+5 IF PRCFA("TT")="AR"
IF $DATA(PRCFA("CANCEL"))
IF PRCFA("CANCEL")]""
IF XRBLD'=2
Begin DoDot:1
+6 SET PRCFA("TT")="SO"
+7 ; set up the SO first
DO STACK
+8 SET PRCFA("TT")="AR"
+9 SET X1=PRCFA("OBLDATE")
SET X2=1
+10 DO C^%DTC
+11 ; SO must be on FMS 1st, thus AR needs future date
SET PRCFA("OBLDATE")=X
+12 SET %DT="FX"
SET X="T+1"
+13 DO ^%DT
+14 IF $PIECE(Y,".",1)>PRCFA("OBLDATE")
SET PRCFA("OBLDATE")=$PIECE(Y,".",1)
End DoDot:1
+15 ; build the appropriate FMS transaction
DO STACK
+16 ;
+17 ;adj fcp committed/obligated balance
Begin DoDot:1
+18 ; the next several lines were omitted by patch 172
+19 ; N TRDA,Z,AMT,DEL,X,TIME,DA
+20 ; S TRDA=$P(^PRC(442,PRCFA("PODA"),0),"^",12),AMT=$P(^(0),"^",$P(PRCFMO,"^",12)="N"+15),DEL=$P(^(0),"^",10)
+21 ; D NOW^%DTC S TIME=X
+22 ; I TRDA="" D QUIT
+23 ; . N A
+24 ; . S A=$$DATE^PRC0C($P(PRCOAMT,"^",3),"I"),$P(PRCOAMT,"^",3,4)=$E(A,3,4)_"^"_$P(A,"^",2)
+25 ; . D EBAL^PRCSEZ(PRCOAMT,"C"),EBAL^PRCSEZ(PRCOAMT,"O")
+26 ; . ;S A=$P($G(^PRC(442,PRCFA("PODA"),1)),"^",15) QUIT:A=""
+27 ; . QUIT:PRC("RBDT") S A=$$DATE^PRC0C(PRC("RBDT"),"I")
+28 ; . S A=+PO(0)_"^"_$P(PO(0),"^",3)_"^"_$E(A,3,4)_"^"_$P(A,"^",2)_"^"_AMT
+29 ; . D EBAL^PRCSEZ(A,"C"),EBAL^PRCSEZ(A,"O")
+30 ; . QUIT
+31 NEW TRDA,DEL,DA,MESSAGE
+32 SET TRDA=$PIECE(^PRC(442,PRCFA("PODA"),0),"^",12)
SET DEL=$PIECE(^(0),"^",10)
+33 IF TRDA=""
QUIT
+34 IF '$DATA(^PRCS(410,TRDA,4))
QUIT
+35 SET DA=TRDA
SET $PIECE(^PRCS(410,TRDA,9),"^",2)=DEL
+36 DO REMOVE^PRCSC2(DA)
DO ENCODE^PRCSC2(DA,DUZ,.MESSAGE)
+37 QUIT
End DoDot:1
+38 ;
FISCST ; Post to Fiscal Status of Funds Tracker
+1 IF $PIECE(PRC("PARAM"),U,17)["Y"
DO FISC^PRCFFU4
+2 ;
PRINT ; Print out copy of Purchase Order Amendment
+1 if 'FLG
GOTO OUT1
+2 SET PRCHQ="^PRCHPAM"
+3 SET PRCHQ("DEST")="S8"
+4 SET D0=PRCFA("PODA")
+5 SET D1=PRCFA("AMEND#")
+6 DO ^PRCHQUE
+7 ;
OUT1 KILL FLG,%,%Y,DIC,I,J,K,P,PRCFAA,PRCFPODA,X,Y,Z
+1 KILL BBFY,SUB,TAG,PRCFMO,PRCCCC,PRCCSCC
+2 KILL PO,PAT,PARAM1,NEW,LOOPVAL,LOOP,LOOP1,LOOP2,LOOP3,LOOP4,GECSFMS
+3 KILL OLD,OLDVAL,FMSMOD,FMSNO,FMSVENID,PODATE,NUMB,MOD,ERFLAG,STR2
+4 WRITE !!
+5 QUIT
+6 ;
STACK ; Create entry in GECS Stack File
+1 ; pass 1 to force batch generation, set up CTL,BAT,DOC
DO STACK^PRCFFU(1)
+2 ;
SEGS ; Create entry into TMP($J for remaining segments
+1 KILL ^TMP($JOB,"PRCMO")
+2 NEW FMSINT
SET FMSINT=+PO
+3 SET FMSMOD=$PIECE(PRCFA("MOD"),U,1)
+4 DO NEW^PRCFFU1(FMSINT,PRCFA("TT"),FMSMOD)
+5 ;
TRANSF ; Transfer nodes from TMP($J, into GECS Stack File
+1 NEW LOOP
SET LOOP=0
FOR
SET LOOP=$ORDER(^TMP($JOB,"PRCMO",GECSFMS("DA"),LOOP))
if 'LOOP
QUIT
DO SETCS^GECSSTAA(GECSFMS("DA"),^(LOOP))
+2 KILL ^TMP($JOB,"PRCMO")
+3 ;
TRANSM ; Mark the document as queued for transmission
+1 DO SETSTAT^GECSSTAA(GECSFMS("DA"),"Q")
+2 NEW P2
SET P2=+PO_"/"_PRCFA("AMEND#")
SET $PIECE(P2,"/",5)=$PIECE($GET(PRCFA("ACCPD")),U)
SET $PIECE(P2,"/",6)=PRCFA("OBLDATE")
+3 DO SETPARAM^GECSSDCT(GECSFMS("DA"),P2)
+4 ;
POBAL ; Enter Obligation Data into Purchase Order Record
+1 IF '$DATA(POESIG)
IF $DATA(PRCFA("PODA"))
IF +PRCFA("PODA")>0
SET POESIG=1
+2 NEW FMSDOCT
SET FMSDOCT=$PIECE(PRCFA("REF"),"-",2)
+3 ; txn log
DO EN7^PRCFFU41(PRCFA("TT"),FMSMOD,PRCFA("OBLDATE"),FMSDOCT)