| 1 | IBJDI4 ;ALB/CPM - PATIENTS WITH UNIDENTIFIED INSURANCE ; 17-DEC-96
 | 
|---|
| 2 |  ;;2.0;INTEGRATED BILLING;**69,98,100,118**;21-MAR-94
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 | EN ; - Option entry point.
 | 
|---|
| 5 |  ;
 | 
|---|
| 6 |  W !!,"This report provides the number of patients who have been treated,"
 | 
|---|
| 7 |  W !,"but not identified as having or not having insurance.",!
 | 
|---|
| 8 |  ;
 | 
|---|
| 9 | DATE D DATE^IBOUTL I IBBDT=""!(IBEDT="") G ENQ
 | 
|---|
| 10 |  ;
 | 
|---|
| 11 |  ; - Sort by division?
 | 
|---|
| 12 |  S DIR(0)="Y",DIR("B")="NO",DIR("?")="^D HLP1^IBJDI4"
 | 
|---|
| 13 |  S DIR("A")="Do you wish to sort this report by division" W !
 | 
|---|
| 14 |  D ^DIR S IBSORT=+Y I $D(DIRUT)!$D(DTOUT)!$D(DUOUT)!$D(DIROUT) G ENQ
 | 
|---|
| 15 |  K DIR,DIROUT,DTOUT,DUOUT,DIRUT
 | 
|---|
| 16 |  ;
 | 
|---|
| 17 |  I IBSORT D PSDR^IBODIV G:Y<0 ENQ ; Select division(s).
 | 
|---|
| 18 |  ;
 | 
|---|
| 19 |  ; - Select a detailed or summary report.
 | 
|---|
| 20 |  D DS^IBJD G:IBRPT["^" ENQ S IBSEL=0
 | 
|---|
| 21 |  I IBRPT="S" W !!,"This report only requires an 80 column printer." G DEV
 | 
|---|
| 22 |  ;
 | 
|---|
| 23 | SEL W !!,"Print 1-MAIN REPORT or 2-LINE ITEM REPORTS: 1// "
 | 
|---|
| 24 |  R X:DTIME G:'$T!(X["^") ENQ S:X="" X=1 I "1^2"'[X D HLP2 G SEL
 | 
|---|
| 25 |  W "  ",$S(X=2:"LINE ITEM REPORTS",1:"MAIN REPORT") I X=1 G RMK
 | 
|---|
| 26 |  ;
 | 
|---|
| 27 | RPTS ; - Select line item report(s).
 | 
|---|
| 28 |  W ! S DIR(0)="LO^1:9^K:+$P(X,""-"",2)>9 X"
 | 
|---|
| 29 |  F X=1:1:9 S DIR("A",X)=X_" - Print "_$$TITLE(X)
 | 
|---|
| 30 |  S DIR("A",10)="",DIR("A")="Select",DIR("B")=1 D ^DIR K DIR I Y["^" G ENQ
 | 
|---|
| 31 |  W ! S IBSEL=Y,DIR(0)="YO",DIR("A",1)="You have selected"
 | 
|---|
| 32 |  I X="1-9" S DIR("A",1)=DIR("A",1)_" ALL the above reports."
 | 
|---|
| 33 |  E  F X=1:1 S X1=$P(IBSEL,",",X) Q:'X1  S DIR("A",X+1)=" "_$$TITLE(X1)
 | 
|---|
| 34 |  S DIR("A")="Are you sure",DIR("B")="NO" D ^DIR K DIR I Y["^" G ENQ
 | 
|---|
| 35 |  I 'Y G RPTS
 | 
|---|
| 36 |  ;
 | 
|---|
| 37 | RMK ; - Select print/not print remarks.
 | 
|---|
| 38 |  W ! S DIR(0)="YO"
 | 
|---|
| 39 |  S DIR("A")="Do you want the patient's remarks to print on the report"
 | 
|---|
| 40 |  S DIR("B")="NO" D ^DIR K DIR S IBRMK=Y I IBRMK["^" G ENQ
 | 
|---|
| 41 |  ;
 | 
|---|
| 42 |  W !!,"You will need a 132 column printer for this report."
 | 
|---|
| 43 |  ;
 | 
|---|
| 44 | DEV ; - Select a device.
 | 
|---|
| 45 |  W !!,"Note: This report may take a while to run."
 | 
|---|
| 46 |  W !?6,"You should queue this report to run after normal business hours.",!
 | 
|---|
| 47 |  ;
 | 
|---|
| 48 |  S %ZIS="QM" D ^%ZIS G:POP ENQ
 | 
|---|
| 49 |  I $D(IO("Q")) D  G ENQ
 | 
|---|
| 50 |  .S ZTRTN="DQ^IBJDI4",ZTDESC="IB - PATIENTS WITH UNIDENTIFIED INSURANCE"
 | 
|---|
| 51 |  .F I="IB*","VAUTD","VAUTD(" S ZTSAVE(I)=""
 | 
|---|
| 52 |  .D ^%ZTLOAD
 | 
|---|
| 53 |  .W !!,$S($D(ZTSK):"This job has been queued. The task number is "_ZTSK_".",1:"Unable to queue this job.")
 | 
|---|
| 54 |  .K ZTSK,IO("Q") D HOME^%ZIS
 | 
|---|
| 55 |  ;
 | 
|---|
| 56 |  U IO
 | 
|---|
| 57 |  ;
 | 
|---|
| 58 | DQ ; - Tasked entry point.
 | 
|---|
| 59 |  ;
 | 
|---|
| 60 |  I $G(IBXTRACT) D E^IBJDE(4,1) ; Change extract status.
 | 
|---|
| 61 |  ;
 | 
|---|
| 62 |  N IBQUERY K IB,^TMP("IBJDI41",$J),^TMP("IBJDI42",$J)
 | 
|---|
| 63 |  S IBC="BILL^DEC^HMO^IND^MEDC^MEDG^NO^NULL^TOT^UNK^YES",IBQ=0
 | 
|---|
| 64 |  I IBSORT D  G PROC
 | 
|---|
| 65 |  .S I=0 F  S I=$S(VAUTD:$O(^DG(40.8,I)),1:$O(VAUTD(I))) Q:'I  D
 | 
|---|
| 66 |  ..S J=$P($G(^DG(40.8,I,0)),U) F K=1:1:11 S IB(J,$P(IBC,U,K))=0
 | 
|---|
| 67 |  S IBDIV="ALL" F I=1:1:11 S IB("ALL",$P(IBC,U,I))=0
 | 
|---|
| 68 |  ;
 | 
|---|
| 69 | PROC D EN^IBJDI41 ; Process and print report(s).
 | 
|---|
| 70 |  ;
 | 
|---|
| 71 | ENQ K ^TMP("IBJDI41",$J),^TMP("IBJDI42",$J)
 | 
|---|
| 72 |  I $D(ZTQUEUED) S ZTREQ="@" G ENQ1
 | 
|---|
| 73 |  ;
 | 
|---|
| 74 |  D ^%ZISC
 | 
|---|
| 75 | ENQ1 K IB,IBQ,IBBDT,IBEDT,IBRMK,IBRPT,IBD,IBDN,IBPH,IBPAG,IBRUN,IBX,IBX1,IBX2
 | 
|---|
| 76 |  K IBC,IBELIG,IBPER,IBPM,IBPMD,IBDOD,IBFL,IBFL1,IBIPC,IBINSC,IBPAT,IBSEL
 | 
|---|
| 77 |  K IBDIV,IBSEL1,IBSORT,VAUTD,DFN,POP,I,J,K,X,X1,X2,Y,ZTDESC,ZTRTN,ZTSAVE
 | 
|---|
| 78 |  K DIR,DIROUT,DTOUT,DUOUT,DIRUT,%,%ZIS
 | 
|---|
| 79 |  Q
 | 
|---|
| 80 |  ;
 | 
|---|
| 81 | HLP1 ; - 'Sort by division' prompt.
 | 
|---|
| 82 |  W !!,"Select: '<CR>' to print the trend report without regard to"
 | 
|---|
| 83 |  W !?15,"division"
 | 
|---|
| 84 |  W !?11,"'Y' to select those divisions for which a separate"
 | 
|---|
| 85 |  W !?15,"trend report should be created",!?11,"'^' to quit"
 | 
|---|
| 86 |  Q
 | 
|---|
| 87 |  ;
 | 
|---|
| 88 | HLP2 ; - 'Print 1-MAIN REPORT'... prompt.
 | 
|---|
| 89 |  W !!,"Select: '1' to print the Patients w/Unidentified Insurance Report"
 | 
|---|
| 90 |  W !?8,"'2' to print up to nine specific reports based on the line items"
 | 
|---|
| 91 |  W !?12,"of the summary report",!?8,"'^' to quit"
 | 
|---|
| 92 |  Q
 | 
|---|
| 93 |  ;
 | 
|---|
| 94 | TITLE(X) ; - Print report title.
 | 
|---|
| 95 |  Q $P($T(TITLE1+X),";;",2)
 | 
|---|
| 96 |  ;
 | 
|---|
| 97 | TITLE1 ;;Patients with Unidentified Insurance
 | 
|---|
| 98 |  ;;Patients Covered by Insurance
 | 
|---|
| 99 |  ;;Patients Covered by Billable Insurance
 | 
|---|
| 100 |  ;;Patients Covered by an HMO
 | 
|---|
| 101 |  ;;Patients Covered by Medicare
 | 
|---|
| 102 |  ;;Patients Covered by Medigap
 | 
|---|
| 103 |  ;;Patients Covered by an Indemnity Policy
 | 
|---|
| 104 |  ;;Patients Not Covered by Insurance
 | 
|---|
| 105 |  ;;Patients with Unknown Insurance
 | 
|---|
| 106 |  ;;Patients with Insurance Question Unanswered
 | 
|---|
| 107 |  ;
 | 
|---|
| 108 | TYPE(INS) ; - Find type of insurance.
 | 
|---|
| 109 |  ;  Input: INS=Patient's insurance info in file #2 (.3121)
 | 
|---|
| 110 |  ; Output:   Y=1-HMO, 2-Medicare, 3-Medigap, 4-Indemnity, or
 | 
|---|
| 111 |  ;             0-None of the above
 | 
|---|
| 112 |  ;
 | 
|---|
| 113 |  N TYP
 | 
|---|
| 114 |  S Y=0,TYP=+$P($G(^IBA(355.3,+$P(INS,U,18),0)),U,9) I 'TYP G TYP1
 | 
|---|
| 115 |  I $D(^IBE(355.1,"B","HEALTH MAINTENANCE ORGANIZ",TYP)) S Y=1
 | 
|---|
| 116 |  I $D(^IBE(355.1,"B","POINT OF SERVICE",TYP)) S Y=1
 | 
|---|
| 117 |  I $D(^IBE(355.1,"B","PREPAID GROUP PRACTICE PLAN",TYP)) S Y=1
 | 
|---|
| 118 |  I $D(^IBE(355.1,"B","MEDICARE (M)",TYP)) S Y=2
 | 
|---|
| 119 |  I $D(^IBE(355.1,"B","MEDICARE/MEDICAID (MEDI-CAL)",TYP)) S Y=2
 | 
|---|
| 120 |  I $D(^IBE(355.1,"B","MEDIGAP (SUPPLEMENTAL)",TYP)) S Y=3
 | 
|---|
| 121 |  I $D(^IBE(355.1,"B","INCOME PROTECTION (INDEMNITY)",TYP)) S Y=4
 | 
|---|
| 122 |  ;
 | 
|---|
| 123 | TYP1 G:Y TYPQ S TYP=+$P($G(^DIC(36,+INS,0)),U,13) I 'TYP G TYPQ
 | 
|---|
| 124 |  I $D(^IBE(355.2,"B","HEALTH MAINTENANCE ORG.",TYP)) S Y=1
 | 
|---|
| 125 |  I $D(^IBE(355.2,"B","MEDICARE",TYP)) S Y=2
 | 
|---|
| 126 |  I $D(^IBE(355.2,"B","MEDIGAP",TYP)) S Y=3
 | 
|---|
| 127 |  I $D(^IBE(355.2,"B","INDEMNITY",TYP)) S Y=4
 | 
|---|
| 128 |  ;
 | 
|---|
| 129 | TYPQ Q Y
 | 
|---|