PRCFFUA ;WISC/SJG-ROUTINE TO PROCESS OBLIGATIONS CONT ;6/13/94 14:34
V ;;5.1;IFCAP;;Oct 20, 2000
;Per VHA Directive 10-93-142, this routine should not be modified.
; Allows Fiscal to edit BOCs prior to PO amendment obligation
; only the BOCs on the amendment can be edited
;
OK ; Prompt user
S DIR(0)="Y"
S DIR("A")="Is the above BOC information correct",DIR("B")="YES"
S DIR("?")="Enter 'NO' or 'N' to edit the BOCs on amended items."
S DIR("?",1)="Enter '^' to exit this option."
S DIR("?",2)="Enter 'YES' or 'Y' or 'RETURN' to continue processing this amendment."
W ! D ^DIR K DIR
Q
POAM ;
D ARRAY^PRCFFUA4 I $D(ITRAY("NOITEMS")) D MSG9^PRCFFUA3 Q
I FATAL=1 D MSG9^PRCFFUA3 Q
N BOCEDIT,ESHEDIT
D PROMPT Q:'Y!($D(DIRUT))
K YY S YY=Y,YY(0)=Y(0)
S (BOCEDIT,ESHEDIT)=0,FILE=$$FILE() D ROLLSET
S PRCFA("BBFY")=$$BBFY^PRCFFU5(+PO) S Y=YY,Y(0)=YY(0) K YY
Q:'Y!($D(DIRUT))
I Y D
.I $P(PCP,"^",2)=2 D MSG7^PRCFFUA3 Q
.D:+$P(PCP,"^",2)<2 SAEDIT
I (BOCEDIT=0)&(ESHEDIT=1) D ROLLSET,MSG1^PRCFFUA3,SF1^PRCFFUA1
QUIT
ROLLSET ; Sets variable needed for amendment rollup
S (DA,PRCHPO)=PRCFA("PODA"),PRCHTOTQ=$P(PO(0),U,15),PRCHAM=PRCFAA
Q
;
SAEDIT ; BOC Edit
D ESHEDIT S BOCEDIT=0
W !! N MSG S MSG="...now editing the BOCs on the amendment..." D EN^DDIOL(MSG) W !
I '$D(ITRAY("NOITEMS")) D ONEITEM
I 'Y!($D(DIRUT)) D MSG6^PRCFFUA3 Q
Q
ONEITEM ; Edit BOC for one item
Q:$D(ITRAY("NOITEMS"))
S BOCEDIT=0
S DIC("A")="Select ITEM: ",DA(1)=PRCFA("PODA"),DIC="^PRC("_FILE_","_DA(1)_",2,",DIC(0)="AEQMZ" D ^DIC K DIC("A") S YY=Y
I Y>0,$D(ITRAY("CANCEL",+Y)) W ! D EN^DDIOL("The Item Number selected by you has been cancelled and cannot be changed in the amendment!") W ! G ONEITEM
I Y>0,'$D(ITRAY(+Y)) W ! D EN^DDIOL("The Item Number selected by you is not on this amendment!") W ! G ONEITEM
I Y<0 S:X["^" PRCFOUT="" D ROLLSET S POX="^PRC("_FILE_","_PRCFA("PODA")_",0)" S PO(0)=@POX S %=$S($D(PRCFOUT):-1,1:1) Q
S DA=+Y,DIE=DIC,DR=3.5,PRCHAMDA=23 D ^DIE S Y=YY,(BOCEDIT,FISCEDIT)=1
I Y>0,$D(ITRAY(+Y)) D ROLLSET,MSG1^PRCFFUA3 D:FILE=442 SF1^PRCFFUA1 D:FILE=443.6 ^PRCHSF3
S DIC("A")="Select Next ITEM: ",(D0,DA)=PRCFA("PODA") G ONEITEM
;
PROMPT ; Prompt for user
S DIR(0)="Y",DIR("A")="Should the amendment BOC information be edited at this time",DIR("B")="NO"
S DIR("?")="Enter 'NO' or 'N' or 'RETURN' if no editing is needed."
S DIR("?",1)="Enter '^' to exit the option."
S DIR("?",2)="Enter 'YES' or 'Y' to edit this information."
W ! D ^DIR K DIR
Q
ESHEDIT ; Edit Shipping BOC
; 13 - Estimated Shipping and/or Handling
; 13.05 - Estimated Shipping BOC
S ESHEDIT=0 Q:'$D(ITRAY("ESH"))
I $G(PRCTMP(FILE,+PO,13,"I"))="" Q
I FILE=442,$G(PRCTMP(442,+PO,13.05,"I"))]"" D MSG10^PRCFFUA3,ESH1
I FILE=443.6,$G(PRCTMP(443.6,+PO,13.05,"I"))]"" D ESH1
K PRCTMP(442,+PO,13),PRCTMP(442,+PO,13.05),PRCTMP(443,6,+PO,13),PRCTMP(443.6,+PO,13.05)
Q
ESH1 K MSG W !!
S MSG(1)="...now editing Estimated Shipping BOC...",MSG(2)=" ",MSG(3)="The BOC for Estimated Shipping is '"_$G(PRCTMP(FILE,+PO,13.05,"E"))_"'."
D EN^DDIOL(.MSG) K MSG
S DIR(0)="Y",DIR("A")="Should I change the BOC for Estimated Shipping",DIR("B")="YES" W ! D ^DIR K DIR
I 'Y!($D(DIRUT)) W ! D EN^DDIOL("No change made to Shipping BOC.") Q
I Y D
.W !
.S DA=+PO,DIE=FILE,DR=13.05 D ^DIE K DIE,DR
.S (ESHEDIT,FISCEDIT)=1
.Q
Q
FILE() ; Determine file for lookup/editing
I $D(PRCFA("RETRAN")),PRCFA("RETRAN")=0 S FILE=443.6
I $D(PRCFA("RETRAN")),PRCFA("RETRAN")=1 S FILE=442
Q FILE
KILL K AESHBOC,FILE,II,ITRAY,OESHBOC,POX
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPRCFFUA 3607 printed Sep 11, 2024@02:23:56 Page 2
PRCFFUA ;WISC/SJG-ROUTINE TO PROCESS OBLIGATIONS CONT ;6/13/94 14:34
V ;;5.1;IFCAP;;Oct 20, 2000
+1 ;Per VHA Directive 10-93-142, this routine should not be modified.
+2 ; Allows Fiscal to edit BOCs prior to PO amendment obligation
+3 ; only the BOCs on the amendment can be edited
+4 ;
OK ; Prompt user
+1 SET DIR(0)="Y"
+2 SET DIR("A")="Is the above BOC information correct"
SET DIR("B")="YES"
+3 SET DIR("?")="Enter 'NO' or 'N' to edit the BOCs on amended items."
+4 SET DIR("?",1)="Enter '^' to exit this option."
+5 SET DIR("?",2)="Enter 'YES' or 'Y' or 'RETURN' to continue processing this amendment."
+6 WRITE !
DO ^DIR
KILL DIR
+7 QUIT
POAM ;
+1 DO ARRAY^PRCFFUA4
IF $DATA(ITRAY("NOITEMS"))
DO MSG9^PRCFFUA3
QUIT
+2 IF FATAL=1
DO MSG9^PRCFFUA3
QUIT
+3 NEW BOCEDIT,ESHEDIT
+4 DO PROMPT
if 'Y!($DATA(DIRUT))
QUIT
+5 KILL YY
SET YY=Y
SET YY(0)=Y(0)
+6 SET (BOCEDIT,ESHEDIT)=0
SET FILE=$$FILE()
DO ROLLSET
+7 SET PRCFA("BBFY")=$$BBFY^PRCFFU5(+PO)
SET Y=YY
SET Y(0)=YY(0)
KILL YY
+8 if 'Y!($DATA(DIRUT))
QUIT
+9 IF Y
Begin DoDot:1
+10 IF $PIECE(PCP,"^",2)=2
DO MSG7^PRCFFUA3
QUIT
+11 if +$PIECE(PCP,"^",2)<2
DO SAEDIT
End DoDot:1
+12 IF (BOCEDIT=0)&(ESHEDIT=1)
DO ROLLSET
DO MSG1^PRCFFUA3
DO SF1^PRCFFUA1
+13 QUIT
ROLLSET ; Sets variable needed for amendment rollup
+1 SET (DA,PRCHPO)=PRCFA("PODA")
SET PRCHTOTQ=$PIECE(PO(0),U,15)
SET PRCHAM=PRCFAA
+2 QUIT
+3 ;
SAEDIT ; BOC Edit
+1 DO ESHEDIT
SET BOCEDIT=0
+2 WRITE !!
NEW MSG
SET MSG="...now editing the BOCs on the amendment..."
DO EN^DDIOL(MSG)
WRITE !
+3 IF '$DATA(ITRAY("NOITEMS"))
DO ONEITEM
+4 IF 'Y!($DATA(DIRUT))
DO MSG6^PRCFFUA3
QUIT
+5 QUIT
ONEITEM ; Edit BOC for one item
+1 if $DATA(ITRAY("NOITEMS"))
QUIT
+2 SET BOCEDIT=0
+3 SET DIC("A")="Select ITEM: "
SET DA(1)=PRCFA("PODA")
SET DIC="^PRC("_FILE_","_DA(1)_",2,"
SET DIC(0)="AEQMZ"
DO ^DIC
KILL DIC("A")
SET YY=Y
+4 IF Y>0
IF $DATA(ITRAY("CANCEL",+Y))
WRITE !
DO EN^DDIOL("The Item Number selected by you has been cancelled and cannot be changed in the amendment!")
WRITE !
GOTO ONEITEM
+5 IF Y>0
IF '$DATA(ITRAY(+Y))
WRITE !
DO EN^DDIOL("The Item Number selected by you is not on this amendment!")
WRITE !
GOTO ONEITEM
+6 IF Y<0
if X["^"
SET PRCFOUT=""
DO ROLLSET
SET POX="^PRC("_FILE_","_PRCFA("PODA")_",0)"
SET PO(0)=@POX
SET %=$SELECT($DATA(PRCFOUT):-1,1:1)
QUIT
+7 SET DA=+Y
SET DIE=DIC
SET DR=3.5
SET PRCHAMDA=23
DO ^DIE
SET Y=YY
SET (BOCEDIT,FISCEDIT)=1
+8 IF Y>0
IF $DATA(ITRAY(+Y))
DO ROLLSET
DO MSG1^PRCFFUA3
if FILE=442
DO SF1^PRCFFUA1
if FILE=443.6
DO ^PRCHSF3
+9 SET DIC("A")="Select Next ITEM: "
SET (D0,DA)=PRCFA("PODA")
GOTO ONEITEM
+10 ;
PROMPT ; Prompt for user
+1 SET DIR(0)="Y"
SET DIR("A")="Should the amendment BOC information be edited at this time"
SET DIR("B")="NO"
+2 SET DIR("?")="Enter 'NO' or 'N' or 'RETURN' if no editing is needed."
+3 SET DIR("?",1)="Enter '^' to exit the option."
+4 SET DIR("?",2)="Enter 'YES' or 'Y' to edit this information."
+5 WRITE !
DO ^DIR
KILL DIR
+6 QUIT
ESHEDIT ; Edit Shipping BOC
+1 ; 13 - Estimated Shipping and/or Handling
+2 ; 13.05 - Estimated Shipping BOC
+3 SET ESHEDIT=0
if '$DATA(ITRAY("ESH"))
QUIT
+4 IF $GET(PRCTMP(FILE,+PO,13,"I"))=""
QUIT
+5 IF FILE=442
IF $GET(PRCTMP(442,+PO,13.05,"I"))]""
DO MSG10^PRCFFUA3
DO ESH1
+6 IF FILE=443.6
IF $GET(PRCTMP(443.6,+PO,13.05,"I"))]""
DO ESH1
+7 KILL PRCTMP(442,+PO,13),PRCTMP(442,+PO,13.05),PRCTMP(443,6,+PO,13),PRCTMP(443.6,+PO,13.05)
+8 QUIT
ESH1 KILL MSG
WRITE !!
+1 SET MSG(1)="...now editing Estimated Shipping BOC..."
SET MSG(2)=" "
SET MSG(3)="The BOC for Estimated Shipping is '"_$GET(PRCTMP(FILE,+PO,13.05,"E"))_"'."
+2 DO EN^DDIOL(.MSG)
KILL MSG
+3 SET DIR(0)="Y"
SET DIR("A")="Should I change the BOC for Estimated Shipping"
SET DIR("B")="YES"
WRITE !
DO ^DIR
KILL DIR
+4 IF 'Y!($DATA(DIRUT))
WRITE !
DO EN^DDIOL("No change made to Shipping BOC.")
QUIT
+5 IF Y
Begin DoDot:1
+6 WRITE !
+7 SET DA=+PO
SET DIE=FILE
SET DR=13.05
DO ^DIE
KILL DIE,DR
+8 SET (ESHEDIT,FISCEDIT)=1
+9 QUIT
End DoDot:1
+10 QUIT
FILE() ; Determine file for lookup/editing
+1 IF $DATA(PRCFA("RETRAN"))
IF PRCFA("RETRAN")=0
SET FILE=443.6
+2 IF $DATA(PRCFA("RETRAN"))
IF PRCFA("RETRAN")=1
SET FILE=442
+3 QUIT FILE
KILL KILL AESHBOC,FILE,II,ITRAY,OESHBOC,POX
+1 QUIT