[613] | 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
|
---|