| [613] | 1 | EC725U27 ;ALB/GTS/JAP/GT - EC National Procedure Update; 9/11/2003 | 
|---|
|  | 2 | ;;2.0; EVENT CAPTURE ;**67**;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 | ;;SP497^01/01/2004 | 
|---|
|  | 38 | ;;SP498^01/01/2004 | 
|---|
|  | 39 | ;;SP499^01/01/2004 | 
|---|
|  | 40 | ;;QUIT | 
|---|
|  | 41 | ; | 
|---|
|  | 42 | REACT ;* reactivate national procedures | 
|---|
|  | 43 | ; | 
|---|
|  | 44 | ;  ECXX is in format: | 
|---|
|  | 45 | ;   NATIONAL NUMBER^DATE (FUTURE)^FIRST NATIONAL NUMBER SEQUENCE^ | 
|---|
|  | 46 | ;   LAST NATIONAL NUMBER SEQUENCE | 
|---|
|  | 47 | ; | 
|---|
|  | 48 | N ECX,ECXX,ECEXDT,ECINDT,ECDA,DIC,DIE,DA,DR,X,Y,%DT,ECBEG,ECEND,ECADD | 
|---|
|  | 49 | N ECSEQ,CODE,CODX,ECDES | 
|---|
|  | 50 | D MES^XPDUTL(" ") | 
|---|
|  | 51 | D BMES^XPDUTL("Reactivating procedures EC NATIONAL PROCEDURE File (#725)...") | 
|---|
|  | 52 | D MES^XPDUTL(" ") | 
|---|
|  | 53 | F ECX=1:1 K DD,DO,DA S ECXX=$P($T(ACT+ECX),";;",2) Q:ECXX="QUIT"  D | 
|---|
|  | 54 | .S ECDES=$P(ECXX,U,5) | 
|---|
|  | 55 | .S CODE=$P(ECXX,U),ECBEG=$P(ECXX,U,3),ECEND=$P(ECXX,U,4),CODX=CODE | 
|---|
|  | 56 | .I ECBEG="" D UPREACT Q | 
|---|
|  | 57 | .F ECSEQ=ECBEG:1:ECEND D | 
|---|
|  | 58 | ..S ECADD="000"_ECSEQ,ECADD=$E(ECADD,$L(ECADD)-2,$L(ECADD)) | 
|---|
|  | 59 | ..S CODE=CODX_ECADD | 
|---|
|  | 60 | ..D UPREACT | 
|---|
|  | 61 | Q | 
|---|
|  | 62 | UPREACT ;Update codes as reactive | 
|---|
|  | 63 | ; | 
|---|
|  | 64 | S ECDA=+$O(^EC(725,"D",CODE,0)) | 
|---|
|  | 65 | I $D(^EC(725,ECDA,0)) D | 
|---|
|  | 66 | .S DA=ECDA,DR="2///@",DIE="^EC(725," D ^DIE | 
|---|
|  | 67 | .D BMES^XPDUTL("   "_CODE_" "_ECDES_" reactivated.") | 
|---|
|  | 68 | Q | 
|---|
|  | 69 | ; | 
|---|
|  | 70 | ACT ;national procedures to be reactivated - national number^date | 
|---|
|  | 71 | ;;SP457^10/1/2004 | 
|---|
|  | 72 | ;;QUIT | 
|---|
|  | 73 | ; | 
|---|
|  | 74 | CPTCHG ;* change cpt codes | 
|---|
|  | 75 | ; | 
|---|
|  | 76 | ;  ECXX is in format: | 
|---|
|  | 77 | ;  NATIONAL NUMBER^NEW CPT^FIRST NATIONAL NUMBER SEQUENCE^LAST NATIONAL | 
|---|
|  | 78 | ;  NUMBER SEQUENCE | 
|---|
|  | 79 | ; | 
|---|
|  | 80 | N ECX,ECXX,CPT,DIC,DIE,DA,DR,X,Y,ECBEG,ECEND,ECADD,NAME,ECSEQ,STR,CPTIEN | 
|---|
|  | 81 | D MES^XPDUTL(" ") | 
|---|
|  | 82 | D BMES^XPDUTL("Changing CPT Codes in EC NATIONAL PROCEDURE file (#725)") | 
|---|
|  | 83 | D MES^XPDUTL(" ") | 
|---|
|  | 84 | F ECX=1:1 S ECXX=$P($T(CPT+ECX),";;",2) Q:ECXX="QUIT"  D | 
|---|
|  | 85 | .S ECBEG=$P(ECXX,U,3),ECEND=$P(ECXX,U,4),CPTIEN=$P(ECXX,U,2) | 
|---|
|  | 86 | .S CPTIEN=$S(CPTIEN="":"@",1:$$FIND1^DIC(81,"","X",CPTIEN)) | 
|---|
|  | 87 | .I CPTIEN'="@",+CPTIEN<1 D  Q | 
|---|
|  | 88 | ..S STR=$P(ECXX,U)_":  CPT code "_$P(ECXX,U,2)_" is invalid." | 
|---|
|  | 89 | ..D MES^XPDUTL(" ") | 
|---|
|  | 90 | ..D BMES^XPDUTL("   "_STR) | 
|---|
|  | 91 | .I ECBEG="" S CPT($P(ECXX,U))=CPTIEN_U_$P(ECXX,U,2) Q | 
|---|
|  | 92 | .F ECSEQ=ECBEG:1:ECEND D | 
|---|
|  | 93 | ..S ECADD="000"_ECSEQ,ECADD=$E(ECADD,$L(ECADD)-2,$L(ECADD)) | 
|---|
|  | 94 | ..S CPT($P(ECXX,U)_ECADD)=CPTIEN_U_$P(ECXX,U,2) | 
|---|
|  | 95 | S ECXX="" | 
|---|
|  | 96 | F  S ECXX=$O(CPT(ECXX)) Q:ECXX=""  D | 
|---|
|  | 97 | .S ECX=$O(^EC(725,"D",ECXX,0)) | 
|---|
|  | 98 | .Q:+ECX=0 | 
|---|
|  | 99 | .I '$D(^EC(725,ECX,0))!(+ECX=0) D  Q | 
|---|
|  | 100 | ..D MES^XPDUTL(" ") | 
|---|
|  | 101 | ..D BMES^XPDUTL("   Can't find entry for "_ECXX_",CPT cde not updated.") | 
|---|
|  | 102 | .S CPT=$P(CPT(ECXX),U),DA=ECX,DR="4////"_CPT,DIE="^EC(725," D ^DIE | 
|---|
|  | 103 | .D MES^XPDUTL(" ") | 
|---|
|  | 104 | .S STR="   Entry #"_ECX_" for "_ECXX | 
|---|
|  | 105 | .D BMES^XPDUTL(STR_" updated to use CPT code "_$P(CPT(ECXX),U,2)) | 
|---|
|  | 106 | Q | 
|---|
|  | 107 | ; | 
|---|
|  | 108 | CPT ;cpt codes to be changed - national #^new CPT code | 
|---|
|  | 109 | ;;BB002^36430 | 
|---|
|  | 110 | ;;BB003^36430 | 
|---|
|  | 111 | ;;BB004^36430 | 
|---|
|  | 112 | ;;SP456^E2500 | 
|---|
|  | 113 | ;;SP457^E2502 | 
|---|
|  | 114 | ;;SP458^E2508 | 
|---|
|  | 115 | ;;SP459^E2510 | 
|---|
|  | 116 | ;;SP460^E2511 | 
|---|
|  | 117 | ;;SP461^E2512 | 
|---|
|  | 118 | ;;SP462^E2599 | 
|---|
|  | 119 | ;;QUIT | 
|---|