| [623] | 1 | IBCEM4 ;ALB/TMP - IB ELECTRONIC MESSAGE SCREEN TEXT MAINT ;19-APR-2001 | 
|---|
|  | 2 | ;;2.0;INTEGRATED BILLING;**137**;21-MAR-1994 | 
|---|
|  | 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
|  | 4 | ; | 
|---|
|  | 5 | EN ; entry point for maintenance | 
|---|
|  | 6 | D EN^VALM("IBCE MESSAGE TEXT MAIN") | 
|---|
|  | 7 | Q | 
|---|
|  | 8 | ; | 
|---|
|  | 9 | HDR ; Header code | 
|---|
|  | 10 | K VALMHDR | 
|---|
|  | 11 | Q | 
|---|
|  | 12 | ; | 
|---|
|  | 13 | INIT ; Build list of text entries | 
|---|
|  | 14 | N Z,Z0 | 
|---|
|  | 15 | S (IBCNT,VALMCNT)=0,VALMBG=1 | 
|---|
|  | 16 | K ^TMP("IBCEMSGT",$J) | 
|---|
|  | 17 | S Z="" F  S Z=$O(^IBE(361.3,"AC",Z),-1) Q:Z=""  D SET(Z) S Z0="" F  S Z0=$O(^IBE(361.3,"AC",Z,Z0)) Q:Z0=""  D SET(Z,Z0) | 
|---|
|  | 18 | Q | 
|---|
|  | 19 | ; | 
|---|
|  | 20 | EXIT ; -- Clean up list | 
|---|
|  | 21 | K ^TMP("IBCEMSGT",$J) | 
|---|
|  | 22 | D CLEAN^VALM10 | 
|---|
|  | 23 | Q | 
|---|
|  | 24 | ; | 
|---|
|  | 25 | SET(Z,Z0) ; Set data into display global | 
|---|
|  | 26 | N X,IB | 
|---|
|  | 27 | S IBCNT=IBCNT+1,X="",IB="" | 
|---|
|  | 28 | S:$G(Z0)'="" Z0="    "_Z0 | 
|---|
|  | 29 | I $G(Z0)="" D | 
|---|
|  | 30 | . S Z0=$S('Z:"*** DO NOT REQUIRE REVIEW ***",1:"*** REQUIRE REVIEW ***"),IB=$J("",(80-$L(Z0))\2),Z0=IB_Z0 | 
|---|
|  | 31 | . I 'Z D SET(Z," ") | 
|---|
|  | 32 | I Z0'="" S X=$$SETFLD^VALM1(Z0,X,"TEXT") | 
|---|
|  | 33 | S VALMCNT=VALMCNT+1,^TMP("IBCEMSGT",$J,VALMCNT,0)=X | 
|---|
|  | 34 | S ^TMP("IBCEMSGT",$J,"IDX",VALMCNT,IBCNT)="" | 
|---|
|  | 35 | I IB'="" D CNTRL^VALM10(VALMCNT,2+$L(IB),$L(Z0)-$L(IB),IORVON,IORVOFF) | 
|---|
|  | 36 | Q | 
|---|
|  | 37 | EDIT ; Add/edit message text | 
|---|
|  | 38 | N DA,DIC,DLAYGO,DIE,DR,DIR,X,Y,IBUPD,IBSTOP,IBY | 
|---|
|  | 39 | D FULL^VALM1 | 
|---|
|  | 40 | S (IBSTOP,IBUPD)=0 | 
|---|
|  | 41 | F  D  Q:IBSTOP | 
|---|
|  | 42 | . S DIC(0)="AELMQ",DLAYGO=361.3,DIC="^IBE(361.3,",DIC("DR")="@1;.02;I X="""" W !,""MUST HAVE A VALUE FOR THIS FIELD"" S Y=""@1""" W ! D ^DIC | 
|---|
|  | 43 | . S IBY=Y | 
|---|
|  | 44 | . I IBY'>0 S IBSTOP=1 Q | 
|---|
|  | 45 | . I $P(IBY,U,3) S IBUPD=1 Q | 
|---|
|  | 46 | . S DIC="^IBE(361.3,",DA=+IBY W ! D EN^DIQ W ! | 
|---|
|  | 47 | . S DIE="^IBE(361.3,",DA=+IBY,DR=".01" D ^DIE ; edit | 
|---|
|  | 48 | . I '$D(^IBE(361.3,+IBY,0)) S IBUPD=1 Q | 
|---|
|  | 49 | . I $P(IBY,U,2)'=$P(^IBE(361.3,+IBY,0),U) S IBUPD=1,DIE="^IBE(361.3,",DR=".05////"_$G(DUZ)_";.06///^S X=""NOW""" D ^DIE | 
|---|
|  | 50 | D:IBUPD INIT | 
|---|
|  | 51 | S VALMBCK="R" | 
|---|
|  | 52 | Q | 
|---|
|  | 53 | ; | 
|---|
|  | 54 | CKREVU(IBTEXT,IBNR,IBSKIP,IBREV) ; Check IBTEXT contains 'no review | 
|---|
|  | 55 | ;        needed' text | 
|---|
|  | 56 | ; IBNR = returned if passed by reference - 'no review needed' text found | 
|---|
|  | 57 | ; IBSKIP = 1 if no check needed for 'always review' | 
|---|
|  | 58 | ; IBREV = returned if passed by reference and 'review always needed' | 
|---|
|  | 59 | ;         text found | 
|---|
|  | 60 | ; | 
|---|
|  | 61 | N T,Y,Z,Z0 | 
|---|
|  | 62 | S (IBREV,Y)=0,Z="" | 
|---|
|  | 63 | I '$G(IBSKIP) F  S Z=$O(^IBE(361.3,"AC",1,Z)) Q:Z=""  I IBTEXT[Z S IBREV=1 Q  ; Always review messages with this text | 
|---|
|  | 64 | I 'IBREV S Z="" F  S Z=$O(^IBE(361.3,"AC",0,Z)) Q:Z=""  I IBTEXT[Z S Y=1,IBNR=Z Q  ; Message contains text to make review unnecessary | 
|---|
|  | 65 | Q Y | 
|---|
|  | 66 | ; | 
|---|
|  | 67 | REPORT ; Produce a report of messages filed without review by user-selected | 
|---|
|  | 68 | ; date range for date received and sort by either bill# or message text | 
|---|
|  | 69 | N IBFR,IBTO,IBSORT,DIR,DA,DR,X,Y,ZTSAVE,ZTRTN,ZTDESC,ZTREQ | 
|---|
|  | 70 | R1 S DIR("A")="FROM DATE RECEIVED: ",DIR(0)="DA^:"_DT_"::PAXE" D ^DIR K DIR | 
|---|
|  | 71 | Q:$D(DTOUT)!$D(DUOUT) | 
|---|
|  | 72 | S IBFR=Y W "   ",$G(Y(0)) | 
|---|
|  | 73 | R2 S DIR("A")="TO DATE RECEIVED: ",DIR(0)="DAO^"_IBFR_":"_DT_"::PAE" D ^DIR K DIR | 
|---|
|  | 74 | Q:$D(DTOUT)!$D(DUOUT) | 
|---|
|  | 75 | I Y'>0 W ! G R1 | 
|---|
|  | 76 | S IBTO=Y W "   ",$G(Y(0)) | 
|---|
|  | 77 | S DIR("A")="SORT BY",DIR(0)="SXBO^B:Bill #;M:Message Screen Text",DIR("B")="B" D ^DIR K DIR | 
|---|
|  | 78 | Q:$D(DTOUT)!$D(DUOUT) | 
|---|
|  | 79 | I (Y="")!("BM"'[Y) W ! G R2 | 
|---|
|  | 80 | S IBSORT=Y | 
|---|
|  | 81 | S %ZIS="QM" D ^%ZIS Q:POP | 
|---|
|  | 82 | I $D(IO("Q")) K IO("Q") S ZTRTN="ENRPT^IBCEM4",ZTSAVE("IB*")="",ZTDESC="IB - MESSAGES FILED WITHOUT REVIEW REPORT" D ^%ZTLOAD K ZTSK D HOME^%ZIS Q | 
|---|
|  | 83 | U IO | 
|---|
|  | 84 | ENRPT ; Queued job entrypoint | 
|---|
|  | 85 | N IB,IB0,IBDA,IB00,IB1,IBS1,IBPAGE,IBLINES,IBHDRDT,IBSB,IBSTOP,DIR,Y,X,Z | 
|---|
|  | 86 | W:$E(IOST,1,2)["C-" @IOF ;Only initial form feed for print to screen | 
|---|
|  | 87 | K ^TMP($J,"IBSORT") | 
|---|
|  | 88 | S IB=IBFR-.000001 | 
|---|
|  | 89 | F  S IB=$O(^IBM(361,"ARD",IB)) Q:'IB!$G(ZTSTOP)  S IBDA=0 F  S IBDA=$O(^IBM(361,"ARD",IB,IBDA)) Q:'IBDA!$G(ZTSTOP)  S IB0=$G(^IBM(361,IBDA,0)) Q:IB0=""!'$P(IB0,U,14)  D | 
|---|
|  | 90 | . I $D(ZTQUEUED) Q:$$STOP(.ZTREQ,.ZTSTOP) | 
|---|
|  | 91 | . S IBS1="" | 
|---|
|  | 92 | . I IBSORT="M" D  ; Find text that caused auto-file | 
|---|
|  | 93 | .. S Z=0 F  S Z=$O(^IBM(361,IBDA,1,Z)) Q:'Z  I $$CKREVU($G(^IBM(361,IBDA,1,Z,0)),.IBS1,1) Q | 
|---|
|  | 94 | .. I IBS1="" S IBS1="??" | 
|---|
|  | 95 | . I IBSORT="B" S IBS1=$P($G(^DGCR(399,+IB0,0)),U) | 
|---|
|  | 96 | . I IBS1'="" S ^TMP($J,"IBSORT",IBS1,IBDA)=IB0 | 
|---|
|  | 97 | S IBHDRDT=$$FMTE^XLFDT($$NOW^XLFDT(),"2P") | 
|---|
|  | 98 | S (IBSTOP,IBLINES,IBPAGE)=0 | 
|---|
|  | 99 | S IB1=1,IB="" F  S IB=$O(^TMP($J,"IBSORT",IB)) Q:IB=""!$G(ZTSTOP)  D  Q:IBSTOP | 
|---|
|  | 100 | . S IBSB=$S(IBSORT="M":"MESSAGE SCREEN TEXT: "_IB,1:"") | 
|---|
|  | 101 | . I IBSB'="" S IBSB=$J("",(80-$L(IBSB)\2))_IBSB | 
|---|
|  | 102 | . D:IB1 RHDR(IBSB,.IBSTOP) Q:IBSTOP | 
|---|
|  | 103 | . I 'IB1,IBSORT="M" D  Q:IBSTOP | 
|---|
|  | 104 | .. I IBLINES>(IOSL-5) D RHDR(IBSB,.IBSTOP) Q | 
|---|
|  | 105 | .. W !!,IBSB,! S IBLINES=IBLINES+3 | 
|---|
|  | 106 | . S (IB1,IBDA)=0 F  S IBDA=$O(^TMP($J,"IBSORT",IB,IBDA)) Q:'IBDA!$G(ZTSTOP)  D  Q:IBSTOP | 
|---|
|  | 107 | .. I $D(ZTQUEUED),$$STOP(.ZTREQ,.ZTSTOP) W !,"*********** REPORT STOPPED BEFORE IT COMPLETED!!! ***********" Q | 
|---|
|  | 108 | .. S IB0=$G(^TMP($J,"IBSORT",IB,IBDA)),IB00=$G(^DGCR(399,+IB0,0)) | 
|---|
|  | 109 | .. I $G(IBLINES)>(IOSL-5) D RHDR("",.IBSTOP) Q:IBSTOP | 
|---|
|  | 110 | .. W !,$E($$BN1^PRCAFN(+IB0)_$J("",10),1,10),"  ",$E($P($G(^DPT(+$P(IB00,U,2),0)),U)_$J("",25),1,25)_"  "_$E($$FMTE^XLFDT($P(IB00,U,3),"2D")_$J("",8),1,8)_"  "_$E($$FMTE^XLFDT($P(IB0,U,2),"2D")_$J("",8),1,8)_"  " | 
|---|
|  | 111 | .. W $E($P($G(^DIC(36,+$$POLICY^IBCEF(+IB0,1,$P(IB0,U,7)),0)),U),1,20) | 
|---|
|  | 112 | .. S IBLINES=IBLINES+1 | 
|---|
|  | 113 | .. I $G(IBLINES)>(IOSL-5) D RHDR("",.IBSTOP) Q:IBSTOP | 
|---|
|  | 114 | .. S Z=0 F  S Z=$O(^IBM(361,IBDA,1,Z)) Q:'Z  D  Q:IBSTOP | 
|---|
|  | 115 | ... N Z0,Z1 | 
|---|
|  | 116 | ... S Z0=$G(^IBM(361,IBDA,1,Z,0)) | 
|---|
|  | 117 | ... F Z1=1:75:$L(Z0) D:$G(IBLINES)>(IOSL-5) RHDR("",.IBSTOP) Q:IBSTOP  W !,?5,$E(Z0,Z1,Z1+74) S IBLINES=IBLINES+1 | 
|---|
|  | 118 | G:IBSTOP!$G(ZTSTOP) ENSTOP | 
|---|
|  | 119 | I $G(IB1) D RHDR("") W !,"NO RECORDS MATCHING SEARCH CRITERIA WERE FOUND",! | 
|---|
|  | 120 | ; | 
|---|
|  | 121 | I $E(IOST,1,2)["C-"  K DIR S DIR(0)="E" D ^DIR K DIR | 
|---|
|  | 122 | ENSTOP I '$D(ZTQUEUED) D ^%ZISC | 
|---|
|  | 123 | I $D(ZTQUEUED),'$G(ZTSTOP) S ZTREQ="@" | 
|---|
|  | 124 | K ^TMP($J,"IBSORT") | 
|---|
|  | 125 | Q | 
|---|
|  | 126 | ; | 
|---|
|  | 127 | RHDR(IBSB,IBSTOP) ; Report header | 
|---|
|  | 128 | ; IBSB'="" if sub header should print | 
|---|
|  | 129 | N Z,DIR,X,Y | 
|---|
|  | 130 | S IBPAGE=IBPAGE+1 | 
|---|
|  | 131 | I IBPAGE>1,$E(IOST,1,2)["C-" S DIR(0)="E" D ^DIR K DIR I $D(DTOUT)!$D(DUOUT) S IBSTOP=1 G RHDRQ | 
|---|
|  | 132 | W !,@IOF | 
|---|
|  | 133 | W !,?22,"MESSAGES FILED WITHOUT REVIEW REPORT",?65,"PAGE: ",IBPAGE | 
|---|
|  | 134 | S Z="RUN DATE: "_IBHDRDT W !,?(80-$L(Z)\2),Z | 
|---|
|  | 135 | S Z="DATE RECEIVED RANGE: "_$$FMTE^XLFDT(IBFR,"2D")_"-"_$$FMTE^XLFDT(IBTO,"2D") W !,?(80-$L(Z)\2),Z,! | 
|---|
|  | 136 | W !,$J("",40),"EVENT      DATE" | 
|---|
|  | 137 | W !,"BILL #      PATIENT NAME"_$J("",15)_" DATE     RECEIVED  INSURANCE CO",! | 
|---|
|  | 138 | S Z="",$P(Z,"-",81)="" W Z | 
|---|
|  | 139 | S IBLINES=7 | 
|---|
|  | 140 | I $G(IBSB)'="" W !,IBSB,! S IBLINES=IBLINES+2 | 
|---|
|  | 141 | RHDRQ Q | 
|---|
|  | 142 | ; | 
|---|
|  | 143 | STOP(IBSTOP,IBREQ) ; Check for job being stopped | 
|---|
|  | 144 | I $$S^%ZTLOAD S IBSTOP=1 K IBREQ | 
|---|
|  | 145 | Q $G(IBSTOP) | 
|---|
|  | 146 | ; | 
|---|