| 1 | IBCNRZPL ;DAOU/DMK - Receive HL7 e-Pharmacy ZPL Segment ;23-OCT-2003 | 
|---|
| 2 | ;;2.0;INTEGRATED BILLING;**251**;21-MAR-94 | 
|---|
| 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
| 4 | ; | 
|---|
| 5 | ; Description | 
|---|
| 6 | ; | 
|---|
| 7 | ; Receive HL7 e-Pharmacy ZPL Segment | 
|---|
| 8 | ; 366.03 PLAN File Update | 
|---|
| 9 | ; | 
|---|
| 10 | ; Called by IBCNRHLT | 
|---|
| 11 | ; | 
|---|
| 12 | ; Entry point | 
|---|
| 13 | ; | 
|---|
| 14 | 1000 ; Control ZPL Segment processing | 
|---|
| 15 | D INIT | 
|---|
| 16 | Q | 
|---|
| 17 | ; | 
|---|
| 18 | INIT ; Initialize ZPL Segment variables | 
|---|
| 19 | ; 366.03 PLAN File | 
|---|
| 20 | ; | 
|---|
| 21 | N NAME | 
|---|
| 22 | ; | 
|---|
| 23 | ; .01 = ID | 
|---|
| 24 | S DATA(.01)=$G(IBSEG(4)) | 
|---|
| 25 | ; | 
|---|
| 26 | ; Error? | 
|---|
| 27 | ; V405 = Plan ID Missing | 
|---|
| 28 | I $TR(DATA(.01)," ","")="" S ERROR="V405" Q | 
|---|
| 29 | ; | 
|---|
| 30 | ; .02 = NAME | 
|---|
| 31 | S DATA(.02)=$G(IBSEG(5)) | 
|---|
| 32 | ; | 
|---|
| 33 | ; Error? | 
|---|
| 34 | ; V410 = Plan Name Missing | 
|---|
| 35 | I $TR(DATA(.02)," ","")="" S ERROR="V410" Q | 
|---|
| 36 | ; | 
|---|
| 37 | ; .03 = PAYER NAME (pointer - 365.12) | 
|---|
| 38 | S DATA(.03)=$G(IBSEG(6)) | 
|---|
| 39 | I DATA(.03)]"" S DATA(.03)=$$LOOKUP3^IBCNRFM1(365.12,"C",DATA(.03)) | 
|---|
| 40 | ; | 
|---|
| 41 | ; Error? | 
|---|
| 42 | ; V415 = Payer ID Undefined | 
|---|
| 43 | I DATA(.03)=-1 S ERROR="V415" Q | 
|---|
| 44 | ; | 
|---|
| 45 | ; .04 = NAME - SHORT | 
|---|
| 46 | S DATA(.04)=$G(IBSEG(7)) | 
|---|
| 47 | ; | 
|---|
| 48 | ; .05 = TYPE | 
|---|
| 49 | S DATA(.05)=$G(IBSEG(8)) | 
|---|
| 50 | ; | 
|---|
| 51 | ; .06 = REGION | 
|---|
| 52 | S DATA(.06)=$G(IBSEG(9)) | 
|---|
| 53 | ; | 
|---|
| 54 | ; .07 = DATE/TIME CREATED | 
|---|
| 55 | ; MAD = Add | 
|---|
| 56 | I IBCNACT="MAD",IEN=-1 S DATA(.07)=DATE("NOW") | 
|---|
| 57 | ; | 
|---|
| 58 | ; Initialize primary contact name variables | 
|---|
| 59 | S NAME=$G(IBSEG(10)) | 
|---|
| 60 | D NAME | 
|---|
| 61 | ; | 
|---|
| 62 | ; 1.01 = PRIMARY CONTACT NAME | 
|---|
| 63 | S DATA(1.01)=NAME("NAME") | 
|---|
| 64 | ; | 
|---|
| 65 | ; 1.02 = PRIMARY CONTACT PREFIX | 
|---|
| 66 | S DATA(1.02)=NAME("PREFIX") | 
|---|
| 67 | ; | 
|---|
| 68 | ; 1.03 = PRIMARY CONTACT DEGREE | 
|---|
| 69 | S DATA(1.03)=NAME("DEGREE") | 
|---|
| 70 | ; | 
|---|
| 71 | ; Initialize alternate contact name variables | 
|---|
| 72 | S NAME=$G(IBSEG(11)) | 
|---|
| 73 | D NAME | 
|---|
| 74 | ; | 
|---|
| 75 | ; 1.04 = ALTERNATE CONTACT NAME | 
|---|
| 76 | S DATA(1.04)=NAME("NAME") | 
|---|
| 77 | ; | 
|---|
| 78 | ; 1.05 = ALETRNATE CONTACT PREFIX | 
|---|
| 79 | S DATA(1.05)=NAME("PREFIX") | 
|---|
| 80 | ; | 
|---|
| 81 | ; 1.06 = ALTERNATE CONTACT DEGREE | 
|---|
| 82 | S DATA(1.06)=NAME("DEGREE") | 
|---|
| 83 | Q | 
|---|
| 84 | ; | 
|---|
| 85 | NAME ; Initialize name variables from NAME string | 
|---|
| 86 | S NAME("SURNAME")=$P($P(NAME,$E(HLECH,1),1),$E(HLECH,4),1) | 
|---|
| 87 | S NAME("SURNAME PREFIX")=$P($P(NAME,$E(HLECH,1),1),$E(HLECH,4),2) | 
|---|
| 88 | S NAME("FAMILY")=$S(NAME("SURNAME PREFIX")]"":NAME("SURNAME PREFIX")_" ",1:"")_NAME("SURNAME") | 
|---|
| 89 | S NAME("GIVEN")=$P(NAME,$E(HLECH,1),2) | 
|---|
| 90 | S NAME("MIDDLE")=$P(NAME,$E(HLECH,1),3) | 
|---|
| 91 | S NAME("SUFFIX")=$P(NAME,$E(HLECH,1),4) | 
|---|
| 92 | S NAME("NAME")="" | 
|---|
| 93 | I NAME("FAMILY")]"" S NAME("NAME")=NAME("FAMILY")_","_NAME("GIVEN")_$S(NAME("MIDDLE")]"":" "_$E(NAME("MIDDLE"),1),1:"")_$S(NAME("SUFFIX")]"":" "_NAME("SUFFIX"),1:"") | 
|---|
| 94 | S NAME("PREFIX")=$P(NAME,$E(HLECH,1),5) | 
|---|
| 95 | S NAME("DEGREE")=$P(NAME,$E(HLECH,1),6) | 
|---|
| 96 | Q | 
|---|