| 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
 | 
|---|