source: WorldVistAEHR/trunk/r/INTEGRATED_BILLING-IB-PRQ--IBD--IBQ--PRQS/IBXSC36.m@ 1766

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

revised back to 6/30/08 version

File size: 8.0 KB
Line 
1IBXSC36 ; ;12/27/07
2 D DE G BEGIN
3DE S DIE="^DGCR(399,",DIC=DIE,DP=399,DL=1,DIEL=0,DU="" K DG,DE,DB Q:$O(^DGCR(399,DA,""))=""
4 I $D(^("M1")) S %Z=^("M1") S %=$P(%Z,U,2) S:%]"" DE(1)=%,DE(7)=% S %=$P(%Z,U,3) S:%]"" DE(19)=% S %=$P(%Z,U,10) S:%]"" DE(2)=%,DE(11)=%,DE(14)=% S %=$P(%Z,U,11) S:%]"" DE(20)=%
5 K %Z Q
6 ;
7W W !?DL+DL-2,DLB_": "
8 Q
9O D W W Y W:$X>45 !?9
10 I $L(Y)>19,'DV,DV'["I",(DV["F"!(DV["K")) G RW^DIR2
11 W:Y]"" "// " I 'DV,DV["I",$D(DE(DQ))#2 S X="" W " (No Editing)" Q
12TR R X:DTIME E S (DTOUT,X)=U W $C(7)
13 Q
14A K DQ(DQ) S DQ=DQ+1
15B G @DQ
16RE G PR:$D(DE(DQ)) D W,TR
17N I X="" G NKEY:$D(^DD("KEY","F",DP,DIFLD)),A:DV'["R",X:'DV,X:D'>0,A
18RD G QS:X?."?" I X["^" D D G ^DIE17
19 I X="@" D D G Z^DIE2
20 I X=" ",DV["d",DV'["P",$D(^DISV(DUZ,"DIE",DLB)) S X=^(DLB) I DV'["D",DV'["S" W " "_X
21T G M^DIE17:DV,^DIE3:DV["V",P:DV'["S" X:$D(^DD(DP,DIFLD,12.1)) ^(12.1) I X?.ANP D SET I 'DDER X:$D(DIC("S")) DIC("S") I W:'$D(DB(DQ)) " "_% G V
22 K DDER G X
23P I DV["P" S DIC=U_DU,DIC(0)=$E("EN",$D(DB(DQ))+1)_"M"_$E("L",DV'["'") S:DIC(0)["L" DLAYGO=+$P(DV,"P",2) G:DV["*" AST^DIED D NOSCR^DIED S X=+Y,DIC=DIE G X:X<0
24 G V:DV'["N" D D I $L($P(X,"."))>24 K X G Z
25 I $P(DQ(DQ),U,5)'["$",X?.1"-".N.1".".N,$P(DQ(DQ),U,5,99)["+X'=X" S X=+X
26V D @("X"_DQ) K YS
27Z K DIC("S"),DLAYGO I $D(X),X'=U D:$G(DE(DW,"INDEX")) SAVEVALS G:'$$KEYCHK UNIQFERR^DIE17 S DG(DW)=X S:DV["d" ^DISV(DUZ,"DIE",DLB)=X G A
28X W:'$D(ZTQUEUED) $C(7),"??" I $D(DB(DQ)) G Z^DIE17
29 S X="?BAD"
30QS S DZ=X D D,QQ^DIEQ G B
31D S D=DIFLD,DQ(DQ)=DLB_U_DV_U_DU_U_DW_U_$P($T(@("X"_DQ))," ",2,99) Q
32Y I '$D(DE(DQ)) D O G RD:"@"'[X,A:DV'["R"&(X="@"),X:X="@" S X=Y G N
33PR S DG=DV,Y=DE(DQ),X=DU I $D(DQ(DQ,2)) X DQ(DQ,2) G RP
34R I DG["P",@("$D(^"_X_"0))") S X=+$P(^(0),U,2) G RP:'$D(^(Y,0)) S Y=$P(^(0),U),X=$P(^DD(X,.01,0),U,3),DG=$P(^(0),U,2) G R
35 I DG["V",+Y,$P(Y,";",2)["(",$D(@(U_$P(Y,";",2)_"0)")) S X=+$P(^(0),U,2) G RP:'$D(^(+Y,0)) S Y=$P(^(0),U) I $D(^DD(+X,.01,0)) S DG=$P(^(0),U,2),X=$P(^(0),U,3) G R
36 X:DG["D" ^DD("DD") I DG["S" S %=$P($P(";"_X,";"_Y_":",2),";") S:%]"" Y=%
37RP D O I X="" S X=DE(DQ) G A:'DV,A:DC<2,N^DIE17
38I I DV'["I",DV'["#" G RD
39 D E^DIE0 G RD:$D(X),PR
40 Q
41SET N DIR S DIR(0)="SV"_$E("o",$D(DB(DQ)))_U_DU,DIR("V")=1
42 I $D(DB(DQ)),'$D(DIQUIET) N DIQUIET S DIQUIET=1
43 D ^DIR I 'DDER S %=Y(0),X=Y
44 Q
45SAVEVALS S @DIEZTMP@("V",DP,DIIENS,DIFLD,"O")=$G(DE(DQ)) S:$D(^("F"))[0 ^("F")=$G(DE(DQ))
46 I $D(DE(DW,"4/")) S @DIEZTMP@("V",DP,DIIENS,DIFLD,"4/")=""
47 E K @DIEZTMP@("V",DP,DIIENS,DIFLD,"4/")
48 Q
49NKEY W:'$D(ZTQUEUED) "?? Required key field" S X="?BAD" G QS
50KEYCHK() Q:$G(DE(DW,"KEY"))="" 1 Q @DE(DW,"KEY")
51BEGIN S DNM="IBXSC36",DQ=1
521 S DW="M1;2",DV="F",DU="",DLB="PRIMARY PROVIDER #",DIFLD=122
53 S DE(DW)="C1^IBXSC36"
54 S Y="@"
55 S X=Y,DB(DQ)=1 G:X="" N^DIE17:DV,A I $D(DE(DQ)),DV["I"!(DV["#") D E^DIE0 G A:'$D(X)
56 G RD
57C1 G C1S:$D(DE(1))[0 K DB
58 S X=DE(1),DIC=DIE
59 K DIV S DIV=X,D0=DA,DIV(0)=D0 S Y(0)=X S Y(1)=$S($D(^DGCR(399,D0,"M1")):^("M1"),1:"") S X=$P(Y(1),U,2)="" I X S X=DIV S Y(1)=$S($D(^DGCR(399,D0,"M1")):^("M1"),1:"") S X=$P(Y(1),U,10),X=X S DIU=X K Y S X="" X ^DD(399,122,1,1,2.4)
60C1S S X="" G:DG(DQ)=X C1F1 K DB
61 S X=DG(DQ),DIC=DIE
62 ;
63C1F1 Q
64X1 K:$L(X)>13!($L(X)<3) X
65 I $D(X),X'?.ANP K X
66 Q
67 ;
682 D:$D(DG)>9 F^DIE17,DE S DQ=2,DW="M1;10",DV="*P355.97'",DU="",DLB="PRIMARY ID QUALIFIER",DIFLD=128
69 S DU="IBE(355.97,"
70 S Y="@"
71 S X=Y,DB(DQ)=1 G:X="" N^DIE17:DV,A I $D(DE(DQ)),DV["I"!(DV["#") D E^DIE0 G A:'$D(X)
72 G RD
73X2 S DIC("S")="I $$BPS^IBCEPU(Y)!($$EPT^IBCEPU(Y))" D ^DIC K DIC S DIC=DIE,X=+Y K:Y<0 X
74 Q
75 ;
763 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=3 D X3 D:$D(DIEFIRE)#2 FIREREC^DIE17 G A:$D(Y)[0,A:Y=U S X=Y,DIC(0)="F",DW=DQ G OUT^DIE17
77X3 S DIE("NO^")=1
78 Q
794 S DQ=5 ;@321
805 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=5 D X5 D:$D(DIEFIRE)#2 FIREREC^DIE17 G A:$D(Y)[0,A:Y=U S X=Y,DIC(0)="F",DW=DQ G OUT^DIE17
81X5 S IBPSIDO=$P($G(^DGCR(399,DA,"M1")),U,2),IBPSQO=$P($G(^DGCR(399,DA,"M1")),U,10)
82 Q
836 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=6 G A
847 S DW="M1;2",DV="F",DU="",DLB="PRIMARY PROVIDER #",DIFLD=122
85 S DE(DW)="C7^IBXSC36"
86 S X="IBPSID" Q:X Q:$NA(@X)[U S X=$G(@X)
87 S Y=X
88 G Y
89C7 G C7S:$D(DE(7))[0 K DB
90 S X=DE(7),DIC=DIE
91 K DIV S DIV=X,D0=DA,DIV(0)=D0 S Y(0)=X S Y(1)=$S($D(^DGCR(399,D0,"M1")):^("M1"),1:"") S X=$P(Y(1),U,2)="" I X S X=DIV S Y(1)=$S($D(^DGCR(399,D0,"M1")):^("M1"),1:"") S X=$P(Y(1),U,10),X=X S DIU=X K Y S X="" X ^DD(399,122,1,1,2.4)
92C7S S X="" G:DG(DQ)=X C7F1 K DB
93 S X=DG(DQ),DIC=DIE
94 ;
95C7F1 Q
96X7 K:$L(X)>13!($L(X)<3) X
97 I $D(X),X'?.ANP K X
98 Q
99 ;
1008 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=8 D X8 D:$D(DIEFIRE)#2 FIREREC^DIE17 G A:$D(Y)[0,A:Y=U S X=Y,DIC(0)="F",DW=DQ G OUT^DIE17
101X8 I $G(IBPSQO)]"",X'=$G(IBPSID),X'=$G(IBPSIDO) S Y="@3214"
102 Q
1039 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=9 D X9 D:$D(DIEFIRE)#2 FIREREC^DIE17 G A:$D(Y)[0,A:Y=U S X=Y,DIC(0)="F",DW=DQ G OUT^DIE17
104X9 I $G(IBPSQO)="",$G(IBPSQUAL)="",X]"" S Y="@3214"
105 Q
10610 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=10 G A
10711 D:$D(DG)>9 F^DIE17,DE S DQ=11,DW="M1;10",DV="*P355.97'",DU="",DLB="PRIMARY ID QUALIFIER",DIFLD=128
108 S DU="IBE(355.97,"
109 S X="IBPSQUAL" Q:X Q:$NA(@X)[U S X=$G(@X)
110 S Y=X
111 S X=Y,DB(DQ)=1 G:X="" N^DIE17:DV,A I $D(DE(DQ)),DV["I"!(DV["#") D E^DIE0 G A:'$D(X)
112 G RD
113X11 S DIC("S")="I $$BPS^IBCEPU(Y)!($$EPT^IBCEPU(Y))" D ^DIC K DIC S DIC=DIE,X=+Y K:Y<0 X
114 Q
115 ;
11612 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=12 D X12 D:$D(DIEFIRE)#2 FIREREC^DIE17 G A:$D(Y)[0,A:Y=U S X=Y,DIC(0)="F",DW=DQ G OUT^DIE17
117X12 S Y="@3215"
118 Q
11913 S DQ=14 ;@3214
12014 S DW="M1;10",DV="*P355.97'",DU="",DLB="Primary ID Qualifier",DIFLD=128
121 S DU="IBE(355.97,"
122 G RE
123X14 S DIC("S")="I $$BPS^IBCEPU(Y)!($$EPT^IBCEPU(Y))" D ^DIC K DIC S DIC=DIE,X=+Y K:Y<0 X
124 Q
125 ;
12615 S DQ=16 ;@3215
12716 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=16 D X16 D:$D(DIEFIRE)#2 FIREREC^DIE17 G A:$D(Y)[0,A:Y=U S X=Y,DIC(0)="F",DW=DQ G OUT^DIE17
128X16 K DIE("NO^")
129 Q
13017 S DQ=18 ;@3221
13118 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=18 D X18 D:$D(DIEFIRE)#2 FIREREC^DIE17 G A:$D(Y)[0,A:Y=U S X=Y,DIC(0)="F",DW=DQ G OUT^DIE17
132X18 I '$$SUPPPT^IBCEP7B(DA,2) S Y="@3222"
133 Q
13419 S DW="M1;3",DV="F",DU="",DLB="SECONDARY PROVIDER #",DIFLD=123
135 S DE(DW)="C19^IBXSC36"
136 S Y="@"
137 S X=Y,DB(DQ)=1 G:X="" N^DIE17:DV,A I $D(DE(DQ)),DV["I"!(DV["#") D E^DIE0 G A:'$D(X)
138 G RD
139C19 G C19S:$D(DE(19))[0 K DB
140 S X=DE(19),DIC=DIE
141 K DIV S DIV=X,D0=DA,DIV(0)=D0 S Y(0)=X S Y(1)=$S($D(^DGCR(399,D0,"M1")):^("M1"),1:"") S X=$P(Y(1),U,3)="" I X S X=DIV S Y(1)=$S($D(^DGCR(399,D0,"M1")):^("M1"),1:"") S X=$P(Y(1),U,11),X=X S DIU=X K Y S X="" X ^DD(399,123,1,1,2.4)
142C19S S X="" G:DG(DQ)=X C19F1 K DB
143 S X=DG(DQ),DIC=DIE
144 ;
145C19F1 Q
146X19 K:$L(X)>13!($L(X)<3) X
147 I $D(X),X'?.ANP K X
148 Q
149 ;
15020 D:$D(DG)>9 F^DIE17,DE S DQ=20,DW="M1;11",DV="*P355.97'",DU="",DLB="SECONDARY ID QUALIFIER",DIFLD=129
151 S DU="IBE(355.97,"
152 S Y="@"
153 S X=Y,DB(DQ)=1 G:X="" N^DIE17:DV,A I $D(DE(DQ)),DV["I"!(DV["#") D E^DIE0 G A:'$D(X)
154 G RD
155X20 S DIC("S")="I $$BPS^IBCEPU(Y)!($$EPT^IBCEPU(Y))" D ^DIC K DIC S DIC=DIE,X=+Y K:Y<0 X
156 Q
157 ;
15821 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=21 D X21 D:$D(DIEFIRE)#2 FIREREC^DIE17 G A:$D(Y)[0,A:Y=U S X=Y,DIC(0)="F",DW=DQ G OUT^DIE17
159X21 W !,"No Billing Prov Secondary IDs will be sent for Secondary Ins/Elect Plan Type."
160 Q
16122 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=22 D X22 D:$D(DIEFIRE)#2 FIREREC^DIE17 G A:$D(Y)[0,A:Y=U S X=Y,DIC(0)="F",DW=DQ G OUT^DIE17
162X22 S Y="@3231"
163 Q
16423 S DQ=24 ;@3222
16524 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=24 D X24 D:$D(DIEFIRE)#2 FIREREC^DIE17 G A:$D(Y)[0,A:Y=U S X=Y,DIC(0)="F",DW=DQ G OUT^DIE17
166X24 I '$$ATTREND^IBCEP7B(DA,2) S Y="@3223"
167 Q
16825 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=25 D X25 D:$D(DIEFIRE)#2 FIREREC^DIE17 G A:$D(Y)[0,A:Y=U S X=Y,DIC(0)="F",DW=DQ G OUT^DIE17
169X25 I $P($G(^DGCR(399,DA,"M1")),U,3)]"" S Y="@3223"
170 Q
17126 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=26 D X26 D:$D(DIEFIRE)#2 FIREREC^DIE17 G A:$D(Y)[0,A:Y=U S X=Y,DIC(0)="F",DW=DQ G OUT^DIE17
172X26 W !,"The Att/Rend ID will be sent as the secondary ins. Billing Prov Sec ID."
173 Q
17427 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=27 D X27 D:$D(DIEFIRE)#2 FIREREC^DIE17 G A:$D(Y)[0,A:Y=U S X=Y,DIC(0)="F",DW=DQ G OUT^DIE17
175X27 S Y="@3231"
176 Q
17728 S DQ=29 ;@3223
17829 D:$D(DG)>9 F^DIE17,DE S Y=U,DQ=29 D X29 D:$D(DIEFIRE)#2 FIREREC^DIE17 G A:$D(Y)[0,A:Y=U S X=Y,DIC(0)="F",DW=DQ G OUT^DIE17
179X29 S IBPSDAT=$$GETID^IBCEP7B(DA,2),IBPSID=$P(IBPSDAT,U),IBPSQUAL=$P(IBPSDAT,U,2) I IBPSID="" S Y="@322"
180 Q
18130 D:$D(DG)>9 F^DIE17 G ^IBXSC37
Note: See TracBrowser for help on using the repository browser.