| [613] | 1 | EC725U31 ;ALB/GTS/JAP/GT - EC National Procedure Update; 1/05/2005
 | 
|---|
 | 2 |  ;;2.0; EVENT CAPTURE ;**71**;8 May 96
 | 
|---|
 | 3 |  ;
 | 
|---|
 | 4 |  ;this routine is used as a post-init in KIDS build 
 | 
|---|
 | 5 |  ;to modify the the EC National Procedure file #725
 | 
|---|
 | 6 |  ;
 | 
|---|
 | 7 | INACT ;* inactivate national procedures
 | 
|---|
 | 8 |  ;
 | 
|---|
 | 9 |  ;  ECXX is in format:
 | 
|---|
 | 10 |  ;   NATIONAL NUMBER^INACTIVATION DATE^FIRST NATIONAL NUMBER SEQUENCE^
 | 
|---|
 | 11 |  ;   LAST NATIONAL NUMBER SEQUENCE
 | 
|---|
 | 12 |  ;
 | 
|---|
 | 13 |  N ECX,ECXX,ECEXDT,ECINDT,ECDA,DIC,DIE,DA,DR,X,Y,%DT,ECBEG,ECEND,ECADD
 | 
|---|
 | 14 |  N ECSEQ,CODE,CODX
 | 
|---|
 | 15 |  D MES^XPDUTL(" ")
 | 
|---|
 | 16 |  D BMES^XPDUTL("Inactivating procedures EC NATIONAL PROCEDURE File (#725)...")
 | 
|---|
 | 17 |  D MES^XPDUTL(" ")
 | 
|---|
 | 18 |  F ECX=1:1 K DD,DO,DA S ECXX=$P($T(OLD+ECX),";;",2) Q:ECXX="QUIT"  D
 | 
|---|
 | 19 |  .S ECEXDT=$P(ECXX,U,2),X=ECEXDT,%DT="X" D ^%DT S ECINDT=$P(Y,".",1)
 | 
|---|
 | 20 |  .S CODE=$P(ECXX,U),ECBEG=$P(ECXX,U,3),ECEND=$P(ECXX,U,4),CODX=CODE
 | 
|---|
 | 21 |  .I ECBEG="" D UPINACT Q
 | 
|---|
 | 22 |  .F ECSEQ=ECBEG:1:ECEND D
 | 
|---|
 | 23 |  ..S ECADD="000"_ECSEQ,ECADD=$E(ECADD,$L(ECADD)-2,$L(ECADD))
 | 
|---|
 | 24 |  ..S CODE=CODX_ECADD
 | 
|---|
 | 25 |  ..D UPINACT
 | 
|---|
 | 26 |  Q
 | 
|---|
 | 27 | UPINACT ;Update codes as inactive
 | 
|---|
 | 28 |  ;
 | 
|---|
 | 29 |  S ECDA=+$O(^EC(725,"D",CODE,0))
 | 
|---|
 | 30 |  I $D(^EC(725,ECDA,0)) D
 | 
|---|
 | 31 |  .S DA=ECDA,DR="2////^S X=ECINDT",DIE="^EC(725," D ^DIE
 | 
|---|
 | 32 |  .D MES^XPDUTL(" ")
 | 
|---|
 | 33 |  .D BMES^XPDUTL("   "_CODE_" inactivated as of "_ECEXDT_".")
 | 
|---|
 | 34 |  Q
 | 
|---|
 | 35 |  ;
 | 
|---|
 | 36 | OLD ;national procedures to be inactivated - national code #^inact. date
 | 
|---|
 | 37 |  ;;SP009^1/1/2005
 | 
|---|
 | 38 |  ;;QUIT
 | 
|---|
 | 39 |  ;
 | 
|---|
 | 40 | REACT ;* reactivate national procedures
 | 
|---|
 | 41 |  ;
 | 
|---|
 | 42 |  ;  ECXX is in format:
 | 
|---|
 | 43 |  ;   NATIONAL NUMBER^DATE (FUTURE)^FIRST NATIONAL NUMBER SEQUENCE^
 | 
|---|
 | 44 |  ;   LAST NATIONAL NUMBER SEQUENCE
 | 
|---|
 | 45 |  ;
 | 
|---|
 | 46 |  N ECX,ECXX,ECEXDT,ECINDT,ECDA,DIC,DIE,DA,DR,X,Y,%DT,ECBEG,ECEND,ECADD
 | 
|---|
 | 47 |  N ECSEQ,CODE,CODX,ECDES
 | 
|---|
 | 48 |  D MES^XPDUTL(" ")
 | 
|---|
 | 49 |  D BMES^XPDUTL("Reactivating procedures EC NATIONAL PROCEDURE File (#725)...")
 | 
|---|
 | 50 |  D MES^XPDUTL(" ")
 | 
|---|
 | 51 |  F ECX=1:1 K DD,DO,DA S ECXX=$P($T(ACT+ECX),";;",2) Q:ECXX="QUIT"  D
 | 
|---|
 | 52 |  .S ECDES=$P(ECXX,U,5)
 | 
|---|
 | 53 |  .S CODE=$P(ECXX,U),ECBEG=$P(ECXX,U,3),ECEND=$P(ECXX,U,4),CODX=CODE
 | 
|---|
 | 54 |  .I ECBEG="" D UPREACT Q
 | 
|---|
 | 55 |  .F ECSEQ=ECBEG:1:ECEND D
 | 
|---|
 | 56 |  ..S ECADD="000"_ECSEQ,ECADD=$E(ECADD,$L(ECADD)-2,$L(ECADD))
 | 
|---|
 | 57 |  ..S CODE=CODX_ECADD
 | 
|---|
 | 58 |  ..D UPREACT
 | 
|---|
 | 59 |  Q
 | 
|---|
 | 60 | UPREACT ;Update codes as reactive
 | 
|---|
 | 61 |  ;
 | 
|---|
 | 62 |  S ECDA=+$O(^EC(725,"D",CODE,0))
 | 
|---|
 | 63 |  I $D(^EC(725,ECDA,0)) D
 | 
|---|
 | 64 |  .S DA=ECDA,DR="2///@",DIE="^EC(725," D ^DIE
 | 
|---|
 | 65 |  .D BMES^XPDUTL("   "_CODE_" "_ECDES_" reactivated.")
 | 
|---|
 | 66 |  Q
 | 
|---|
 | 67 |  ;
 | 
|---|
 | 68 | ACT ;national procedures to be reactivated - national number^date
 | 
|---|
 | 69 |  ;;QUIT
 | 
|---|
 | 70 |  ;
 | 
|---|
 | 71 | CPTCHG ;* change cpt codes
 | 
|---|
 | 72 |  ;
 | 
|---|
 | 73 |  ;  ECXX is in format:
 | 
|---|
 | 74 |  ;  NATIONAL NUMBER^NEW CPT^FIRST NATIONAL NUMBER SEQUENCE^LAST NATIONAL
 | 
|---|
 | 75 |  ;  NUMBER SEQUENCE
 | 
|---|
 | 76 |  ;
 | 
|---|
 | 77 |  N ECX,ECXX,CPT,DIC,DIE,DA,DR,X,Y,ECBEG,ECEND,ECADD,NAME,ECSEQ,STR,CPTIEN
 | 
|---|
 | 78 |  D MES^XPDUTL(" ")
 | 
|---|
 | 79 |  D BMES^XPDUTL("Changing CPT Codes in EC NATIONAL PROCEDURE file (#725)")
 | 
|---|
 | 80 |  D MES^XPDUTL(" ")
 | 
|---|
 | 81 |  F ECX=1:1 S ECXX=$P($T(CPT+ECX),";;",2) Q:ECXX="QUIT"  D
 | 
|---|
 | 82 |  .S ECBEG=$P(ECXX,U,3),ECEND=$P(ECXX,U,4),CPTIEN=$P(ECXX,U,2)
 | 
|---|
 | 83 |  .S CPTIEN=$S(CPTIEN="":"@",1:$$FIND1^DIC(81,"","X",CPTIEN))
 | 
|---|
 | 84 |  .I CPTIEN'="@",+CPTIEN<1 D  Q
 | 
|---|
 | 85 |  ..S STR=$P(ECXX,U)_":  CPT code "_$P(ECXX,U,2)_" is invalid."
 | 
|---|
 | 86 |  ..D MES^XPDUTL(" ")
 | 
|---|
 | 87 |  ..D BMES^XPDUTL("   "_STR)
 | 
|---|
 | 88 |  .I ECBEG="" S CPT($P(ECXX,U))=CPTIEN_U_$P(ECXX,U,2) Q
 | 
|---|
 | 89 |  .F ECSEQ=ECBEG:1:ECEND D
 | 
|---|
 | 90 |  ..S ECADD="000"_ECSEQ,ECADD=$E(ECADD,$L(ECADD)-2,$L(ECADD))
 | 
|---|
 | 91 |  ..S CPT($P(ECXX,U)_ECADD)=CPTIEN_U_$P(ECXX,U,2)
 | 
|---|
 | 92 |  S ECXX=""
 | 
|---|
 | 93 |  F  S ECXX=$O(CPT(ECXX)) Q:ECXX=""  D
 | 
|---|
 | 94 |  .S ECX=$O(^EC(725,"D",ECXX,0))
 | 
|---|
 | 95 |  .Q:+ECX=0
 | 
|---|
 | 96 |  .I '$D(^EC(725,ECX,0))!(+ECX=0) D  Q
 | 
|---|
 | 97 |  ..D MES^XPDUTL(" ")
 | 
|---|
 | 98 |  ..D BMES^XPDUTL("   Can't find entry for "_ECXX_",CPT cde not updated.")
 | 
|---|
 | 99 |  .S CPT=$P(CPT(ECXX),U),DA=ECX,DR="4////"_CPT,DIE="^EC(725," D ^DIE
 | 
|---|
 | 100 |  .D MES^XPDUTL(" ")
 | 
|---|
 | 101 |  .S STR="   Entry #"_ECX_" for "_ECXX
 | 
|---|
 | 102 |  .D BMES^XPDUTL(STR_" updated to use CPT code "_$P(CPT(ECXX),U,2))
 | 
|---|
 | 103 |  Q
 | 
|---|
 | 104 |  ;
 | 
|---|
 | 105 | CPT ;cpt codes to be changed - national #^new CPT code
 | 
|---|
 | 106 |  ;;SP003^92625
 | 
|---|
 | 107 |  ;;SP004^92700
 | 
|---|
 | 108 |  ;;SP007^92700
 | 
|---|
 | 109 |  ;;SP008^92700
 | 
|---|
 | 110 |  ;;SP026^92700
 | 
|---|
 | 111 |  ;;SP100^92620
 | 
|---|
 | 112 |  ;;SP268^92700
 | 
|---|
 | 113 |  ;;SP269^92700
 | 
|---|
 | 114 |  ;;SP287^92700
 | 
|---|
 | 115 |  ;;SP288^92700
 | 
|---|
 | 116 |  ;;SP317^92621
 | 
|---|
 | 117 |  ;;QUIT
 | 
|---|