Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: PRSRL41

PRSRL41.m

Go to the documentation of this file.
  1. PRSRL41 ;HISC/JH-INDIVIDUAL EMPLOYEE LEAVE USAGE PATTERN (Continued) ;09/24/01
  1. ;;4.0;PAID;**2,19,21,35,69,141**;Sep 21, 1995;Build 3
  1. ;;Per VHA Directive 2004-038, this routine should not be modified
  1. ;
  1. S ORG=$E(ORG,1,12)
  1. D HDR1
  1. S (PP(1),DAY(1),DATT(1))=""
  1. S DATE(1)=0
  1. ;
  1. ;initialize leave arrays, subscripted by ("AL","SL","ML","WP"...)
  1. F I=1:1 S X=$P($P(LVT,";",I+1),":") Q:X="" S LEV(X)="",TLEV(X)=""
  1. D TYPSTF^PRSRUT0
  1. S INX=0
  1. ;
  1. ;Loop through LEAVE pattern temp global.
  1. ;
  1. ;debug line
  1. ;W !!,"LEAVE PATTERN TEMP GLOBAL: "," ^TMP(",$J,",USE," Q
  1. F I=0:0 S INX=$O(^TMP($J,"USE",INX)) Q:INX'>0 D Q:POUT
  1. .;
  1. .; Loop through each pay period.
  1. . S PP=""
  1. . F I=0:0 S PP=$O(^TMP($J,"USE",INX,PP)) Q:PP="" S SW(1)=0 D Q:POUT
  1. ..;
  1. ..; Loop through the dates within the pay period.
  1. .. S DATE=0
  1. .. F I=0:0 S DATE=$O(^TMP($J,"USE",INX,PP,DATE)) Q:DATE'>0 D Q:POUT
  1. ...;
  1. ...; Loop through days of week (even though only one per loop)
  1. ... S DAY=""
  1. ... F I=0:0 S DAY=$O(^TMP($J,"USE",INX,PP,DATE,DAY)) Q:DAY="" S TOUR=$G(^(DAY)) Q:TOUR="" S SW(3)=0 D Q:POUT
  1. ....;
  1. .... D:($Y>(IOSL-5)) HDR Q:POUT
  1. .... S DATT=$E(DATE,4,5)_"/"_$E(DATE,6,7)_"/"_$E(DATE,2,3)
  1. .... D CHK,VLIN0:X>1
  1. .... W !,"|"
  1. .... W $S(PP'=PP(1):$E(PP,3,7),1:"")
  1. .... W ?7,"|",DAY,?12,"|"
  1. .... W $S(DATT'=DATT(1):DATT,1:""),?22,"|" D
  1. ..... D:TOUR["DO" DAY
  1. ..... I TOUR'["DO" F K=1:4 Q:$P(TOUR,"^",K+2)="" S LEV=$P(TOUR,"^",K+2),%=$F(LVT,";"_LEV_":") W:SW(3) !,"|",?7,"|",?12,"|",?22,"|" D
  1. ...... W:%>0 ?23,LEV
  1. ...... W ?27,"|",$P(TOUR,"^",K)
  1. ...... W ?35,"|",$P(TOUR,"^",K+1)
  1. ...... W ?43,"|"
  1. ...... S Z="^^"_DATE_"^"_$P(TOUR,"^",K)_"^"_DATE_"^"_$P(TOUR,"^",K+1) D
  1. ....... S COM=$G(^TMP($J,"US",INX))
  1. ....... D D^PRSRLL:$P($E(LVT,%,999),";")="ML"!(SW(2)=77),H^PRSRLL:$P($E(LVT,%,999),";")'="ML"&(SW(2)=73) W $S(SW(2)=77:$J(TIM,6),1:$J(TIM,6,2)),?($X+1),TYL,?52,"|",$S($D(COM):$E(COM,1,26),1:""),?79,"|" D
  1. ........ S LEV(LEV)=LEV(LEV)+TIM,TLEV(LEV)=TLEV(LEV)+TIM S SW(1)=SW(1)+1,SW(3)=1
  1. ........ Q
  1. ....... Q
  1. ...... Q
  1. ..... S PP(1)=PP,DATT(1)=DATT,DAY(1)=DAY,DATE(1)=DATE Q
  1. .... Q
  1. ... Q
  1. .. Q
  1. . Q
  1. ;
  1. ; Print Totals
  1. ;
  1. Q:POUT
  1. D:$Y>(IOSL-7) VLIN0,HDR Q:POUT
  1. I SW(1) D VLIN0 W !,"|",?7,"|",?12,"|",?15,"TOTALS:" S (SW(3),TLEV)=0,X="" D
  1. . F I=0:0 S X=$O(TLEV(X)) Q:X="" D:$Y>(IOSL-5) HDR Q:POUT S %=$F(LVT,";"_X_":") W:SW(3)&(TLEV(X)'="") !,"|",?7,"|",?12,"|",?22,"|" S TLEV=TLEV+TLEV(X) D
  1. .. W:TLEV(X)'="" ?24,$P($E(LVT,%,999),";"),?44,$S(SW(2)=77:$J($G(TLEV(X)),6),1:$J($G(TLEV(X)),6,2)),?($X+1),TYL,?52,"|",?79,"|" S:'SW(3)&(TLEV(X)'="") SW(3)=1
  1. .. Q
  1. . Q
  1. I IOSL<66 F I=$Y:1:IOSL-6 D VLIN0
  1. Q
  1. CHK S X1=DATE,X2=DATE(1) D ^%DTC Q
  1. DAY W TOUR,?27,"|",?35,"|",?43,"|",?52,"|",?79,"|" S SW(1)=SW(1)+1 Q
  1. HDR S CODE="L005",FOOT="VA TIME & ATTENDANCE SYSTEM" D VLIDSH0,FOOT2^PRSRUT0
  1. I $E(IOST)="C"!($G(IOT)="VTRM") R !,"Press Return/Enter to continue. ",II:DTIME S:II="^" POUT=1 Q:POUT
  1. Q:POUT
  1. HDR1 ; Main header for report contains:
  1. ; Title, ALL/ONLY, date, date range, employee, cost center, T&L unit
  1. ;
  1. ; Subheader according to type of report user selected
  1. S SUBHDR=$S(ALOO="A":"All Leave Taken With Days Off",1:"Every Occurrence of Leave, ONLY Before And After Days Off")
  1. W @IOF
  1. W !?29,^TMP($J,"USE"),?66
  1. W "DATE: ",DAT,!?22,"from: ",XX," to ",YY
  1. W !,?(80-$L(SUBHDR))\2,SUBHDR ;tab depending on length of subheader
  1. W !?25,"for: ",NAM," - "
  1. W ORG,!,?33
  1. W "T&L Unit: ",TLE
  1. D VLIDSH0
  1. W !,"|","P/P",?7,"|","DAY",?12,"|","DATE",?22,"|","TYPE",?27,"|","FROM",?35,"|","TO",?43,"|","LENGTH",?52,"|","COMMENT",?79,"|" D VLIDSH0 Q
  1. VLIDSH0 W !,"|------|----|---------|----|-------|-------|--------|--------------------------|" Q
  1. VLIN0 W !,"|",?7,"|",?12,"|",?22,"|",?27,"|",?35,"|",?43,"|",?52,"|",?79,"|" Q
  1. ASKDSPLY() ; Ask user if they want to see all leave, including days off and
  1. ; Holidays or if they want to see only leave taken immediately
  1. ; before or after Holidays and days off.
  1. N DIR
  1. S RTN=""
  1. S DIR(0)="SM^A:All leave;O:Only around days off & holidays"
  1. S DIR("A")=" Choose A or O "
  1. S DIR("A",1)="You may display ALL leave taken within the date range"
  1. S DIR("A",2)="or ONLY leave taken the day before and after holidays"
  1. S DIR("A",3)="and scheduled days off."
  1. S DIR("A",4)=""
  1. S DIR("?",1)="If you select ONLY leave around days off and holidays,"
  1. S DIR("?",2)="then for example, when an employee with weekends off has"
  1. S DIR("?",3)="taken annual leave for the entire week (Mon-Fri), only"
  1. S DIR("?",4)="the leave for Monday and Friday will be displayed."
  1. S DIR("?")="Selecting ALL, will display all leave taken."
  1. D ^DIR S RTN=Y
  1. Q RTN