1 | RMPRPIX2 ;HINCIO/ODJ - APIs for 660 file (Patient 2319) ;3/8/01
|
---|
2 | ;;3.0;PROSTHETICS;**61**;Feb 09, 1996
|
---|
3 | Q
|
---|
4 | ;
|
---|
5 | ; CRE - Create a 2319 record for a stock issue (file 660)
|
---|
6 | ;
|
---|
7 | ; Inputs:
|
---|
8 | ;
|
---|
9 | ; Outputs:
|
---|
10 | ;
|
---|
11 | CRE(RMPR60,RMPR6111) ;
|
---|
12 | N RMPRFDA,RMPRFME,RMPRIEN,RMPRRET,X,Y,RMPR699,RMPRTMP,RMPRI,RMPRJ
|
---|
13 | N RMPR611,RMPR611I,RMPRERR,RMPRTMP
|
---|
14 | S RMPRRET=0
|
---|
15 | S RMPR611("HCPCS")=RMPR6111("HCPCS")
|
---|
16 | S RMPRRET=$$HPACT^RMPRPIX1(.RMPR611)
|
---|
17 | I RMPRRET S RMPRRET=1 G CREX
|
---|
18 | S RMPRRET=$$HPETOI^RMPRPIX1(.RMPR611,.RMPR611I)
|
---|
19 | I RMPRRET S RMPRRET=1 G CREX
|
---|
20 | ;S RMPR60("CPT IEN")=RMPR611I("CPT CODE")
|
---|
21 | S RMPRFDA(660,"+1,",.01)=RMPR60("ENTRY DATE")
|
---|
22 | S RMPRFDA(660,"+1,",.02)=RMPR60("PATIENT IEN")
|
---|
23 | S RMPRFDA(660,"+1,",1)=RMPR60("REQ DATE")
|
---|
24 | S RMPRFDA(660,"+1,",2)=RMPR60("ISSUE TYPE")
|
---|
25 | S RMPRFDA(660,"+1,",4)=$G(RMPR60("IFCAP ITEM"))
|
---|
26 | S RMPRFDA(660,"+1,",5)=RMPR60("QUANTITY")
|
---|
27 | S RMPRFDA(660,"+1,",78)=$G(RMPR60("UNIT"))
|
---|
28 | S RMPRFDA(660,"+1,",7)=RMPR60("VENDOR IEN")
|
---|
29 | S RMPRFDA(660,"+1,",8)=RMPR6111("STATION IEN")
|
---|
30 | S RMPRFDA(660,"+1,",9)=$G(RMPR60("SERIAL NUM"))
|
---|
31 | S RMPRFDA(660,"+1,",10)=RMPR60("DELIV DATE")
|
---|
32 | S RMPRFDA(660,"+1,",11)=$G(RMPR60("REQ TYPE"))
|
---|
33 | S RMPRFDA(660,"+1,",12)=$G(RMPR60("SOURCE"))
|
---|
34 | S RMPRFDA(660,"+1,",14)=RMPR60("COST")
|
---|
35 | S RMPRFDA(660,"+1,",16)=$G(RMPR60("REMARKS"))
|
---|
36 | S RMPRFDA(660,"+1,",4.1)=RMPR60("CPT IEN")
|
---|
37 | S RMPRFDA(660,"+1,",21)=$G(RMPR60("LOT NUM"))
|
---|
38 | S RMPRFDA(660,"+1,",27)=$G(RMPR60("USER"))
|
---|
39 | ;
|
---|
40 | ; for the type 1 rec.
|
---|
41 | S RMPRFDA(660,"+1,",24)=RMPR611("SHORT DESC")
|
---|
42 | S RMPRFDA(660,"+1,",4.5)=RMPR60("HCPCS")
|
---|
43 | ;S RMPRFDA(660,"+1,",4.5)=RMPR611("IEN")
|
---|
44 | S RMPRFDA(660,"+1,",4.7)=RMPR60("CPT MOD")
|
---|
45 | S RMPRFDA(660,"+1,",4.6)=RMPR60("TRANS IEN")
|
---|
46 | S RMPRFDA(660,"+1,",39)=RMPR60("DATE OF SERVICE")
|
---|
47 | ;
|
---|
48 | ; for the type 2 rec.
|
---|
49 | S RMPRFDA(660,"+1,",37)=RMPR6111("HCPCS")_"-"_RMPR6111("ITEM")
|
---|
50 | S RMPRFDA(660,"+1,",38)=RMPR6111("DESCRIPTION")
|
---|
51 | ;
|
---|
52 | ; for the type AM rec.
|
---|
53 | S RMPRFDA(660,"+1,",62)=RMPR60("PAT CAT")
|
---|
54 | S RMPRFDA(660,"+1,",63)=$G(RMPR60("SPEC CAT"))
|
---|
55 | ;
|
---|
56 | ; for the type AMS rec.
|
---|
57 | S RMPR699("IEN")=RMPR60("SITE IEN")
|
---|
58 | S RMPRFDA(660,"+1,",68)=RMPR60("GROUPER")
|
---|
59 | ;
|
---|
60 | ; for the type DES rec.
|
---|
61 | S RMPRERR=$$HCDES(.RMPR611,.RMPRTMP)
|
---|
62 | I RMPRERR S RMPRRET=2 G CREX
|
---|
63 | S RMPRFDA(660,"+1,",28)="RMPRTMP"
|
---|
64 | D UPDATE^DIE("","RMPRFDA","RMPRIEN","RMPRFME")
|
---|
65 | I $D(RMPRFME) S RMPRRET=99 G CREX
|
---|
66 | S RMPR60("IEN")=RMPRIEN(1)
|
---|
67 | CREX Q RMPRRET
|
---|
68 | ;
|
---|
69 | ; UPD - Update existing 660 rec.
|
---|
70 | UPD(RMPR60,RMPR6111) ;
|
---|
71 | N RMPRFDA,RMPRFME,RMPRERR,RMPRI,X,Y,DA,RMPR611,RMPR611I,RMPRTMP
|
---|
72 | S RMPRERR=0
|
---|
73 | I $G(RMPR60("IEN"))="" S RMPRERR=1 G UPDX
|
---|
74 | S RMPRI=RMPR60("IEN")_","
|
---|
75 | I $D(RMPR6111("HCPCS")) D
|
---|
76 | . S RMPR611("HCPCS")=RMPR6111("HCPCS")
|
---|
77 | . S RMPRERR=$$HPACT^RMPRPIX1(.RMPR611)
|
---|
78 | . Q:RMPRERR
|
---|
79 | . S RMPRERR=$$HPETOI^RMPRPIX1(.RMPR611,.RMPR611I)
|
---|
80 | . Q:RMPRERR
|
---|
81 | . S RMPRERR=$$HCDES(.RMPR611,.RMPRTMP)
|
---|
82 | . Q:RMPRERR
|
---|
83 | . S RMPRFDA(660,RMPRI,28)="RMPRTMP"
|
---|
84 | . Q
|
---|
85 | I RMPRERR S RMPRERR=1 G UPDX
|
---|
86 | S:$D(RMPR60("ENTRY DATE")) RMPRFDA(660,RMPRI,.01)=RMPR60("ENTRY DATE")
|
---|
87 | S:$D(RMPR60("PATIENT IEN")) RMPRFDA(660,RMPRI,.02)=RMPR60("PATIENT IEN")
|
---|
88 | S:$D(RMPR60("REQ DATE")) RMPRFDA(660,RMPRI,1)=RMPR60("REQ DATE")
|
---|
89 | S:$D(RMPR60("ISSUE TYPE")) RMPRFDA(660,RMPRI,2)=RMPR60("ISSUE TYPE")
|
---|
90 | S:$D(RMPR60("IFCAP ITEM")) RMPRFDA(660,RMPRI,4)=RMPR60("IFCAP ITEM")
|
---|
91 | S:$D(RMPR60("QUANTITY")) RMPRFDA(660,RMPRI,5)=RMPR60("QUANTITY")
|
---|
92 | S:$D(RMPR6111("UNIT")) RMPRFDA(660,RMPRI,78)=RMPR6111("UNIT")
|
---|
93 | S:$D(RMPR60("VENDOR IEN")) RMPRFDA(660,RMPRI,7)=RMPR60("VENDOR IEN")
|
---|
94 | S:$D(RMPR6111("STATION IEN")) RMPRFDA(660,RMPRI,8)=RMPR6111("STATION IEN")
|
---|
95 | S:$D(RMPR60("SERIAL NUM")) RMPRFDA(660,RMPRI,9)=RMPR60("SERIAL NUM")
|
---|
96 | S:$D(RMPR60("DELIV DATE")) RMPRFDA(660,RMPRI,10)=RMPR60("DELIV DATE")
|
---|
97 | S:$D(RMPR60("DATE OF SERVICE")) RMPRFDA(660,RMPRI,39)=RMPR60("DATE OF SERVICE")
|
---|
98 | S:$D(RMPR60("REQ TYPE")) RMPRFDA(660,RMPRI,11)=RMPR60("REQ TYPE")
|
---|
99 | S:$D(RMPR60("SOURCE")) RMPRFDA(660,RMPRI,12)=RMPR60("SOURCE")
|
---|
100 | S:$D(RMPR60("COST")) RMPRFDA(660,RMPRI,14)=RMPR60("COST")
|
---|
101 | S:$D(RMPR60("REMARKS")) RMPRFDA(660,RMPRI,16)=RMPR60("REMARKS")
|
---|
102 | S:$D(RMPR60("TRANS IEN")) RMPRFDA(660,RMPRI,4.6)=RMPR60("TRANS IEN")
|
---|
103 | S:$D(RMPR60("CPT IEN")) RMPRFDA(660,RMPRI,4.1)=RMPR60("CPT IEN")
|
---|
104 | S:$D(RMPR60("LOT NUM")) RMPRFDA(660,RMPRI,21)=RMPR60("LOT NUM")
|
---|
105 | ;
|
---|
106 | ; for the type 1 rec.
|
---|
107 | S:$D(RMPR611("SHORT DESC")) RMPRFDA(660,RMPRI,24)=RMPR611("SHORT DESC")
|
---|
108 | S:$D(RMPR60("HCPCS")) RMPRFDA(660,RMPRI,4.5)=RMPR60("HCPCS")
|
---|
109 | ;S:$D(RMPR611("IEN")) RMPRFDA(660,RMPRI,4.5)=RMPR611("IEN")
|
---|
110 | S:$D(RMPR60("CPT MOD")) RMPRFDA(660,RMPRI,4.7)=RMPR60("CPT MOD")
|
---|
111 | ;
|
---|
112 | ; for the type 2 rec.
|
---|
113 | S:$D(RMPR6111("HCPCS")) RMPRFDA(660,RMPRI,37)=RMPR6111("HCPCS")_"-"_RMPR6111("ITEM")
|
---|
114 | S:$D(RMPR6111("DESCRIPTION")) RMPRFDA(660,RMPRI,38)=RMPR6111("DESCRIPTION")
|
---|
115 | ;
|
---|
116 | ; for the type AM rec.
|
---|
117 | S:$D(RMPR60("PAT CAT")) RMPRFDA(660,RMPRI,62)=RMPR60("PAT CAT")
|
---|
118 | S:$D(RMPR60("SPEC CAT")) RMPRFDA(660,RMPRI,63)=RMPR60("SPEC CAT")
|
---|
119 | D:$D(RMPRFDA) FILE^DIE("","RMPRFDA","RMPRFME")
|
---|
120 | I $D(RMPRFME) S RMPRERR=1
|
---|
121 | UPDX Q RMPRERR
|
---|
122 | ;
|
---|
123 | ; Update AMIS grouper
|
---|
124 | AMGR(RMPR699) ;
|
---|
125 | N RMPRFDA,RMPRIEN,RMPRFME,X,Y,RMPRRET
|
---|
126 | S RMPRRET=0
|
---|
127 | S RMPRIEN=RMPR699("IEN")_","
|
---|
128 | L +^RMPR(669.9,RMPR699("IEN"))
|
---|
129 | S RMPR699("AMIS GROUPER")=$P(^RMPR(669.9,RMPR699("IEN"),0),"^",7)
|
---|
130 | S RMPR699("AMIS GROUPER")=RMPR699("AMIS GROUPER")-1
|
---|
131 | S RMPRFDA(669.9,RMPRIEN,11)=RMPR699("AMIS GROUPER")
|
---|
132 | D FILE^DIE("","RMPRFDA","RMPRFME")
|
---|
133 | I $D(RMPRFME) S RMPRRET=1
|
---|
134 | L -^RMPR(669.9,RMPR699("IEN"))
|
---|
135 | Q RMPRRET
|
---|
136 | ;
|
---|
137 | ; Read description for HCPCS
|
---|
138 | HCDES(RMPR611,RMPRFDA) ;
|
---|
139 | N RMPRIEN,RMPRFME,RMPRRET,RMPRTMP,RMPRI,RMPRJ
|
---|
140 | K RMPRFDA
|
---|
141 | S RMPRRET=0
|
---|
142 | S RMPRIEN=RMPR611("IEN")_","
|
---|
143 | D GETS^DIQ(661.1,RMPRIEN,"**","","RMPRTMP","RMPRFME")
|
---|
144 | I $D(RMPRFME) S RMPRRET=1 G HCDESX
|
---|
145 | S RMPRJ=0,RMPRI=""
|
---|
146 | F S RMPRI=$O(RMPRTMP(661.18,RMPRI)) Q:RMPRI="" D
|
---|
147 | . S RMPRJ=RMPRJ+1
|
---|
148 | . S RMPRFDA(RMPRJ)=RMPRTMP(661.18,RMPRI,.01)
|
---|
149 | . Q
|
---|
150 | HCDESX Q RMPRRET
|
---|
151 | ;
|
---|
152 | ; DEL - Delete a record
|
---|
153 | DEL(RMPR60) ;
|
---|
154 | N RMPRFDA,RMPRFME,RMPRERR,RMPRIEN,X,Y,DA
|
---|
155 | S RMPRERR=0
|
---|
156 | I $G(RMPR60("IEN"))="" S RMPRERR=1 G DELX
|
---|
157 | S RMPRIEN=RMPR60("IEN")_","
|
---|
158 | S RMPRFDA(660,RMPRIEN,.01)="@"
|
---|
159 | D FILE^DIE("","RMPRFDA","RMPRFME")
|
---|
160 | I $D(RMPRFME) S RMPRERR=1
|
---|
161 | DELX Q RMPRERR
|
---|
162 | ;
|
---|
163 | ; GET - read in 660 record
|
---|
164 | GET(RMPR60,RMPR11) ;
|
---|
165 | S RMPRERR=$$GET^RMPRPIXC(.RMPR60,.RMPR11)
|
---|
166 | GETX Q RMPRERR
|
---|
167 | ;
|
---|
168 | ; ETOI - convert external to internal form
|
---|
169 | ETOI(RMPR60,RMPR11,RMPR60I,RMPR11I) ;
|
---|
170 | S RMPRERR=$$ETOI^RMPRPIXC(.RMPR60,.RMPR11,.RMPR60I,.RMPR11I)
|
---|
171 | ETOIX Q RMPRERR
|
---|