| 1 | IBCEM ;ALB/TMP - 837 EDI RETURN MESSAGE PROCESSING ;17-APR-96
 | 
|---|
| 2 |  ;;2.0;INTEGRATED BILLING;**137,191,155**;21-MAR-94
 | 
|---|
| 3 |  Q
 | 
|---|
| 4 |  ;
 | 
|---|
| 5 | UPD ; Update messages manually from messages list
 | 
|---|
| 6 |  N IBDA,IBOK,IBTDA,ZTSK,IBTSK,IBTYP,IBU,IBU1,IB0
 | 
|---|
| 7 |  D FULL^VALM1
 | 
|---|
| 8 |  D SEL(.IBDA,1)
 | 
|---|
| 9 |  S IBDA=$O(IBDA(""))
 | 
|---|
| 10 |  I IBDA="" G UPDQ
 | 
|---|
| 11 |  S IBTDA=+IBDA(IBDA)
 | 
|---|
| 12 |  I '$$LOCK(IBTDA) G UPDQ
 | 
|---|
| 13 |  S IB0=$G(^IBA(364.2,IBTDA,0))
 | 
|---|
| 14 |  ;
 | 
|---|
| 15 |  I IB0="" D  G UPDQ
 | 
|---|
| 16 |  . W !,*7,"Message ",IBDA," is no longer in return message file" S IBOK=""
 | 
|---|
| 17 |  . D PAUSE^VALM1
 | 
|---|
| 18 |  I $P(IB0,U,11) S IBOK=1 D  G:'IBOK UPDQ
 | 
|---|
| 19 |  . N ZTSK
 | 
|---|
| 20 |  . S ZTSK=$P(IB0,U,11) D STAT^%ZTLOAD Q:ZTSK(0)=0  ;Task not scheduled
 | 
|---|
| 21 |  . I "12"[ZTSK(1) W *7,!,"This message has already been scheduled for update.  Task # is: ",$P(IB0,U,11) S IBOK="" D PAUSE^VALM1
 | 
|---|
| 22 |  ;
 | 
|---|
| 23 |  I $P(IB0,U,6)=""!("UP"'[$P(IB0,U,6)) D  G UPDQ
 | 
|---|
| 24 |  . W !,*7,"Message status ("_$$EXPAND^IBTRE(364.2,.06,$P(IB0,U,6))_") is not appropriate for this action"
 | 
|---|
| 25 |  . D PAUSE^VALM1
 | 
|---|
| 26 |  ;
 | 
|---|
| 27 |  S IBTYP=$P($G(^IBE(364.3,+$P(IB0,U,2),0)),U)
 | 
|---|
| 28 |  S IBU=$S(IBTYP="REPORT":"MAILIT^IBCESRV2",IBTYP["837REC":"CON837^IBCESRV2",IBTYP["837REJ":"REJ837^IBCESRV2",IBTYP["835EOB":"EOB835^IBCESRV3",1:""),IBU1=$S(IBTYP["837":$E(IBTYP,$L(IBTYP)),1:2)
 | 
|---|
| 29 |  I IBU="" W !,*7,"This message has an invalid message type - can't update" D PAUSE^VALM1 G UPDQ
 | 
|---|
| 30 |  S IBTSK=$$TASK(IBU,$P(IB0,U,4),IBTDA,IBU1)
 | 
|---|
| 31 |  I IBTSK W !,"Update has been tasked (#",IBTSK,")"
 | 
|---|
| 32 |  I 'IBTSK W !,*7,"Update could not be tasked.  Please try again later!!!"
 | 
|---|
| 33 |  D PAUSE^VALM1
 | 
|---|
| 34 |  ;
 | 
|---|
| 35 |  D BLD^IBCEM1
 | 
|---|
| 36 | UPDQ I $G(IBTDA) L -^IBA(364.2,IBTDA,0)
 | 
|---|
| 37 |  S VALMBCK="R"
 | 
|---|
| 38 |  Q
 | 
|---|
| 39 |  ;
 | 
|---|
| 40 | VP ; View/Print Return Messages
 | 
|---|
| 41 |  N DHD,DIC,FLDS,BY,FR,TO,DIR,Y,L,IBDA,IBTDA,IBBILLS
 | 
|---|
| 42 |  D FULL^VALM1,SEL(.IBDA,1)
 | 
|---|
| 43 |  S IBDA=$O(IBDA(""))
 | 
|---|
| 44 |  G:'IBDA VPQ
 | 
|---|
| 45 |  S IBTDA=$G(IBDA(IBDA)),IBBILLS=""
 | 
|---|
| 46 |  I $P($G(^IBA(364.2,IBTDA,0)),U,4),'$P(^(0),U,5) D
 | 
|---|
| 47 |  .S DIR(0)="YA",DIR("B")="NO",DIR("A")="Do you want to list all bills for this batch?: " D ^DIR K DIR
 | 
|---|
| 48 |  .I Y S IBBILLS=1
 | 
|---|
| 49 |  S DHD=$S(IBBILLS:"[IBCEM MESSAGE LIST HDR]",1:""),DIC="^IBA(364.2,",FLDS=$S(IBBILLS:"[IBCEM MESSAGE LIST]",1:"[CAPTIONED]"),BY="@NUMBER",(FR,TO)=$G(IBDA(IBDA)),L=0 D EN1^DIP
 | 
|---|
| 50 |  D PAUSE^VALM1
 | 
|---|
| 51 | VPQ S VALMBCK="R"
 | 
|---|
| 52 |  Q
 | 
|---|
| 53 |  ;
 | 
|---|
| 54 | SEL(IBDA,ONE) ; Select entry(s) from list
 | 
|---|
| 55 |  ; IBDA = array returned if selections made
 | 
|---|
| 56 |  ;    IBDA(n)=ien of bill selected in file 399
 | 
|---|
| 57 |  ; ONE = if set to 1, only one selection can be made at a time
 | 
|---|
| 58 |  N IB
 | 
|---|
| 59 |  K IBDA
 | 
|---|
| 60 |  D EN^VALM2($G(XQORNOD(0)),$S('$G(ONE):"",1:"S"))
 | 
|---|
| 61 |  S IBDA=0 F  S IBDA=$O(VALMY(IBDA)) Q:'IBDA  S IB=$G(^TMP("IBCEM-837DX",$J,IBDA)),IBDA(IBDA)=+$P(IB,U,2)
 | 
|---|
| 62 |  Q
 | 
|---|
| 63 |  ;
 | 
|---|
| 64 | UPDEDI(IBDA,FUNC,NOCT) ; Update EDI files - cancel/resubmit/print as
 | 
|---|
| 65 |  ;   resolution to message
 | 
|---|
| 66 |  ; IBDA = transmit bill ien # for bill
 | 
|---|
| 67 |  ; FUNC = "E" for edit/resubmit, "C" for cancel, "R" for resubmit not
 | 
|---|
| 68 |  ;       from edit, "P" for print, "Z" for COB processed , "N" for no
 | 
|---|
| 69 |  ;       further action needed-close record
 | 
|---|
| 70 |  ; NOCT = 1 if not necessary to update batch count, 0 if update needed
 | 
|---|
| 71 |  ;
 | 
|---|
| 72 |  N IB0,IBBA,IBBDA,IBCT,IBM,IBTDA,IBNEW,DA,DIE,DR,Z,IBTEXT,IBZ,IBIFN,IBSTAT
 | 
|---|
| 73 |  S IB0=$G(^IBA(364,+IBDA,0)),IBBA=$P(IB0,U,2)
 | 
|---|
| 74 |  Q:IB0=""  S IBIFN=+IB0
 | 
|---|
| 75 |  ;
 | 
|---|
| 76 |  S IBNEW=$S(FUNC="E"!(FUNC="R"):+$P($G(^IBA(364,+$$LAST364^IBCEF4(+IB0),0)),U,2),1:"") S:IBNEW=IBBA IBNEW=""
 | 
|---|
| 77 |  ;
 | 
|---|
| 78 |  S IBSTAT=$P(IB0,U,3)                ; current status in file 364
 | 
|---|
| 79 |  I '$F(".C.R.E.Z.","."_IBSTAT_".") D   ; don't update if in final status
 | 
|---|
| 80 |  . S DR=".03////"_$S(FUNC="E":"R","NP"'[FUNC:FUNC,1:"Z")_";.04///NOW" S:FUNC="E"!(FUNC="R") DR=DR_$S(IBNEW:";.06////"_IBNEW,1:"")
 | 
|---|
| 81 |  . S DA=+IBDA,DIE="^IBA(364," D ^DIE ;Update the transmit bill record
 | 
|---|
| 82 |  . Q
 | 
|---|
| 83 |  ;
 | 
|---|
| 84 |  I IBBA D CKRES^IBCESRV2(IBBA) ;Update completely resubmitted flags
 | 
|---|
| 85 |  ;
 | 
|---|
| 86 |  I IBBA,(FUNC="P"!(IBNEW&'$G(NOCT))) D CTDOWN^IBCEM02(IBBA,1) ;If resubmitted in a new batch or printed, update old batch
 | 
|---|
| 87 |  ;
 | 
|---|
| 88 |  S IBTEXT(1)=" UPDATED BY: "_$$EXTERNAL^DILFD(361.02,.02,,+$G(DUZ))
 | 
|---|
| 89 |  S IBTEXT(2)="ACTION USED: "_$S(FUNC="E":"BILL EDITED/RESUBMITTED",FUNC="C":"BILL CANCELED",FUNC="R":"BILL RESUBMITTED WITHOUT EDIT)",FUNC="P":"PRINT BILL",FUNC="Z":"PROCESS COB",1:"")
 | 
|---|
| 90 |  S IBTEXT(2)=$S(IBTEXT(2)="":"UNSPECIFIED",1:IBTEXT(2)_" - REVIEW MARKED AS COMPLETE")
 | 
|---|
| 91 |  S IBTEXT=2
 | 
|---|
| 92 |  ;
 | 
|---|
| 93 |  ; Update file 361
 | 
|---|
| 94 |  S IBZ=0 F  S IBZ=$O(^IBM(361,"AERR",+IBDA,IBZ)) Q:'IBZ  I $D(^IBM(361,IBZ,0)),$P(^(0),U,10)="",$P(^(0),U,9)<2 D
 | 
|---|
| 95 |  . S DIE="^IBM(361,",DR=".09////2;.1////"_$TR(FUNC,"RCEIBZPN","RCROOFOO"),DA=IBZ D ^DIE
 | 
|---|
| 96 |  . I FUNC'="","ECRPIBZ"[FUNC D  ; Update review status, notes for message
 | 
|---|
| 97 |  .. D NOTECHG^IBCECSA2(IBZ,1,.IBTEXT)
 | 
|---|
| 98 |  ;
 | 
|---|
| 99 |  ; Update file 361.1 with the Cancel Status, to cancel All EOB's on file
 | 
|---|
| 100 |  I FUNC="C" D STAT^IBCEMU2(IBIFN,9,0)
 | 
|---|
| 101 |  ;
 | 
|---|
| 102 |  Q
 | 
|---|
| 103 |  ;
 | 
|---|
| 104 | DEL ; Delete messages from messages list - locked with IB SUPERVISOR key
 | 
|---|
| 105 |  N IBDA,IBOK,IBTDA,IBTYP,IBU,IBU1,IB0,DIR,IBT,IBE,Z,X,Y,XMSUBJ,XMTO,XMBODY,XMDUZ
 | 
|---|
| 106 |  D FULL^VALM1
 | 
|---|
| 107 |  S IBTDA=0
 | 
|---|
| 108 |  I '$D(^XUSEC("IB SUPERVISOR",DUZ)) D  G DELQ
 | 
|---|
| 109 |  . W !,"You don't have authority to use this action. See your supervisr for assistance"
 | 
|---|
| 110 |  . D PAUSE^VALM1
 | 
|---|
| 111 |  D SEL(.IBDA,1)
 | 
|---|
| 112 |  S IBDA=$O(IBDA(""))
 | 
|---|
| 113 |  I IBDA="" G DELQ
 | 
|---|
| 114 |  W !
 | 
|---|
| 115 |  S DIR(0)="YA",DIR("A",1)="This action will PERMANENTLY delete a return message from your system",DIR("A",2)="A bulletin will be sent to report the deletion",DIR("A",3)=" "
 | 
|---|
| 116 |  S DIR("A")="ARE YOU SURE YOU WANT TO CONTINUE? ",DIR("B")="NO"
 | 
|---|
| 117 |  D ^DIR K DIR
 | 
|---|
| 118 |  G:Y'=1 DELQ
 | 
|---|
| 119 |  S IBTDA=+IBDA(IBDA)
 | 
|---|
| 120 |  I '$$LOCK(IBTDA) G DELQ
 | 
|---|
| 121 |  S IB0=$G(^IBA(364.2,IBTDA,0))
 | 
|---|
| 122 |  ;
 | 
|---|
| 123 |  I $P(IB0,U,11) S IBOK=1 D  G:'IBOK DELQ
 | 
|---|
| 124 |  . N ZTSK
 | 
|---|
| 125 |  . S ZTSK=$P(IB0,U,11) D STAT^%ZTLOAD Q:ZTSK(0)=0  ;Task not scheduled
 | 
|---|
| 126 |  . I "12"[ZTSK(1) W *7,!,"This message is currently scheduled for update.  Task # is: ",$P(IB0,U,11) S IBOK="" D PAUSE^VALM1
 | 
|---|
| 127 |  ;
 | 
|---|
| 128 |  I $P(IB0,U,6)=""!("UP"'[$P(IB0,U,6)) D  G DELQ
 | 
|---|
| 129 |  . W !,*7,"Message status ("_$$EXPAND^IBTRE(364.2,.06,$P(IB0,U,6))_") is not appropriate for this action"
 | 
|---|
| 130 |  . D PAUSE^VALM1
 | 
|---|
| 131 |  ;
 | 
|---|
| 132 |  S DIR(0)="YA",DIR("A",1)=" ",DIR("A",2)="",$P(DIR("A",2),"*",54)="",DIR("A",3)="* This message is about to be PERMANENTLY deleted!! *",DIR("A",4)=DIR("A",2),DIR("A",5)=" "
 | 
|---|
| 133 |  S DIR("A")="ARE YOU STILL SURE YOU WANT TO CONTINUE? ",DIR("B")="NO"
 | 
|---|
| 134 |  W ! D ^DIR W ! K DIR
 | 
|---|
| 135 |  I Y'=1 W !!,"Nothing deleted" D PAUSE^VALM1 G DELQ
 | 
|---|
| 136 |  ;
 | 
|---|
| 137 |  K ^TMP("IBMSG",$J)
 | 
|---|
| 138 |  M ^TMP("IBMSG",$J)=^IBA(364.2,IBTDA)
 | 
|---|
| 139 |  D DELMSG^IBCESRV2(IBTDA)
 | 
|---|
| 140 |  I $D(^IBA(364.2,IBTDA)) D  G DELQ
 | 
|---|
| 141 |  . W !,"Message not deleted - problem with delete" D PAUSE^VALM1
 | 
|---|
| 142 |  ;
 | 
|---|
| 143 |  S IBT(1)="EDI return message #"_$P(IB0,U)_" has been deleted"
 | 
|---|
| 144 |  S IBT(2)=" "
 | 
|---|
| 145 |  S IBT(3)="DELETED BY: "_$P($G(^VA(200,+$G(DUZ),0)),U)_"   "_$$FMTE^XLFDT($$NOW^XLFDT,2)
 | 
|---|
| 146 |  S Z=$$EXPAND^IBTRE(364.2,.06,$P(IB0,U,6)) S:Z="" Z="??"
 | 
|---|
| 147 |  S IBT(4)="    STATUS: "_$E(Z_$J("",11),1,11)_"  MESSAGE TYPE: "_$P($G(^IBE(364.3,+$P(IB0,U,2),0)),U,5)
 | 
|---|
| 148 |  S IBT(5)=" MESSAGE #: "_$E($P(IB0,U)_$J("",11),1,11)_"   STATUS DATE: "_$$FMTE^XLFDT($P($G(^TMP("IBMSG",$J,1)),U,3))
 | 
|---|
| 149 |  S IBT(6)="   BATCH #: "_$E($P($G(^IBA(364.1,+$P(IB0,U,4),0)),U)_$J("",11),1,11)_"        BILL #: "_$$EXPAND^IBTRE(364.2,.05,$P(IB0,U,5))
 | 
|---|
| 150 |  S IBT(7)=" "
 | 
|---|
| 151 |  S IBT(8)="MESSAGE TEXT:",IBE=8
 | 
|---|
| 152 |  S Z=0 F  S Z=$O(^TMP("IBMSG",$J,2,Z)) Q:'Z  S IBE=IBE+1,IBT(IBE)=$G(^(Z,0))
 | 
|---|
| 153 |  S XMSUBJ="EDI MESSAGE DELETED",XMBODY="IBT",XMDUZ="",XMTO("I:G.IB EDI")=""
 | 
|---|
| 154 |  D SENDMSG^XMXAPI(XMDUZ,XMSUBJ,XMBODY,.XMTO,,.XMZ)
 | 
|---|
| 155 |  ;
 | 
|---|
| 156 |  K ^TMP("IBMSG",$J)
 | 
|---|
| 157 |  ;
 | 
|---|
| 158 |  W !,"A bulletin has been sent to report this deletion",!
 | 
|---|
| 159 |  D PAUSE^VALM1
 | 
|---|
| 160 |  ;
 | 
|---|
| 161 |  D BLD^IBCEM1
 | 
|---|
| 162 | DELQ L -^IBA(364.2,IBTDA,0)
 | 
|---|
| 163 |  S VALMBCK="R"
 | 
|---|
| 164 |  Q
 | 
|---|
| 165 |  ;
 | 
|---|
| 166 | TASK(IBRTN,IBBDA,IBTDA,IBTYP) ; Schedule the task to update data base from message
 | 
|---|
| 167 |  ; IBRTN = routine to task
 | 
|---|
| 168 |  ; IBBDA = batch # associated with the message (OPTIONAL)
 | 
|---|
| 169 |  ; IBTDA = internal entry of message
 | 
|---|
| 170 |  ; IBTYP = the number that is the last digit in the message type
 | 
|---|
| 171 |  ;
 | 
|---|
| 172 |  N ZTSK,ZTDESC,ZTIO,ZTDTH,ZTSAVE,DA,DR,DIE
 | 
|---|
| 173 |  S ZTIO="",ZTDTH=$H,ZTDESC="UPDATE DATA BASE FROM EDI RETURN MESSAGE",ZTSAVE("IB*")="",ZTRTN=IBRTN
 | 
|---|
| 174 |  D ^%ZTLOAD
 | 
|---|
| 175 |  I $G(ZTSK),$G(^IBA(364.2,IBTDA,0)) S DIE="^IBA(364.2,",DR=".11////"_ZTSK_";.06////U",DA=IBTDA D ^DIE
 | 
|---|
| 176 |  Q $G(ZTSK)
 | 
|---|
| 177 |  ;
 | 
|---|
| 178 | LOCK(IBTDA) ; Attempt to lock message file entry IBTDA
 | 
|---|
| 179 |  ; Return 1 if successful, 0 if not able to lock
 | 
|---|
| 180 |  ;
 | 
|---|
| 181 |  N OK
 | 
|---|
| 182 |  S OK=1
 | 
|---|
| 183 |  L +^IBA(364.2,IBTDA,0):5
 | 
|---|
| 184 |  I '$T D
 | 
|---|
| 185 |  . I '$D(DIQUIET) W !,*7,"Another user is editing this entry ... try again later" D PAUSE^VALM1
 | 
|---|
| 186 |  . S IBDA="",OK=0
 | 
|---|
| 187 |  Q OK
 | 
|---|
| 188 |  ;
 | 
|---|