PRSAOTT ;WCIOFO/JAH/PLT- 8B CODES ARRAY. COMPARE OT (8B-vs-APPROVED). ;11/29/2006
;;4.0;PAID;**37,43,54,112**;Sep 21, 1995;Build 54
;;Per VHA Directive 2004-038, this routine should not be modified.
;
;Function & subroutine Index for this routine.
;
; APOTWEEK(PAYPRD,WEEKID,EMP450).....return all approved OT in a week.
; ARRAY8B(RECORD)...............Build employee 8B array for payperiod.
; CODES(WEEK)........return string of valid time codes for week 1,2,3.
; GET8BCDS(TT8B).................return timecode portion of 8B string.
; GET8BOT(EMPIEN,WEEK,TT8B)..........return all OT in an 8b string.
; GETOTS(PP,EI,T8,WK,.O8,.OA)......Get overtimes (tt8b & approved).
; OTREQ(REC).................returns true if Request is type Overtime.
; OTAPPR(REC)...................returns true if a Request is Approved.
; WEEKRNG(PPE,WEEK,FIRST,LAST)........1st & last FM days in a pp week.
; WARNSUP(PPE,EI,E8B,WK,OTERR,O8,OA)... check ot's for a week & warn.
Q
;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
GETOTS(PP,EI,T8,WK,O8,OA) ;Get overtimes (tt8b & approved)
; Sample call:
; D GETOTS("98-05",1255,TT8BSTRING,1,.O8,.OA)
; where TT8BSTRING might be =
; "658229548868WIL 8B268380A106 AN320NA060DA030NR300SE080CD000790"
;
; subroutine returns overtime from request file & TT8B string for
; week specified in parameter 4
;
; Input: PP - Pay period in format YY-PP.
; EI - Employees ien from file 450.
; T8 - Entire 8B record. Stored in
; ^PRST(458,PP,"E",EI,5).
; Output: O8 - TT8B overtime calculated
; OA - approved overtime in request fiLE
;
S (OA,O8)=0
Q:((WK'=1)&(WK'=2))
;
S O8=$$GET8BOT^PRSAOTT(EI,WK,T8) ; get all OT from 8b string
S OA=$$APOTWEEK^PRSAOTT(PP,WK,EI) ; get approved overtime
Q
;
;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
WARNSUP(PPE,EI,E8B,WK,OTERR,O8,OA) ;Gets overtime from request
; file & TT8B string & displays warning if 8B string has more
; OT than approved requests.
;
;Input: PPE - (P)ay (P)eriod (E)xternal in format YY-PP.
; EI - (E)mployees (I)nternal entry # from file 450.
; E8B - (E)ntire (8B) record. Stored in ^PRST(458,PP,"E",EI,5).
; WK - week number 1 or 2 of pay period.
;Output: Warning message to screen.
;Local: OA - (O)vertime (A)pproved from requests file.
; O8 - (O)vertime totaled from (8)b string.
;
S (OA,O8,OTERR)=0
; Compare week of approved ot requests to 8B OT.
S O8=$$GET8BOT(EI,WK,E8B) ; get all OT from 8b string
S OA=$$APOTWEEK(PPE,WK,EI) ; get approved overtime
I OA<O8 D DISPLAY(EI,O8,OA,WK) S OTERR=1 ; Display warning if calc>apprv
Q
;
;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
DISPLAY(IEN,OT8B,OTRQ,WK) ;Output warning message. 8b ot > approved ot.
;
; Input: IEN - employees 450 ien.
; OT8B - employees total overtime calculated from 8b string.
; OTRQ - employees total approved OT request's from 458.2
; WK - week 1 or 2 of payperiod.
;
W !,?3,"WARNING: Week ",WK," -Overtime being paid (",OT8B,") is more than approved (",OTRQ,")."
Q
;
;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
GET8BOT(EMPIEN,WEEK,TT8B) ;
; Output: Function returns total hrs of overtime that is coded
; into TT8B string for either week (1) or (2).
; Input: EMPIEN - internal entry # of employee to check 8B overtime
; WEEK - week (1) or (2) of pay period to check 8B overtime.
; TT8B - full 8B string stub & values.
;
N PPIEN,TT8BOT,OTCODES,CODE,OTTOTAL,OTTMP
S OTTOTAL=0
;
; get time coded portion of 8B string
;
S TT8B=$$GET8BCDS(TT8B)
Q:$L(TT8B)<2 OTTOTAL ; Aint no coded OT if there aint no codes.
;
; create array of codes & values for this 8b string.
D ARRAY8B(TT8B)
;
; create string with all overtime codes.
S OTCODES=$S(WEEK=1:"^DA^DB^DC^OA^OB^OC^OK^",1:"^DE^DF^DG^OE^OF^OG^OS^")
; Only count total regular hours @ OT rate when not a firefighter
; with premium pay code "R" or "C". These firefighters get RA/RE from
; their scheduled tour and do not need to have overtime requests. *54
I "^R^C^"'[(U_$P($G(^PRSPC(EMPIEN,"PREMIUM")),U,6)_U) D
. S OTCODES=OTCODES_$S(WEEK=1:"RA^RB^RC^",1:"RE^RF^RG^")
;
; loop thru employees 8b array to see if they have any of
; overtime codes & add any of them up.
;
S CODE=""
F S CODE=$O(TT8B(WEEK,CODE)) Q:CODE="" D
. I OTCODES[("^"_CODE_"^") D
.. S OTTMP=TT8B(WEEK,CODE)
.. S OTTOTAL=OTTOTAL+$E(OTTMP,1,2)+($E(OTTMP,3)*.25)
Q OTTOTAL
;
;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
;
APOTWEEK(PAYPRD,WEEKID,EMP450) ;
;Function returns approved overtime totals for a week.
;Input: PPE,PAYPRD - pay period of concern. YY-PP
; WEEKID - week (1) or week (2) of pay period
; EMP450 - employees internal entry number in file 450.
;Output: TOTALOT - total hrs of overtime for a week
;
;local vars: D1 - 1st day of payperiod-returned by NX^PRSAPPU
; OTREC - a record containing 1 overtime request.
; START,STOP - 1st & last FM days of week (Sun,Sat)
;
; quit returning 0 if anything is missing.
Q:$G(PAYPRD)=""!$G(WEEKID)=""!$G(EMP450)="" 0
;
; Loop thru OT/CT requests file x-ref on requested work date &
; add up all employees approved OT requests within week.
;
N D1,PPE,TOTALOT,START,STOP,OTREC
S TOTALOT=0
D WEEKRNG(PAYPRD,WEEKID,.START,.STOP)
S D1=START-.1
F S D1=$O(^PRST(458.2,"AD",EMP450,D1)) Q:D1>STOP!(D1="") D
. S OTREC=""
. F S OTREC=$O(^PRST(458.2,"AD",EMP450,D1,OTREC)) Q:OTREC="" D
.. I $$OTREQ(OTREC),$$OTAPPR(OTREC) D
... S TOTALOT=TOTALOT+$P($G(^PRST(458.2,OTREC,0)),"^",6)
Q TOTALOT
;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
OTREQ(REC) ;Function returns true if Request is type Overtime.
Q:$G(REC)="" 0
Q $P($G(^PRST(458.2,REC,0)),"^",5)="OT"
;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
OTAPPR(REC) ;Function returns true if a Request is Approved.
Q:$G(REC)="" 0
Q "AS"[$P($G(^PRST(458.2,REC,0)),"^",8)
;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
WEEKRNG(PPE,WEEK,FIRST,LAST) ;
;
; Routine takes a pay period & a week number & returns
; 1st & last FileMan days of specified week.
; Input: PPE - pay period in format YY-PP.
; WEEK - week (1) or (2).
; Output: .FIRST - first day of specified week-FM format
; .LAST - last day of specified week-FM format
N D1,X1,X2,PPD1
D NX^PRSAPPU S PPD1=D1
I WEEK=1 D
. S (FIRST,X1)=PPD1,X2=6 D C^%DTC S LAST=X
E D
. S X1=PPD1,X2=7 D C^%DTC S FIRST=X
. S X1=PPD1,X2=13 D C^%DTC S LAST=X
Q
;
;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
GET8BCDS(TT8B) ; GET 8B time CoDeS
; Input: Full 8b record as stored on node 5 of employee record
; in time & attendance file.
; Output: Function returns section of 8b record with pay
; codes & values.
;
; i.e. return last portion of 8b record ----- <<AN280AL120CD00040>>
; ^PRST(458,,"E",,5)=658226944741FLI 8B256280A112 AN280AL120CD00040
;
; Input: FULL 8B RECORD
;
Q $E(TT8B,33,$L(TT8B))
;
;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
ARRAY8B(RECORD) ; Build employee 8B array.
; calls to this routine are responsible for cleaning up TT8B( array.
;
; Build a TT8B array which contains ONLY codes & values
; that are in employees 8B record.
;
; Input: RECORD - last portion of 8B array with codes & values.
; e.g. <<AN280AL120CD00040>> (see GET8BCDS^PRSAOTT)
;
; Output: array subscripted by time code & set equal to value.
; e.g. TT8B(1,"AN")=010
; TT8B(1,"DA")=020
; TT8B(1,"NA")=020
; TT8B(2,"SL")=080
; TT8B(3,"CD")=000130
;
K TT8B S TT8B(0)=0
Q:$G(RECORD)=""
N EOR,TYPE,VALUE,LOOP,WK
S EOR=0
F D Q:EOR=1
. S TYPE=$E(RECORD,1,2)
.; I TYPE="CD" S VALUE=$E(RECORD,3,$L(RECORD)) S EOR=1
.;
.;traverse record to next code so LOOP gets len of curr code value
.;
. F LOOP=3:1:$L(RECORD) Q:$E(RECORD,LOOP)?1U
. S:LOOP=$L(RECORD) EOR=1
. S VALUE=$S(EOR=1:$E(RECORD,3,LOOP),1:$E(RECORD,3,LOOP-1))
. S:EOR=0 RECORD=$E(RECORD,LOOP,$L(RECORD))
.;
.;Put code into corresponding week of TT8B array.
.;
. S WK=$S($F($$CODES(1),TYPE):1,$F($$CODES(2),TYPE):2,$F($$CODES(3),TYPE):3,1:"unknown")
. S TT8B(WK,TYPE)=VALUE,TT8B(0)=TT8B(0)+1
Q
;
;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
CODES(WEEK) ;
; 8b string can contain any number of codes. Some of codes
; are strictly for types of time in week 1 & some are for week 2.
; There are also pay period codes that are independant from weeks.
;
; This function returns a string of codes for specified
; week (1) or (2) -OR- (3)---8b codes independant of week.
;
; Input: WEEK - week (1) (2) of pay period.
;
Q:$G(WEEK)="" 0
Q:WEEK=1 "AN SK WD NO AU RT CE CU UN NA NB SP SA SB SC DA DB DC TF OA OB OC YA OK OM RA RB RC HA HB HC PT PA ON YD HD VC EA EB TA TC FA FC AD NT RS ND SR SD"
;
Q:WEEK=2 "AL SL WP NP AB RL CT CO US NR NS SQ SE SF SG DE DF DG TG OE OF OG YE OS OU RE RF RG HL HM HN PH PB CL YH HO VS EC ED TB TD FB FD AF NH RN NU SS SH"
;
Q:WEEK=3 "NL DW IN TL LU LN LD DT TO LA ML CA PC CY RR FF FE CD"
Q 0
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPRSAOTT 9593 printed Dec 13, 2024@02:23:46 Page 2
PRSAOTT ;WCIOFO/JAH/PLT- 8B CODES ARRAY. COMPARE OT (8B-vs-APPROVED). ;11/29/2006
+1 ;;4.0;PAID;**37,43,54,112**;Sep 21, 1995;Build 54
+2 ;;Per VHA Directive 2004-038, this routine should not be modified.
+3 ;
+4 ;Function & subroutine Index for this routine.
+5 ;
+6 ; APOTWEEK(PAYPRD,WEEKID,EMP450).....return all approved OT in a week.
+7 ; ARRAY8B(RECORD)...............Build employee 8B array for payperiod.
+8 ; CODES(WEEK)........return string of valid time codes for week 1,2,3.
+9 ; GET8BCDS(TT8B).................return timecode portion of 8B string.
+10 ; GET8BOT(EMPIEN,WEEK,TT8B)..........return all OT in an 8b string.
+11 ; GETOTS(PP,EI,T8,WK,.O8,.OA)......Get overtimes (tt8b & approved).
+12 ; OTREQ(REC).................returns true if Request is type Overtime.
+13 ; OTAPPR(REC)...................returns true if a Request is Approved.
+14 ; WEEKRNG(PPE,WEEK,FIRST,LAST)........1st & last FM days in a pp week.
+15 ; WARNSUP(PPE,EI,E8B,WK,OTERR,O8,OA)... check ot's for a week & warn.
+16 QUIT
+17 ;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
GETOTS(PP,EI,T8,WK,O8,OA) ;Get overtimes (tt8b & approved)
+1 ; Sample call:
+2 ; D GETOTS("98-05",1255,TT8BSTRING,1,.O8,.OA)
+3 ; where TT8BSTRING might be =
+4 ; "658229548868WIL 8B268380A106 AN320NA060DA030NR300SE080CD000790"
+5 ;
+6 ; subroutine returns overtime from request file & TT8B string for
+7 ; week specified in parameter 4
+8 ;
+9 ; Input: PP - Pay period in format YY-PP.
+10 ; EI - Employees ien from file 450.
+11 ; T8 - Entire 8B record. Stored in
+12 ; ^PRST(458,PP,"E",EI,5).
+13 ; Output: O8 - TT8B overtime calculated
+14 ; OA - approved overtime in request fiLE
+15 ;
+16 SET (OA,O8)=0
+17 if ((WK'=1)&(WK'=2))
QUIT
+18 ;
+19 ; get all OT from 8b string
SET O8=$$GET8BOT^PRSAOTT(EI,WK,T8)
+20 ; get approved overtime
SET OA=$$APOTWEEK^PRSAOTT(PP,WK,EI)
+21 QUIT
+22 ;
+23 ;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
WARNSUP(PPE,EI,E8B,WK,OTERR,O8,OA) ;Gets overtime from request
+1 ; file & TT8B string & displays warning if 8B string has more
+2 ; OT than approved requests.
+3 ;
+4 ;Input: PPE - (P)ay (P)eriod (E)xternal in format YY-PP.
+5 ; EI - (E)mployees (I)nternal entry # from file 450.
+6 ; E8B - (E)ntire (8B) record. Stored in ^PRST(458,PP,"E",EI,5).
+7 ; WK - week number 1 or 2 of pay period.
+8 ;Output: Warning message to screen.
+9 ;Local: OA - (O)vertime (A)pproved from requests file.
+10 ; O8 - (O)vertime totaled from (8)b string.
+11 ;
+12 SET (OA,O8,OTERR)=0
+13 ; Compare week of approved ot requests to 8B OT.
+14 ; get all OT from 8b string
SET O8=$$GET8BOT(EI,WK,E8B)
+15 ; get approved overtime
SET OA=$$APOTWEEK(PPE,WK,EI)
+16 ; Display warning if calc>apprv
IF OA<O8
DO DISPLAY(EI,O8,OA,WK)
SET OTERR=1
+17 QUIT
+18 ;
+19 ;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
DISPLAY(IEN,OT8B,OTRQ,WK) ;Output warning message. 8b ot > approved ot.
+1 ;
+2 ; Input: IEN - employees 450 ien.
+3 ; OT8B - employees total overtime calculated from 8b string.
+4 ; OTRQ - employees total approved OT request's from 458.2
+5 ; WK - week 1 or 2 of payperiod.
+6 ;
+7 WRITE !,?3,"WARNING: Week ",WK," -Overtime being paid (",OT8B,") is more than approved (",OTRQ,")."
+8 QUIT
+9 ;
+10 ;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
GET8BOT(EMPIEN,WEEK,TT8B) ;
+1 ; Output: Function returns total hrs of overtime that is coded
+2 ; into TT8B string for either week (1) or (2).
+3 ; Input: EMPIEN - internal entry # of employee to check 8B overtime
+4 ; WEEK - week (1) or (2) of pay period to check 8B overtime.
+5 ; TT8B - full 8B string stub & values.
+6 ;
+7 NEW PPIEN,TT8BOT,OTCODES,CODE,OTTOTAL,OTTMP
+8 SET OTTOTAL=0
+9 ;
+10 ; get time coded portion of 8B string
+11 ;
+12 SET TT8B=$$GET8BCDS(TT8B)
+13 ; Aint no coded OT if there aint no codes.
if $LENGTH(TT8B)<2
QUIT OTTOTAL
+14 ;
+15 ; create array of codes & values for this 8b string.
+16 DO ARRAY8B(TT8B)
+17 ;
+18 ; create string with all overtime codes.
+19 SET OTCODES=$SELECT(WEEK=1:"^DA^DB^DC^OA^OB^OC^OK^",1:"^DE^DF^DG^OE^OF^OG^OS^")
+20 ; Only count total regular hours @ OT rate when not a firefighter
+21 ; with premium pay code "R" or "C". These firefighters get RA/RE from
+22 ; their scheduled tour and do not need to have overtime requests. *54
+23 IF "^R^C^"'[(U_$PIECE($GET(^PRSPC(EMPIEN,"PREMIUM")),U,6)_U)
Begin DoDot:1
+24 SET OTCODES=OTCODES_$SELECT(WEEK=1:"RA^RB^RC^",1:"RE^RF^RG^")
End DoDot:1
+25 ;
+26 ; loop thru employees 8b array to see if they have any of
+27 ; overtime codes & add any of them up.
+28 ;
+29 SET CODE=""
+30 FOR
SET CODE=$ORDER(TT8B(WEEK,CODE))
if CODE=""
QUIT
Begin DoDot:1
+31 IF OTCODES[("^"_CODE_"^")
Begin DoDot:2
+32 SET OTTMP=TT8B(WEEK,CODE)
+33 SET OTTOTAL=OTTOTAL+$EXTRACT(OTTMP,1,2)+($EXTRACT(OTTMP,3)*.25)
End DoDot:2
End DoDot:1
+34 QUIT OTTOTAL
+35 ;
+36 ;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
+37 ;
APOTWEEK(PAYPRD,WEEKID,EMP450) ;
+1 ;Function returns approved overtime totals for a week.
+2 ;Input: PPE,PAYPRD - pay period of concern. YY-PP
+3 ; WEEKID - week (1) or week (2) of pay period
+4 ; EMP450 - employees internal entry number in file 450.
+5 ;Output: TOTALOT - total hrs of overtime for a week
+6 ;
+7 ;local vars: D1 - 1st day of payperiod-returned by NX^PRSAPPU
+8 ; OTREC - a record containing 1 overtime request.
+9 ; START,STOP - 1st & last FM days of week (Sun,Sat)
+10 ;
+11 ; quit returning 0 if anything is missing.
+12 if $GET(PAYPRD)=""!$GET(WEEKID)=""!$GET(EMP450)=""
QUIT 0
+13 ;
+14 ; Loop thru OT/CT requests file x-ref on requested work date &
+15 ; add up all employees approved OT requests within week.
+16 ;
+17 NEW D1,PPE,TOTALOT,START,STOP,OTREC
+18 SET TOTALOT=0
+19 DO WEEKRNG(PAYPRD,WEEKID,.START,.STOP)
+20 SET D1=START-.1
+21 FOR
SET D1=$ORDER(^PRST(458.2,"AD",EMP450,D1))
if D1>STOP!(D1="")
QUIT
Begin DoDot:1
+22 SET OTREC=""
+23 FOR
SET OTREC=$ORDER(^PRST(458.2,"AD",EMP450,D1,OTREC))
if OTREC=""
QUIT
Begin DoDot:2
+24 IF $$OTREQ(OTREC)
IF $$OTAPPR(OTREC)
Begin DoDot:3
+25 SET TOTALOT=TOTALOT+$PIECE($GET(^PRST(458.2,OTREC,0)),"^",6)
End DoDot:3
End DoDot:2
End DoDot:1
+26 QUIT TOTALOT
+27 ;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
OTREQ(REC) ;Function returns true if Request is type Overtime.
+1 if $GET(REC)=""
QUIT 0
+2 QUIT $PIECE($GET(^PRST(458.2,REC,0)),"^",5)="OT"
+3 ;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
OTAPPR(REC) ;Function returns true if a Request is Approved.
+1 if $GET(REC)=""
QUIT 0
+2 QUIT "AS"[$PIECE($GET(^PRST(458.2,REC,0)),"^",8)
+3 ;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
WEEKRNG(PPE,WEEK,FIRST,LAST) ;
+1 ;
+2 ; Routine takes a pay period & a week number & returns
+3 ; 1st & last FileMan days of specified week.
+4 ; Input: PPE - pay period in format YY-PP.
+5 ; WEEK - week (1) or (2).
+6 ; Output: .FIRST - first day of specified week-FM format
+7 ; .LAST - last day of specified week-FM format
+8 NEW D1,X1,X2,PPD1
+9 DO NX^PRSAPPU
SET PPD1=D1
+10 IF WEEK=1
Begin DoDot:1
+11 SET (FIRST,X1)=PPD1
SET X2=6
DO C^%DTC
SET LAST=X
End DoDot:1
+12 IF '$TEST
Begin DoDot:1
+13 SET X1=PPD1
SET X2=7
DO C^%DTC
SET FIRST=X
+14 SET X1=PPD1
SET X2=13
DO C^%DTC
SET LAST=X
End DoDot:1
+15 QUIT
+16 ;
+17 ;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
GET8BCDS(TT8B) ; GET 8B time CoDeS
+1 ; Input: Full 8b record as stored on node 5 of employee record
+2 ; in time & attendance file.
+3 ; Output: Function returns section of 8b record with pay
+4 ; codes & values.
+5 ;
+6 ; i.e. return last portion of 8b record ----- <<AN280AL120CD00040>>
+7 ; ^PRST(458,,"E",,5)=658226944741FLI 8B256280A112 AN280AL120CD00040
+8 ;
+9 ; Input: FULL 8B RECORD
+10 ;
+11 QUIT $EXTRACT(TT8B,33,$LENGTH(TT8B))
+12 ;
+13 ;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
ARRAY8B(RECORD) ; Build employee 8B array.
+1 ; calls to this routine are responsible for cleaning up TT8B( array.
+2 ;
+3 ; Build a TT8B array which contains ONLY codes & values
+4 ; that are in employees 8B record.
+5 ;
+6 ; Input: RECORD - last portion of 8B array with codes & values.
+7 ; e.g. <<AN280AL120CD00040>> (see GET8BCDS^PRSAOTT)
+8 ;
+9 ; Output: array subscripted by time code & set equal to value.
+10 ; e.g. TT8B(1,"AN")=010
+11 ; TT8B(1,"DA")=020
+12 ; TT8B(1,"NA")=020
+13 ; TT8B(2,"SL")=080
+14 ; TT8B(3,"CD")=000130
+15 ;
+16 KILL TT8B
SET TT8B(0)=0
+17 if $GET(RECORD)=""
QUIT
+18 NEW EOR,TYPE,VALUE,LOOP,WK
+19 SET EOR=0
+20 FOR
Begin DoDot:1
+21 SET TYPE=$EXTRACT(RECORD,1,2)
+22 ; I TYPE="CD" S VALUE=$E(RECORD,3,$L(RECORD)) S EOR=1
+23 ;
+24 ;traverse record to next code so LOOP gets len of curr code value
+25 ;
+26 FOR LOOP=3:1:$LENGTH(RECORD)
if $EXTRACT(RECORD,LOOP)?1U
QUIT
+27 if LOOP=$LENGTH(RECORD)
SET EOR=1
+28 SET VALUE=$SELECT(EOR=1:$EXTRACT(RECORD,3,LOOP),1:$EXTRACT(RECORD,3,LOOP-1))
+29 if EOR=0
SET RECORD=$EXTRACT(RECORD,LOOP,$LENGTH(RECORD))
+30 ;
+31 ;Put code into corresponding week of TT8B array.
+32 ;
+33 SET WK=$SELECT($FIND($$CODES(1),TYPE):1,$FIND($$CODES(2),TYPE):2,$FIND($$CODES(3),TYPE):3,1:"unknown")
+34 SET TT8B(WK,TYPE)=VALUE
SET TT8B(0)=TT8B(0)+1
End DoDot:1
if EOR=1
QUIT
+35 QUIT
+36 ;
+37 ;= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
CODES(WEEK) ;
+1 ; 8b string can contain any number of codes. Some of codes
+2 ; are strictly for types of time in week 1 & some are for week 2.
+3 ; There are also pay period codes that are independant from weeks.
+4 ;
+5 ; This function returns a string of codes for specified
+6 ; week (1) or (2) -OR- (3)---8b codes independant of week.
+7 ;
+8 ; Input: WEEK - week (1) (2) of pay period.
+9 ;
+10 if $GET(WEEK)=""
QUIT 0
+11 if WEEK=1
QUIT "AN SK WD NO AU RT CE CU UN NA NB SP SA SB SC DA DB DC TF OA OB OC YA OK OM RA RB RC HA HB HC PT PA ON YD HD VC EA EB TA TC FA FC AD NT RS ND SR SD"
+12 ;
+13 if WEEK=2
QUIT "AL SL WP NP AB RL CT CO US NR NS SQ SE SF SG DE DF DG TG OE OF OG YE OS OU RE RF RG HL HM HN PH PB CL YH HO VS EC ED TB TD FB FD AF NH RN NU SS SH"
+14 ;
+15 if WEEK=3
QUIT "NL DW IN TL LU LN LD DT TO LA ML CA PC CY RR FF FE CD"
+16 QUIT 0