| [613] | 1 | IBCEMCA1 ;ALB/ESG - Multiple CSA Message Management - Actions ;20-SEP-2005 | 
|---|
|  | 2 | ;;2.0;INTEGRATED BILLING;**320**;21-MAR-1994 | 
|---|
|  | 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
|  | 4 | ; | 
|---|
|  | 5 | Q | 
|---|
|  | 6 | REVSTAT ; change review status | 
|---|
|  | 7 | NEW DIR,X,Y,DA,DIRUT,DIROUT,DTOUT,DUOUT,NS,IBRVUST,IBFNRVAC,IBRVCMT | 
|---|
|  | 8 | NEW DIC,DWLW,DWPK,DIWESUB,DIWETXT,LN,IBDA,IBOLD,DIE,DA,DR | 
|---|
|  | 9 | D FULL^VALM1 | 
|---|
|  | 10 | S NS=+$G(^TMP($J,"IBCEMCL",4)) | 
|---|
|  | 11 | I 'NS D  G REVSTATX | 
|---|
|  | 12 | . W !!?5,"There are no selected messages." D PAUSE^VALM1 | 
|---|
|  | 13 | . Q | 
|---|
|  | 14 | ; | 
|---|
|  | 15 | W !!?5,"Number of messages selected:  ",NS,! | 
|---|
|  | 16 | ; | 
|---|
|  | 17 | ; reader call for the new review status field | 
|---|
|  | 18 | S DIR(0)="361,.09" | 
|---|
|  | 19 | S DIR("A")="Enter the REVIEW STATUS for the selected message"_$S(NS>1:"s",1:"") | 
|---|
|  | 20 | D ^DIR K DIR | 
|---|
|  | 21 | I $D(DIRUT) G REVSTATX | 
|---|
|  | 22 | M IBRVUST=Y | 
|---|
|  | 23 | I IBRVUST'=2 G RVCQ    ; skip down to the confirmation | 
|---|
|  | 24 | ; | 
|---|
|  | 25 | RSQ2 ; Reader call for the final review action field | 
|---|
|  | 26 | W ! | 
|---|
|  | 27 | S DIR(0)="361,.1" | 
|---|
|  | 28 | S DIR("A")="Enter the FINAL REVIEW ACTION for the selected message"_$S(NS>1:"s",1:"") | 
|---|
|  | 29 | D ^DIR K DIR | 
|---|
|  | 30 | I X="",Y="" W !!?5,"This field is required when the review has been completed." G RSQ2 | 
|---|
|  | 31 | I $D(DIRUT) G REVSTATX | 
|---|
|  | 32 | M IBFNRVAC=Y | 
|---|
|  | 33 | ; | 
|---|
|  | 34 | RSQ3 ; review comment text | 
|---|
|  | 35 | W ! | 
|---|
|  | 36 | K ^TMP($J,"IBCEMCA1-COMMENTS"),IBRVCMT | 
|---|
|  | 37 | S DIC="^TMP($J,""IBCEMCA1-COMMENTS""," | 
|---|
|  | 38 | S DWLW=75,DWPK=1,DIWESUB="REVIEW COMMENTS" | 
|---|
|  | 39 | S DIWETXT="These comments are optional" | 
|---|
|  | 40 | I IBFNRVAC="O" S DIWETXT="These comments are required because OTHER ACTION was selected." | 
|---|
|  | 41 | D EN^DIWE | 
|---|
|  | 42 | M IBRVCMT=^TMP($J,"IBCEMCA1-COMMENTS") | 
|---|
|  | 43 | K ^TMP($J,"IBCEMCA1-COMMENTS") | 
|---|
|  | 44 | I IBFNRVAC="O",'$D(IBRVCMT(0)) D  G RSQ3 | 
|---|
|  | 45 | . W !!?5,"Comments are required when the Final Review Action is OTHER ACTION." | 
|---|
|  | 46 | . D PAUSE^VALM1 | 
|---|
|  | 47 | . Q | 
|---|
|  | 48 | I $P($G(IBRVCMT(0)),U,4) S IBRVCMT=$P($G(IBRVCMT(0)),U,4) | 
|---|
|  | 49 | ; | 
|---|
|  | 50 | RVCQ ; display a summary of the user responses and get confirmation | 
|---|
|  | 51 | W !!,"  Number of selected",!,"     Status Messages:  ",NS | 
|---|
|  | 52 | W !?7,"Review Status:  ",$G(IBRVUST(0)) | 
|---|
|  | 53 | I IBRVUST=2 D | 
|---|
|  | 54 | . W !," Final Review Action:  ",$G(IBFNRVAC(0)) | 
|---|
|  | 55 | . W !?5,"Review Comments:  " | 
|---|
|  | 56 | . I '$D(IBRVCMT(0)) W "<none>" | 
|---|
|  | 57 | . E  S LN=0 F  S LN=$O(IBRVCMT(LN)) Q:'LN  W !?5,IBRVCMT(LN,0) | 
|---|
|  | 58 | . Q | 
|---|
|  | 59 | W ! | 
|---|
|  | 60 | S DIR(0)="YO" | 
|---|
|  | 61 | S DIR("A")="OK to proceed",DIR("B")="No" | 
|---|
|  | 62 | D ^DIR K DIR | 
|---|
|  | 63 | I Y'=1 G REVSTATX | 
|---|
|  | 64 | ; | 
|---|
|  | 65 | ; Loop thru selected status messages and update them | 
|---|
|  | 66 | S IBDA=0 | 
|---|
|  | 67 | F  S IBDA=$O(^TMP($J,"IBCEMCL",4,1,IBDA)) Q:'IBDA  D | 
|---|
|  | 68 | . S IBOLD=$P($G(^IBM(361,IBDA,0)),U,9)    ; old review status | 
|---|
|  | 69 | . S DIE=361,DA=IBDA | 
|---|
|  | 70 | . S DR=".09////"_IBRVUST | 
|---|
|  | 71 | . I $G(IBFNRVAC)'="" S DR=DR_";.1////"_$G(IBFNRVAC) | 
|---|
|  | 72 | . D ^DIE | 
|---|
|  | 73 | . I $D(IBRVCMT(0)) D NOTECHG^IBCECSA2(IBDA,0,.IBRVCMT,1) | 
|---|
|  | 74 | . I IBOLD'=IBRVUST D NOTECHG^IBCECSA2(IBDA,0) | 
|---|
|  | 75 | . L -^IBM(361,IBDA)       ; unlock | 
|---|
|  | 76 | . Q | 
|---|
|  | 77 | W "   ... Done!" | 
|---|
|  | 78 | ; | 
|---|
|  | 79 | ; rebuild the list | 
|---|
|  | 80 | KILL ^TMP($J,"IBCEMCA"),VALMHDR | 
|---|
|  | 81 | S VALMBG=1 | 
|---|
|  | 82 | D INIT^IBCEMCL | 
|---|
|  | 83 | I $G(IBCSAMCS)=1 S IBCSAMCS=2   ; flag to rebuild CSA | 
|---|
|  | 84 | ; | 
|---|
|  | 85 | REVSTATX ; | 
|---|
|  | 86 | S VALMBCK="R" | 
|---|
|  | 87 | Q | 
|---|
|  | 88 | ; | 
|---|
|  | 89 | COMMENT ; enter review comments | 
|---|
|  | 90 | NEW NS,DIR,X,Y,DTOUT,DUOUT,DIRUT,DIROUT,IBRVCMT,DIC,DWLW,DWPK,DIWESUB,IBDA,LN | 
|---|
|  | 91 | D FULL^VALM1 | 
|---|
|  | 92 | S NS=+$G(^TMP($J,"IBCEMCL",4)) | 
|---|
|  | 93 | I 'NS D  G COMMX | 
|---|
|  | 94 | . W !!?5,"There are no selected messages." D PAUSE^VALM1 | 
|---|
|  | 95 | . Q | 
|---|
|  | 96 | ; | 
|---|
|  | 97 | W !!?5,"Number of messages selected:  ",NS,! | 
|---|
|  | 98 | ; | 
|---|
|  | 99 | S DIR(0)="YO",DIR("B")="Yes" | 
|---|
|  | 100 | S DIR("A")="Do you want to add a new Review Comment for all of these messages" | 
|---|
|  | 101 | I NS=1 S DIR("A")="Do you want to add a new Review Comment for this message" | 
|---|
|  | 102 | D ^DIR K DIR | 
|---|
|  | 103 | I Y'=1 G COMMX | 
|---|
|  | 104 | ; | 
|---|
|  | 105 | ; review comment text | 
|---|
|  | 106 | W ! | 
|---|
|  | 107 | K ^TMP($J,"IBCEMCA1-COMMENTS"),IBRVCMT | 
|---|
|  | 108 | S DIC="^TMP($J,""IBCEMCA1-COMMENTS""," | 
|---|
|  | 109 | S DWLW=75,DWPK=1,DIWESUB="REVIEW COMMENTS" | 
|---|
|  | 110 | D EN^DIWE | 
|---|
|  | 111 | M IBRVCMT=^TMP($J,"IBCEMCA1-COMMENTS") | 
|---|
|  | 112 | K ^TMP($J,"IBCEMCA1-COMMENTS") | 
|---|
|  | 113 | I $P($G(IBRVCMT(0)),U,4) S IBRVCMT=$P($G(IBRVCMT(0)),U,4) | 
|---|
|  | 114 | I '$D(IBRVCMT(0)) G COMMX    ; no comments entered | 
|---|
|  | 115 | ; | 
|---|
|  | 116 | ; final confirmation | 
|---|
|  | 117 | W ! | 
|---|
|  | 118 | S LN=0 F  S LN=$O(IBRVCMT(LN)) Q:'LN  W !?5,IBRVCMT(LN,0) | 
|---|
|  | 119 | W ! | 
|---|
|  | 120 | S DIR(0)="YO" | 
|---|
|  | 121 | S DIR("A")="OK to add this comment for all selected status messages",DIR("B")="No" | 
|---|
|  | 122 | I NS=1 S DIR("A")="OK to add this comment for the selected status message" | 
|---|
|  | 123 | D ^DIR K DIR | 
|---|
|  | 124 | I Y'=1 G COMMX | 
|---|
|  | 125 | ; | 
|---|
|  | 126 | ; Loop thru selected status messages and update them | 
|---|
|  | 127 | S IBDA=0 | 
|---|
|  | 128 | F  S IBDA=$O(^TMP($J,"IBCEMCL",4,1,IBDA)) Q:'IBDA  D | 
|---|
|  | 129 | . D NOTECHG^IBCECSA2(IBDA,0,.IBRVCMT,1) | 
|---|
|  | 130 | . L -^IBM(361,IBDA)       ; unlock | 
|---|
|  | 131 | . Q | 
|---|
|  | 132 | W "   ... Done!" | 
|---|
|  | 133 | ; | 
|---|
|  | 134 | ; rebuild the list | 
|---|
|  | 135 | KILL ^TMP($J,"IBCEMCA"),VALMHDR | 
|---|
|  | 136 | S VALMBG=1 | 
|---|
|  | 137 | D INIT^IBCEMCL | 
|---|
|  | 138 | ; | 
|---|
|  | 139 | COMMX ; | 
|---|
|  | 140 | S VALMBCK="R" | 
|---|
|  | 141 | Q | 
|---|
|  | 142 | ; | 
|---|
|  | 143 | RETRAN ; retransmit claims | 
|---|
|  | 144 | NEW NS,IBIFN,NSC,DIR,X,Y,DUOUT,DTOUT,DIRUT,DIROUT,IBDA,IB364 | 
|---|
|  | 145 | D FULL^VALM1 | 
|---|
|  | 146 | S NS=+$G(^TMP($J,"IBCEMCL",4)) | 
|---|
|  | 147 | I 'NS D  G RETRANX | 
|---|
|  | 148 | . W !!?5,"There are no selected messages." D PAUSE^VALM1 | 
|---|
|  | 149 | . Q | 
|---|
|  | 150 | ; | 
|---|
|  | 151 | ; count number of claims too | 
|---|
|  | 152 | S IBIFN=0 F NSC=0:1 S IBIFN=$O(^TMP($J,"IBCEMCL",4,2,IBIFN)) Q:'IBIFN | 
|---|
|  | 153 | ; | 
|---|
|  | 154 | W !!?5,"Number of messages selected:  ",NS | 
|---|
|  | 155 | W !?7,"Number of claims selected:  ",NSC,! | 
|---|
|  | 156 | ; | 
|---|
|  | 157 | S DIR("A",1)="In order to retransmit these claims, the transmission status for all of these" | 
|---|
|  | 158 | S DIR("A",2)="claims will be reset to be ""READY FOR EXTRACT"".  These claims will then be" | 
|---|
|  | 159 | S DIR("A",3)="sent with the next regularly scheduled claims transmission process." | 
|---|
|  | 160 | S DIR("A",4)="" | 
|---|
|  | 161 | S DIR("A")="Do you want to retransmit these claims" | 
|---|
|  | 162 | I NSC=1 D | 
|---|
|  | 163 | . S DIR("A",1)="In order to retransmit this claim, the transmission status for this claim will" | 
|---|
|  | 164 | . S DIR("A",2)="be reset to be ""READY FOR EXTRACT"".  This claim will then be sent with the" | 
|---|
|  | 165 | . S DIR("A",3)="next regularly scheduled claims transmission process." | 
|---|
|  | 166 | . S DIR("A")="Do you want to retransmit this claim" | 
|---|
|  | 167 | . Q | 
|---|
|  | 168 | S DIR(0)="YO",DIR("B")="No" D ^DIR K DIR | 
|---|
|  | 169 | I Y'=1 G RETRANX | 
|---|
|  | 170 | ; | 
|---|
|  | 171 | ; Loop thru selected claims and add new transmission records in a | 
|---|
|  | 172 | ; "Ready to Extract" status | 
|---|
|  | 173 | S IBIFN=0 | 
|---|
|  | 174 | F  S IBIFN=$O(^TMP($J,"IBCEMCL",4,2,IBIFN)) Q:'IBIFN  D | 
|---|
|  | 175 | . S IBDA=+$O(^TMP($J,"IBCEMCL",4,2,IBIFN,""),-1)  ; most recent 361 ien | 
|---|
|  | 176 | . S IB364=+$P($G(^IBM(361,IBDA,0)),U,11)          ; transmit bill 364 ien | 
|---|
|  | 177 | . I 'IBDA!'IB364 Q | 
|---|
|  | 178 | . D UPDEDI^IBCEM(IB364,"R")        ; update EDI files for transmission | 
|---|
|  | 179 | . S Y=$$ADDTBILL^IBCB1(IBIFN,1)    ; add new transmission record | 
|---|
|  | 180 | . Q | 
|---|
|  | 181 | W "   ... Done!" | 
|---|
|  | 182 | ; | 
|---|
|  | 183 | ; rebuild the list | 
|---|
|  | 184 | KILL ^TMP($J,"IBCEMCA"),VALMHDR | 
|---|
|  | 185 | S VALMBG=1 | 
|---|
|  | 186 | D UNLOCK^IBCEMCL | 
|---|
|  | 187 | D INIT^IBCEMCL | 
|---|
|  | 188 | I $G(IBCSAMCS)=1 S IBCSAMCS=2   ; flag to rebuild CSA | 
|---|
|  | 189 | ; | 
|---|
|  | 190 | RETRANX ; | 
|---|
|  | 191 | S VALMBCK="R" | 
|---|
|  | 192 | Q | 
|---|
|  | 193 | ; | 
|---|