| 1 | ECMFLPX ;ALB/JAM-Event Capture Management Local Procedure Filer ;1 Dec 00
 | 
|---|
| 2 |  ;;2.0; EVENT CAPTURE ;**25,87**;8 May 96;Build 1
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 | FILE ;Used by the RPC broker to file local procedures in #725
 | 
|---|
| 5 |  ;     Variables passed in
 | 
|---|
| 6 |  ;       ECIEN  - IEN of #725, if editing
 | 
|---|
| 7 |  ;       ECPN   - Local Procedure Name
 | 
|---|
| 8 |  ;       ECNA   - National Number
 | 
|---|
| 9 |  ;       ECST   - Active/Inactive Status
 | 
|---|
| 10 |  ;       ECSYN  - Synonym
 | 
|---|
| 11 |  ;       ECPT   - CPT Code
 | 
|---|
| 12 |  ;
 | 
|---|
| 13 |  ;     Variable return
 | 
|---|
| 14 |  ;       ^TMP($J,"ECMSG",n)=Success or failure to file in #725^Message
 | 
|---|
| 15 |  ;
 | 
|---|
| 16 |  N ECFLG,ECERR,ERR,ECOST,ECDAT,ONM,ONA,ECRES
 | 
|---|
| 17 |  S ECERR=0 D CHKDT I ECERR Q
 | 
|---|
| 18 |  S ECIEN=$G(ECIEN),ECFLG=1
 | 
|---|
| 19 |  I $L(ECNA)'=5 D  Q
 | 
|---|
| 20 |  .S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid Procedure Number"
 | 
|---|
| 21 |  I $G(ECPT)'="" D  I ECERR Q
 | 
|---|
| 22 |  .D CHK^DIE(725,4,,ECPT,.ECRES) I +ECRES<1 D  Q
 | 
|---|
| 23 |  ..S ECERR=1,^TMP($J,"ECMSG",1)="0^Invalid CPT Code"
 | 
|---|
| 24 |  I ECIEN'="" S ECFLG=0 D  I ECERR Q
 | 
|---|
| 25 |  .I '$D(^EC(725,ECIEN,0)) D  Q
 | 
|---|
| 26 |  ..S ECERR=1,^TMP($J,"ECMSG",1)="0^Local Procedure Not on File" Q
 | 
|---|
| 27 |  .I ECIEN<90001 D  Q
 | 
|---|
| 28 |  ..S ECERR=1,^TMP($J,"ECMSG",1)="0^National Procedure cant be changed"
 | 
|---|
| 29 |  .S ECDAT=$G(^EC(725,ECIEN,0)),ONM=$P(ECDAT,U),ONA=$P(ECDAT,U,2)
 | 
|---|
| 30 |  S ERR=0 D PXCHK^ECUMRPC1(.ERR,ECPN_"^"_ECNA) D  I ECERR Q
 | 
|---|
| 31 |  .I +ERR,(ECIEN="")!(ECIEN&($G(ONM)'=ECPN)) D  Q
 | 
|---|
| 32 |  ..S ^TMP($J,"ECMSG",1)="0^Procedure description already exist",ECERR=1
 | 
|---|
| 33 |  .I +$P(ERR,U,2),(ECIEN="")!(ECIEN&($G(ONA)'=ECNA)) D
 | 
|---|
| 34 |  ..S ^TMP($J,"ECMSG",1)="0^Procedure number already exist",ECERR=1
 | 
|---|
| 35 |  I ECIEN="" D  I ECERR Q
 | 
|---|
| 36 |  . D NEWIEN
 | 
|---|
| 37 |  K DA,DR,DIE
 | 
|---|
| 38 |  S DIE="^EC(725,",DA=ECIEN
 | 
|---|
| 39 |  S ECOST=$P($G(^EC(725,ECIEN,0)),U,3),ECOST=$S(ECOST'="":"I",1:"A")
 | 
|---|
| 40 |  S DR=".01////"_ECPN_";1////"_ECNA_";3////"_$G(ECSYN)_";4////"_$G(ECPT)
 | 
|---|
| 41 |  I $G(ECST)'="","^I^A^"[ECST,ECST'=ECOST D
 | 
|---|
| 42 |  .S DR=DR_";2////"_$S(ECST="I":DT,1:"@")
 | 
|---|
| 43 |  D ^DIE I $D(DTOUT) D RECDEL D  Q
 | 
|---|
| 44 |  . S ^TMP($J,"ECMSG",1)="0^Record not Filed"
 | 
|---|
| 45 |  S ^TMP($J,"ECMSG",1)="1^Record Filed"_U_ECIEN
 | 
|---|
| 46 |  Q
 | 
|---|
| 47 |  ;
 | 
|---|
| 48 | RECDEL ; Delete record
 | 
|---|
| 49 |  I ECFLG S DA=ECIEN,DIK="^EC(725," D ^DIK K DA,DIK
 | 
|---|
| 50 |  Q
 | 
|---|
| 51 |  ;
 | 
|---|
| 52 | NEWIEN ;Create new IEN in file #725
 | 
|---|
| 53 |  N DIC,DA,DD,DO
 | 
|---|
| 54 |  L +^EC(725)
 | 
|---|
| 55 |  S ECIEN=$O(^EC(725,"A"),-1)
 | 
|---|
| 56 |  F  S ECIEN=ECIEN+1 Q:'$D(^EC(725,ECIEN))
 | 
|---|
| 57 |  I ECIEN<90001 S ECIEN=90001
 | 
|---|
| 58 |  S $P(^EC(725,0),U,3)=ECIEN,$P(^EC(725,0),U,4)=$P(^EC(725,0),U,4)+1
 | 
|---|
| 59 |  L -^EC(725)
 | 
|---|
| 60 |  Q
 | 
|---|
| 61 |  ;
 | 
|---|
| 62 | CHKDT ;Required Data Check
 | 
|---|
| 63 |  N I,C
 | 
|---|
| 64 |  S C=1
 | 
|---|
| 65 |  F I="ECPN","ECNA" D
 | 
|---|
| 66 |  .I $G(@I)="" S ^TMP($J,"ECMSG",C)="0^Key data missing "_I,C=C+1,ECERR=1
 | 
|---|
| 67 |  Q
 | 
|---|