1 | RMPRPIX7 ;HINCIO/ODJ - PIP CURRENT INVENTORY FILE 661.7 APIs ;3/8/01
|
---|
2 | ;;3.0;PROSTHETICS;**61**;Feb 09, 1996
|
---|
3 | Q
|
---|
4 | ;
|
---|
5 | ; CRE - create a new 661.7 record
|
---|
6 | CRE(RMPR617,RMPR6111) ;
|
---|
7 | N RMPRFDA,RMPRFME,RMPRRET,RMPRIENA,X,Y,DA
|
---|
8 | S RMPRRET=0
|
---|
9 | S RMPRFDA(661.7,"+1,",.01)=RMPR6111("HCPCS")
|
---|
10 | S RMPRFDA(661.7,"+1,",1)=RMPR617("DATE&TIME")
|
---|
11 | S RMPRFDA(661.7,"+1,",2)=RMPR617("SEQUENCE")
|
---|
12 | S RMPRFDA(661.7,"+1,",6)=RMPR617("QUANTITY")
|
---|
13 | S RMPRFDA(661.7,"+1,",7)=RMPR617("VALUE")
|
---|
14 | S RMPRFDA(661.7,"+1,",3)=RMPR6111("ITEM")
|
---|
15 | S RMPRFDA(661.7,"+1,",4)=RMPR6111("STATION")
|
---|
16 | S RMPRFDA(661.7,"+1,",5)=RMPR617("LOCATION")
|
---|
17 | S RMPRFDA(661.7,"+1,",8)=$G(RMPR617("UNIT"))
|
---|
18 | D UPDATE^DIE("","RMPRFDA","RMPRIENA","RMPRFME")
|
---|
19 | I $D(RMPRFME) S RMPRRET=1
|
---|
20 | CREX Q RMPRRET
|
---|
21 | ;
|
---|
22 | ; UPD - Update existing record
|
---|
23 | UPD(RMPR617,RMPR6111) ;
|
---|
24 | N RMPRFDA,RMPRFME,RMPRERR,RMPRIEN,X,Y,DA
|
---|
25 | S RMPRERR=0
|
---|
26 | I $G(RMPR617("IEN"))="" S RMPRERR=1 G UPDX
|
---|
27 | I $D(RMPR617("QUANTITY")),RMPR617("QUANTITY")<1 S DA=RMPR617("IEN"),DIK="^RMPR(661.7," D ^DIK G UPDX
|
---|
28 | S RMPRIEN=RMPR617("IEN")_","
|
---|
29 | S:$D(RMPR6111("HCPCS")) RMPRFDA(661.7,RMPRIEN,.01)=RMPR6111("HCPCS")
|
---|
30 | S:$D(RMPR617("DATE&TIME")) RMPRFDA(661.7,RMPRIEN,1)=RMPR617("DATE&TIME")
|
---|
31 | S:$D(RMPR617("SEQUENCE")) RMPRFDA(661.7,RMPRIEN,2)=RMPR617("SEQUENCE")
|
---|
32 | S:$D(RMPR617("QUANTITY")) RMPRFDA(661.7,RMPRIEN,6)=RMPR617("QUANTITY")
|
---|
33 | S:$D(RMPR617("VALUE")) RMPRFDA(661.7,RMPRIEN,7)=RMPR617("VALUE")
|
---|
34 | S:$D(RMPR6111("ITEM")) RMPRFDA(661.7,RMPRIEN,3)=RMPR6111("ITEM")
|
---|
35 | S:$D(RMPR6111("STATION")) RMPRFDA(661.7,RMPRIEN,4)=RMPR6111("STATION")
|
---|
36 | S:$D(RMPR617("LOCATION")) RMPRFDA(661.7,RMPRIEN,5)=RMPR617("LOCATION")
|
---|
37 | S:$G(RMPR617("UNIT")) RMPRFDA(661.7,RMPRIEN,8)=RMPR617("UNIT")
|
---|
38 | D FILE^DIE("","RMPRFDA","RMPRFME")
|
---|
39 | I $D(RMPRFME) S RMPRERR=1
|
---|
40 | UPDX Q RMPRERR
|
---|
41 | ;
|
---|
42 | ; DEL - Delete a record
|
---|
43 | DEL(RMPR617) ;
|
---|
44 | N RMPRFDA,RMPRFME,RMPRERR,RMPRIEN,X,Y,DA
|
---|
45 | S RMPRERR=0
|
---|
46 | I $G(RMPR617("IEN"))="" S RMPRERR=1 G UPDX
|
---|
47 | S RMPRIEN=RMPR617("IEN")_","
|
---|
48 | S RMPRFDA(661.7,RMPRIEN,.01)="@"
|
---|
49 | D FILE^DIE("","RMPRFDA","RMPRFME")
|
---|
50 | I $D(RMPRFME) S RMPRERR=1
|
---|
51 | DELX Q RMPRERR
|
---|
52 | ;
|
---|
53 | ; GET - read in a 661.7 record
|
---|
54 | GET(RMPR) ;
|
---|
55 | N RMPRRET,RMPRFME,RMPRIEN,RMPRKEY,RMPRERR,RMPROUP
|
---|
56 | S RMPRRET=0
|
---|
57 | I $G(RMPR("IEN"))="" D
|
---|
58 | . I $G(RMPR("HCPCS"))="" S RMPRRET=1 Q
|
---|
59 | . I $G(RMPR("DATE&TIME"))="" S RMPRRET=2 Q
|
---|
60 | . S RMPRKEY("HCPCS")=RMPR("HCPCS")
|
---|
61 | . S RMPRKEY("DATE&TIME")=RMPR("DATE&TIME")
|
---|
62 | . S RMPRERR=$$NEXT^RMPRPIXE(.RMPRKEY,"XHDS","",-1,,.RMPREOF)
|
---|
63 | . I RMPRERR S RMPRRET=3 Q
|
---|
64 | . Q:'$D(RMPRKEY("SEQUENCE"))
|
---|
65 | . I RMPRKEY("SEQUENCE")'=1 S RMPRRET=4 Q
|
---|
66 | . S RMPR("IEN")=RMPRKEY("IEN")
|
---|
67 | . Q
|
---|
68 | I RMPRRET G GETX
|
---|
69 | S RMPRIEN=RMPR("IEN")_","
|
---|
70 | D GETS^DIQ(661.7,RMPRIEN,"*","","RMPROUP","RMPRFME")
|
---|
71 | I $D(RMPRFME) S RMPRRET=5 G GETX
|
---|
72 | S RMPR("HCPCS")=RMPROUP(661.7,RMPRIEN,.01)
|
---|
73 | S RMPR("DATE&TIME")=RMPROUP(661.7,RMPRIEN,1)
|
---|
74 | S RMPR("SEQUENCE")=RMPROUP(661.7,RMPRIEN,2)
|
---|
75 | S RMPR("QUANTITY")=RMPROUP(661.7,RMPRIEN,6)
|
---|
76 | S RMPR("VALUE")=RMPROUP(661.7,RMPRIEN,7)
|
---|
77 | S RMPR("ITEM")=RMPROUP(661.7,RMPRIEN,3)
|
---|
78 | S RMPR("STATION")=RMPROUP(661.7,RMPRIEN,4)
|
---|
79 | S RMPR("LOCATION")=RMPROUP(661.7,RMPRIEN,5)
|
---|
80 | S RMPR("UNIT")=RMPROUP(661.7,RMPRIEN,8)
|
---|
81 | GETX Q RMPRRET
|
---|
82 | ;
|
---|
83 | ; ETOI - Convert external 661.7 record to internal form
|
---|
84 | ETOI(RMPRE,RMPRI) ;
|
---|
85 | N RMPRFDA,RMPRIEN,RMPRFDI,RMPRFME,RMPRERR
|
---|
86 | S RMPRERR=0
|
---|
87 | S RMPRIEN=RMPRE("IEN")_","
|
---|
88 | D GETS^DIQ(661.7,RMPRIEN,"*","I","RMPRFDI","RMPRFME")
|
---|
89 | I $D(RMPRFME) S RMPRERR=1 G ETOIX
|
---|
90 | S RMPRI("IEN")=RMPRE("IEN")
|
---|
91 | S RMPRI("HCPCS")=RMPRFDI(661.7,RMPRIEN,.01,"I")
|
---|
92 | S RMPRI("DATE&TIME")=RMPRFDI(661.7,RMPRIEN,1,"I")
|
---|
93 | S RMPRI("ITEM")=RMPRFDI(661.7,RMPRIEN,3,"I")
|
---|
94 | S RMPRI("SEQUENCE")=RMPRFDI(661.7,RMPRIEN,2,"I")
|
---|
95 | S RMPRI("STATION")=RMPRFDI(661.7,RMPRIEN,4,"I")
|
---|
96 | S RMPRI("LOCATION")=RMPRFDI(661.7,RMPRIEN,5,"I")
|
---|
97 | S RMPRI("UNIT")=RMPRFDI(661.7,RMPRIEN,8,"I")
|
---|
98 | S RMPRI("QUANTITY")=RMPRFDI(661.7,RMPRIEN,6,"I")
|
---|
99 | S RMPRI("VALUE")=RMPRFDI(661.7,RMPRIEN,7,"I")
|
---|
100 | ETOIX Q RMPRERR
|
---|
101 | ;
|
---|
102 | ; RMUBA - read 661.7 records for total balance.
|
---|
103 | BAL(RMPR11) ;
|
---|
104 | N I,J,K,RS,RL,RH,RI,RD,RMB7,RM7
|
---|
105 | S RMUB=0
|
---|
106 | S RS=RMPR11("STATION")
|
---|
107 | S RL=RMPR11("LOCATION")
|
---|
108 | S RH=RMPR11("HCPCS")
|
---|
109 | S RI=RMPR11("ITEM")
|
---|
110 | F RD=0:0 S RD=$O(^RMPR(661.7,"XSLHIDS",RS,RL,RH,RI,RD)) Q:RD'>0 F I=0:0 S I=$O(^RMPR(661.7,"XSLHIDS",RS,RL,RH,RI,RD,1,I)) Q:I'>0 D
|
---|
111 | .Q:I'>0
|
---|
112 | .Q:'$D(^RMPR(661.7,I,0))
|
---|
113 | .S RM7=^RMPR(661.7,I,0)
|
---|
114 | .S RMB7=$P(RM7,U,7)
|
---|
115 | .S RMUB=RMUB+RMB7
|
---|
116 | Q RMUB
|
---|