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