1 | PRCFFU17 ;WISC/SJG-1358 OBLIGATION UTILITY ;6/29/00 12:15
|
---|
2 | V ;;5.1;IFCAP;;Oct 20, 2000
|
---|
3 | ;Per VHA Directive 10-93-142, this routine should not be modified.
|
---|
4 | ;
|
---|
5 | QUIT
|
---|
6 | ; No top level entry
|
---|
7 | ;
|
---|
8 | DATE ; Determine ending date
|
---|
9 | I $D(TMP("NEWDATE")) S (NEWDATE,DIR("B"))=$P(TMP("NEWDATE"),U,2) Q
|
---|
10 | I $G(PRCTMP(442,+POIEN,29,"E"))]"" S (NEWDATE,DIR("B"))=$G(PRCTMP(442,+POIEN,29,"E"))
|
---|
11 | I $G(PRCTMP(442,+POIEN,29,"E"))="" D
|
---|
12 | .I $G(PRCTMP(410,IEN,11,"E"))]"" D
|
---|
13 | ..I $G(PRCTMP(410,IEN,13,"I"))]"" D
|
---|
14 | ...S VENID=$G(PRCTMP(410,IEN,12,"I")) Q:VENID=""
|
---|
15 | ...S VENCONT=$G(PRCTMP(410,IEN,13,"I")) Q:VENCONT=""
|
---|
16 | ...S DIC="^PRC(440,"_VENID_",4,",DIC(0)="MNZ",X=VENCONT D ^DIC K DIC
|
---|
17 | ...I Y<0 D:$G(PRCTMP(410,IEN,13,"E"))]"" EOM Q
|
---|
18 | ...I Y>0 D Q
|
---|
19 | ....N DA S CONTIEN=+Y
|
---|
20 | ....S DIC=440,DR=6,DA=+VENID,DIQ="PRCTMP(",DIQ(0)="IEN",DR(440.03)=".5;1",DA(440.03)=CONTIEN D EN^DIQ1 K DIC,DIQ,DR
|
---|
21 | ....S CONTEND=$G(PRCTMP(440.03,CONTIEN,1,"E"))
|
---|
22 | ....I CONTEND]"" S (NEWDATE,DIR("B"))=CONTEND
|
---|
23 | ....Q
|
---|
24 | ...Q
|
---|
25 | ..Q
|
---|
26 | .I $G(PRCTMP(410,IEN,13,"E"))="" D EOM
|
---|
27 | .I $D(NEWDATE) S DIR("B")=NEWDATE
|
---|
28 | Q
|
---|
29 | ;
|
---|
30 | FLAG ; Determine prompt for Auto Accrual
|
---|
31 | I $D(TMP("NEWACC")) S (NEWACC,DIR("B"))=$P(TMP("NEWACC"),U,2) Q
|
---|
32 | I $G(PRCTMP(442,+POIEN,30,"E"))]"" S (NEWACC,DIR("B"))=$G(PRCTMP(442,+POIEN,30,"E"))
|
---|
33 | I $G(PRCTMP(442,+POIEN,30,"E"))="" D
|
---|
34 | .S (NEWACC,DIR("B"))="YES"
|
---|
35 | .S X1=NEWDATE,X2=$G(PRCTMP(410,IEN,21,"I")) D ^%DTC I X<31 S (NEWACC,DIR("B"))="NO"
|
---|
36 | I $G(PRCTMP(442,+POIEN,30,"E"))]"" S (NEWACC,DIR("B"))=$G(PRCTMP(442,+POIEN,30,"E"))
|
---|
37 | Q
|
---|
38 | ;
|
---|
39 | EOM ; Determine last date of month
|
---|
40 | N COM
|
---|
41 | S COM=$G(PRCTMP(410,IEN,21,"I")),Y=$P($$EOM^PRCFFU16(COM),U,2)
|
---|
42 | D DD^%DT S (NEWDATE,DIR("B"))=Y
|
---|
43 | Q
|
---|
44 | CHK ; Check for changes
|
---|
45 | S OLDDATE=$G(PRCTMP(442,+POIEN,29,"I"))
|
---|
46 | S OLDACC=$G(PRCTMP(442,+POIEN,30,"I"))
|
---|
47 | I OLDDATE=NEWDATE&(OLDACC=NEWACC) Q
|
---|
48 | I OLDDATE'=NEWDATE S (PRCFA("ACCEDIT"),ACCEDIT)=1
|
---|
49 | I OLDACC'=NEWACC S (PRCFA("ACCEDIT"),ACCEDIT)=1
|
---|
50 | Q
|
---|