VistA-WorldVistAEHR/r/ENGINEERING-EN/ENTIUTL2.m

234 lines
7.3 KiB
Mathematica

ENTIUTL2 ;WOIFO/SAB - Find and Sort Equipment Utilities ;2/14/2008
;;7.0;ENGINEERING;**87**;Aug 17, 1993;Build 16
;
ASKEQSM(ENAML,ENDM) ; Ask Equipment Selection Method
; input
; ENAML = allowed method list, may contain the following characters
; A = all equipment
; E = by Entry #
; C = by CMR
; U = by using service
; L = by location
; S = by service of location
; example "ECULS"
; ENDM = (optional) default method
; returns null if no method selected or
; piece 1 = A, E, C, U, L, or S if a method was selected
; piece 2 = specified value when method is C, U, L, or S
; e.g. "C^12" for CMR with internal entry number = 12
;
N DIC,DIR,DIROUT,DIRUT,DTOUT,DUOUT,ENRET,ENVAL,X,Y
S ENRET="",ENVAL=""
;
; ask method
S DIR(0)="S^"
I ENAML["A" S DIR(0)=DIR(0)_"A:ALL TRACKED IT EQUIPMENT;"
I ENAML["E" S DIR(0)=DIR(0)_"E:ENTRY #;"
I ENAML["C" S DIR(0)=DIR(0)_"C:CMR;"
I ENAML["U" S DIR(0)=DIR(0)_"U:USING SERVICE;"
I ENAML["L" S DIR(0)=DIR(0)_"L:LOCATION;"
I ENAML["S" S DIR(0)=DIR(0)_"S:SERVICE OF LOCATION;"
Q:DIR(0)="S^" ENRET
; remove trailing ;
I $E(DIR(0),$L(DIR(0)))=";" S DIR(0)=$E(DIR(0),1,$L(DIR(0))-1)
S DIR("A")="Specify method to select equipment by"
I $G(ENDM)]"" S DIR("B")=ENDM
S DIR("?")="Enter a code from the list."
S DIR("?",1)="The system considers tracked IT equipment to be"
S DIR("?",2)="equipment that is on a CMR with IT TRACKING = YES."
S DIR("?",3)=" "
D ^DIR
I '$D(DIRUT) S ENRET=Y
;
; ask a value for applicable methods
;
; method C - by CMR
I ENRET="C" D
. ; ask CMR
. S DIC("S")="I $P($G(^(0)),U,9)=1" ; screen IT TRACKING = YES
. S DIC="^ENG(6914.1,"
. S DIC(0)="AQEM"
. D ^DIC K DIC I Y<1 S ENRET="" Q
. S ENVAL=+Y
;
; method U - by using service
I ENRET="U" D
. ; ask USING SERVICE
. S DIC("S")="I $D(^ENG(6914,""AC"",+Y))" ; screen services with equip
. S DIC="^DIC(49,"
. S DIC(0)="AQEM"
. D ^DIC K DIC I Y<1 S ENRET="" Q
. S ENVAL=+Y
;
; method L - by location
I ENRET="L" D
. ; ask LOCATION
. S DIC("S")="I $D(^ENG(6914,""D"",+Y))" ; screen locations with equip
. S DIC="^ENG(""SP"","
. S DIC(0)="AQEM"
. D ^DIC K DIC I Y<1 S ENRET="" Q
. S ENVAL=+Y
;
; method S - by service of location
I ENRET="S" D
. ; ask SERVICE
. S DIC("S")="I $D(^ENG(""SP"",""D"",+Y))" ; screen services with space
. S DIC="^DIC(49,"
. S DIC(0)="AQEM"
. D ^DIC K DIC I Y<1 S ENRET="" Q
. S ENVAL=+Y
;
I ENVAL]"" S ENRET=ENRET_"^"_ENVAL
Q ENRET
;
ASKIAEQ() ; Ask Include Assigned Equipment
;
; returns null if time-out or uparrorw
; 1 if assigned equipment should be included
; 0 if not
;
N DIR,DIROUT,DIRUT,DTOUT,DUOUT,ENRET,X,Y
S ENRET=""
S DIR(0)="Y"
S DIR("A")="Include equipment with an existing active assignment"
S DIR("B")="NO"
D ^DIR
I '$D(DIRUT) S ENRET=Y
Q ENRET
;
ASKEQSRT(ENSM,ENDM) ; Ask Equipment Sort
; input ENSM = (optional) selection method
; if method is E then sort is set to E
; ENDM = (optional) default sort method
;
; returns null if no sort selected
; E, C, U, L, or S if a sort was selected
;
N DIR,DIROUT,DIRUT,DTOUT,DUOUT,ENRET,X,Y
S ENRET=""
I $G(ENSM)="E" S ENRET="E"
E D
. S DIR(0)="S^E:ENTRY #;C:CMR;U:USING SERVICE;L:LOCATION;S:SERVICE OF LOCATION"
. S DIR("A")="Sort equipment by"
. I $G(ENDM)]"" S DIR("B")=ENDM
. D ^DIR K DIR
. I '$D(DIRUT) S ENRET=Y
Q ENRET
;
GETEQ(ENSM,ENVAL,ENSRT,ENIA) ; Get Equipment
; input ENSM = selection method (A, E, C, U, L, or S)
; NOTE: E method is interactive, while the others are not
; ENVAL = value when method is C, U, L, or S (e.g. ien of CMR)
; ENSRT = sort by (E, C, U, L, or S) - must be E for method E
; ENIA = 1 (include) or 0 (don't include) equip w/active assign
; this does not apply to method E
; optional, default = 1
; output
; ^TMP($J,"ENITEQ",0)=count^method^specified value^sort
; ^TMP($J,"ENITEQ",sort value,equip ien)="" list of equipment
;
N ENCMR,ENCNT,END,ENDA
K ^TMP($J,"ENITEQ")
S ENVAL=$G(ENVAL)
S ENSRT=$G(ENSRT,"E")
S ENIA=$G(ENIA,1)
S ENCNT=0,END=0
;
; method A - all tracked equipment
I ENSM="A" D
. ; loop thru CMRs with IT TRACKING = YES
. S ENCMR=0 F S ENCMR=$O(^ENG(6914.1,"AIT",1,ENCMR)) Q:'ENCMR D
. . ; loop thru equipment on CMR
. . S ENDA=0 F S ENDA=$O(^ENG(6914,"AD",ENCMR,ENDA)) Q:'ENDA D
. . . I 'ENIA,$D(^ENG(6916.3,"AEA",ENDA)) Q ; chose to excl. assigned
. . . D SETTMP
;
; method E - by individual equipment (interactive)
I ENSM="E" D
. N DA,DIC,DIR,DIROUT,DIRUT,DTOUT,DUOUT,ENSCR,X,Y
. ; screen by CMR:IT TRACKING
. S ENSCR="N ENCMR S ENCMR=$P($G(^(2)),U,9) I ENCMR,$D(^ENG(6914.1,""AIT"",1,ENCMR))"
. ; ask equipment in loop
. F S DIC("S")=ENSCR D GETEQ^ENUTL Q:Y<1 D Q:END
. . S ENDA=+Y
. . ; display equip
. . W @(IOF)
. . D DISEQ^ENTIUTL(ENDA)
. . W !
. . D DISASGN^ENTIUTL(ENDA)
. . ;
. . ; check if already selected (sort is always "E" for this method)
. . I $D(^TMP($J,"ENITEQ","NA",ENDA)) D Q
. . . W !!,"This equipment item has already been selected."
. . . W !,"If all desired equipment has been selected then press RETURN"
. . . W !,"at the equipment selection prompt."
. . ;
. . ; ask confirmation
. . W !
. . S DIR(0)="Y",DIR("A")="Do you want to select this item"
. . D ^DIR I $D(DIRUT) S END=1 Q
. . I 'Y Q
. . ;
. . ; user confirmed
. . D SETTMP
;
; method C - by CMR
I ENSM="C" D
. ; loop thru equipment on the CMR
. S ENDA=0 F S ENDA=$O(^ENG(6914,"AD",ENVAL,ENDA)) Q:'ENDA D
. . I 'ENIA,$D(^ENG(6916.3,"AEA",ENDA)) Q ; chose to exclude assigned
. . D SETTMP
;
; method U - by using service
I ENSM="U" D
. ; loop thru equipment with this using service
. S ENDA=0 F S ENDA=$O(^ENG(6914,"AC",ENVAL,ENDA)) Q:'ENDA D
. . S ENCMR=$P($G(^ENG(6914,ENDA,2)),U,9)
. . Q:'ENCMR ; not on a cmr
. . Q:$P($G(^ENG(6914.1,ENCMR,0)),U,9)'=1 ; IT tracking not yes
. . I 'ENIA,$D(^ENG(6916.3,"AEA",ENDA)) Q ; chose to exclude assigned
. . D SETTMP
;
; method L - by location
I ENSM="L" D
. ; loop thru equipment in this location
. S ENDA=0 F S ENDA=$O(^ENG(6914,"D",ENVAL,ENDA)) Q:'ENDA D
. . S ENCMR=$P($G(^ENG(6914,ENDA,2)),U,9)
. . Q:'ENCMR ; not on a cmr
. . Q:$P($G(^ENG(6914.1,ENCMR,0)),U,9)'=1 ; IT tracking not yes
. . I 'ENIA,$D(^ENG(6916.3,"AEA",ENDA)) Q ; chose to exclude assigned
. . D SETTMP
;
; method S - by service of location
I ENSM="S" D
. N ENSP
. ; loop thru locations with this service
. S ENSP=0 F S ENSP=$O(^ENG("SP","D",ENVAL,ENSP)) Q:'ENSP D
. . ; loop thru equipment with this location
. . S ENDA=0 F S ENDA=$O(^ENG(6914,"D",ENSP,ENDA)) Q:'ENDA D
. . . S ENCMR=$P($G(^ENG(6914,ENDA,2)),U,9)
. . . Q:'ENCMR ; not on a cmr
. . . Q:$P($G(^ENG(6914.1,ENCMR,0)),U,9)'=1 ; IT tracking not yes
. . . I 'ENIA,$D(^ENG(6916.3,"AEA",ENDA)) Q ; chose to exclude assigned
. . . D SETTMP
;
; set output header node
S ^TMP($J,"ENITEQ",0)=ENCNT_U_ENSM_U_ENVAL_ENSRT
;
Q
;
SETTMP ; save equipment in sorted TMP global
N ENSRTV
S ENSRTV=""
I ENSRT="E" S ENSRTV="NA"
I ENSRT="C" S ENSRTV=$$GET1^DIQ(6914,ENDA,19) ; cmr
I ENSRT="U" S ENSRTV=$$GET1^DIQ(6914,ENDA,21) ; service
I ENSRT="L" S ENSRTV=$$GET1^DIQ(6914,ENDA,24) ; location
I ENSRT="S" S ENSRTV=$$GET1^DIQ(6914,ENDA,"24:1.5") ; svc of loc
I ENSRTV="" S ENSRTV=" <null>"
S ^TMP($J,"ENITEQ",ENSRTV,ENDA)=""
S ENCNT=ENCNT+1
Q
;
;ENTIUTL2