| [613] | 1 | PXRMLREX ;SLC/PJH - Delete rule components ;07/03/2002
|
|---|
| 2 | ;;2.0;CLINICAL REMINDERS;;Feb 04, 2005
|
|---|
| 3 | ;
|
|---|
| 4 | ;=====================================================================
|
|---|
| 5 | ;
|
|---|
| 6 | ;Yes/No Prompts
|
|---|
| 7 | ;--------------
|
|---|
| 8 | ASK(YESNO,TEXT,HELP) ;
|
|---|
| 9 | W !
|
|---|
| 10 | N DIR,X,Y
|
|---|
| 11 | K DIROUT,DIRUT,DTOUT,DUOUT
|
|---|
| 12 | S DIR(0)="YA0"
|
|---|
| 13 | M DIR("A")=TEXT
|
|---|
| 14 | S DIR("B")="Y"
|
|---|
| 15 | S DIR("?")="Enter Y or N. For detailed help type ??"
|
|---|
| 16 | S DIR("??")=U_"D HLP^PXRMLREX(HELP)"
|
|---|
| 17 | D ^DIR K DIR
|
|---|
| 18 | I $D(DIROUT) S DTOUT=1
|
|---|
| 19 | I $D(DTOUT)!($D(DUOUT)) Q
|
|---|
| 20 | S YESNO=$E(Y(0))
|
|---|
| 21 | Q
|
|---|
| 22 | ;
|
|---|
| 23 | ;Give option to delete all descendents
|
|---|
| 24 | ;-------------------------------------
|
|---|
| 25 | DELETE(COMP) ;
|
|---|
| 26 | N ANS,HLP,LRIEN,LRNAM,LRTYP,IC,TEXT
|
|---|
| 27 | ;Parent name and type
|
|---|
| 28 | S LRNAM=$P(COMP(0),U)
|
|---|
| 29 | ;Prompt information
|
|---|
| 30 | S TEXT(1)="List Rule Set "_LRNAM_" had unused components."
|
|---|
| 31 | S TEXT="Delete all these component rules:"
|
|---|
| 32 | ;List component names
|
|---|
| 33 | S IC=2,LRIEN=0,TEXT(2)="",HLP=1
|
|---|
| 34 | F S LRIEN=$O(COMP(LRIEN)) Q:'LRIEN D Q:IC>15
|
|---|
| 35 | .S IC=IC+1 I IC>15 S TEXT(IC)="<<more>>" Q
|
|---|
| 36 | .N LRTYP
|
|---|
| 37 | .S LRTYP=$P(COMP(LRIEN),U,2)
|
|---|
| 38 | .S LRTYP=$S(LRTYP=1:"list rule",LRTYP=2:"reminder rule",1:"output rule")
|
|---|
| 39 | .S TEXT(IC)=$P(COMP(LRIEN),U)_$J("",5)_LRTYP
|
|---|
| 40 | S TEXT(IC+1)=""
|
|---|
| 41 | ;Ask Delete Y/N?
|
|---|
| 42 | D ASK(.ANS,.TEXT,HLP) Q:$G(ANS)'="Y"
|
|---|
| 43 | ;Use DIK to remove all unused components
|
|---|
| 44 | N DA,DIK
|
|---|
| 45 | S LRIEN=0
|
|---|
| 46 | ;Scan list of unused components
|
|---|
| 47 | F S LRIEN=$O(COMP(LRIEN)) Q:'LRIEN D
|
|---|
| 48 | .;Delete component dialog
|
|---|
| 49 | .S DA=LRIEN,DIK="^PXRM(810.4," D ^DIK
|
|---|
| 50 | Q
|
|---|
| 51 | ;
|
|---|
| 52 | ;Build list of components
|
|---|
| 53 | ;------------------------
|
|---|
| 54 | COMP(IEN,COMP) ;
|
|---|
| 55 | ;Build list of components
|
|---|
| 56 | D COMPR(IEN,.COMP) Q:'$D(COMP)
|
|---|
| 57 | ;Get reminder dialog, group or element name and type
|
|---|
| 58 | N DATA
|
|---|
| 59 | S DATA=$G(^PXRM(810.4,IEN,0))
|
|---|
| 60 | ;Save for future use
|
|---|
| 61 | S COMP(0)=$P(DATA,U)_U_$P(DATA,U,4)
|
|---|
| 62 | Q
|
|---|
| 63 | ;
|
|---|
| 64 | ;Recursive call
|
|---|
| 65 | ;--------------
|
|---|
| 66 | COMPR(IEN,COMP) ;
|
|---|
| 67 | N DATA,LRIEN,LRNAME,LRTYP,PARENT,SUB
|
|---|
| 68 | S LRIEN=0,PARENT="LOCAL"
|
|---|
| 69 | ;Check if parent is national
|
|---|
| 70 | I $P($G(^PXRM(810.4,IEN,100)),U)="N" S PARENT="NATIONAL"
|
|---|
| 71 | ;
|
|---|
| 72 | F S LRIEN=$O(^PXRM(810.4,IEN,30,"D",LRIEN)) Q:'LRIEN D
|
|---|
| 73 | .;Ignore national components
|
|---|
| 74 | .I $P($G(^PXRM(810.4,LRIEN,100)),U)="N",PARENT'="NATIONAL" Q
|
|---|
| 75 | .;Ignore if in use
|
|---|
| 76 | .I $$USED(LRIEN,IEN) Q
|
|---|
| 77 | .;Save component dialog type and name
|
|---|
| 78 | .S DATA=$G(^PXRM(810.4,LRIEN,0)),LRNAME=$P(DATA,U),LRTYP=$P(DATA,U,3)
|
|---|
| 79 | .S COMP(LRIEN)=LRNAME_U_LRTYP
|
|---|
| 80 | .;For groups and element check sub-components
|
|---|
| 81 | .I (LRTYP="G")!(LRTYP="E") D COMPR(LRIEN,.COMP)
|
|---|
| 82 | Q
|
|---|
| 83 | ;
|
|---|
| 84 | ;Check if in use
|
|---|
| 85 | ;---------------
|
|---|
| 86 | USED(LRIEN,IEN) ;
|
|---|
| 87 | N SUB,DINUSE
|
|---|
| 88 | S SUB=0,DINUSE=0
|
|---|
| 89 | F S SUB=$O(^PXRM(810.4,"AD",LRIEN,SUB)) Q:'SUB D Q:DINUSE
|
|---|
| 90 | .;In use by other than parent
|
|---|
| 91 | .I SUB'=IEN S DINUSE=1
|
|---|
| 92 | Q DINUSE
|
|---|
| 93 | ;
|
|---|
| 94 | ;General help text routine.
|
|---|
| 95 | ;--------------------------
|
|---|
| 96 | HLP(CALL) ;
|
|---|
| 97 | N HTEXT
|
|---|
| 98 | N DIWF,DIWL,DIWR,IC
|
|---|
| 99 | S DIWF="C75",DIWL=0,DIWR=75
|
|---|
| 100 | ;
|
|---|
| 101 | I CALL=1 D
|
|---|
| 102 | .S HTEXT(1)="Enter 'Yes' to DELETE all sub-components listed above"
|
|---|
| 103 | .S HTEXT(2)="or enter 'No' to quit."
|
|---|
| 104 | ;
|
|---|
| 105 | D HELP^PXRMEUT(.HTEXT)
|
|---|
| 106 | Q
|
|---|