| [613] | 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 |  ;
 | 
|---|