1 | PRS8MSC1 ;HISC/DAD,WCIOFO/MGD,SAB-MISC TIME CARD ADJUST(contd) ;1/30/2007
|
---|
2 | ;;4.0;PAID;**56,68,111**;Sep 21, 1995;Build 2
|
---|
3 | ;;Per VHA Directive 2004-038, this routine should not be modified.
|
---|
4 | ;
|
---|
5 | ; This routine may automatically charge days to WP (leave without pay)
|
---|
6 | ; if the employee has not performed any duty during the week. This
|
---|
7 | ; routine is only called for employees on a daily tour.
|
---|
8 | ; The software does not automatically charge NP (Non Pay) since the
|
---|
9 | ; effective start or end day may be on a day off such that an entire
|
---|
10 | ; week should not be charged to NP.
|
---|
11 | ;
|
---|
12 | ; This routine is called from PRS8MSC0.
|
---|
13 | ;
|
---|
14 | NODUTY ;
|
---|
15 | ; inputs
|
---|
16 | ; PY - pay period IEN
|
---|
17 | ; DFN - employee IEN
|
---|
18 | ;
|
---|
19 | N CHGDAY,DO,DW,DY,END,EXC,START,TOD,WEEK
|
---|
20 | ;
|
---|
21 | ; loop thru both weeks in pay period
|
---|
22 | F WEEK=1,2 D
|
---|
23 | . ; init week counts and list of days that could be charged
|
---|
24 | . S (DW,DW("WP"),DW("NP"),DW("HX"),DO("CP"))=0
|
---|
25 | . K CHGDAY
|
---|
26 | . ;
|
---|
27 | . ; loop thru days in week
|
---|
28 | . I WEEK=1 S START=1,END=7
|
---|
29 | . I WEEK=2 S START=8,END=14
|
---|
30 | . F DY=START:1:END D
|
---|
31 | . . ; get tour and how day was charged
|
---|
32 | . . S TOD=$P($G(^PRST(458,PY,"E",DFN,"D",DY,0)),U,2)
|
---|
33 | . . S EXC=$P($G(^PRST(458,PY,"E",DFN,"D",DY,2)),U,3)
|
---|
34 | . . ; update if day charged differently due to encapsulation
|
---|
35 | . . I $D(^TMP($J,"PRS8",DY,2,0)) S EXC=^TMP($J,"PRS8",DY,2,0)
|
---|
36 | . . ;
|
---|
37 | . . ; update week counts for the day
|
---|
38 | . . I TOD>1 D ; scheduled work day
|
---|
39 | . . . S DW=DW+1
|
---|
40 | . . . I EXC="WP" S DW("WP")=DW("WP")+1
|
---|
41 | . . . I EXC="NP" S DW("NP")=DW("NP")+1
|
---|
42 | . . . I EXC="HX" S DW("HX")=DW("HX")+1,CHGDAY(DY)="" ; add HX to list
|
---|
43 | . . I TOD=1 D ; day off
|
---|
44 | . . . I EXC="CP" S DO("CP")=DO("CP")+1
|
---|
45 | . . . I EXC="" S CHGDAY(DY)="" ; add not charged day off to list
|
---|
46 | . ;
|
---|
47 | . ; if all work days were counted as a combination of WP, NP, and HX
|
---|
48 | . ; and at least one day was counted as WP and no days off were counted
|
---|
49 | . ; as CP then automatically charge appropriate remaining days to WP.
|
---|
50 | . I DW("WP")+DW("NP")+DW("HX")'<DW,DW("WP")>0,DO("CP")=0 D
|
---|
51 | . . D SET^PRS8EX0(DFN,PY,"WP",3,.CHGDAY)
|
---|
52 | ;
|
---|
53 | Q
|
---|