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