| 1 | EC725U22 ;ALB/GTS/JAP/GT - EC National Procedure Update; 9/11/2003 | 
|---|
| 2 | ;;2.0; EVENT CAPTURE ;**52**;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 | ;;NONVIDEO MONIT UNSPECIF PROGRM^CC001 | 
|---|
| 61 | ;;NONVIDEO MONIT CD CARDIAC DIS^CC002 | 
|---|
| 62 | ;;NONVIDEO MONIT CG COAG MGMT^CC003 | 
|---|
| 63 | ;;NONVIDEO MONIT DE DEMENTIA^CC004 | 
|---|
| 64 | ;;NONVIDEO MONIT DM DIABETES MEL^CC005 | 
|---|
| 65 | ;;NONVIDEO MONIT HT HYPERTENSION^CC006 | 
|---|
| 66 | ;;NONVIDEO MONIT ID INFECTIOUS D^CC007 | 
|---|
| 67 | ;;NONVIDEO MONIT MH MENTAL HLTH^CC008 | 
|---|
| 68 | ;;NONVIDEO MONIT MM MULT COMORB^CC009 | 
|---|
| 69 | ;;NONVIDEO MONIT PL PALLIATIVE^CC010 | 
|---|
| 70 | ;;NONVIDEO MONIT PN PAIN MGMT^CC011 | 
|---|
| 71 | ;;NONVIDEO MONIT PD PULMONARY D^CC012 | 
|---|
| 72 | ;;NONVIDEO MONIT RH REHAB^CC013 | 
|---|
| 73 | ;;NONVIDEO MONIT SC SPINAL CORD^CC014 | 
|---|
| 74 | ;;NONVIDEO MONIT WC WOUND CARE^CC015 | 
|---|
| 75 | ;;HH PURCH VISITS/MO-CHIROPRACTR^HH127 | 
|---|
| 76 | ;;HH REF VA PD CHIROPRACTR^HH128 | 
|---|
| 77 | ;;HH REF END VA PD CHIROPRACTR^HH129 | 
|---|
| 78 | ;;QUIT | 
|---|
| 79 | NAMECHG ;* change national procedure names | 
|---|
| 80 | ; | 
|---|
| 81 | ;  ECXX is in format: | 
|---|
| 82 | ;   NATIONAL NUMBER^NEW NAME | 
|---|
| 83 | ; | 
|---|
| 84 | N ECX,ECXX,ECDA,DA,DR,DIC,DIE,X,Y,STR | 
|---|
| 85 | D MES^XPDUTL(" ") | 
|---|
| 86 | D BMES^XPDUTL("Changing names in EC NATIONAL PROCEDURE File (#725)...") | 
|---|
| 87 | D MES^XPDUTL(" ") | 
|---|
| 88 | F ECX=1:1 S ECXX=$P($T(CHNG+ECX),";;",2) Q:ECXX="QUIT"  D | 
|---|
| 89 | .I $D(^EC(725,"D",$P(ECXX,U,1))) D | 
|---|
| 90 | ..S ECDA=+$O(^EC(725,"D",$P(ECXX,U,1),0)) | 
|---|
| 91 | ..I $D(^EC(725,ECDA,0)) D | 
|---|
| 92 | ...S DA=ECDA,DR=".01////^S X=$P(ECXX,U,2)",DIE="^EC(725," D ^DIE | 
|---|
| 93 | ...D MES^XPDUTL(" ") | 
|---|
| 94 | ...D MES^XPDUTL("   Entry #"_ECDA_" for "_$P(ECXX,U,1)) | 
|---|
| 95 | ...D BMES^XPDUTL("      ... field (#.01) updated to  "_$P(ECXX,U,2)_".") | 
|---|
| 96 | .I '$D(^EC(725,"D",$P(ECXX,U,1))) D | 
|---|
| 97 | ..D MES^XPDUTL(" ") | 
|---|
| 98 | ..S STR="Can't find entry for "_$P(ECXX,U,1) | 
|---|
| 99 | ..D BMES^XPDUTL(STR_" ...field (#.01) not updated.") | 
|---|
| 100 | Q | 
|---|
| 101 | ; | 
|---|
| 102 | CHNG ;name changes -national code #^new procedure name | 
|---|
| 103 | ;;QUIT | 
|---|