[613] | 1 | EC725U40 ;ALB/GTS/JAP/GT - EC National Procedure Update; 4/03/2006
|
---|
| 2 | ;;2.0; EVENT CAPTURE ;**81**;8 May 96
|
---|
| 3 | ;
|
---|
| 4 | ;this routine is used as a post-init in a KIDS build
|
---|
| 5 | ;to modify the EC National Procedure file #725
|
---|
| 6 | ;
|
---|
| 7 | ADDPROC ;* add national procedures
|
---|
| 8 | ;
|
---|
| 9 | ; ECXX is in format:
|
---|
| 10 | ; NAME^NATIONAL NUMBER^CPT CODE^FIRST NATIONAL NUMBER SEQUENCE
|
---|
| 11 | ; LAST NATIONAL NUMBER SEQUENCE
|
---|
| 12 | ;
|
---|
| 13 | N ECX,ECXX,ECDINUM,NAME,CODE,CPT,COUNT,X,Y,DIC,DIE,DA,DR,DLAYGO,DINUM
|
---|
| 14 | N ECADD,ECBEG,ECEND,CODX,NAMX,ECSEQ,LIEN,STR,CPTN,STR
|
---|
| 15 | D MES^XPDUTL(" ")
|
---|
| 16 | D BMES^XPDUTL("Adding new procedures to EC NATIONAL PROCEDURE File (#725)...")
|
---|
| 17 | D MES^XPDUTL(" ")
|
---|
| 18 | S ECDINUM=$O(^EC(725,9999),-1),COUNT=$P(^EC(725,0),U,4)
|
---|
| 19 | F ECX=1:1 S ECXX=$P($T(NEW+ECX),";;",2) Q:ECXX="QUIT" D
|
---|
| 20 | .S NAME=$P(ECXX,U,1),CODE=$P(ECXX,U,2),CPTN=$P(ECXX,U,3),CODX=CODE
|
---|
| 21 | .S CPT=""
|
---|
| 22 | .I CPTN'="" S CPT=$$FIND1^DIC(81,"","X",CPTN) I +CPT<1 D Q
|
---|
| 23 | ..S STR=" CPT code "_CPTN_" not a valid code in CPT File."
|
---|
| 24 | ..D MES^XPDUTL(" ")
|
---|
| 25 | ..D BMES^XPDUTL(" ["_CODE_"] "_STR)
|
---|
| 26 | .S ECBEG=$P(ECXX,U,4),ECEND=$P(ECXX,U,5),NAMX=NAME
|
---|
| 27 | .I ECBEG="" S X=NAME D FILPROC Q
|
---|
| 28 | .F ECSEQ=ECBEG:1:ECEND D
|
---|
| 29 | ..S ECADD="000"_ECSEQ,ECADD=$E(ECADD,$L(ECADD)-2,$L(ECADD))
|
---|
| 30 | ..;S NAME=NAMX_ECADD,X=NAME,CODE=CODX_ECADD
|
---|
| 31 | ..I $E(CODX,1,3)'="RCM" S NAME=NAMX_ECSEQ,X=NAME,CODE=CODX_ECADD
|
---|
| 32 | ..E S NAME=NAMX_$E(ECADD,2,99),X=NAME,CODE=CODX_$E(ECADD,2,99)
|
---|
| 33 | ..D FILPROC
|
---|
| 34 | S $P(^EC(725,0),U,4)=COUNT,X=$O(^EC(725,999999),-1),$P(^EC(725,0),U,3)=X
|
---|
| 35 | Q
|
---|
| 36 | ;
|
---|
| 37 | FILPROC ;File national procedures
|
---|
| 38 | I '$D(^EC(725,"D",CODE)) D
|
---|
| 39 | .S ECDINUM=ECDINUM+1,DINUM=ECDINUM,DIC(0)="L",DLAYGO=725,DIC="^EC(725,"
|
---|
| 40 | .S DIC("DR")="1////^S X=CODE;4////^S X=CPT"
|
---|
| 41 | .D FILE^DICN
|
---|
| 42 | .I +Y>0 D
|
---|
| 43 | ..S COUNT=COUNT+1
|
---|
| 44 | ..D MES^XPDUTL(" ")
|
---|
| 45 | ..S STR=" Entry #"_+Y_" for "_$P(Y,U,2)
|
---|
| 46 | ..S STR=STR_$S(CPT'="":" [CPT: "_CPT_"]",1:"")_" ("_CODE_")"
|
---|
| 47 | ..D BMES^XPDUTL(STR_" ...successfully added.")
|
---|
| 48 | .I Y=-1 D
|
---|
| 49 | ..D MES^XPDUTL(" ")
|
---|
| 50 | ..D BMES^XPDUTL("ERROR when attempting to add "_NAME_" ("_CODE_")")
|
---|
| 51 | I $D(^EC(725,"DL",CODE)) D
|
---|
| 52 | .S LIEN=$O(^EC(725,"DL",CODE,""))
|
---|
| 53 | .D MES^XPDUTL(" ")
|
---|
| 54 | .D BMES^XPDUTL(" Your site has a local procedure (entry #"_LIEN_") in File #725")
|
---|
| 55 | .D BMES^XPDUTL(" which uses "_CODE_" as its National Number.")
|
---|
| 56 | .D BMES^XPDUTL(" Please inactivate this local procedure.")
|
---|
| 57 | .K Y
|
---|
| 58 | Q
|
---|
| 59 | NEW ;national procedures to add;;descript^nation #^CPT code^beg seq^end seq
|
---|
| 60 | ;;THERAPEUTIC PROCEDURE, GROUP^SP545^97150
|
---|
| 61 | ;;EDUC & TRAINING, IND, 30 MIN^SP546^98960
|
---|
| 62 | ;;EDUC & TRAINING 2-4 PT, 30 MIN^SP547^98961
|
---|
| 63 | ;;EDUC & TRAINING 5-8 PT, 30 MIN^SP548^98962
|
---|
| 64 | ;;L8624 LITHIUM BAT,CIDEV,EARLVL^SP549^L8624
|
---|
| 65 | ;;V5095 SEMI-IMPLNT MIDEAR HRDV^SP550^V5095
|
---|
| 66 | ;;QUIT
|
---|
| 67 | NAMECHG ;* change national procedure names
|
---|
| 68 | ;
|
---|
| 69 | ; ECXX is in format:
|
---|
| 70 | ; NATIONAL NUMBER^NEW NAME
|
---|
| 71 | ;
|
---|
| 72 | N ECX,ECXX,ECDA,DA,DR,DIC,DIE,X,Y,STR
|
---|
| 73 | D MES^XPDUTL(" ")
|
---|
| 74 | D BMES^XPDUTL("Changing names in EC NATIONAL PROCEDURE File (#725)...")
|
---|
| 75 | D MES^XPDUTL(" ")
|
---|
| 76 | F ECX=1:1 S ECXX=$P($T(CHNG+ECX),";;",2) Q:ECXX="QUIT" D
|
---|
| 77 | .I $D(^EC(725,"D",$P(ECXX,U,1))) D
|
---|
| 78 | ..S ECDA=+$O(^EC(725,"D",$P(ECXX,U,1),0))
|
---|
| 79 | ..I $D(^EC(725,ECDA,0)) D
|
---|
| 80 | ...S DA=ECDA,DR=".01////^S X=$P(ECXX,U,2)",DIE="^EC(725," D ^DIE
|
---|
| 81 | ...D MES^XPDUTL(" ")
|
---|
| 82 | ...D MES^XPDUTL(" Entry #"_ECDA_" for "_$P(ECXX,U,1))
|
---|
| 83 | ...D BMES^XPDUTL(" ... field (#.01) updated to "_$P(ECXX,U,2)_".")
|
---|
| 84 | .I '$D(^EC(725,"D",$P(ECXX,U,1))) D
|
---|
| 85 | ..D MES^XPDUTL(" ")
|
---|
| 86 | ..S STR="Can't find entry for "_$P(ECXX,U,1)
|
---|
| 87 | ..D BMES^XPDUTL(STR_" ...field (#.01) not updated.")
|
---|
| 88 | Q
|
---|
| 89 | ;
|
---|
| 90 | CHNG ;name changes -national code #^new procedure name
|
---|
| 91 | ;;NU157^FOOT ASSESSMENT EA 10MIN
|
---|
| 92 | ;;SP038^INITIAL ACOUSTIC DEVICE FIT
|
---|
| 93 | ;;SP107^INITIAL HEARING AID FIT, MON
|
---|
| 94 | ;;SP108^INITIAL HEARING AID FIT, BIN
|
---|
| 95 | ;;SP449^FOLLOW-UP ACOUSTIC DEV FIT
|
---|
| 96 | ;;SP450^FOLLOW-UP HEARING AID FIT, MON
|
---|
| 97 | ;;SP451^FOLLOW-UP HEARING AID FIT, BIN
|
---|
| 98 | ;;SP506^A5120 SKIN BARRIER WIPE/SWAB
|
---|
| 99 | ;;SP531^L8623 LITHIUM ION BAT,CIDEVBDY
|
---|
| 100 | ;;QUIT
|
---|