| 1 | IBCNEUT6 ;DAOU/ESG - IIV MISC. UTILITIES ;14-AUG-2002 | 
|---|
| 2 | ;;2.0;INTEGRATED BILLING;**184,252,271**;21-MAR-94 | 
|---|
| 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
| 4 | ; | 
|---|
| 5 | ; Can't be called from the top | 
|---|
| 6 | Q | 
|---|
| 7 | ; | 
|---|
| 8 | AMCHECK ; This procedure will examine the insurance company names in the | 
|---|
| 9 | ; Auto Match file (#365.11) to make sure there is still at least | 
|---|
| 10 | ; one active insurance company with that name.  If there isn't, | 
|---|
| 11 | ; then the Auto Match entries for that insurance company name | 
|---|
| 12 | ; will be deleted. | 
|---|
| 13 | ; | 
|---|
| 14 | NEW NAME,INSIEN,FOUNDACT,DA,DIK,DIC,X,Y,% | 
|---|
| 15 | S NAME="" | 
|---|
| 16 | F  S NAME=$O(^IBCN(365.11,"C",NAME)) Q:NAME=""  D | 
|---|
| 17 | . ; | 
|---|
| 18 | . ; For this Auto Match ins co name, see if there is an active ins co | 
|---|
| 19 | . S INSIEN=0,FOUNDACT=0 | 
|---|
| 20 | . F  S INSIEN=$O(^DIC(36,"B",NAME,INSIEN)) Q:'INSIEN  I $$ACTIVE^IBCNEUT4(INSIEN) S FOUNDACT=1 Q | 
|---|
| 21 | . ; | 
|---|
| 22 | . ; If an active ins co was found, then we're OK so quit | 
|---|
| 23 | . I FOUNDACT Q | 
|---|
| 24 | . ; | 
|---|
| 25 | . ; Otherwise, we need to delete all Auto Match entries for this name | 
|---|
| 26 | . S DA=0,DIK="^IBCN(365.11," | 
|---|
| 27 | . F  S DA=$O(^IBCN(365.11,"C",NAME,DA)) Q:'DA  D ^DIK | 
|---|
| 28 | . Q | 
|---|
| 29 | AMCHKX ; | 
|---|
| 30 | Q | 
|---|
| 31 | ; | 
|---|
| 32 | ; | 
|---|
| 33 | AMADD(INSNAME,IBCNEXT1) ; Conditionally add an Auto Match entry based on user input | 
|---|
| 34 | ; Input Parameters: | 
|---|
| 35 | ;    INSNAME is a valid, active insurance company name | 
|---|
| 36 | ;   IBCNEXT1 is the existing entry in the ins co name field in the | 
|---|
| 37 | ;            buffer.  This may be used as the Auto Match value for | 
|---|
| 38 | ;            a new auto match entry. | 
|---|
| 39 | ; | 
|---|
| 40 | NEW AMDATA,AMIEN,AMERROR | 
|---|
| 41 | NEW DIR,X,Y,DTOUT,DUOUT,DIRUT,DIROUT | 
|---|
| 42 | NEW D,D0,D1,DA,DB,DC,DDH,DE,DG,DH,DI,DIC,DIE,DIEL,DIFLD,DIG,DIH | 
|---|
| 43 | NEW DIK,DILN,DIPA,DISYS,DIV,DK,DL,DM,DN,DOV,DP,DQ,DR,DU,DV,DZ | 
|---|
| 44 | ; | 
|---|
| 45 | ; First, check security key to see if user is allowed to do this | 
|---|
| 46 | I '$$KCHK^XUSRB("IBCNE IIV AUTO MATCH") G AMADDX | 
|---|
| 47 | ; | 
|---|
| 48 | S IBCNEXT1=$$UP^XLFSTR(IBCNEXT1)               ; all uppercase | 
|---|
| 49 | S IBCNEXT1=$$TRIM^XLFSTR(IBCNEXT1)             ; lead/trail spaces | 
|---|
| 50 | I IBCNEXT1="" G AMADDX                         ; must exist | 
|---|
| 51 | I $L(IBCNEXT1)>30!($L(IBCNEXT1)<3) G AMADDX    ; too long or too short | 
|---|
| 52 | I IBCNEXT1=INSNAME G AMADDX                    ; cannot equal the name | 
|---|
| 53 | I $D(^IBCN(365.11,"B",IBCNEXT1)) G AMADDX      ; already in Auto Match | 
|---|
| 54 | I $D(^DIC(36,"B",IBCNEXT1)) G AMADDX           ; already an ins co name | 
|---|
| 55 | I $D(^DIC(36,"C",IBCNEXT1)) G AMADDX           ; already a synonym | 
|---|
| 56 | I IBCNEXT1["*" G AMADDX                        ; no wildcards allowed | 
|---|
| 57 | ; | 
|---|
| 58 | S DIR(0)="YO" | 
|---|
| 59 | S DIR("A",1)=" " | 
|---|
| 60 | S DIR("A",2)="Do you want to add an Auto Match entry that associates" | 
|---|
| 61 | S DIR("A")=IBCNEXT1_" with "_INSNAME | 
|---|
| 62 | S DIR("B")="No" | 
|---|
| 63 | S DIR("?",1)="      The Auto Match Value is "_IBCNEXT1_"." | 
|---|
| 64 | S DIR("?",2)="The Insurance Company Name is "_INSNAME_"." | 
|---|
| 65 | S DIR("?",3)=" " | 
|---|
| 66 | S DIR("?",4)="Please enter NO if you do not want to associate these two values together" | 
|---|
| 67 | S DIR("?",5)="in the Auto Match file." | 
|---|
| 68 | S DIR("?",6)=" " | 
|---|
| 69 | S DIR("?",7)="Please enter YES if you do want to create an Auto Match entry for these" | 
|---|
| 70 | S DIR("?",8)="two values.  If you enter YES, then you will have the chance to modify" | 
|---|
| 71 | S DIR("?")="the Auto Match Value." | 
|---|
| 72 | D ^DIR K DIR | 
|---|
| 73 | D EN^DDIOL(,,"!!") | 
|---|
| 74 | ; | 
|---|
| 75 | ; If user didn't say Yes, then we exit | 
|---|
| 76 | I 'Y G AMADDX | 
|---|
| 77 | ; To allow for edits to the .01 field and not the .02 field, | 
|---|
| 78 | ; Add this new entry first and then edit only the .01 field. | 
|---|
| 79 | S AMDATA(365.11,"+1,",.01)=IBCNEXT1 | 
|---|
| 80 | S AMDATA(365.11,"+1,",.02)=INSNAME | 
|---|
| 81 | S AMDATA(365.11,"+1,",.03)=$$NOW^XLFDT | 
|---|
| 82 | S AMDATA(365.11,"+1,",.04)=DUZ | 
|---|
| 83 | S AMDATA(365.11,"+1,",.05)=$$NOW^XLFDT | 
|---|
| 84 | S AMDATA(365.11,"+1,",.06)=DUZ | 
|---|
| 85 | S AMDATA(365.11,"+1,",.07)=IBCNEXT1 | 
|---|
| 86 | S AMDATA(365.11,"+1,",.08)=INSNAME | 
|---|
| 87 | D UPDATE^DIE("","AMDATA","AMIEN","AMERROR") | 
|---|
| 88 | ; | 
|---|
| 89 | I $D(AMERROR) G AMADDX       ; FileMan error so get out | 
|---|
| 90 | S AMIEN=+$G(AMIEN(1))        ; internal entry number created | 
|---|
| 91 | I 'AMIEN G AMADDX            ; if IEN not there get out | 
|---|
| 92 | ; | 
|---|
| 93 | ; Here we have to edit the entry to allow for the opportunity to | 
|---|
| 94 | ; change something | 
|---|
| 95 | S DIE=365.11,DA=AMIEN,DR=".01;.05////"_$$NOW^XLFDT_";.06////"_DUZ | 
|---|
| 96 | D ^DIE | 
|---|
| 97 | ; | 
|---|
| 98 | ; Display the confirmation message to the user | 
|---|
| 99 | S AMDATA=$G(^IBCN(365.11,AMIEN,0)) | 
|---|
| 100 | I AMDATA'="" D EN^DDIOL($P(AMDATA,U,1)_" is now associated with "_$P(AMDATA,U,2)_".",,"!!?3") | 
|---|
| 101 | D EN^DDIOL(,,"!!") | 
|---|
| 102 | AMADDX ; | 
|---|
| 103 | Q | 
|---|
| 104 | ; | 
|---|
| 105 | PYRFLTR() ; | 
|---|
| 106 | ; Function to assist with filtering items in custom payer | 
|---|
| 107 | ; lookups for most popular list.  This logic is used in the | 
|---|
| 108 | ; DIC("S") definition for the lookup | 
|---|
| 109 | ; | 
|---|
| 110 | NEW IBDATA,IBPIEN,IBPNM,IBAIEN,IBADATA,OK | 
|---|
| 111 | ; | 
|---|
| 112 | S OK=1 | 
|---|
| 113 | ; | 
|---|
| 114 | S IBDATA=^(0)   ; Naked reference from DIC call | 
|---|
| 115 | S IBPIEN=$G(Y) I IBPIEN="" S OK=0 G XPFLTR | 
|---|
| 116 | ; | 
|---|
| 117 | ; Set Payer Name and IEN | 
|---|
| 118 | S IBPNM=$P(IBDATA,U,1) I IBPNM="" S OK=0 G XPFLTR | 
|---|
| 119 | ; | 
|---|
| 120 | ; Set Payer Application IEN (365.13) | 
|---|
| 121 | ;  Quit if IIV not defined for payer | 
|---|
| 122 | S IBAIEN=$$PYRAPP^IBCNEUT5("IIV",IBPIEN) I IBAIEN="" S OK=0 G XPFLTR | 
|---|
| 123 | ; | 
|---|
| 124 | ; Get IIV application specific data | 
|---|
| 125 | S IBADATA=$G(^IBE(365.12,IBPIEN,1,IBAIEN,0)) I IBADATA="" S OK=0 G XPFLTR | 
|---|
| 126 | ; | 
|---|
| 127 | ; Filter if Deactivated | 
|---|
| 128 | I +$P(IBADATA,U,11) S OK=0 G XPFLTR | 
|---|
| 129 | ; | 
|---|
| 130 | ; Filter if ID Inq Req ID and SSN is not ID | 
|---|
| 131 | I +$P(IBADATA,U,8),'$P(IBADATA,U,9) S OK=0 G XPFLTR | 
|---|
| 132 | ; | 
|---|
| 133 | ; Filter if already in the list | 
|---|
| 134 | I $D(^TMP($J,"IBJPI3-IENS",IBPIEN)) S OK=0 G XPFLTR | 
|---|
| 135 | ; | 
|---|
| 136 | XPFLTR Q OK | 
|---|
| 137 | ; | 
|---|
| 138 | DSPLINE() ; | 
|---|
| 139 | ; Format display text for custom Most Pop. payer lookup | 
|---|
| 140 | ; | 
|---|
| 141 | N ITEMDATA,DISPSTR,IBAIEN,IBADATA,PYRIEN,PADLEN | 
|---|
| 142 | ; | 
|---|
| 143 | ; Initialize the data for the item to be displayed | 
|---|
| 144 | ; Naked reference is referencing the DIC data | 
|---|
| 145 | S ITEMDATA=^(0) | 
|---|
| 146 | ; | 
|---|
| 147 | ; Initialize Display string | 
|---|
| 148 | S DISPSTR="" | 
|---|
| 149 | ; | 
|---|
| 150 | ; Payer IEN is passed from DIC as Y | 
|---|
| 151 | S PYRIEN=+$G(Y) I 'PYRIEN G EXDSP | 
|---|
| 152 | ; | 
|---|
| 153 | ; Set Payer Application IEN (365.13) | 
|---|
| 154 | S IBAIEN=$$PYRAPP^IBCNEUT5("IIV",PYRIEN) I IBAIEN="" G EXDSP | 
|---|
| 155 | ; | 
|---|
| 156 | ; Get IIV Application specific data | 
|---|
| 157 | S IBADATA=$G(^IBE(365.12,PYRIEN,1,IBAIEN,0)) I IBADATA="" G EXDSP | 
|---|
| 158 | ; | 
|---|
| 159 | ; Pad start of display data, adjusting for payer name length | 
|---|
| 160 | S PADLEN=$L($E($P($G(ITEMDATA),U),1,30)) | 
|---|
| 161 | S DISPSTR=DISPSTR_$$FO^IBCNEUT1("",31-PADLEN,"L") | 
|---|
| 162 | ; | 
|---|
| 163 | ; Add National and Local active flags | 
|---|
| 164 | S DISPSTR=DISPSTR_"  National: "_$$FO^IBCNEUT1($S('$P(IBADATA,U,2):"Inactive",1:"Active"),8) | 
|---|
| 165 | S DISPSTR=DISPSTR_"  Local: "_$$FO^IBCNEUT1($S('$P(IBADATA,U,3):"Inactive",1:"Active"),8) | 
|---|
| 166 | EXDSP ; | 
|---|
| 167 | Q DISPSTR | 
|---|
| 168 | ; | 
|---|