source: FOIAVistA/trunk/r/INTEGRATED_BILLING-IB-PRQ--IBD--IBQ--PRQS/IBJDI4.m@ 1397

Last change on this file since 1397 was 628, checked in by George Lilly, 15 years ago

initial load of FOIAVistA 6/30/08 version

File size: 4.8 KB
Line 
1IBJDI4 ;ALB/CPM - PATIENTS WITH UNIDENTIFIED INSURANCE ; 17-DEC-96
2 ;;2.0;INTEGRATED BILLING;**69,98,100,118**;21-MAR-94
3 ;
4EN ; - 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 ;
9DATE 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 ;
23SEL 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 ;
27RPTS ; - 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 ;
37RMK ; - 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 ;
44DEV ; - 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 ;
58DQ ; - 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 ;
69PROC D EN^IBJDI41 ; Process and print report(s).
70 ;
71ENQ K ^TMP("IBJDI41",$J),^TMP("IBJDI42",$J)
72 I $D(ZTQUEUED) S ZTREQ="@" G ENQ1
73 ;
74 D ^%ZISC
75ENQ1 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 ;
81HLP1 ; - '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 ;
88HLP2 ; - '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 ;
94TITLE(X) ; - Print report title.
95 Q $P($T(TITLE1+X),";;",2)
96 ;
97TITLE1 ;;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 ;
108TYPE(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 ;
123TYP1 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 ;
129TYPQ Q Y
Note: See TracBrowser for help on using the repository browser.