| 1 | EC725U44 ;ALB/GTS/JAP/GT - EC National Procedure Update; 10/17/2006
|
---|
| 2 | ;;2.0; EVENT CAPTURE ;**89**;8 May 96;Build 3
|
---|
| 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 | ;;OPT ASSMNT ONLY,1ST 10M^NU158^99211^
|
---|
| 61 | ;;OPT ASSMNT ONLY,EA AD'L10M^NU159^^
|
---|
| 62 | ;;IP INTERDISC IND VISIT,EA15M^NU160^^
|
---|
| 63 | ;;QUIT
|
---|
| 64 | NAMECHG ;* change national procedure names
|
---|
| 65 | ;
|
---|
| 66 | ; ECXX is in format:
|
---|
| 67 | ; NATIONAL NUMBER^NEW NAME
|
---|
| 68 | ;
|
---|
| 69 | N ECX,ECXX,ECDA,DA,DR,DIC,DIE,X,Y,STR
|
---|
| 70 | D MES^XPDUTL(" ")
|
---|
| 71 | D BMES^XPDUTL("Changing names in EC NATIONAL PROCEDURE File (#725)...")
|
---|
| 72 | D MES^XPDUTL(" ")
|
---|
| 73 | F ECX=1:1 S ECXX=$P($T(CHNG+ECX),";;",2) Q:ECXX="QUIT" D
|
---|
| 74 | .I $D(^EC(725,"D",$P(ECXX,U,1))) D
|
---|
| 75 | ..S ECDA=+$O(^EC(725,"D",$P(ECXX,U,1),0))
|
---|
| 76 | ..I $D(^EC(725,ECDA,0)) D
|
---|
| 77 | ...S DA=ECDA,DR=".01////^S X=$P(ECXX,U,2)",DIE="^EC(725," D ^DIE
|
---|
| 78 | ...D MES^XPDUTL(" ")
|
---|
| 79 | ...D MES^XPDUTL(" Entry #"_ECDA_" for "_$P(ECXX,U,1))
|
---|
| 80 | ...D BMES^XPDUTL(" ... field (#.01) updated to "_$P(ECXX,U,2)_".")
|
---|
| 81 | .I '$D(^EC(725,"D",$P(ECXX,U,1))) D
|
---|
| 82 | ..D MES^XPDUTL(" ")
|
---|
| 83 | ..S STR="Can't find entry for "_$P(ECXX,U,1)
|
---|
| 84 | ..D BMES^XPDUTL(STR_" ...field (#.01) not updated.")
|
---|
| 85 | Q
|
---|
| 86 | ;
|
---|
| 87 | CHNG ;name changes -national code #^new procedure name
|
---|
| 88 | ;;NU014^MDS CARE PLAN DOC,5M
|
---|
| 89 | ;;NU025^OPT INTERDISC GP,2-5PT,EA15M
|
---|
| 90 | ;;NU026^OPT INTERDISC GP,6-10PT,EA15M
|
---|
| 91 | ;;NU027^OPT INTERDISC GP,11-20PT,EA15M
|
---|
| 92 | ;;NU028^OPT INTERDIS GP,>20PT,EA15M
|
---|
| 93 | ;;NU033^IP GROUP,2-5PT,EA,30M
|
---|
| 94 | ;;NU034^IP GROUP,6-10PT,EA,30M
|
---|
| 95 | ;;NU035^IP GROUP,11-20PT,EA,30M
|
---|
| 96 | ;;NU036^IP GROUP,>20PT,EA30M
|
---|
| 97 | ;;NU042^OPT INTERDISC IND VISIT,EA15M
|
---|
| 98 | ;;QUIT
|
---|