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

PXAICPT.m

Go to the documentation of this file.
  1. PXAICPT ;ISL/JVS,PKR,ISA/KWP,ESW,SCK - SET THE PROCEDURE(CPT) NODES ;01/26/2021
  1. ;;1.0;PCE PATIENT CARE ENCOUNTER;**19,73,108,112,149,124,164,194,211**;Aug 12, 1996;Build 454
  1. ;
  1. Q
  1. CPT ;
  1. SET ;--SET AND NEW VARIABLES
  1. N AFTER0,AFTER1,AFTER12,AFTER801,AFTER802,AFTER811,AFTER812
  1. N BEFOR0,BEFOR1,BEFOR12,BEFOR801,BEFOR802,BEFOR811,BEFOR812
  1. N EVENTDT,PXAA,PXAB,SUB,PIECE,IENB,STOP
  1. K PXAERR
  1. S PXAERR(8)=PXAK
  1. S PXAERR(7)="PROCEDURE"
  1. ;
  1. S SUB="" F S SUB=$O(@PXADATA@("PROCEDURE",PXAK,SUB)) Q:SUB="" D
  1. .S PXAA(SUB)=$G(@PXADATA@("PROCEDURE",PXAK,SUB))
  1. ;Setup PXAA array for Modifiers
  1. S SUB=""
  1. F S SUB=$O(@PXADATA@("PROCEDURE",PXAK,"MODIFIERS",SUB)) Q:SUB="" D
  1. .S PXAA("MODIFIERS",SUB)=""
  1. ;
  1. VAL ;--VALIDATE ENOUGH DATA
  1. D VAL^PXAICPTV Q:$G(STOP)
  1. ;
  1. SETVARA ;--SET V CPT VARIABLES
  1. S $P(AFTER0,U,1)=$G(PXAA("PROCEDURE"))
  1. I $G(PXAA("DELETE")) S $P(AFTER0,U,1)="@"
  1. S $P(AFTER0,U,2)=$G(PATIENT)
  1. S $P(AFTER0,U,3)=$G(PXAVISIT)
  1. ;If Provider Narrative is not passed or is too long use the
  1. ;CPT short description.
  1. I ($G(PXAA("NARRATIVE"))="")!($L($G(PXAA("NARRATIVE")))>245) D
  1. .S EVENTDT=$G(PXAA("EVENT D/T"))
  1. .I EVENTDT="" S EVENTDT=$P(^AUPNVSIT(PXAVISIT,0),U,1)
  1. .S PXAA("NARRATIVE")=$P($$CPT^ICPTCOD($G(PXAA("PROCEDURE")),EVENTDT),U,3)
  1. ;Get the Provider Narrative pointer.
  1. S $P(AFTER0,U,4)=+$$PROVNARR^PXAPI($G(PXAA("NARRATIVE")),9000010.18)
  1. I $P(AFTER0,U,4)'>0 D VAL04^PXAICPTV,ERR^PXAI("NARRATIVE",1) Q:$D(STOP)
  1. S $P(AFTER0,U,5)=$G(PXAA("DIAGNOSIS"))
  1. ;PX*1*124 - add dx
  1. S $P(AFTER0,U,9)=$G(PXAA("DIAGNOSIS 2"))
  1. S $P(AFTER0,U,10)=$G(PXAA("DIAGNOSIS 3"))
  1. S $P(AFTER0,U,11)=$G(PXAA("DIAGNOSIS 4"))
  1. S $P(AFTER0,U,12)=$G(PXAA("DIAGNOSIS 5"))
  1. S $P(AFTER0,U,13)=$G(PXAA("DIAGNOSIS 6"))
  1. S $P(AFTER0,U,14)=$G(PXAA("DIAGNOSIS 7"))
  1. S $P(AFTER0,U,15)=$G(PXAA("DIAGNOSIS 8"))
  1. I $G(PXAA("QTY"))="" S PXAA("QTY")=1
  1. S $P(AFTER0,U,16)=$G(PXAA("QTY")) I $G(PXAA("QTY"))<1 S PXAA("DELETE")=1
  1. S $P(AFTER0,U,17)=$G(PXAA("ORD REFERENCE"))
  1. I $$SWSTAT^IBBAPI() D ;PX*1.0*164
  1. . S $P(AFTER0,U,19)=$G(PXAA("DEPARTMENT"))
  1. . I $P(AFTER0,U,19)="",$G(^AUPNVSIT(PXAVISIT,0)),$P(^AUPNVSIT(PXAVISIT,0),U,8) S $P(AFTER0,U,19)=$P($G(^DIC(40.7,$P(^AUPNVSIT(PXAVISIT,0),U,8),0)),U,2)
  1. ;
  1. S $P(AFTER12,U,1)=$G(PXAA("EVENT D/T"))
  1. ;PX*1*124 - add ord prv
  1. S $P(AFTER12,U,2)=$G(PXAA("ORD PROVIDER"))
  1. S $P(AFTER12,U,4)=$G(PXAA("ENC PROVIDER"))
  1. ;PX*1*108 - do not try to file a provider from a "DELETED" cpt
  1. I $G(PXAA("ENC PROVIDER"))]"",'$G(PXAA("DELETE")) D
  1. .S ^TMP("PXAIADDPRV",$J,$G(PXAA("ENC PROVIDER")))="ENC"
  1. ;PX*1*124 - do not try to file a provider from a "DELETED" cpt
  1. I $G(PXAA("ORD PROVIDER"))]"",'$G(PXAA("DELETE")) D
  1. .S ^TMP("PXAIADDPRV",$J,$G(PXAA("ORD PROVIDER")))="ORD"
  1. ;
  1. I $G(PXAA("CATEGORY"))="" S $P(AFTER802,U,1)=""
  1. E D
  1. . S $P(AFTER802,U,1)=+$$PROVNARR^PXAPI(PXAA("CATEGORY"),9000010.18)
  1. . I $P(AFTER802,U,1)'>0 D
  1. .. D VAL802^PXAICPTV,ERR^PXAI("CATEGORY",1)
  1. .. S $P(AFTER802,U,1)=""
  1. ;
  1. S $P(AFTER811,U,1)=$G(PXAA("COMMENT"))
  1. ;
  1. ;--PACKAGE AND SOURCE
  1. S $P(AFTER812,U,2)=$S($G(PXAA("PKG"))'="":PXAA("PKG"),1:$G(PXAPKG))
  1. S $P(AFTER812,U,3)=$S($G(PXAA("SOURCE"))'="":PXAA("SOURCE"),1:$G(PXASOURC))
  1. ;
  1. N PXBKY,PXBSAM,PXBSKY,PXBCNT,PXI,PRV,ITEM
  1. D CPT^PXBGCPT(PXAVISIT)
  1. S ITEM=""
  1. I PXBCNT>0,$G(PXAA("PROCEDURE"))]"" S ITEM=$O(PXBKY(PXAA("PROCEDURE"),0))
  1. S IENB=+$S(ITEM'="":$O(PXBSKY(ITEM,"")),1:0)
  1. ;
  1. SETPXKA ;--SET PXK ARRAY AFTER
  1. S ^TMP("PXK",$J,"CPT",PXAK,0,"AFTER")=AFTER0
  1. D SETPXKA^PXAIMOD(IENB,PXAK,.PXAA)
  1. S ^TMP("PXK",$J,"CPT",PXAK,12,"AFTER")=AFTER12
  1. S ^TMP("PXK",$J,"CPT",PXAK,802,"AFTER")=AFTER802
  1. S ^TMP("PXK",$J,"CPT",PXAK,811,"AFTER")=AFTER811
  1. S ^TMP("PXK",$J,"CPT",PXAK,812,"AFTER")=AFTER812
  1. ;
  1. SETVARB ;--SET VARIABLES BEFORE
  1. I IENB>0 D
  1. .S ^TMP("PXK",$J,"CPT",PXAK,"IEN")=IENB
  1. .F PIECE=0,12,802,811,812 S ^TMP("PXK",$J,"CPT",PXAK,PIECE,"BEFORE")=$G(^AUPNVCPT(IENB,PIECE))
  1. E D
  1. .S (BEFOR0,BEFOR12,BEFOR802,BEFOR811,BEFOR812)=""
  1. .;
  1. SETPXKB .;--SET PXK ARRAY BEFORE
  1. .S ^TMP("PXK",$J,"CPT",PXAK,0,"BEFORE")=BEFOR0
  1. .S ^TMP("PXK",$J,"CPT",PXAK,12,"BEFORE")=BEFOR12
  1. .S ^TMP("PXK",$J,"CPT",PXAK,802,"BEFORE")=BEFOR802
  1. .S ^TMP("PXK",$J,"CPT",PXAK,811,"BEFORE")=BEFOR811
  1. .S ^TMP("PXK",$J,"CPT",PXAK,812,"BEFORE")=BEFOR812
  1. .S ^TMP("PXK",$J,"CPT",PXAK,"IEN")=$S(IENB>0:IENB,1:"")
  1. D SETPXKB^PXAIMOD(IENB,PXAK,.PXAA)
  1. ;
  1. ;Package and Data Source cannot be edited.
  1. S BEFOR812=^TMP("PXK",$J,"CPT",PXAK,812,"BEFORE")
  1. I BEFOR812'="" D
  1. . I AFTER812=BEFOR812 Q
  1. . I $P(BEFOR812,U,2)'="" S $P(AFTER812,U,2)=$P(BEFOR812,U,2)
  1. . I $P(BEFOR812,U,3)'="" S $P(AFTER812,U,3)=$P(BEFOR812,U,3)
  1. . S ^TMP("PXK",$J,"CPT",PXAK,812,"AFTER")=AFTER812
  1. ;
  1. MISC ;--MISCELLANEOUS NODE
  1. ;
  1. Q