| [613] | 1 | OOPSGUIC ;WIOFO/LLH-RPC routine for GET/SET CA7 ;04/22/04 | 
|---|
|  | 2 | ;;2.0;ASISTS;**8,7**;Jun 03, 2002 | 
|---|
|  | 3 | ; | 
|---|
|  | 4 | CA7LIST(RESULTS,PERSON,CALL) ; builds CA-7 selection list from existing | 
|---|
|  | 5 | ;                         cases - not an add | 
|---|
|  | 6 | ; | 
|---|
|  | 7 | ;   Input:  PERSON  - person's SSN whether CALL="E" or "W" | 
|---|
|  | 8 | ;              CALL - contains the calling menu and file number in the | 
|---|
|  | 9 | ;                     format FILENUM^CALL. | 
|---|
|  | 10 | ;  Output:  RESULTS - returns an array containing | 
|---|
|  | 11 | ;                     CA7 case #^IEN^DATE OF INCIDENT | 
|---|
|  | 12 | K ^TMP("CA7LIST",DUZ) | 
|---|
|  | 13 | N ARR,CA7,CAIEN,CALLER,ESSN,FILE | 
|---|
|  | 14 | S FILE=$P($G(CALL),U),CALLER=$P($G(CALL),U,2) | 
|---|
|  | 15 | I $G(PERSON)=""!($G(CALL)="")!($G(FILE)="") D  Q | 
|---|
|  | 16 | . S ^TMP("CA7LIST",DUZ,1)="Not enough info - can't process request" | 
|---|
|  | 17 | S CAIEN=0,^TMP("CA7LIST",DUZ,1)="No CA-7's Selectable" | 
|---|
|  | 18 | S ESSN=$$GET1^DIQ(200,DUZ,9) | 
|---|
|  | 19 | I CALLER="E",ESSN'=PERSON D  Q | 
|---|
|  | 20 | .S ^TMP("CA7LIST",DUZ,1)="User SSN, file SSN do not match-form aborted" | 
|---|
|  | 21 | F  S CAIEN=$O(^OOPS(FILE,"SSN",PERSON,CAIEN)) Q:CAIEN=""  D | 
|---|
|  | 22 | .;if from emp menu & signed by both, don't give access | 
|---|
|  | 23 | .I CALLER="E",$P($G(^OOPS(FILE,CAIEN,"CA7S7")),U,2)'="",($P($G(^OOPS(FILE,CAIEN,"CA7S15")),U,2)'="") Q | 
|---|
|  | 24 | .I CALLER="W",(ESSN=PERSON) Q | 
|---|
|  | 25 | .S CA7=$$GET1^DIQ(FILE,CAIEN,.01),ARR(CA7)=CAIEN | 
|---|
|  | 26 | ; drop thru here and | 
|---|
|  | 27 | SORT ; reverse the order | 
|---|
|  | 28 | N CN,CA7,CAIEN,DOI,NM,SSN | 
|---|
|  | 29 | S ^TMP("CA7LIST",DUZ,0)="",CN=1,CA7="" | 
|---|
|  | 30 | I '$D(ARR) S ^TMP("CA7LIST",DUZ,1)="No CA7's Selectable" | 
|---|
|  | 31 | F  S CA7=$O(ARR(CA7),-1) Q:CA7=""  D | 
|---|
|  | 32 | .S CAIEN=ARR(CA7) | 
|---|
|  | 33 | .S ASISTS=$$GET1^DIQ(2260,$$GET1^DIQ(FILE,CAIEN,.7,"I"),52,"I") | 
|---|
|  | 34 | .S ASISTS="CA-"_$G(ASISTS) | 
|---|
|  | 35 | .S NM=$E($$GET1^DIQ(FILE,CAIEN,.9),1,27) | 
|---|
|  | 36 | .S DOI=$$GET1^DIQ(FILE,CAIEN,7) | 
|---|
|  | 37 | .S SSN=$$GET1^DIQ(FILE,CAIEN,.8) | 
|---|
|  | 38 | .S ^TMP("CA7LIST",DUZ,CN)=CA7_U_DOI_U_NM_U_ASISTS_U_CAIEN_U_SSN_$C(10) | 
|---|
|  | 39 | .S CN=CN+1 | 
|---|
|  | 40 | ; then quit | 
|---|
|  | 41 | S RESULTS=$NA(^TMP("CA7LIST",DUZ)) | 
|---|
|  | 42 | Q | 
|---|
|  | 43 | LISTCA(RESULTS,INPUT) ; returns a list of valid CA (1 or 2) claims that | 
|---|
|  | 44 | ;                 can be selected to create a new CA-7 | 
|---|
|  | 45 | ;  Input:   INPUT - 3 pieces to input parameter | 
|---|
|  | 46 | ;                   SSN^FILE^CALLER - CALLER contains either E | 
|---|
|  | 47 | ;                   or W (menu called from). | 
|---|
|  | 48 | ;                   FILE now only contains 2260 (for CA-1 or 2) | 
|---|
|  | 49 | ; Output: RESULTS - contains a array of ASISTS Claims with the | 
|---|
|  | 50 | ;                   claim number, name, and date of injury.  Other | 
|---|
|  | 51 | ;                   default fields returned are, grade, step, pay amt, | 
|---|
|  | 52 | ;                   pay period, FEGLI Code, and Health Ins. | 
|---|
|  | 53 | ; | 
|---|
|  | 54 | K ^TMP("LISTCA",DUZ) | 
|---|
|  | 55 | N ARR,CAIEN,CALLER,CAIEN,CN,CNUM,DOI,FILE,INJ,NM,PAR,PDFLD,SSN | 
|---|
|  | 56 | S PAR=$P($G(INPUT),U),FILE=$P($G(INPUT),U,2),CALLER=$P($G(INPUT),U,3) | 
|---|
|  | 57 | I $G(PAR)=""!($G(FILE)="")!($G(CALLER)="") D  Q | 
|---|
|  | 58 | .S ^TMP("LISTCA",DUZ,0)="Missing parameters - cannot continue" | 
|---|
|  | 59 | S CAIEN=0 | 
|---|
|  | 60 | F  S CAIEN=$O(^OOPS(FILE,"SSN",PAR,CAIEN)) Q:CAIEN=""  D | 
|---|
|  | 61 | .I '$$INCLUDE() Q | 
|---|
|  | 62 | .I CALLER="E",($$GET1^DIQ(200,DUZ,9)'=PAR) Q | 
|---|
|  | 63 | .I CALLER="W",($$GET1^DIQ(200,DUZ,9)=PAR) Q | 
|---|
|  | 64 | .S CNUM=$$GET1^DIQ(FILE,CAIEN,.01),ARR(CNUM)=CAIEN | 
|---|
|  | 65 | ; No cases to send back | 
|---|
|  | 66 | I '$D(ARR) D  Q | 
|---|
|  | 67 | .S ^TMP("LISTCA",DUZ,1)="No Cases Selectable" | 
|---|
|  | 68 | .S RESULTS=$NA(^TMP("LISTCA",DUZ)) | 
|---|
|  | 69 | ; get reverse order | 
|---|
|  | 70 | S CNUM="",CN=1 | 
|---|
|  | 71 | F  S CNUM=$O(ARR(CNUM),-1) Q:CNUM=""  D | 
|---|
|  | 72 | .S CAIEN=ARR(CNUM) | 
|---|
|  | 73 | .S NM=$$GET1^DIQ(FILE,CAIEN,1) | 
|---|
|  | 74 | .S DOI=$$GET1^DIQ(FILE,CAIEN,4) | 
|---|
|  | 75 | .S SSN=$TR($$GET1^DIQ(FILE,CAIEN,5),"-","") | 
|---|
|  | 76 | .S GRD=$$GET1^DIQ(FILE,CAIEN,16) | 
|---|
|  | 77 | .S STP=$$GET1^DIQ(FILE,CAIEN,17) | 
|---|
|  | 78 | .S INJ=$$GET1^DIQ(FILE,CAIEN,52) | 
|---|
|  | 79 | .S RET=$$GET1^DIQ(FILE,CAIEN,60) | 
|---|
|  | 80 | .S PAY=$$GET1^DIQ(FILE,CAIEN,166) | 
|---|
|  | 81 | .S PER=$$GET1^DIQ(FILE,CAIEN,167) | 
|---|
|  | 82 | .; only need to do this 1 time, should never have but 1 different | 
|---|
|  | 83 | .; person in this list, many claims but all for the same person | 
|---|
|  | 84 | .I CN=1 S PDFLD=$$PDDEF() | 
|---|
|  | 85 | .S STR=CNUM_U_DOI_U_NM_U_CAIEN_U_SSN_U_INJ_U_GRD_U_STP_U_PAY_U_PER | 
|---|
|  | 86 | .S ^TMP("LISTCA",DUZ,CN)=STR_U_RET_U_PDFLD_U_DUZ_$C(10) | 
|---|
|  | 87 | .S CN=CN+1 | 
|---|
|  | 88 | S RESULTS=$NA(^TMP("LISTCA",DUZ)) | 
|---|
|  | 89 | Q | 
|---|
|  | 90 | INCLUDE() ; checks to make sure ok to include claim in list | 
|---|
|  | 91 | N CA7OK | 
|---|
|  | 92 | S CA7OK=1 | 
|---|
|  | 93 | ; if claim not sent to DOL, can't pick | 
|---|
|  | 94 | I $$GET1^DIQ(FILE,CAIEN,67)="" S CA7OK=0 | 
|---|
|  | 95 | ; if deleted, replaced by amendment - can't pick | 
|---|
|  | 96 | I $$GET1^DIQ(FILE,CAIEN,51,"I")>1 S CA7OK=0 | 
|---|
|  | 97 | Q (CA7OK) | 
|---|
|  | 98 | PDDEF() ; get Fegli Code and Health insurance fields from paid | 
|---|
|  | 99 | N CNT,FEG,FEG1,INS,INS1,PAID | 
|---|
|  | 100 | S (FEG,FEG1,INS,INS1)="" | 
|---|
|  | 101 | D FIND^DIC(450,,"@;226EI;231I","MPSC",SSN,10,"SSN") | 
|---|
|  | 102 | I $G(DIERR) D CLEAN^DILF Q FEG_U_INS | 
|---|
|  | 103 | I $P(^TMP("DILIST",$J,0),U)=0 Q FEG_U_INS | 
|---|
|  | 104 | S PAID=$G(^TMP("DILIST",$J,1,0)),FEG=$P(PAID,U,3) | 
|---|
|  | 105 | ; if A0 - ineligible, B0 - waived therefore No | 
|---|
|  | 106 | I FEG="A0"!(FEG="B0") S FEG1="N;" | 
|---|
|  | 107 | ; if C0 - only Basic | 
|---|
|  | 108 | I FEG="C0" S FEG1="Y;" | 
|---|
|  | 109 | ; has Fegli, but not basic, additional, get additional code | 
|---|
|  | 110 | I $G(FEG1)="",($L($P(PAID,U,2),"Basic +")>1) S FEG1="Y;"_FEG | 
|---|
|  | 111 | ; now deal with insurance | 
|---|
|  | 112 | S INS=$P(PAID,U,4) | 
|---|
|  | 113 | ; if INS = 000, 001, 002, 003 they don't have insurance | 
|---|
|  | 114 | I (INS?.N)&(+INS<4) S INS1="N;" | 
|---|
|  | 115 | ; otherwise they do, get the code | 
|---|
|  | 116 | I $G(INS1)="" S INS1="Y;"_INS | 
|---|
|  | 117 | Q INS1_U_FEG1 | 
|---|
|  | 118 | MULTIPLE(RESULTS,INPUT,DATA) ; retrieve data from multiple | 
|---|
|  | 119 | ; NOTE:  When filing into subrecord, the entire subrecord is deleted | 
|---|
|  | 120 | ;        then rebuilt.  Also, the field number for the subrecord | 
|---|
|  | 121 | ;        must be passed with the data. | 
|---|
|  | 122 | ;        WORD PROCESSING fields CANNOT file using this code | 
|---|
|  | 123 | ;   Input:   INPUT - in the format FILE^FIELD^IEN | 
|---|
|  | 124 | ;             DATA - array of data in the format | 
|---|
|  | 125 | ;                    DATA(SIEN)=data where data = P1^P2^P3 etc, where | 
|---|
|  | 126 | ;                    P1 = subfield #;data | 
|---|
|  | 127 | ;                    DATA="" must be true for a GET. | 
|---|
|  | 128 | ;  Output: RESULTS - data from all records in the multiple will | 
|---|
|  | 129 | ;                     be returned.  it will be saved in a pieced | 
|---|
|  | 130 | ;                     string. | 
|---|
|  | 131 | N ACTION,ARR,IEN,FIELD,FILE,ROOT,SAVEDIK,SPEC,SUB | 
|---|
|  | 132 | S FILE=$P($G(INPUT),U),FIELD=$P($G(INPUT),U,2),IEN=$P($G(INPUT),U,3) | 
|---|
|  | 133 | S ACTION="" I $D(DATA)>1 S ACTION=1 | 
|---|
|  | 134 | S RESULTS(0)="Record Accessed, no data" | 
|---|
|  | 135 | I $G(IEN)=""!($G(FILE)="")!($G(FIELD)="") D  Q | 
|---|
|  | 136 | . S RESULTS(0)="Invalid parameters cannot continue" | 
|---|
|  | 137 | S ROOT=$$ROOT^DILFD(FILE,0,"GL") | 
|---|
|  | 138 | S SPEC=+$$GET1^DID(FILE,FIELD,"","SPECIFIER") | 
|---|
|  | 139 | S SUB=$$GET1^DID(FILE,FIELD,"","GLOBAL SUBSCRIPT LOCATION") | 
|---|
|  | 140 | I '$$GET1^DID(FILE,FIELD,"","MULTIPLE-VALUED"),'$G(SPEC) D  Q | 
|---|
|  | 141 | . S RESULTS(1)="Field in not a multiple, cannot continue" | 
|---|
|  | 142 | ; now go get data from subfile | 
|---|
|  | 143 | S SAVEDIK=ROOT_IEN_","_$C(34)_$P(SUB,";")_$C(34)_"," | 
|---|
|  | 144 | I 'ACTION D GETD | 
|---|
|  | 145 | I ACTION D KILLD,SETD | 
|---|
|  | 146 | Q | 
|---|
|  | 147 | GETD ; get the data | 
|---|
|  | 148 | N CNT,DATA,FLDA,FLDS,IENS,SIEN,SFLD,SREC,TYPE | 
|---|
|  | 149 | S CNT=0,IENS=IEN_"," | 
|---|
|  | 150 | S FLDA=FIELD_"*" | 
|---|
|  | 151 | ; hate to hardwire, but need data back as entered, not canonical | 
|---|
|  | 152 | I FILE=2262.03,FIELD=15 D FLD15 Q | 
|---|
|  | 153 | D GETS^DIQ(FILE,IENS,FLDA,,"ARR") | 
|---|
|  | 154 | I $D(ARR) S SIEN="",RESULTS(0)="" D | 
|---|
|  | 155 | .F  S SIEN=$O(ARR(SPEC,SIEN)) Q:SIEN=""  D | 
|---|
|  | 156 | ..S SFLD="",SREC=$P(SIEN,",") | 
|---|
|  | 157 | ..F  S SFLD=$O(ARR(SPEC,SIEN,SFLD)) Q:SFLD=""  D | 
|---|
|  | 158 | ...S DATA=ARR(SPEC,SIEN,SFLD)_U | 
|---|
|  | 159 | ...S:$D(RESULTS(CNT))=0 RESULTS(CNT)="" | 
|---|
|  | 160 | ...S RESULTS(CNT)=RESULTS(CNT)_DATA | 
|---|
|  | 161 | ..S CNT=CNT+1 | 
|---|
|  | 162 | Q | 
|---|
|  | 163 | KILLD ; first kill all records in subfile, then rebuild | 
|---|
|  | 164 | N DA,DIK,NODE | 
|---|
|  | 165 | S NODE=$P(SUB,";"),DA=0,DA(1)=IEN,DIK=SAVEDIK | 
|---|
|  | 166 | F  S DA=$O(@(ROOT_"DA(1),NODE,DA)")) Q:(+DA'>0)  D ^DIK | 
|---|
|  | 167 | Q | 
|---|
|  | 168 | SETD ; subrecord cleaned out, now rebuild | 
|---|
|  | 169 | N BAD,CN,DR,DIE,DA,DLAYGO,I,NUM,STR,DIC,TYPE | 
|---|
|  | 170 | K DR | 
|---|
|  | 171 | S RESULTS(0)="Filing successful" | 
|---|
|  | 172 | S CN=0,DLAYGO=FILE,DA(1)=IEN,DIC=SAVEDIK,DIC(0)="L" | 
|---|
|  | 173 | F  S CN=$O(DATA(CN)) Q:CN'>0  S X="",BAD=0 D | 
|---|
|  | 174 | .S STR=DATA(CN),NUM=$L(DATA(CN),U),DIC("DR")="" | 
|---|
|  | 175 | .F I=1:1:NUM S STR1=$P($G(STR),U,I) D:('BAD) | 
|---|
|  | 176 | ..I $P(STR1,";")=.01,$P(STR1,";")="",$P(STR1,";",2)="" S BAD=1 Q | 
|---|
|  | 177 | ..I $P(STR1,";")=.01 D | 
|---|
|  | 178 | ...S TYPE=$$GET1^DID(SPEC,.01,"","TYPE") | 
|---|
|  | 179 | ...I TYPE="DATE/TIME" S X=$$FMTE^XLFDT($P(STR1,";",2),2) | 
|---|
|  | 180 | ...E  S X=$P(STR1,";",2) | 
|---|
|  | 181 | ..S DIC("DR")=DIC("DR")_$P(STR1,";")_"///"_$P(STR1,";",2)_";" | 
|---|
|  | 182 | .D MFILE | 
|---|
|  | 183 | Q | 
|---|
|  | 184 | MFILE ; file the multiple | 
|---|
|  | 185 | N PCE,PCE1,TMP | 
|---|
|  | 186 | I X="" S RESULTS(0)=".01 field missing - could not file" Q | 
|---|
|  | 187 | I $G(BAD) S RESULTS(0)="Problems Filing subrecord" Q | 
|---|
|  | 188 | I $L(DIC("DR"))>240 D | 
|---|
|  | 189 | .S PCE=$L(DIC("DR"),";"),TMP=DIC("DR"),PCE1=$P(PCE/2,".") | 
|---|
|  | 190 | .S DIC("DR")=$P(TMP,";",1,PCE1) | 
|---|
|  | 191 | .K DD,DO D FILE^DICN I Y'>0 S BAD=1 | 
|---|
|  | 192 | .S DIC("DR")=$P(TMP,";",(PCE1+1),PCE) | 
|---|
|  | 193 | K DD,DO D FILE^DICN I Y'>0 S BAD=1 | 
|---|
|  | 194 | I BAD S RESULTS(0)="Problems filing subrecord" | 
|---|
|  | 195 | Q | 
|---|
|  | 196 | OSHA300(RESULTS,STA,DATA) ; Files data into subrecord 2262.315 | 
|---|
|  | 197 | ;  Input - STA is the station number subrecord IEN | 
|---|
|  | 198 | ;         DATA is an number subscripted array containing the records | 
|---|
|  | 199 | ;              that contain the Emp Numbers and hours worked in the | 
|---|
|  | 200 | ;              OSHA MONTH/YEAR subrecord. | 
|---|
|  | 201 | ; Output - RESULTS indicating the success of the filing. | 
|---|
|  | 202 | ; | 
|---|
|  | 203 | N CNT,IENS,FILE,OSHAFDA,LV1,LV2,PAR,REC,STR | 
|---|
|  | 204 | S CNT=1,FILE=2262.315 | 
|---|
|  | 205 | S PAR="^OOPS(2262,0)",PAR=$Q(@PAR),PAR=$Q(@PAR) | 
|---|
|  | 206 | S LV1=$P(PAR,",",2),LV2=$P(PAR,",",3) | 
|---|
|  | 207 | S RESULTS="" | 
|---|
|  | 208 | I $D(DATA)<10 S RESULTS="NO DATA TO FILE, CANNOT CONTINUE" Q | 
|---|
|  | 209 | I '$G(STA) S RESULTS="NOT ENOUGH PARAMETERS, COULDN'T FILE" Q | 
|---|
|  | 210 | I '$D(^OOPS(2262,LV1,LV2,STA)) D  Q | 
|---|
|  | 211 | .S RESULTS="NO STATION RECORD, COULDN'T FILE" | 
|---|
|  | 212 | K ^OOPS(2262,LV1,LV2,STA,2) | 
|---|
|  | 213 | S REC=0 F  S REC=$O(DATA(REC)) Q:REC=""  D | 
|---|
|  | 214 | .S IENS="?+"_CNT_","_STA_","_LV1_"," | 
|---|
|  | 215 | .S STR=DATA(REC) | 
|---|
|  | 216 | .S OSHAFDA(FILE,IENS,.01)=$P($P(STR,U,1),";",2) | 
|---|
|  | 217 | .S OSHAFDA(FILE,IENS,1)=$P($P(STR,U,2),";",2) | 
|---|
|  | 218 | .S OSHAFDA(FILE,IENS,2)=$P($P(STR,U,3),";",2) | 
|---|
|  | 219 | .S CNT=CNT+1 | 
|---|
|  | 220 | D UPDATE^DIE("E","OSHAFDA","IENS","MSG") | 
|---|
|  | 221 | I '$D(MSG) S RESULTS="Filing Successful" | 
|---|
|  | 222 | K MSG,STR,Y,X,%DT | 
|---|
|  | 223 | Q | 
|---|
|  | 224 | FLD15 ; retrieves OSHA 300A Summary data from file 2262 | 
|---|
|  | 225 | N CNT,DATE,LV1,LV2,PAR,REC | 
|---|
|  | 226 | S CNT=0,PAR="^OOPS(2262,0)",PAR=$Q(@PAR),PAR=$Q(@PAR) | 
|---|
|  | 227 | S LV1=$P(PAR,",",2),LV2=$P(PAR,",",3),IENS=$P(IEN,",",1),REC=0 | 
|---|
|  | 228 | F  S REC=$O(^OOPS(2262,LV1,LV2,IENS,2,REC)) Q:REC'>0  D | 
|---|
|  | 229 | .S STR=$G(^OOPS(2262,LV1,LV2,IENS,2,REC,0)) | 
|---|
|  | 230 | .S Y=$P(STR,U,1) D DD^%DT | 
|---|
|  | 231 | .S RESULTS(CNT)=Y_U_$P(STR,U,2,3) | 
|---|
|  | 232 | .S CNT=CNT+1 | 
|---|
|  | 233 | Q | 
|---|