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

OOPSWCSE.m

Go to the documentation of this file.
  1. OOPSWCSE ;WIOFO/LLH-Workers' Comp Sign for Employee ;01/20/01
  1. ;;2.0;ASISTS;;Jun 03, 2002
  1. ;
  1. EN1(CALLER) ; Entry point for routine
  1. ; Input: CALLER = "S" for Safety Officer
  1. ; "H" for Employee Health
  1. ; "W" for Workers' Comp
  1. ;
  1. N DIC,IEN,FORM,PRM1,PRM2,SIGN,VALID,Y
  1. Q:DUZ<1
  1. Q:$G(^VA(200,DUZ,1))=""
  1. S IEN=0
  1. S DIC="^OOPS(2260,"
  1. S DIC("S")="I $$SCR^OOPSWCSE(Y)"_",'$$GET1^DIQ(2260,Y,51,""I"")"
  1. S DIC(0)="AEMNZ",DIC("A")=" Select Case: "
  1. D ^DIC
  1. I (Y<1)!$D(DTOUT)!($D(DUOUT)) Q
  1. S IEN=$P(Y,U)
  1. S FORM=$$GET1^DIQ(2260,IEN,52,"I")
  1. S FORM=$S(FORM=1:"CA1",FORM=2:"CA2",1:"")
  1. I $G(FORM)="" Q
  1. D ^OOPSDIS
  1. S PRM1=$S(CALLER="S":"Safety Officer",CALLER="H":"Employee Health",1:0)
  1. S PRM2=PRM1_" approves the WCP signing for the Employee: "
  1. S SIGN=""
  1. I CALLER="W" G WCPS4E
  1. I $$VALID^OOPSWCSE() D
  1. . W !,PRM2
  1. . S SIGN=$$SIG^OOPSESIG(DUZ,IEN)
  1. . Q:+SIGN=0 ; form not signed
  1. . I CALLER="S" S $P(^OOPS(2260,IEN,"WCSE"),U,1,3)=SIGN
  1. . I CALLER="H" S $P(^OOPS(2260,IEN,"WCSE"),U,4,6)=SIGN
  1. G EXIT
  1. WCPS4E ; allow WCP to sign for employee if all approvals given
  1. N CONT,EHS,SIGN,SOS,VALID,VIEW
  1. S SIGN=0,VALID=0,VIEW=1
  1. S SOS=$$GET1^DIQ(2260,IEN,76,"I")
  1. S EHS=$$GET1^DIQ(2260,IEN,79,"I")
  1. S CONT=$S(DUZ=SOS:"S",DUZ=EHS:"H",1:"")
  1. I (CONT="S")!(CONT="H") D
  1. . W !,"You have approved as "_$S(CONT="S":"Safety Officer",CONT="H":"Emp Health Rep",1:"")
  1. . W " and cannot sign as Employee."
  1. . W !,"Three different individuals must be involved."
  1. . S VIEW=0
  1. I '$G(SOS) S VIEW=0 W !,"Safety Officer has not approved WCP signing for employee."
  1. I '$G(EHS) S VIEW=0 W !,"Employee Health has not approved WCP signing for employee."
  1. I VIEW D
  1. . ; Allow clearing WCP signature, employee may be able to sign
  1. . I $$GET1^DIQ(2260,IEN,119,"I") D CLRES^OOPSUTL1(IEN,"E",FORM)
  1. . W ! D VALIDATE^OOPSUTL4(IEN,FORM,"E",.VALID)
  1. . I 'VALID Q
  1. . S SIGN=$$SIG^OOPSESIG(DUZ,IEN)
  1. . Q:+SIGN=0
  1. . D EMP^OOPSVAL1
  1. EXIT ;
  1. K DTOUT,DUOUT,SUP ; left over from OOPSDIS
  1. Q
  1. VALID() ; make sure same person is not signing for both safety and EH and if
  1. ; signed from menu option being called not needed again - so quit
  1. N CONT,EHAPP,ERR,SOAPP,VALID
  1. S VALID=1,ERR=0
  1. S SOAPP=$P($G(^OOPS(2260,IEN,"WCSE")),U)
  1. S EHAPP=$P($G(^OOPS(2260,IEN,"WCSE")),U,4)
  1. S CONT=$S(DUZ=SOAPP:"S",DUZ=EHAPP:"H",1:"")
  1. I CALLER="S" D
  1. . I CONT="S" S ERR=1
  1. . I $G(EHAPP)=DUZ S ERR=2
  1. . I $G(SOAPP)&($G(CONT)="") S ERR=3
  1. I CALLER="H" D
  1. . I CONT="H" S ERR=1
  1. . I $G(SOAPP)=DUZ S ERR=2
  1. . I $G(EHAPP)&($G(CONT)="") S ERR=3
  1. I ERR=1 D
  1. . W !,"You have signed as "_PRM1_" if you continue, your ES will be removed"
  1. . N DIR,FLD,Y
  1. . W !
  1. . S DIR("A")="Continue",DIR(0)="SBM^Y:Yes;N:No"
  1. . D ^DIR
  1. . I Y="Y" D
  1. .. S FLD=$S(CALLER="S":"1,3",CALLER="H":"4,6",1:"")
  1. .. F I=$P(FLD,","):1:$P(FLD,",",2) S $P(^OOPS(2260,IEN,"WCSE"),U,I)=""
  1. . I Y'="Y" S VALID=0
  1. I ERR=2 D
  1. . W !,"You have already signed as "
  1. . W $S(CALLER="S":"Employee Health",CALLER="H":"Safety Officer",1:0)
  1. . W ".",!,"Both signatures cannot be made by the same person."
  1. . S VALID=0
  1. I ERR=3 D
  1. . W !,PRM1_" has already signed, re-signing is not required."
  1. . S VALID=0
  1. Q VALID
  1. SCR(IEN) ; Screen to allow access to claims that have not been
  1. ; signed by the Employee
  1. ; Input: IEN = Internal record number of claim
  1. N VIEW,EES,ESTAT,FORM,FLD
  1. S VIEW=1
  1. S FORM=$$GET1^DIQ(2260,IEN,52,"I")
  1. I '$$ISEMP^OOPSUTL4(IEN) S VIEW=0 ; not emp, can't sign
  1. S ESTAT=$$EDSTA^OOPSUTL1(IEN,"E") ; employee signed?
  1. I CALLER'="W",$P(ESTAT,U,FORM) S VIEW=0 ; employee signed
  1. I CALLER="W" D ; from WC menu
  1. . S FLD=$S(FORM=1:119,FORM=2:221,1:"")
  1. . I 'FLD S VIEW=0 Q
  1. . S EES=$$GET1^DIQ(2260,IEN,FLD,"I")
  1. . I 'EES Q ; not signed by emp
  1. . I EES'=DUZ S VIEW=0 Q ; signer = user
  1. . I $P($$EDSTA^OOPSUTL1(IEN,"S"),U,FORM) S VIEW=0 ; Super Signed
  1. Q VIEW