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
|
---|