| 1 | ENY2REP4 ;:(WIRMFO)/DH-Y2K Cum Report ;8.20.98
 | 
|---|
| 2 |  ;;7.0;ENGINEERING;**51,55**;August 17, 1993
 | 
|---|
| 3 | EN W @IOF,!,?18,"CUMULATIVE EFFECTS OF Y2K ACTION TAKEN TO DATE"
 | 
|---|
| 4 |  W !!,"There are approximately "_$P(^ENG(6914,0),U,4)_" entries in your Equipment file. Inactive entries"
 | 
|---|
| 5 |  W !,"(USE STATUS of 'TURNED-IN' or 'LOST OR STOLEN') will be automatically excluded",!,"from Y2K consideration (unless they were turned in due to Y2K non-compliance)."
 | 
|---|
| 6 |  W !!,"Equipment entries without a MANUFACTURER and a MODEL will also be excluded",!,"from Y2K consideration."
 | 
|---|
| 7 |  I $P($G(^DIC(6910,1,0)),U,2)']"" W !!,"There is no STATION NUMBER in your Engineering Init Paramaters file.",!,"Can't proceed.",*7 Q
 | 
|---|
| 8 |  S ENSTN=0
 | 
|---|
| 9 |  I $P(^DIC(6910,1,0),U,10)!($D(^DIC(6910,1,3))) D  I ENSTN="^" K ENSTN Q
 | 
|---|
| 10 |  . W !! S DIR(0)="Y",DIR("A")="Do you want a breakout by station",DIR("B")="NO"
 | 
|---|
| 11 |  . S DIR("?",1)="If you say 'NO' you will obtain a single report for all your equipment,"
 | 
|---|
| 12 |  . S DIR("?")="regardless of which station it belongs to."
 | 
|---|
| 13 |  . D ^DIR K DIR I $D(DIRUT) S ENSTN="^" Q
 | 
|---|
| 14 |  . S ENSTN=Y
 | 
|---|
| 15 |  W ! S DIR(0)="Y",DIR("A")="Do you want a breakout by FUNCTIONAL CLASSIFICATION",DIR("B")="NO"
 | 
|---|
| 16 |  S DIR("?",1)="If you say 'NO' you will obtain a single report for all of your equipment,"
 | 
|---|
| 17 |  S DIR("?",2)="regardless of which FUNCTIONAL CLASSIFICATION ('MED', 'PC', 'FS', or 'TEL')"
 | 
|---|
| 18 |  S DIR("?")="it happens to be assigned to."
 | 
|---|
| 19 |  D ^DIR K DIR I $D(DIRUT) K ENSTN Q
 | 
|---|
| 20 |  S ENCLASS=Y
 | 
|---|
| 21 |  W !! K IO("Q") S %ZIS="QM" D ^%ZIS G:POP EXIT
 | 
|---|
| 22 |  I $D(IO("Q")) S ZTRTN="DEQ^ENY2REP4" D  G EXIT
 | 
|---|
| 23 |  . S ZTDESC="Y2K Equipment Cumulative",ZTIO=ION
 | 
|---|
| 24 |  . S ZTSAVE("EN*")=""
 | 
|---|
| 25 |  . D ^%ZTLOAD,HOME^%ZIS K ZTSK
 | 
|---|
| 26 |  ;
 | 
|---|
| 27 | DEQ ; get the net results to date
 | 
|---|
| 28 |  K ^TMP($J)
 | 
|---|
| 29 |  N COUNT,TOTAL,STATION,DA,COST,MONTH,YEAR,CLASS,J,K,L
 | 
|---|
| 30 | DEQ1 S STATION("PARNT")=$P(^DIC(6910,1,0),U,2),STATION=STATION("PARNT")
 | 
|---|
| 31 |  ;  begin initialization
 | 
|---|
| 32 |  F K="CON",0,"MED","PC","FS","TEL" F J="ACT","Y2K",0,"FC","NC","CC","NA" S COUNT(STATION,K,J)=0
 | 
|---|
| 33 |  F K="CON",0,"MED","PC","FS","TEL" F J=0,"REP","SREP","RET","USE" S COUNT(STATION,K,"NC",J)=0
 | 
|---|
| 34 |  F J="CON",0,"MED","PC","FS","TEL" S COUNT(STATION,J,"NC","ATD")=0
 | 
|---|
| 35 |  F K="CON",0,"MED","PC","FS","TEL" F J="ETD","ATD","ETOT" S ^TMP($J,STATION,K,"NC",J)=0
 | 
|---|
| 36 |  F J="CON",0,"MED","PC","FS","TEL" S COUNT(STATION,J,"FC","UPG")=0
 | 
|---|
| 37 |  F K="CON",0,"MED","PC","FS","TEL" F J="ECST","ACST" S COUNT(STATION,K,"FC",J)=0,^TMP($J,STATION,K,"FC",J)=0
 | 
|---|
| 38 |  F J="CON",0,"MED","PC","FS","TEL" S ^TMP($J,STATION,J,"CC","ECST")=0
 | 
|---|
| 39 |  F L="CON",0,"MED","PC","FS","TEL" F J=1998,1999,2000 F K=0:1:12 S COUNT(STATION,L,"CC","UPG",J,K)=0,^TMP($J,STATION,L,"CC","ECST",J,K)=0,COUNT(STATION,L,"NC","SCHDT",J,K)=0,^TMP($J,STATION,L,"NC","ECST",J,K)=0
 | 
|---|
| 40 |  ;  begin data collection
 | 
|---|
| 41 | DATA S STATION=STATION("PARNT"),CLASS="CON",DA=0 F  S DA=$O(^ENG(6914,DA)) Q:'DA  D
 | 
|---|
| 42 |  . Q:'$D(^ENG(6914,DA,0))
 | 
|---|
| 43 |  . I "^4^5^"[(U_$P($G(^ENG(6914,DA,3)),U)_U),$P($G(^(11)),U)'="NC" Q  ;inactive and not Y2K NC
 | 
|---|
| 44 |  . I '$D(ZTQUEUED),'(DA#100) W "." ; activity indicator
 | 
|---|
| 45 |  . I ENSTN S STATION=$S($P($G(^ENG(6914,DA,9)),U,5)]"":$P(^(9),U,5),1:STATION("PARNT")) D:'$D(COUNT(STATION))
 | 
|---|
| 46 |  .. F K="CON",0,"MED","PC","FS","TEL" F J="ACT","Y2K",0,"FC","NC","CC","NA" S COUNT(STATION,K,J)=0
 | 
|---|
| 47 |  .. F K="CON",0,"MED","PC","FS","TEL" F J=0,"REP","SREP","RET","USE" S COUNT(STATION,K,"NC",J)=0
 | 
|---|
| 48 |  .. F J="CON",0,"MED","PC","FS","TEL" S COUNT(STATION,J,"NC","ATD")=0
 | 
|---|
| 49 |  .. F K="CON",0,"MED","PC","FS","TEL" F J="ETD","ATD","ETOT" S ^TMP($J,STATION,K,"NC",J)=0
 | 
|---|
| 50 |  .. F J="CON",0,"MED","PC","FS","TEL" S COUNT(STATION,J,"FC","UPG")=0
 | 
|---|
| 51 |  .. F K="CON",0,"MED","PC","FS","TEL" F J="ECST","ACST" S COUNT(STATION,K,"FC",J)=0,^TMP($J,STATION,K,"FC",J)=0
 | 
|---|
| 52 |  .. F J="CON",0,"MED","PC","FS","TEL" S ^TMP($J,STATION,J,"CC","ECST")=0
 | 
|---|
| 53 |  .. F L="CON",0,"MED","PC","FS","TEL" F J=1998,1999,2000 F K=0:1:12 S COUNT(STATION,L,"CC","UPG",J,K)=0,^TMP($J,STATION,L,"CC","ECST",J,K)=0,COUNT(STATION,L,"NC","SCHDT",J,K)=0,^TMP($J,STATION,L,"NC","ECST",J,K)=0
 | 
|---|
| 54 |  . I $G(ENCLASS) S CLASS=$P($G(^ENG(6914,DA,9)),U,11) S:CLASS="" CLASS=0
 | 
|---|
| 55 |  . S COUNT(STATION,CLASS,"ACT")=COUNT(STATION,CLASS,"ACT")+1
 | 
|---|
| 56 |  . S EN=$G(^ENG(6914,DA,11)) I $P(EN,U)="" Q:$P($G(^ENG(6914,DA,1)),U,4)=""  Q:$P(^(1),U,2)=""  ;not deemed a Y2K candidate
 | 
|---|
| 57 |  . S COUNT(STATION,CLASS,"Y2K")=COUNT(STATION,CLASS,"Y2K")+1
 | 
|---|
| 58 |  . S ENY2K("CAT")=$P(EN,U) I ENY2K("CAT")="" S COUNT(STATION,CLASS,0)=COUNT(STATION,CLASS,0)+1 Q  ;no Y2K info
 | 
|---|
| 59 |  . S COUNT(STATION,CLASS,ENY2K("CAT"))=COUNT(STATION,CLASS,ENY2K("CAT"))+1
 | 
|---|
| 60 |  . I ENY2K("CAT")="FC" D  Q  ;fully compliant
 | 
|---|
| 61 |  .. I $P(^ENG(6914,DA,11),U,9)]"" D
 | 
|---|
| 62 |  ... S COUNT(STATION,CLASS,"FC","UPG")=COUNT(STATION,CLASS,"FC","UPG")+1
 | 
|---|
| 63 |  ... I $P(EN,U,3)]"" S COUNT(STATION,CLASS,"FC","ECST")=COUNT(STATION,CLASS,"FC","ECST")+1,^TMP($J,STATION,CLASS,"FC","ECST")=^TMP($J,STATION,CLASS,"FC","ECST")+$P(EN,U,3)
 | 
|---|
| 64 |  ... I $P(EN,U,4)]"" S COUNT(STATION,CLASS,"FC","ACST")=COUNT(STATION,CLASS,"FC","ACST")+1,^TMP($J,STATION,CLASS,"FC","ACST")=^TMP($J,STATION,CLASS,"FC","ACST")+$P(EN,U,4)
 | 
|---|
| 65 |  . ;
 | 
|---|
| 66 |  . I ENY2K("CAT")="NC" D  Q  ;non-compliant
 | 
|---|
| 67 |  .. S ENY2K("ACT")=$P(EN,U,6) S:ENY2K("ACT")="" ENY2K("ACT")=0 S COUNT(STATION,CLASS,"NC",ENY2K("ACT"))=COUNT(STATION,CLASS,"NC",ENY2K("ACT"))+1
 | 
|---|
| 68 |  .. I ENY2K("ACT")="REP" D
 | 
|---|
| 69 |  ... S COST("E")=$P($G(^ENG(6914,DA,2)),U,3),^TMP($J,STATION,CLASS,"NC","ETOT")=^TMP($J,STATION,CLASS,"NC","ETOT")+COST("E")
 | 
|---|
| 70 |  ... I '$D(^ENG(6914,"AO",DA)) D
 | 
|---|
| 71 |  .... S MONTH=+$E($P(EN,U,13),4,5),YEAR=$E($P(EN,U,13),1,3)+1700 S:MONTH="" MONTH=0
 | 
|---|
| 72 |  .... I YEAR>1990 S COUNT(STATION,CLASS,"NC","SCHDT",YEAR,MONTH)=COUNT(STATION,CLASS,"NC","SCHDT",YEAR,MONTH)+1 D
 | 
|---|
| 73 |  ..... S ^TMP($J,STATION,CLASS,"NC","ECST",YEAR,MONTH)=^TMP($J,STATION,CLASS,"NC","ECST",YEAR,MONTH)+COST("E"),COUNT(STATION,CLASS,"NC","SREP")=COUNT(STATION,CLASS,"NC","SREP")+1
 | 
|---|
| 74 |  ... I $D(^ENG(6914,"AO",DA)) D
 | 
|---|
| 75 |  .... S COUNT(STATION,CLASS,"NC","ATD")=COUNT(STATION,CLASS,"NC","ATD")+1,^TMP($J,STATION,CLASS,"NC","ETD")=^TMP($J,STATION,CLASS,"NC","ETD")+COST("E")
 | 
|---|
| 76 |  .... S DA(1)=$O(^ENG(6914,"AO",DA,0)) I DA(1) S ^TMP($J,STATION,CLASS,"NC","ATD")=^TMP($J,STATION,CLASS,"NC","ATD")+$P($G(^ENG(6914,DA(1),2)),U,3)
 | 
|---|
| 77 |  . I ENY2K("CAT")="CC" D  ;conditionally compliant
 | 
|---|
| 78 |  .. S ^TMP($J,STATION,CLASS,"CC","ECST")=^TMP($J,STATION,CLASS,"CC","ECST")+$P(EN,U,3)
 | 
|---|
| 79 |  .. S MONTH=+$E($P(EN,U,2),4,5),YEAR=$E($P(EN,U,2),1,3)+1700
 | 
|---|
| 80 |  .. I MONTH>0,YEAR>0 S COUNT(STATION,CLASS,"CC","UPG",YEAR,MONTH)=COUNT(STATION,CLASS,"CC","UPG",YEAR,MONTH)+1,^TMP($J,STATION,CLASS,"CC","ECST",YEAR,MONTH)=^TMP($J,STATION,CLASS,"CC","ECST",YEAR,MONTH)+$P(EN,U,3)
 | 
|---|
| 81 |  . ; end of data collection
 | 
|---|
| 82 |  Q:$G(ENY2K("VACO"))  ;  invoked by national roll-up
 | 
|---|
| 83 |  D PRT^ENY2REP6  ;print routine
 | 
|---|
| 84 | EXIT ;
 | 
|---|
| 85 |  K ^TMP($J)
 | 
|---|
| 86 |  K ENSTN,ENCLASS
 | 
|---|
| 87 |  I $D(ZTQUEUED) S ZTREQN="@"
 | 
|---|
| 88 |  D ^%ZISC,HOME^%ZIS
 | 
|---|
| 89 |  Q
 | 
|---|
| 90 |  ;ENY2REP4
 | 
|---|