1 | PRCFFU14 ;WISC/SJG-1358 OBLIGATION UTILITY ;8/18/94 17:03
|
---|
2 | V ;;5.1;IFCAP;;Oct 20, 2000
|
---|
3 | ;Per VHA Directive 10-93-142, this routine should not be modified.
|
---|
4 | ;
|
---|
5 | EN(IEN) ; Called from 1358 obligation processing
|
---|
6 | ; IEN - Internal entry number from 410
|
---|
7 | W !,"Editing Auto Accrual information...",!
|
---|
8 | S (ACCEDIT,AUTOACC,EXIT)=0
|
---|
9 | D GENDIQ^PRCFFU7(410,IEN,"1;11;13;21;52","IEN","")
|
---|
10 | I $G(PRCTMP(410,IEN,21,"I"))="",$G(PRCTMP(410,IEN,1,"I"))="O" D Q
|
---|
11 | .S FLDCHK=1
|
---|
12 | .K MSG W !!
|
---|
13 | .S MSG(1)="The DATE COMMITTED is missing - cannot process in Fiscal!!"
|
---|
14 | .S MSG(2)="Please return this 1358 to the Service!!"
|
---|
15 | .D EN^DDIOL(.MSG) W ! K MSG H 3
|
---|
16 | .Q
|
---|
17 | D GENDIQ^PRCFFU7(410,IEN,"1;3;17.5;20","IEN","")
|
---|
18 | N PRCCOMCT,PRCBOCCT
|
---|
19 | S PRCCOMCT=$G(PRCTMP(410,IEN,20,"I")),PRCBOCCT=$G(PRCTMP(410,IEN,17.5,"I"))
|
---|
20 | I $G(PRCTMP(410,IEN,1,"I"))="O",$G(PRCTMP(410,IEN,3,"I"))=1,$J(PRCCOMCT,0,2)'=$J(PRCBOCCT,0,2) D Q
|
---|
21 | . S FLDCHK=1
|
---|
22 | . K MSG W !!
|
---|
23 | . S MSG(1)="The COMMITTED COST does not equal BOC $ AMOUNT!"
|
---|
24 | . S MSG(2)="Please return this 1358 to the Service!!"
|
---|
25 | . D EN^DDIOL(.MSG) W ! K MSG H 3
|
---|
26 | . Q
|
---|
27 | S POIEN=$G(PRCTMP(410,IEN,52,"I")) I POIEN]"" D
|
---|
28 | .D GENDIQ^PRCFFU7(442,POIEN,".8;29;30","IEN","")
|
---|
29 | .N FISCSTAT S FISCSTAT=$G(PRCTMP(442,POIEN,.8,"I")) I FISCSTAT=45 K PRCTMP(410,IEN,52),PRCTMP(442,POIEN)
|
---|
30 | .Q
|
---|
31 | I $G(PRCTMP(410,IEN,52,"I"))="" I '$D(NEWDATE) D DATE,FLAG,PROMPT I 'Y!($D(DIRUT)) D:EXIT MSG5 G:EXIT EN2
|
---|
32 | I $G(PRCTMP(410,IEN,52,"I"))="" I $D(NEWDATE) D DATE,FLAG S OB=IEN D MSG1(NEWDATE,NEWACC),CHK1(NEWDATE),PROMPT1 I Y!($D(DIRUT)) D:EXIT MSG5 G:EXIT EN2
|
---|
33 | I $G(PRCTMP(410,IEN,52,"I"))'="" D G:EXIT EN2
|
---|
34 | .S OB=IEN
|
---|
35 | .S NEWDATE=$G(PRCTMP(442,POIEN,29,"E")) I $D(TMP("NEWDATE")) S NEWDATE=$P(TMP("NEWDATE"),U,2)
|
---|
36 | .S NEWACC=$G(PRCTMP(442,POIEN,30,"E")) I $D(TMP("NEWACC")) S NEWACC=$P(TMP("NEWACC"),U,2)
|
---|
37 | .D MSG1(NEWDATE,NEWACC),CHK1(NEWDATE),PROMPT1 I Y!($D(DIRUT)) D:EXIT MSG5 Q
|
---|
38 | .Q
|
---|
39 | EN1 W ! D DATE,MSG3(NEWDATE),CHK1(NEWDATE),FLAG,MSG4(NEWACC)
|
---|
40 | I EXIT D MSG5 G EN2
|
---|
41 | W ! D CHK
|
---|
42 | I (NEWDATE="")&(NEWACC="YES") D
|
---|
43 | .K MSG W !!
|
---|
44 | .S MSG(1)="This 1358 Obligation does not have an Ending Date, but the"
|
---|
45 | .S MSG(2)="Auto Accrual flag is set to 'YES'.",MSG(3)=" "
|
---|
46 | .S MSG(4)="The Auto Accural flag will be corrected and set to 'NO'."
|
---|
47 | .D EN^DDIOL(.MSG) W ! K MSG H 3
|
---|
48 | .Q
|
---|
49 | EN2 S TMP("NEWACC")=NEWACC,$P(TMP("NEWACC"),U,2)=$S(NEWACC=0:"NO",NEWACC=1:"YES",1:"YES")
|
---|
50 | S TMP("NEWDATE")=NEWDATE S Y=NEWDATE D DD^%DT S $P(TMP("NEWDATE"),U,2)=Y
|
---|
51 | KILL AUTOACC,OLDACC,OLDDATE
|
---|
52 | QUIT
|
---|
53 | ;
|
---|
54 | PROMPT ; Prompt user
|
---|
55 | S EXIT=0
|
---|
56 | D EN^DDIOL("This 1358 Obligation appears to be for services.")
|
---|
57 | S DIR(0)="Y",DIR("A")="Will this 1358 Obligation need to be accrued in FMS",DIR("B")="YES"
|
---|
58 | S DIR("?")=" '^' to exit this option."
|
---|
59 | S DIR("?",1)="Enter one of the following:"
|
---|
60 | S DIR("?",2)=" 'NO' or 'N' if no accrual is needed OR it is for one month."
|
---|
61 | S DIR("?",3)=" 'YES' or 'Y' if the 1358 covers more than one month AND accrual is needed."
|
---|
62 | S DIR("?",4)=" 'RETURN' for YES."
|
---|
63 | S DIR("??")="^D MSG2^PRCFFU15"
|
---|
64 | D ^DIR K DIR W !
|
---|
65 | I 'Y!($D(DIRUT)) D MSG5 Q
|
---|
66 | S NEWDATE="",NEWACC=Y(0)
|
---|
67 | Q
|
---|
68 | MSG1(DATE,FLAG) ; Display current auto accrual information
|
---|
69 | K MSG W !
|
---|
70 | S MSG(1)="CURRENT VALUES FOR AUTO ACCRUAL FOR 1358: "
|
---|
71 | S MSG(2)=" ENDING DATE FOR SERVICE: "_DATE
|
---|
72 | S MSG(3)=" AUTO ACCRUAL FLAG: "_FLAG
|
---|
73 | D EN^DDIOL(.MSG) K MSG
|
---|
74 | Q
|
---|
75 | PROMPT1 ; Prompt for correct values
|
---|
76 | S EXIT=0
|
---|
77 | S DIR(0)="Y",DIR("A")="Are these Auto Accrual values correct",DIR("B")="YES",DIR("??")="^D MSG2^PRCFFU15"
|
---|
78 | W ! D ^DIR K DIR W !
|
---|
79 | I Y S EXIT=1
|
---|
80 | Q
|
---|
81 | DATE ; Determine ending date
|
---|
82 | D DATE^PRCFFU17
|
---|
83 | Q
|
---|
84 | MSG3(DATE) ; Prompt for ending date
|
---|
85 | MSG31 S EXIT=0,DIR(0)="D",DIR("A")="END DATE FOR 1358"
|
---|
86 | D ^DIR K DIR
|
---|
87 | I $D(DIRUT) S EXIT=1 Q
|
---|
88 | I Y S NEWDATE=Y
|
---|
89 | S X1=NEWDATE,X2=$G(PRCTMP(410,IEN,21,"I")) D ^%DTC I X<0 W ! D EN^DDIOL("The Ending Date cannot come before the Committed Date - "_$G(PRCTMP(410,IEN,21,"E"))) W ! G MSG31
|
---|
90 | Q
|
---|
91 | FLAG ; Determine prompt for Auto Accrual
|
---|
92 | D FLAG^PRCFFU17
|
---|
93 | Q
|
---|
94 | MSG4(FLAG) ; Prompt for auto accrual
|
---|
95 | Q:EXIT
|
---|
96 | S DIR(0)="Y",DIR("A")="AUTO ACCRUAL FLAG"
|
---|
97 | D ^DIR K DIR
|
---|
98 | I $D(DIRUT) S EXIT=1 Q
|
---|
99 | S NEWACC=$S($E(Y,1)="Y":1,$E(Y,1)="N":0,$G(DIRUT)=1:0,'Y:0,Y:1,1:1)
|
---|
100 | Q
|
---|
101 | MSG5 ; Exit message
|
---|
102 | D MSG5^PRCFFU15
|
---|
103 | Q
|
---|
104 | CHK ; Check for changes
|
---|
105 | D CHK^PRCFFU17
|
---|
106 | Q
|
---|
107 | CHK1(DATE) ;Check for Ending Date crossover to next FY
|
---|
108 | S X="0930"_PRC("FY") D ^%DT
|
---|
109 | S X2=Y ; end of FY for 1358
|
---|
110 | S X=DATE D ^%DT
|
---|
111 | S X1=Y D ^%DTC
|
---|
112 | I X>0 W ! D EN^DDIOL("NOTE: The Ending Date for Service exceeds the End of the Fiscal Year!!")
|
---|
113 | W !
|
---|
114 | Q
|
---|