Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: RMPRPIX7

RMPRPIX7.m

Go to the documentation of this file.
  1. RMPRPIX7 ;HINCIO/ODJ - PIP CURRENT INVENTORY FILE 661.7 APIs ;3/8/01
  1. ;;3.0;PROSTHETICS;**61**;Feb 09, 1996
  1. Q
  1. ;
  1. ; CRE - create a new 661.7 record
  1. CRE(RMPR617,RMPR6111) ;
  1. N RMPRFDA,RMPRFME,RMPRRET,RMPRIENA,X,Y,DA
  1. S RMPRRET=0
  1. S RMPRFDA(661.7,"+1,",.01)=RMPR6111("HCPCS")
  1. S RMPRFDA(661.7,"+1,",1)=RMPR617("DATE&TIME")
  1. S RMPRFDA(661.7,"+1,",2)=RMPR617("SEQUENCE")
  1. S RMPRFDA(661.7,"+1,",6)=RMPR617("QUANTITY")
  1. S RMPRFDA(661.7,"+1,",7)=RMPR617("VALUE")
  1. S RMPRFDA(661.7,"+1,",3)=RMPR6111("ITEM")
  1. S RMPRFDA(661.7,"+1,",4)=RMPR6111("STATION")
  1. S RMPRFDA(661.7,"+1,",5)=RMPR617("LOCATION")
  1. S RMPRFDA(661.7,"+1,",8)=$G(RMPR617("UNIT"))
  1. D UPDATE^DIE("","RMPRFDA","RMPRIENA","RMPRFME")
  1. I $D(RMPRFME) S RMPRRET=1
  1. CREX Q RMPRRET
  1. ;
  1. ; UPD - Update existing record
  1. UPD(RMPR617,RMPR6111) ;
  1. N RMPRFDA,RMPRFME,RMPRERR,RMPRIEN,X,Y,DA
  1. S RMPRERR=0
  1. I $G(RMPR617("IEN"))="" S RMPRERR=1 G UPDX
  1. I $D(RMPR617("QUANTITY")),RMPR617("QUANTITY")<1 S DA=RMPR617("IEN"),DIK="^RMPR(661.7," D ^DIK G UPDX
  1. S RMPRIEN=RMPR617("IEN")_","
  1. S:$D(RMPR6111("HCPCS")) RMPRFDA(661.7,RMPRIEN,.01)=RMPR6111("HCPCS")
  1. S:$D(RMPR617("DATE&TIME")) RMPRFDA(661.7,RMPRIEN,1)=RMPR617("DATE&TIME")
  1. S:$D(RMPR617("SEQUENCE")) RMPRFDA(661.7,RMPRIEN,2)=RMPR617("SEQUENCE")
  1. S:$D(RMPR617("QUANTITY")) RMPRFDA(661.7,RMPRIEN,6)=RMPR617("QUANTITY")
  1. S:$D(RMPR617("VALUE")) RMPRFDA(661.7,RMPRIEN,7)=RMPR617("VALUE")
  1. S:$D(RMPR6111("ITEM")) RMPRFDA(661.7,RMPRIEN,3)=RMPR6111("ITEM")
  1. S:$D(RMPR6111("STATION")) RMPRFDA(661.7,RMPRIEN,4)=RMPR6111("STATION")
  1. S:$D(RMPR617("LOCATION")) RMPRFDA(661.7,RMPRIEN,5)=RMPR617("LOCATION")
  1. S:$G(RMPR617("UNIT")) RMPRFDA(661.7,RMPRIEN,8)=RMPR617("UNIT")
  1. D FILE^DIE("","RMPRFDA","RMPRFME")
  1. I $D(RMPRFME) S RMPRERR=1
  1. UPDX Q RMPRERR
  1. ;
  1. ; DEL - Delete a record
  1. DEL(RMPR617) ;
  1. N RMPRFDA,RMPRFME,RMPRERR,RMPRIEN,X,Y,DA
  1. S RMPRERR=0
  1. I $G(RMPR617("IEN"))="" S RMPRERR=1 G UPDX
  1. S RMPRIEN=RMPR617("IEN")_","
  1. S RMPRFDA(661.7,RMPRIEN,.01)="@"
  1. D FILE^DIE("","RMPRFDA","RMPRFME")
  1. I $D(RMPRFME) S RMPRERR=1
  1. DELX Q RMPRERR
  1. ;
  1. ; GET - read in a 661.7 record
  1. GET(RMPR) ;
  1. N RMPRRET,RMPRFME,RMPRIEN,RMPRKEY,RMPRERR,RMPROUP
  1. S RMPRRET=0
  1. I $G(RMPR("IEN"))="" D
  1. . I $G(RMPR("HCPCS"))="" S RMPRRET=1 Q
  1. . I $G(RMPR("DATE&TIME"))="" S RMPRRET=2 Q
  1. . S RMPRKEY("HCPCS")=RMPR("HCPCS")
  1. . S RMPRKEY("DATE&TIME")=RMPR("DATE&TIME")
  1. . S RMPRERR=$$NEXT^RMPRPIXE(.RMPRKEY,"XHDS","",-1,,.RMPREOF)
  1. . I RMPRERR S RMPRRET=3 Q
  1. . Q:'$D(RMPRKEY("SEQUENCE"))
  1. . I RMPRKEY("SEQUENCE")'=1 S RMPRRET=4 Q
  1. . S RMPR("IEN")=RMPRKEY("IEN")
  1. . Q
  1. I RMPRRET G GETX
  1. S RMPRIEN=RMPR("IEN")_","
  1. D GETS^DIQ(661.7,RMPRIEN,"*","","RMPROUP","RMPRFME")
  1. I $D(RMPRFME) S RMPRRET=5 G GETX
  1. S RMPR("HCPCS")=RMPROUP(661.7,RMPRIEN,.01)
  1. S RMPR("DATE&TIME")=RMPROUP(661.7,RMPRIEN,1)
  1. S RMPR("SEQUENCE")=RMPROUP(661.7,RMPRIEN,2)
  1. S RMPR("QUANTITY")=RMPROUP(661.7,RMPRIEN,6)
  1. S RMPR("VALUE")=RMPROUP(661.7,RMPRIEN,7)
  1. S RMPR("ITEM")=RMPROUP(661.7,RMPRIEN,3)
  1. S RMPR("STATION")=RMPROUP(661.7,RMPRIEN,4)
  1. S RMPR("LOCATION")=RMPROUP(661.7,RMPRIEN,5)
  1. S RMPR("UNIT")=RMPROUP(661.7,RMPRIEN,8)
  1. GETX Q RMPRRET
  1. ;
  1. ; ETOI - Convert external 661.7 record to internal form
  1. ETOI(RMPRE,RMPRI) ;
  1. N RMPRFDA,RMPRIEN,RMPRFDI,RMPRFME,RMPRERR
  1. S RMPRERR=0
  1. S RMPRIEN=RMPRE("IEN")_","
  1. D GETS^DIQ(661.7,RMPRIEN,"*","I","RMPRFDI","RMPRFME")
  1. I $D(RMPRFME) S RMPRERR=1 G ETOIX
  1. S RMPRI("IEN")=RMPRE("IEN")
  1. S RMPRI("HCPCS")=RMPRFDI(661.7,RMPRIEN,.01,"I")
  1. S RMPRI("DATE&TIME")=RMPRFDI(661.7,RMPRIEN,1,"I")
  1. S RMPRI("ITEM")=RMPRFDI(661.7,RMPRIEN,3,"I")
  1. S RMPRI("SEQUENCE")=RMPRFDI(661.7,RMPRIEN,2,"I")
  1. S RMPRI("STATION")=RMPRFDI(661.7,RMPRIEN,4,"I")
  1. S RMPRI("LOCATION")=RMPRFDI(661.7,RMPRIEN,5,"I")
  1. S RMPRI("UNIT")=RMPRFDI(661.7,RMPRIEN,8,"I")
  1. S RMPRI("QUANTITY")=RMPRFDI(661.7,RMPRIEN,6,"I")
  1. S RMPRI("VALUE")=RMPRFDI(661.7,RMPRIEN,7,"I")
  1. ETOIX Q RMPRERR
  1. ;
  1. ; RMUBA - read 661.7 records for total balance.
  1. BAL(RMPR11) ;
  1. N I,J,K,RS,RL,RH,RI,RD,RMB7,RM7
  1. S RMUB=0
  1. S RS=RMPR11("STATION")
  1. S RL=RMPR11("LOCATION")
  1. S RH=RMPR11("HCPCS")
  1. S RI=RMPR11("ITEM")
  1. 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
  1. .Q:I'>0
  1. .Q:'$D(^RMPR(661.7,I,0))
  1. .S RM7=^RMPR(661.7,I,0)
  1. .S RMB7=$P(RM7,U,7)
  1. .S RMUB=RMUB+RMB7
  1. Q RMUB