| 1 | IBCNRPSI ;BHAM ISC/ALA - Group Plan Status Inquiry ;14-NOV-2003
 | 
|---|
| 2 |  ;;2.0;INTEGRATED BILLING;**276**;21-MAR-94
 | 
|---|
| 3 |  ;;Per VHA Directive 10-93-142, this routine should not be modified.
 | 
|---|
| 4 |  ;
 | 
|---|
| 5 |  ;**Program Description**
 | 
|---|
| 6 |  ;  This program select an insurance company and displays group plans 
 | 
|---|
| 7 |  ; (All, Pharmacy covered or Matched) for that insurance company
 | 
|---|
| 8 |  Q
 | 
|---|
| 9 |  ;
 | 
|---|
| 10 | EN ; Select an insurance company (inquiry entry point)
 | 
|---|
| 11 |  S IBCNRRPT=""
 | 
|---|
| 12 | EN0 ;
 | 
|---|
| 13 |  S DIR(0)="350.9,4.06"
 | 
|---|
| 14 |  S DIR("A")="Select INSURANCE COMPANY",DIR("??")="^D ADH^IBCNSM3"
 | 
|---|
| 15 |  S DIR("?")="Select the Insurance Company for the plan you are entering"
 | 
|---|
| 16 |  D ^DIR K DIR S IBCNSP=+Y I Y<1 G EXIT
 | 
|---|
| 17 |  I $P($G(^DIC(36,+IBCNSP,0)),"^",2)="N" W !,"This company does not reimburse.  "
 | 
|---|
| 18 |  I $P($G(^DIC(36,+IBCNSP,0)),"^",5) W !,*7,"Warning: Inactive Company" H 3 K IBCNSP G EXIT
 | 
|---|
| 19 |  ;
 | 
|---|
| 20 | TYPE ; Prompt to allow users to inquire for All group plans, Pharmacy group
 | 
|---|
| 21 |  ; plans or Matched group plans
 | 
|---|
| 22 |  N DIR,DIRUT
 | 
|---|
| 23 |  ;
 | 
|---|
| 24 |  S DIR(0)="S^A:All Group Plans;P:Pharmacy Group Plans;M:Matched Group Plans"
 | 
|---|
| 25 |  S DIR("A")=" Select the type of Group Plans you want to see"
 | 
|---|
| 26 |  S DIR("B")="M"
 | 
|---|
| 27 |  S DIR("?",1)="  A - All Group Plans"
 | 
|---|
| 28 |  S DIR("?",2)="  P - Pharmacy Group Plans"
 | 
|---|
| 29 |  S DIR("?",3)="  M - Matched Group Plans"
 | 
|---|
| 30 |  D ^DIR K DIR
 | 
|---|
| 31 |  I $D(DIRUT) G TYPEX
 | 
|---|
| 32 |  S IBCNTYP=Y
 | 
|---|
| 33 |  ;
 | 
|---|
| 34 |  D EN^IBCNRPS2
 | 
|---|
| 35 |  ;
 | 
|---|
| 36 | TYPEX ; TYPE exit point
 | 
|---|
| 37 |  ;
 | 
|---|
| 38 | EXIT K IBCNSP,IBCPOL,IBIND,IBMULT,IBSEL,IBW,IBALR,IBGRP,IBCNGP
 | 
|---|
| 39 |  K IBCNRRPT,IBCNTYP,ZTDESC,ZTSTOP,X,Y
 | 
|---|
| 40 |  Q
 | 
|---|
| 41 |  ;
 | 
|---|
| 42 | PRINT ; Entry pt.
 | 
|---|
| 43 |  ;
 | 
|---|
| 44 |  ; Init vars
 | 
|---|
| 45 |  N CRT,MAXCNT,IBPGC,IBBDT,IBEDT,IBPY,IBPXT,IBSRT,IBDTL
 | 
|---|
| 46 |  N X,Y,DIR,DTOUT,DUOUT,LIN,TOTALS
 | 
|---|
| 47 |  D:'$D(IOF) HOME^%ZIS
 | 
|---|
| 48 |  ;
 | 
|---|
| 49 |  S (IBPXT,IBPGC)=0
 | 
|---|
| 50 |  ;
 | 
|---|
| 51 |  ; Determine IO parameters
 | 
|---|
| 52 |  I IOST["C-" S MAXCNT=IOSL-3,CRT=1
 | 
|---|
| 53 |  E  S MAXCNT=IOSL-6,CRT=0
 | 
|---|
| 54 |  ;
 | 
|---|
| 55 |  D PRINTDT(MAXCNT,IBPGC)
 | 
|---|
| 56 |  I $G(ZTSTOP)!IBPXT G EXIT3
 | 
|---|
| 57 |  I CRT,IBPGC>0,'$D(ZTQUEUED) D
 | 
|---|
| 58 |  . I MAXCNT<51 F LIN=1:1:(MAXCNT-$Y) W !
 | 
|---|
| 59 |  . S DIR(0)="E" D ^DIR K DIR
 | 
|---|
| 60 |  ;
 | 
|---|
| 61 | EXIT3 ; Exit pt
 | 
|---|
| 62 |  Q
 | 
|---|
| 63 |  ;
 | 
|---|
| 64 | PRINTDT(MAX,PGC) ; Print data
 | 
|---|
| 65 |  ;
 | 
|---|
| 66 |  ; Init vars
 | 
|---|
| 67 |  N EORMSG,NONEMSG,TOTDASHS,DISPDATA,SORT,CT,PRT1,PRT2
 | 
|---|
| 68 |  ;
 | 
|---|
| 69 |  S EORMSG="*** END OF REPORT ***"
 | 
|---|
| 70 |  S NONEMSG="* * * N O  D A T A  F O U N D * * *"
 | 
|---|
| 71 |  S $P(TOTDASHS,"=",89)=""
 | 
|---|
| 72 |  S CT=0
 | 
|---|
| 73 |  ;
 | 
|---|
| 74 |  ; Display lines of response
 | 
|---|
| 75 |  D LINE
 | 
|---|
| 76 |  K ^TMP("IBCNR",$J,"DSPDATA")
 | 
|---|
| 77 |  Q
 | 
|---|
| 78 | HEADER ; Print header info for each page
 | 
|---|
| 79 |  ; Assumes vars from PRINT: CRT,PGC,IBPXT,MAX,SRT,BDT,EDT,PYR,RDTL,MAR
 | 
|---|
| 80 |  ; Init vars
 | 
|---|
| 81 |  N DIR,X,Y,DTOUT,DUOUT,OFFSET,HDR,DASHES,DASHES2,LIN
 | 
|---|
| 82 |  ;
 | 
|---|
| 83 |  I CRT,PGC>0,'$D(ZTQUEUED) D  I IBPXT G HEADERX
 | 
|---|
| 84 |  . I MAX<51 F LIN=1:1:(MAX-$Y) W !
 | 
|---|
| 85 |  . S DIR(0)="E" D ^DIR K DIR
 | 
|---|
| 86 |  . I $D(DTOUT)!$D(DUOUT) S IBPXT=1 Q
 | 
|---|
| 87 |  I $D(ZTQUEUED),$$S^%ZTLOAD() S (ZTSTOP,IBPXT)=1 G HEADERX
 | 
|---|
| 88 |  S PGC=PGC+1
 | 
|---|
| 89 |  W @IOF,!,?1,"ePHARM GROUP PLAN STATUS INQUIRY"
 | 
|---|
| 90 |  S HDR=$$FMTE^XLFDT($$NOW^XLFDT,1)_"  Page: "_PGC
 | 
|---|
| 91 |  S OFFSET=80-$L(HDR)
 | 
|---|
| 92 |  W ?OFFSET,HDR
 | 
|---|
| 93 |  W !,?1,"Report for "_$S(IBCNTYP="A":"All",IBCNTYP="P":"Pharmacy Covered",1:"Matched")_" Group Plans for "_$$GET1^DIQ(36,IBCNSP_",",.01)
 | 
|---|
| 94 |  W !,?1,"Group Name",?20,"Group #",?38,"Plan Type",?52,"Plan ID"
 | 
|---|
| 95 |  W ?71,"Pln Stat"
 | 
|---|
| 96 |  S $P(DASHES,"=",80)=""
 | 
|---|
| 97 |  W !,?1,DASHES
 | 
|---|
| 98 |  ;
 | 
|---|
| 99 | HEADERX ; HEADER exit pt
 | 
|---|
| 100 |  Q
 | 
|---|
| 101 |  ;
 | 
|---|
| 102 | LINE ; Print line of data
 | 
|---|
| 103 |  ; Assumes vars from PRINT: PGC,IBPXT,MAX
 | 
|---|
| 104 |  ; Init vars
 | 
|---|
| 105 |  N CT,II
 | 
|---|
| 106 |  ;
 | 
|---|
| 107 |  S CT=+$O(^TMP("IBCNR",$J,"DSPDATA",""),-1)
 | 
|---|
| 108 |  I $Y+1+CT>MAX D HEADER I $G(ZTSTOP)!IBPXT G LINEX
 | 
|---|
| 109 |  F II=1:1:CT D  Q:$G(ZTSTOP)!IBPXT
 | 
|---|
| 110 |  . I $Y+1>MAX!('PGC) D HEADER I $G(ZTSTOP)!IBPXT Q
 | 
|---|
| 111 |  . W !,?1,^TMP("IBCNR",$J,"DSPDATA",II)
 | 
|---|
| 112 |  . Q
 | 
|---|
| 113 |  ;
 | 
|---|
| 114 | LINEX ; LINE exit pt
 | 
|---|
| 115 |  Q
 | 
|---|
| 116 | QUITX ;
 | 
|---|
| 117 |  Q
 | 
|---|