| 1 | OOPSLOG ;HINES CIOFO/GB-Log of Federal Occupational Injuries and Illnesses ;8/15/96 | 
|---|
| 2 | ;;2.0;ASISTS;;Jun 03, 2002 | 
|---|
| 3 | N CN,CL,DA,DASHES,DATE,EX,FCILL,FCINJ,FCINJILL,FYR,FY,HDR,HDR1,HDR2 | 
|---|
| 4 | N HDRFLG,ILL,INC,INJ,INJILL,LIN,LP1,LTILL,LTINJ,LTINJILL,LYR,OUT,PG,STA | 
|---|
| 5 | N RANGE | 
|---|
| 6 | SDED N DIR,DIRUT,DUOUT,X,Y,SD,ED,SDT,EDT | 
|---|
| 7 | S DIR(0)="D^2981001:DT:EX" | 
|---|
| 8 | S DIR("A")="Starting Date for the Report" | 
|---|
| 9 | S DIR("?")="Select a Starting Date from the range displayed." | 
|---|
| 10 | D ^DIR | 
|---|
| 11 | G:$D(DIRUT) EXIT | 
|---|
| 12 | S SD=Y,SDT=Y(0) | 
|---|
| 13 | K DIR,DIRUT,DUOUT,X,Y S DIR(0)="D^2981001:DT:EX" | 
|---|
| 14 | S DIR("A")="Ending Date for the Report" | 
|---|
| 15 | S DIR("?")="Select a Ending Date from the range displayed" | 
|---|
| 16 | D ^DIR | 
|---|
| 17 | G:$D(DIRUT) EXIT | 
|---|
| 18 | S ED=Y,EDT=Y(0) | 
|---|
| 19 | I $$FMDIFF^XLFDT(ED,SD,1)'>0 W !?5,"The Ending Date cannot be before or on the Starting Date, please re-enter this data." G SDED | 
|---|
| 20 | S RANGE="for Period "_SDT_" - "_EDT | 
|---|
| 21 | I $D(EV) S INC=0,HDR1="Employees and volunteers only" G PREDEV | 
|---|
| 22 | K DIR S DIR(0)="SA^E/V:Employees and volunteers only;A:All cases",DIR("A")="Cases to be included: " D ^DIR K DIR | 
|---|
| 23 | G:$D(DIRUT) EXIT | 
|---|
| 24 | S EV=Y | 
|---|
| 25 | K DIR S DIR(0)="Y",DIR("A")="Include names of persons involved",DIR("B")="Yes" D ^DIR K DIR | 
|---|
| 26 | G:$D(DIRUT) EXIT | 
|---|
| 27 | S INC=Y | 
|---|
| 28 | ; Patch 5 -Get Station Number | 
|---|
| 29 | PREDEV S OUT="" | 
|---|
| 30 | D STATION(.STA,.OUT) | 
|---|
| 31 | G:$D(DIRUT)!(OUT) EXIT | 
|---|
| 32 | DEV K IOP,%ZIS S %ZIS="MQ" W ! D ^%ZIS K %ZIS,IOP G:POP EXIT | 
|---|
| 33 | I $D(IO("Q")) D TASK G EXIT | 
|---|
| 34 | U IO D PRT D ^%ZISC K %ZIS,IOP G EXIT | 
|---|
| 35 | PRT S PG=0 | 
|---|
| 36 | S (INJ,ILL,FCINJ,FCILL,LTINJ,LTILL)=0 | 
|---|
| 37 | S EX="",LIN=$S(IOST?1"C".E:IOSL-4,1:IOSL-5)  ; was 5 and 6 | 
|---|
| 38 | K DASHES S $P(DASHES,"-",80)="-" | 
|---|
| 39 | D NOW^%DTC S DATE=%,Y=DATE X ^DD("DD") S DATE=Y | 
|---|
| 40 | S HDR=$S($G(NS):"Log of Needlestick Incidents ",1:"Log of Federal Occupational Injuries and Illnesses ") | 
|---|
| 41 | S HDR1=$S(EV="E/V":"Employees and volunteers only",1:"All cases") | 
|---|
| 42 | ; Patch 5 - change for Station Number looping | 
|---|
| 43 | S LP1="" | 
|---|
| 44 | I STA="A" D  G EXIT | 
|---|
| 45 | . F  S LP1=$O(^OOPS(2260,"D",LP1)) Q:LP1=""!(EX=U)  S HDRFLG=0 D | 
|---|
| 46 | .. S DA=0 F  S DA=$O(^OOPS(2260,"D",LP1,DA)) D:DA="" LOGSUM Q:DA=""!(EX=U)  D DATA | 
|---|
| 47 | I STA'="A" D  G EXIT | 
|---|
| 48 | . S LP1=STA,HDRFLG=0 | 
|---|
| 49 | . S DA=0 F  S DA=$O(^OOPS(2260,"D",LP1,DA)) D:DA="" LOGSUM Q:DA=""!(EX=U)  D DATA | 
|---|
| 50 | EXIT ; Clean up and exit | 
|---|
| 51 | K POP,X,Y,%,NS,EV | 
|---|
| 52 | Q | 
|---|
| 53 | DATA ; | 
|---|
| 54 | N CASE,OOPS,YR,DIC,DIQ,DR,CD | 
|---|
| 55 | S CASE=$$GET1^DIQ(2260,DA,.01) | 
|---|
| 56 | S YR=$E(CASE,1,4) | 
|---|
| 57 | S CD=($P(^OOPS(2260,DA,0),"^",5))\1 | 
|---|
| 58 | I ($$FMDIFF^XLFDT(CD,SD,1)<0)!($$FMDIFF^XLFDT(CD,ED,1)>0) Q | 
|---|
| 59 | K OOPS | 
|---|
| 60 | S DIC="^OOPS(2260," | 
|---|
| 61 | S DR=".01;2;3;4;1;15;14;29;30;33;37;51;52;82;83;84;85;86" | 
|---|
| 62 | S DIQ="OOPS",DIQ(0)="IE" D EN^DIQ1 | 
|---|
| 63 | I $G(NS),OOPS(2260,DA,3,"I")<11 Q | 
|---|
| 64 | I EV="E/V","1,2,6,"'[OOPS(2260,DA,2,"I")_"," Q | 
|---|
| 65 | Q:OOPS(2260,DA,51,"E")="Deleted" | 
|---|
| 66 | Q:OOPS(2260,DA,51,"E")="Replaced by amendment" | 
|---|
| 67 | ; Patch 9 fix summary logic | 
|---|
| 68 | I OOPS(2260,DA,52,"E")="Injury" S INJ=INJ+1 D | 
|---|
| 69 | . S:OOPS(2260,DA,29,"E")="Death" FCINJ=FCINJ+1 | 
|---|
| 70 | . S:OOPS(2260,DA,33,"E")="Yes" LTINJ=LTINJ+1 | 
|---|
| 71 | I OOPS(2260,DA,52,"E")="Illness/disease" S ILL=ILL+1 D | 
|---|
| 72 | . S:OOPS(2260,DA,29,"E")="Death" FCILL=FCILL+1 | 
|---|
| 73 | . S:OOPS(2260,DA,33,"E")="Yes" LTILL=LTILL+1 | 
|---|
| 74 | S:INC=0 OOPS(2260,DA,1,"E")="",OOPS(2260,DA,15,"E")="",OOPS(2260,DA,14,"E")="" | 
|---|
| 75 | I 'HDRFLG D HDR S HDRFLG=1 | 
|---|
| 76 | W !,CASE,?12,$P(OOPS(2260,DA,4,"E"),"@",1),?26,OOPS(2260,DA,1,"E") | 
|---|
| 77 | W ?58,OOPS(2260,DA,15,"E"),?64,$E(OOPS(2260,DA,14,"E"),1,4) | 
|---|
| 78 | W ?70,OOPS(2260,DA,33,"E") D P Q:EX=U | 
|---|
| 79 | W !,$E(OOPS(2260,DA,52,"E"),1,7),?12,$E(OOPS(2260,DA,51,"E"),1,12) | 
|---|
| 80 | W ?26,OOPS(2260,DA,3,"E") D P Q:EX=U | 
|---|
| 81 | I OOPS(2260,DA,86,"I")'="" W ?58,$E($$GET1^DIQ(49,OOPS(2260,DA,86,"I"),.01),1,22) D P Q:EX=U | 
|---|
| 82 | W !,$E(OOPS(2260,DA,29,"E"),1,35),?58,$E(OOPS(2260,DA,30,"E"),1,21) D P Q:EX=U | 
|---|
| 83 | ; patch 11 - if NS then print new prompts | 
|---|
| 84 | I $G(NS) D  Q:EX=U | 
|---|
| 85 | . W ! I $G(OOPS(2260,DA,37,"I"))'="" W $$GET1^DIQ(2261.6,OOPS(2260,DA,37,"I"),.01) D P Q:EX=U | 
|---|
| 86 | . ; patch 11 v3 08/03/01 | 
|---|
| 87 | . W !,$$GET1^DIQ(2260,DA,"38:.01") D P Q:EX=U | 
|---|
| 88 | . W !,$$GET1^DIQ(2260,DA,"82:.01") D P Q:EX=U | 
|---|
| 89 | . W !,$$GET1^DIQ(2260,DA,108) D P Q:EX=U | 
|---|
| 90 | . S OPFLD=28 D WP K OPFLD | 
|---|
| 91 | W !,DASHES | 
|---|
| 92 | Q | 
|---|
| 93 | LOGSUM ;Log Summary | 
|---|
| 94 | Q:EX=U | 
|---|
| 95 | ; Patch 9 - if nothing to summarize, don't print | 
|---|
| 96 | I 'INJ&('ILL)&('FCINJ)&('FCILL)&('LTINJ)&('LTILL) Q | 
|---|
| 97 | I IOST?1"C".E,$Y>14 D  Q:EX=U | 
|---|
| 98 | .W ! K DIR S DIR(0)="E" D ^DIR I 'Y S EX=U Q | 
|---|
| 99 | .W @IOF S PG=PG+1 | 
|---|
| 100 | .W !,HDR,?72,"Page",$S($L(PG)=2:" ",1:"  "),PG | 
|---|
| 101 | .W !?(40-($L(RANGE)/2)),RANGE | 
|---|
| 102 | .W !,DASHES | 
|---|
| 103 | W !,"Log Summary" D P Q:EX=U | 
|---|
| 104 | W !,DASHES D P Q:EX=U | 
|---|
| 105 | W !,"Injuries.: ",$J(INJ,3),?16,"Fatal Injuries....: ",$J(FCINJ,3) | 
|---|
| 106 | W ?41,"Lost Time Injuries....: ",$J(LTINJ,3) D P Q:EX=U | 
|---|
| 107 | W !,"Illnesses: ",$J(ILL,3),?16,"Fatal Illnesses...: ",$J(FCILL,3) | 
|---|
| 108 | W ?41,"Lost Time Illnesses...: ",$J(LTILL,3) D P Q:EX=U | 
|---|
| 109 | W !,"--------------",?16,"-----------------------",?41,"---------------------------" D P Q:EX=U | 
|---|
| 110 | S INJILL=INJ+ILL,FCINJILL=FCINJ+FCILL,LTINJILL=LTINJ+LTILL | 
|---|
| 111 | W !,"Total....: ",$J(INJILL,3),?16,"Total.............: ",$J(FCINJILL,3) | 
|---|
| 112 | W ?41,"Total.................: ",$J(LTINJILL,3) | 
|---|
| 113 | W !,DASHES | 
|---|
| 114 | I IOST?1"C".E W ! K DIR S DIR(0)="E" D ^DIR I 'Y S EX=U Q | 
|---|
| 115 | S (INJ,FCINJ,LTINJ,ILL,FCILL,LTILL,INJILL,FCINJILL,LTINJILL)=0 | 
|---|
| 116 | Q | 
|---|
| 117 | P ;Display Data | 
|---|
| 118 | I $Y'<LIN D  Q:EX=U | 
|---|
| 119 | .I IOST?1"C".E W ! K DIR S DIR(0)="E" D ^DIR I 'Y S EX=U Q | 
|---|
| 120 | .D HDR | 
|---|
| 121 | Q | 
|---|
| 122 | TASK ;Queue a task | 
|---|
| 123 | K IO("Q"),ZTUCI,ZTDTH,ZTIO,ZTSAVE | 
|---|
| 124 | S ZTRTN="PRT^OOPSLOG",ZTREQ="@",ZTSAVE("ZTREQ")="" | 
|---|
| 125 | S ZTDESC="Log of Federal Occupational Injuries and Illnesses" | 
|---|
| 126 | S ZTSAVE("FY")="",ZTSAVE("INC")="",ZTSAVE("NS")="",ZTSAVE("EV")="" | 
|---|
| 127 | ; Patch 5 - added STA | 
|---|
| 128 | S ZTSAVE("STA")="" | 
|---|
| 129 | ; Patch 11 - Added date Ranges | 
|---|
| 130 | S ZTSAVE("SD")="",ZTSAVE("SDT")="",ZTSAVE("ED")="",ZTSAVE("EDT")="" | 
|---|
| 131 | ; patch 11 v3 8/2/01 add new variables | 
|---|
| 132 | S ZTSAVE("RANGE")="",ZTSAVE("HDR")="",ZTSAVE("HDR1")="" | 
|---|
| 133 | S ZTSAVE("HDR2")="" | 
|---|
| 134 | D ^%ZTLOAD D ^%ZISC U IO W !,"Request Queued",! | 
|---|
| 135 | K ZTSK Q | 
|---|
| 136 | HDR ;Header | 
|---|
| 137 | S HDR2="Station Name: "_$$GET1^DIQ(4,LP1,.01,"E") | 
|---|
| 138 | W @IOF S PG=PG+1 | 
|---|
| 139 | W !?(40-($L(HDR)/2)),HDR,?72,"Page",$S($L(PG)=2:" ",1:"  "),PG | 
|---|
| 140 | W !?(40-($L(RANGE)/2)),RANGE | 
|---|
| 141 | W !?(40-($L(HDR1)/2)),HDR1,!?(40-($L(HDR2)/2)),HDR2,! | 
|---|
| 142 | W:INC=1 !,"Case #",?12,"Date",?26,"Name",?58,"Occ",?64,"CC",?69,"Lost Time" | 
|---|
| 143 | W:INC=0 !,"Case #",?12,"Date",?69,"Lost Time" | 
|---|
| 144 | W !,"Inj/Ill",?12,"Status",?26,"Type of Incident",?58,"Service" | 
|---|
| 145 | W !,"Char. of Injury",?58,"Body Part Affected" | 
|---|
| 146 | I $G(NS) D | 
|---|
| 147 | . W !,"Activity at time of Injury" | 
|---|
| 148 | . ; Patch 11 v3 08/02/01 | 
|---|
| 149 | . W !,"Object Causing Injury" | 
|---|
| 150 | . W !,"Model and Brand of Object Causing Injury" | 
|---|
| 151 | . W !,"Location of Injury" | 
|---|
| 152 | . ; W !,"Description of Injury" | 
|---|
| 153 | W !,DASHES | 
|---|
| 154 | Q | 
|---|
| 155 | STATION(STA,OUT) ; Get 'ALL' or one station | 
|---|
| 156 | S STA="" | 
|---|
| 157 | N DIC,DIR,DIRUT,Y | 
|---|
| 158 | S DIR(0)="Y",DIR("A")="Run report for 'ALL' Stations",DIR("B")="Yes" | 
|---|
| 159 | S DIR("?")="Enter 'Y'es to run for all Stations or 'N'o to run " | 
|---|
| 160 | S DIR("?")=DIR("?")_"for just one Station." | 
|---|
| 161 | D ^DIR I Y S STA="A" Q | 
|---|
| 162 | I $D(DIRUT)!($D(DUOUT)) S OUT=1 Q | 
|---|
| 163 | S1 ; if get here user <CR> | 
|---|
| 164 | S DIC("A")="Select STATION NUMBER: " | 
|---|
| 165 | S DIC="^DIC(4,",DIC(0)="AEMQZ" | 
|---|
| 166 | D ^DIC | 
|---|
| 167 | I $D(DUOUT) S OUT=1 Q | 
|---|
| 168 | I Y=-1 W !?5,"No Station selected, report will not run" S OUT=1 Q | 
|---|
| 169 | S STA=+Y | 
|---|
| 170 | I '$D(^OOPS(2260,"D",STA)) W !?5,"No data for that Station Number, Please select again." G S1 | 
|---|
| 171 | Q | 
|---|
| 172 | WP ;Process Word Processing Fields | 
|---|
| 173 | N DIWL,DIWR,DIWF,OPGLB,OPI,OPNODE,OPT,OPC | 
|---|
| 174 | K ^UTILITY($J,"W") | 
|---|
| 175 | S DIWL=1,DIWR="",DIWF="|C76" | 
|---|
| 176 | S OPNODE=$P($$GET1^DID(2260,OPFLD,"","GLOBAL SUBSCRIPT LOCATION"),";") | 
|---|
| 177 | S OPI=0 F  S OPI=$O(^OOPS(2260,DA,OPNODE,OPI)) Q:'OPI  S X=$G(^OOPS(2260,DA,OPNODE,OPI,0)) D:X]"" ^DIWP | 
|---|
| 178 | S OPT=$G(^UTILITY($J,"W",1))+0 | 
|---|
| 179 | I OPT D | 
|---|
| 180 | . W !,"Description of Injury:" | 
|---|
| 181 | . S OPI=0 F OPC=1:1 S OPI=$O(^UTILITY($J,"W",1,OPI)) Q:'OPI!(EX=U)  D | 
|---|
| 182 | .. W !?2,^UTILITY($J,"W",1,OPI,0) D P Q:EX=U | 
|---|
| 183 | K ^UTILITY($J,"W"),X | 
|---|
| 184 | Q | 
|---|