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

ICPTID.m

Go to the documentation of this file.
  1. ICPTID ;SLC/KER - CPT IDENTIFIERS ; 04/18/2004
  1. ;;6.0;CPT/HCPCS;**19**;May 19, 1997
  1. ;
  1. ; External References
  1. ; DBIA 2056 $$GET1^DIQ
  1. ; DBIA 10103 $$DT^XLFDT
  1. ;
  1. Q
  1. ; Versioned Identifiers use the following
  1. ; input parameters:
  1. ;
  1. ; X Fileman's Internal Entry Number
  1. ; Y DD Field Number
  1. ;
  1. ; Format for using Identifiers
  1. ;
  1. ; ^DD(file,0,"ID",field)=
  1. ; D EN^DDIOL((" "_$$IDCP^ICPTID(+Y,field)),"","?0")
  1. ;
  1. IDCP(Y,X) ; CPT/HCPCS Identifiers (versioned)
  1. N FLD,MSG,CODE S FLD=+($G(X)),Y=+($G(Y)) Q:+FLD'>0 "" Q:+Y'>0 ""
  1. S:'$D(DT) DT=$$DT^XLFDT I '$D(ICPTVDT) N ICPTVDT S ICPTVDT=DT
  1. S MSG=$$MSG^ICPTSUPT($G(ICPTVDT),1),CODE=$P($G(^ICPT(+Y,0)),U,1)
  1. I FLD=2 S X=$$VSTCP^ICPTCOD(+Y,$G(ICPTVDT))_$S($L(MSG):(" ("_MSG_")"),1:"") Q X
  1. I FLD=5 S X=$$STA(+($$STATCHK^ICPTAPIU(CODE,$G(ICPTVDT)))) Q X
  1. I FLD=50!(FLD=60)!(FLD=61)!(FLD=62) Q ""
  1. S X=$$GET1^DIQ(81,(+($G(Y))_","),FLD)
  1. Q X
  1. IDCPS(Y) ; CPT/HCPCS Identifiers (versioned - short)
  1. N ICID,MSG,CODE,ST,X S Y=+($G(Y)) Q:+Y'>0 ""
  1. S:'$D(DT) DT=$$DT^XLFDT I '$D(ICPTVDT) N ICPTVDT S ICPTVDT=DT
  1. S MSG=$$MSG^ICPTSUPT($G(ICPTVDT),1) S:MSG["CODE " MSG="Text may be inaccurate"
  1. S CODE=$P($G(^ICPT(+Y,0)),U,1)
  1. S ICID=$$VSTCP^ICPTCOD(+Y,$G(ICPTVDT)) S:$L(MSG) ICID=ICID_" ("_MSG_")"
  1. S ST=$$STA(+($$STATCHK^ICPTAPIU(CODE,$G(ICPTVDT))))
  1. S:$L(ST) ICID=ICID_$S('$L(MSG):" ",1:"")_" "_ST
  1. F Q:$E(ICID,1)'=" " S ICID=$E(ICID,2,$L(ICID))
  1. S Y=ICID
  1. Q Y
  1. IDMD(Y,X) ; CPT Modifier Identifiers (versioned)
  1. N FLD,MSG,CODE S FLD=+($G(X)),Y=+($G(Y)) Q:+FLD'>0 "" Q:+Y'>0 ""
  1. S:'$D(DT) DT=$$DT^XLFDT I '$D(ICPTVDT) N ICPTVDT S ICPTVDT=DT
  1. S MSG=$$MSG^ICPTSUPT($G(ICPTVDT),1)
  1. I FLD=.02 S X=$$VSTCM^ICPTMOD(+Y,$G(ICPTVDT))_$S($L(MSG):(" ("_MSG_")"),1:"") Q X
  1. I FLD=5 D Q X
  1. . N VD,I S VD=$O(^DIC(81.3,+Y,60,"B"," "),-1)
  1. . S I=+($O(^DIC(81.3,+Y,60,"B",+VD," "),-1))
  1. . S X=$$STA(+($P($G(^DIC(81.3,+Y,60,+I,0)),U,2)))
  1. I FLD=10!(FLD=50)!(FLD=60)!(FLD=61)!(FLD=62) Q ""
  1. S X=$$GET1^DIQ(81.3,(+($G(Y))_","),FLD)
  1. Q X
  1. IDMDS(Y) ; CPT Modifier Identifiers (versioned - short)
  1. N ICID,MSG,CODE,ST,X,VD,VI S Y=+($G(Y)) Q:+Y'>0 ""
  1. S:'$D(DT) DT=$$DT^XLFDT I '$D(ICPTVDT) N ICPTVDT S ICPTVDT=DT
  1. S MSG=$$MSG^ICPTSUPT($G(ICPTVDT),1) S:MSG["CODE " MSG="Text may be inaccurate"
  1. S ICID=$$VSTCM^ICPTMOD(+Y,$G(ICPTVDT)) S:$L(MSG) ICID=ICID_" ("_MSG_")"
  1. S VD=$O(^DIC(81.3,+Y,60,"B"," "),-1)
  1. S VI=+($O(^DIC(81.3,+Y,60,"B",+VD," "),-1))
  1. S ST=$$STA(+($P($G(^DIC(81.3,+Y,60,+VI,0)),U,2)))
  1. S:$L(ST) ICID=ICID_$S('$L(MSG):" ",1:"")_" "_ST
  1. F Q:$E(ICID,1)'=" " S ICID=$E(ICID,2,$L(ICID))
  1. S Y=ICID
  1. Q Y
  1. STA(X) ; Status
  1. Q $S(+($G(X)):"",1:"INACTIVE")