1 | RCDPURE1 ;WISC/RFJ-process a receipt ;1 Jun 99
|
---|
2 | ;;4.5;Accounts Receivable;**114,148,153,169,204,173,214,217**;Mar 20, 1995
|
---|
3 | ;;Per VHA Directive 10-93-142, this routine should not be modified.
|
---|
4 | Q
|
---|
5 | ;
|
---|
6 | ;
|
---|
7 | PROCESS(RCRECTDA,RCSCREEN) ; process a receipt, update ar, generate cr/tr documents to fms
|
---|
8 | ; the receipt and deposit must be locked before calling this label
|
---|
9 | ; if $g(rcscreen) = 1 show messages during processing
|
---|
10 | ; if $g(rcscreen) = 2 store messages during processing
|
---|
11 | N RCPAYDA,RCDPFPAY,RCERROR,RCMSG,RCEFT,RCERA
|
---|
12 | K ^TMP($J,"RCDPEMSG")
|
---|
13 | ;
|
---|
14 | ; first mark the receipt as processed/closed to prevent changing the
|
---|
15 | ; data if the receipt does not fully process. this will lock the
|
---|
16 | ; cancel payment, edit payment, etc. options. once a receipt is
|
---|
17 | ; processed, even partially, it should not be changed.
|
---|
18 | D MARKPROC^RCDPUREC(RCRECTDA,"")
|
---|
19 | ;
|
---|
20 | ; Special processing needed for EFT-related receipts
|
---|
21 | ; RCEFT = 1 if EFT deposit, = 2 if receipt detail transfer, 0 if no EFT
|
---|
22 | S RCEFT=+$$EDILB^RCDPEU(RCRECTDA)
|
---|
23 | S RCERA=$P($G(^RCY(344,RCRECTDA,0)),U,18)
|
---|
24 | ;
|
---|
25 | ; === no payments ===
|
---|
26 | ; if there are no payments for the receipt, quit
|
---|
27 | I '$O(^RCY(344,RCRECTDA,1,0)) D Q
|
---|
28 | . I $G(RCSCREEN) S RCMSG="Receipt does not have any payments and has been marked as processed/closed." D MSG(RCMSG,RCSCREEN,"!!")
|
---|
29 | . I RCERA D UPDERA(RCERA)
|
---|
30 | ;
|
---|
31 | ; check to see if the payments have dollar amounts
|
---|
32 | S RCPAYDA=0 F S RCPAYDA=$O(^RCY(344,RCRECTDA,1,RCPAYDA)) Q:'RCPAYDA I $P($G(^(RCPAYDA,0)),"^",4) S RCDPFPAY=1 Q
|
---|
33 | I '$G(RCDPFPAY) D Q
|
---|
34 | . I $G(RCSCREEN) S RCMSG="Receipt does not have any payments and has been marked as processed/closed." D MSG(RCMSG,RCSCREEN,"!!")
|
---|
35 | . I RCERA D UPDERA(RCERA)
|
---|
36 | ;
|
---|
37 | ; === update AR accounts ===
|
---|
38 | I $G(RCSCREEN) S RCMSG="Updating AR accounts..." D MSG(RCMSG,RCSCREEN,"!!")
|
---|
39 | ;
|
---|
40 | ; loop payments and apply to account in AR
|
---|
41 | S RCPAYDA=0 F S RCPAYDA=$O(^RCY(344,RCRECTDA,1,RCPAYDA)) Q:'RCPAYDA D I RCERROR Q
|
---|
42 | . S RCERROR=$$PROCESS^RCBEPAY(RCRECTDA,RCPAYDA)
|
---|
43 | ;
|
---|
44 | ; an error occurred during processing a payment
|
---|
45 | I $G(RCERROR) D Q
|
---|
46 | . I '$G(RCSCREEN) Q
|
---|
47 | . S RCMSG="+-----------------------------------------------------------------------------+" D MSG(RCMSG,RCSCREEN,"!!")
|
---|
48 | . S RCMSG="| An ERROR has occurred when processing payment "_RCPAYDA_" on receipt "_$P(^RCY(344,RCRECTDA,0),"^")_".",RCMSG=$E(RCMSG_$J("",77),1,77)_"|" D MSG(RCMSG,RCSCREEN,"!")
|
---|
49 | . S RCMSG="| The error message returned during processing is:",RCMSG=$E(RCMSG_$J("",77),1,77)_"|" D MSG(RCMSG,RCSCREEN,"!")
|
---|
50 | . S RCMSG="|"_$J("",77)_"|" D MSG(RCMSG,RCSCREEN,"!")
|
---|
51 | . S RCMSG=$E("| "_$P(RCERROR,"^",2)_$J("",77),1,77)_"|" D MSG(RCMSG,RCSCREEN,"!")
|
---|
52 | . S RCMSG="|"_$J("",77)_"|" D MSG(RCMSG,RCSCREEN,"!")
|
---|
53 | . S RCMSG=$E("| You will need to correct the error before you can completely process the"_$J("",77),1,77)_"|" D MSG(RCMSG,RCSCREEN,"!")
|
---|
54 | . S RCMSG=$E("| receipt. Once the receipt is completely processed, the FMS "_$S(RCEFT'=2:"Cash Receipt",1:"'TR'")_$J("",77),1,77)_"|" D MSG(RCMSG,RCSCREEN,"!")
|
---|
55 | . S RCMSG=$E("| document will be generated."_$J("",77),1,77)_"|" D MSG(RCMSG,RCSCREEN,"!")
|
---|
56 | . S RCMSG="+-----------------------------------------------------------------------------+" D MSG(RCMSG,RCSCREEN,"!")
|
---|
57 | ;
|
---|
58 | ; all payments processed correctly
|
---|
59 | I RCERA D UPDERA(RCERA)
|
---|
60 | I $G(RCSCREEN) D MSG(" Done.",RCSCREEN)
|
---|
61 | ;
|
---|
62 | ; if no deposit ticket and not related to EFT or is a HAC payment, do not send to fms
|
---|
63 | I '$P(^RCY(344,RCRECTDA,0),"^",6),$S('RCEFT:1,1:$$HACEFT^RCDPEU(+$P(^RCY(344,RCRECTDA,0),U,17))) D Q
|
---|
64 | . D 215
|
---|
65 | . I $G(RCSCREEN) S RCMSG="Receipt does not have a deposit ticket and will NOT be sent to FMS." D MSG(RCMSG,RCSCREEN,"!!")
|
---|
66 | ;
|
---|
67 | ; === send fms cash receipt document ===
|
---|
68 | N GECSDATA,FMSDOCNO,RESULT,REFMS
|
---|
69 | ; lookup fms document number to see if the receipt has been
|
---|
70 | ; sent to fms (field 200 in file 344)
|
---|
71 | S FMSDOCNO=$P($G(^RCY(344,RCRECTDA,2)),"^")
|
---|
72 | ; if there is an entry, find the code sheet in gcs to rebuild
|
---|
73 | ; gecsdata will be the ien for file 2100.1
|
---|
74 | I FMSDOCNO'="" S REFMS=1 N DIQ2 D DATA^GECSSGET(FMSDOCNO,0)
|
---|
75 | ;
|
---|
76 | I $G(RCSCREEN)&$G(GECSDATA) S RCMSG="Re-Transmitting CR document to FMS... " D MSG(RCMSG,RCSCREEN,"!!")
|
---|
77 | I $G(RCSCREEN)&'$G(GECSDATA) S RCMSG="Transmitting CR document to FMS... " D MSG(RCMSG,RCSCREEN,"!!")
|
---|
78 | ;
|
---|
79 | ; build and send the tr/cr document to fms
|
---|
80 | I RCEFT'=2 D ; Send CR doc
|
---|
81 | . S RESULT=$$BUILDCR^RCXFMSCR(RCRECTDA,+$G(GECSDATA),RCEFT)
|
---|
82 | E D ; Send TR doc
|
---|
83 | . S RESULT=$$GETTR^RCXFMST1(RCRECTDA,+$G(GECSDATA))
|
---|
84 | ; error in building code sheet
|
---|
85 | I 'RESULT D:$G(RCSCREEN) MSG("ERROR - "_$P(RESULT,"^",2),RCSCREEN,"!!") Q
|
---|
86 | ;
|
---|
87 | ; no document to send
|
---|
88 | I $P(RESULT,"^")=-1,$G(RCSCREEN) S RCMSG="NOTE - "_$P(RESULT,"^",2) S $P(RESULT,"^",2)="" D MSG(RCMSG,RCSCREEN,"!!")
|
---|
89 | ; document built and sent
|
---|
90 | I $P(RESULT,"^")=1,$G(RCSCREEN) D
|
---|
91 | . N Z,DIE,DR,DA
|
---|
92 | . D MSG("Done. FMS document number "_$P(RESULT,"^",2),RCSCREEN,"!!")
|
---|
93 | . I +$O(^RCY(344.4,"ARCT",RCRECTDA,0)) S DIE="^RCY(344.4,",DR=".14////1",DA=+$O(^RCY(344.4,"ARCT",RCRECTDA,0)) D ^DIE
|
---|
94 | . I $P($G(^RCY(344,RCRECTDA,0)),U,17) S Z=$P($G(^RCY(344.31,+$P(^RCY(344,RCRECTDA,0),U,17),0)),U,15) I Z'="" S DA=RCRECTDA,DIE="^RCY(344,",DR=".16////"_Z D ^DIE
|
---|
95 | I $G(RCSCREEN) D
|
---|
96 | . I '$G(REFMS)&(DT>$$LDATE^RCRJR(DT)) S Y=$E($$FPS^RCAMFN01(DT,1),1,5)_"01" D DD^%DT W !! S RCMSG=" * * * * Transmission will be held until "_Y_" * * * *" D MSG(RCMSG,RCSCREEN,"!!")
|
---|
97 | ;
|
---|
98 | ;
|
---|
99 | ; store the fms document number (receipt already marked processed/
|
---|
100 | ; closed at the top of the routine just before posting the dollars.
|
---|
101 | D MARKPROC^RCDPUREC(RCRECTDA,$P(RESULT,"^",2))
|
---|
102 | I RCEFT=2 D MSG("No 215 report generated for this receipt",RCSCREEN,"!!") G Q215
|
---|
103 | ;
|
---|
104 | ;
|
---|
105 | 215 ; === print 215 report ===
|
---|
106 | I $G(RCSCREEN) D MSG("Queuing 215 report...",RCSCREEN,"!!")
|
---|
107 | N DEVICE
|
---|
108 | S DEVICE=$$OPTCK^RCDPRPL2("215REPORT",3)
|
---|
109 | I DEVICE="" D:$G(RCSCREEN) MSG(" Use Customize Option to set up the default printer.",RCSCREEN) Q
|
---|
110 | ;
|
---|
111 | S ZTIO=DEVICE,ZTDTH=$H,ZTRTN="DQ^RCDPR215",ZTSAVE("RECEIPDA")=RCRECTDA,ZTSAVE("RCTYPE")="A"
|
---|
112 | D ^%ZTLOAD,^%ZISC
|
---|
113 | Q215 I $G(RCSCREEN) D MSG(" Done.",RCSCREEN)
|
---|
114 | Q
|
---|
115 | ;
|
---|
116 | UPDERA(RCERA) ; Update detail posted status for ERA entry RCERA
|
---|
117 | ;
|
---|
118 | N DA,DIE,DR
|
---|
119 | S DA=+$G(RCERA),DR=".14////1",DIE="^RCY(344.4," D:DA ^DIE
|
---|
120 | Q
|
---|
121 | ;
|
---|
122 | MSG(RCMSG,RCSCREEN,PRELINE,POSTLINE) ; Write message or set into msg array
|
---|
123 | ; RCMSG = text to write RCSCREEN = screen flag
|
---|
124 | ; PRELINE = the line feeds to print before the text
|
---|
125 | ; POSTLINE = the line feeds to print after the text
|
---|
126 | Q:'RCSCREEN
|
---|
127 | N RCPRE,RCPOST,Z
|
---|
128 | S RCPRE=$L($G(PRELINE),"!")-1,RCPOST=$L($G(POSTLINE),"!")-1
|
---|
129 | I RCSCREEN=1 D G MSGQ
|
---|
130 | . F Z=1:1:RCPRE W !
|
---|
131 | . W RCMSG
|
---|
132 | . F Z=1:1:RCPOST W !
|
---|
133 | F Z=1:1:RCPRE S ^TMP($J,"RCDPEMSG",+$O(^TMP("RCDPEMSG",""),-1)+1)=""
|
---|
134 | S ^TMP($J,"RCDPEMSG",+$O(^TMP("RCDPEMSG",""),-1)+1)=RCMSG
|
---|
135 | F Z=1:1:RCPOST S ^TMP($J,"RCDPEMSG",+$O(^TMP("RCDPEMSG",""),-1)+1)=""
|
---|
136 | MSGQ Q
|
---|
137 | ;
|
---|
138 | EDIT4(DA,DR,RCDR1,RCDR2,RCDR3) ; Modify DR string for type of payment edit
|
---|
139 | ; for EDI Lockbox
|
---|
140 | ; Input: DA,DR Output: RCDR1,RCDR2,RCDR3
|
---|
141 | ; If type unchanged, or neither old/new are EDI Lockbox, no chk needed
|
---|
142 | ; If old type is EDI Lockbox and scratch pad exists, no change allowed
|
---|
143 | ; If changed to EDI Lockbox and detail already exists, no chg allowed
|
---|
144 | ; If changed to EDI Lockbox, ask for related EFT
|
---|
145 | N Z,Z0,RCSTRT,RCLST,RCDR,RCOE,RCNE,RCNO,RCM,RCM1,RCM2,RCM3,RCO4,RCN4,RCP,DIPA
|
---|
146 | S (RCDR1,RCDR2,RCDR3)=""
|
---|
147 | ;
|
---|
148 | S RCP=10 F Z=2:1 Q:DR'[("@"_RCP)&(DR'[("@"_(RCP+1)))&(DR'[("@"_(RCP+2)))&(DR'[("@"_(RCP+3)))&(DR'[("@"_(RCP+4))) S RCP=RCP*Z
|
---|
149 | ;
|
---|
150 | S Z=$L(DR,".04;"),RCSTRT=1,RCLST=Z
|
---|
151 | I Z>2 D ; Find .04, not n.04
|
---|
152 | . F S Z0=$P(DR,".04;",RCSTRT) Q:Z0=""!'$E(Z0,$L(Z0)) S RCSTRT=RCSTRT+1
|
---|
153 | ;
|
---|
154 | ; If unchanged/changed from/to other than EDI Lockbox, jump over edits
|
---|
155 | S RCDR1="S RCP="_RCP_" D SETV^RCDPURE1;"_$P(DR,".04;",1,RCSTRT)
|
---|
156 | S RCDR2="@"_RCP_";.04;S RCNO=0,RCN4=X D TYP^RCDPUREC(.Y);.17////^S X=RCNE;S Y=""@"_(RCP+2)_""""
|
---|
157 | ; Reset field .04 and .17 if not a valid type change
|
---|
158 | S RCDR2=RCDR2_";@"_(RCP+1)_";.04////^S X=RCO4;I RCOE="""" S Y=""@"_(RCP+3)_""";.17////^S X=RCOE;@"_(RCP+3)_";W !,*7,$S(RCO4=14:$S('RCNO:RCM1,1:RCM2),1:RCM) S Y=""@"_RCP_""";@"_(RCP+2)
|
---|
159 | S RCDR3=$P(DR,".04;",RCSTRT+1,RCLST)
|
---|
160 | Q
|
---|
161 | ;
|
---|
162 | SETV ; Set up variables needed to edit change of receipt type
|
---|
163 | S DIPA("RCPT")=$G(^RCY(344,DA,0)),RCO4=$P(DIPA("RCPT"),U,4),RCOE=$P(DIPA("RCPT"),U,17)
|
---|
164 | S RCM="EDI Lockbox payment type is invalid for this receipt",RCM1="Payment type can't be changed once detail has been loaded from the ERA",RCM2="Must have an EFT for an EFT Lockbox payment type"
|
---|
165 | S RCM3=">>If receipt is for an ERA and a paper check, select the ERA now"
|
---|
166 | Q
|
---|
167 | ;
|
---|
168 | WL(DA) ; Function returns 0 if the worklist did not create the receipt
|
---|
169 | ; or the ien of the worklist entry if it did (344.4 and 344.49 are DINUMED)
|
---|
170 | N Z
|
---|
171 | S Z=+$O(^RCY(344.4,"AREC",DA,0))
|
---|
172 | Q Z
|
---|
173 | ;
|
---|
174 | HAC(RC) ; Returns 1 if the receipt in RC is related to a HAC EFT
|
---|
175 | N Z,HAC
|
---|
176 | S HAC=0
|
---|
177 | ; ERA related to an EFT detail record
|
---|
178 | S Z=+$G(^RCY(344.31,+$P($G(^RCY(344,RC,0)),U,17),0))
|
---|
179 | ; Deposit # in EFT transmission starts with HAC
|
---|
180 | I Z S Z=$P($G(^RCY(344.3,+Z,0)),U,6) I $E(Z,1,3)="HAC" S HAC=1
|
---|
181 | Q HAC
|
---|
182 | ;
|
---|