- USRECCL ; SLC/PKR,MA - Routines for expanding/collapsing class views ;11/25/09
- ;;1.0;AUTHORIZATION/SUBSCRIPTION;**7,18,33**;Jun 20, 1997;Build 5
- ; Patch USR*1*18 additional quit to contract logic in tag EC.
- ; This routine invokes IA #872
- ;======================================================================
- COPYCL(LIST,LSTART,START,END) ;Copy elements of ^TMP("USRCLASS",$J) starting
- ;at START going to END.
- N IND,TEXT
- F IND=START:1:END D
- . S LSTART=LSTART+1
- . S TEXT=^TMP("USRCLASS",$J,IND,0)
- . S TEXT=$$SETFLD^VALM1(LSTART,TEXT,"NUMBER")
- . S LIST(LSTART)=TEXT_U_$P($G(^TMP("USRCLASSIDX",$J,IND)),U,2)
- Q LSTART
- ;
- ;======================================================================
- EC(USRVALMY) ;Expand or contract the list of classes in VALMY.
- ;Make sure the request is valid.
- I '$$VEXREQ(.USRVALMY) Q
- N ACTION,DIROUT,LISTNUM,REBUILD,START,TSTART,TEXT,USRTMP
- N USRDATA,USRI,USRIEN,USRPICK,TMP0
- S REBUILD=0
- S START=1
- S TSTART=0
- S USRI=""
- F S USRI=$O(VALMY(USRI)) Q:+USRI'>0 D Q:$D(DIROUT)
- . S USRDATA=^TMP("USRCLASSIDX",$J,USRI)
- . S LISTNUM=$P(USRDATA,U,1)
- . S USRIEN=$P(USRDATA,U,2)
- . S TEXT=$G(^TMP("USRCLASS",$J,LISTNUM,0))
- . S ACTION=$S(TEXT["+":"+",TEXT["-":"-",1:"")
- . I ACTION="" Q
- .;If ACTION="+" then expand the class, if ACTION="-" shrink the class.
- . I ACTION="+" D
- .. S REBUILD=1
- .. S TSTART=$$COPYCL(.USRTMP,TSTART,START,LISTNUM-1)
- .. S START=LISTNUM+1
- .. S TSTART=TSTART+1
- .. S USRTMP(TSTART)=$$SETFLD^VALM1(TSTART,TEXT,"NUMBER")
- .. S USRTMP(TSTART)=$TR(USRTMP(TSTART),"+","-")
- .. S USRTMP(TSTART)=USRTMP(TSTART)_U_USRIEN
- .. S TSTART=$$INSSUB(.USRTMP,TSTART,USRIEN)
- . ; -- ACTION="-" --
- . I ACTION="-" D
- .. N TEMP,CONTRACT
- .. S REBUILD=1
- .. S TSTART=$$COPYCL(.USRTMP,TSTART,START,LISTNUM-1)
- .. S TSTART=TSTART+1
- .. S USRTMP(TSTART)=$$SETFLD^VALM1(TSTART,TEXT,"NUMBER")
- .. S USRLEVEL=$L(TEXT,"|")
- .. S USRTMP(TSTART)=$TR(USRTMP(TSTART),"-","+")_U_USRIEN
- .. S START=USRI+1
- .. S CONTRACT=1
- .. ; Patch 18 added the second quit.
- .. F Q:'CONTRACT Q:'$D(^TMP("USRCLASS",$J,START,0)) D
- ... S TEMP=^TMP("USRCLASS",$J,START,0)
- ...;Contract if at a or higher level than the main line
- ... I TEMP["|",$L(TEMP,"|")>USRLEVEL S START=START+1
- ... E S CONTRACT=0
- .;
- .;Restore the original video attributes.
- . D RESTORE^VALM10(USRI)
- ;No more classes to expand or contract, add the rest of the list.
- I 'REBUILD Q
- S TMP0=^TMP("USRCLASS",$J,0)
- S LISTNUM=$P(TMP0,U)
- S TSTART=$$COPYCL(.USRTMP,TSTART,START,LISTNUM)
- ;Rebuild the ^TMP arrays.
- K ^TMP("USRCLASS",$J),^TMP("USRCLASSIDX",$J),^TMP("USRCLASS",$J,"PICK")
- S VALMCNT=0
- S START=0
- F S START=$O(USRTMP(START)) Q:START="" D
- . S VALMCNT=VALMCNT+1
- . S TEXT=$P(USRTMP(START),U,1)
- . S USRIEN=$P(USRTMP(START),U,2)
- . S ^TMP("USRCLASS",$J,START,0)=TEXT
- . S ^TMP("USRCLASS",$J,"IDX",START,START)=""
- . S ^TMP("USRCLASSIDX",$J,START)=START_U_USRIEN
- S ^TMP("USRCLASS",$J,0)=VALMCNT_U_$P(TMP0,U,2)_$P(TMP0,U,3)_$P(TMP0,U,4)
- S USRPICK=+$O(^ORD(101,"B","USR ACTION SELECT LIST ELEMENT",0))
- S ^TMP("USRCLASS",$J,"#")=USRPICK_U_"1:"_+$G(VALMCNT)
- Q
- ;
- ;======================================================================
- INSSUB(LIST,TSTART,USRIEN) ;Insert the subclasses into the list.
- N ACTIVE,CLN,CLNS,DATA,IND,IEN,USRLEVEL,MSG,TEXT
- ;Determine the level of the subclass and create the appropriate
- ;diagram.
- S USRLEVEL=$L(LIST(TSTART),"|")
- I USRLEVEL=1 S CLNS=" "
- E S CLNS=""
- F IND=2:1:USRLEVEL S CLNS=CLNS_" | "
- I USRLEVEL>1 S CLNS=CLNS_" |_"
- E S CLNS=CLNS_"|_"
- S IND=0
- F S IND=$O(^USR(8930,USRIEN,1,IND)) Q:+IND=0 D
- . S IEN=^USR(8930,USRIEN,1,IND,0)
- . S DATA=$G(^USR(8930,IEN,0))
- . S TSTART=TSTART+1
- . S TEXT=$$SETFLD^VALM1(TSTART,"","NUMBER")
- . S CLN=CLNS
- . I $D(^USR(8930,IEN,1,0))&$D(^USR(8930,IEN,1,"B")) S CLN=CLN_"+"
- . E S CLN=CLN_" "
- . S CLN=CLN_$P(DATA,U) ; Use .01 name, not dipsplay name
- . S TEXT=$$SETFLD^VALM1(CLN,TEXT,"CLASS NAME")
- . S TEXT=$$SETFLD^VALM1($P(DATA,U,2),TEXT,"ABBREVIATION")
- . S ACTIVE=$$EXTERNAL^DILFD(8930,.03,"",$P(DATA,U,3),"MSG")
- . S TEXT=$$SETFLD^VALM1(ACTIVE,TEXT,"ACTIVE")
- .;NEED USRCLASSIDX INFO
- . S LIST(TSTART)=TEXT_U_IEN
- Q TSTART
- ;
- ;======================================================================
- ISSUB(CLASS1,CLASS2,USRLEVEL) ;Return true if CLASS2 is sub to CLASS1.
- N IND,ISSUB
- I USRLEVEL(CLASS1)'<USRLEVEL(CLASS2) Q 0
- ;Check sublevel links between class1 and class2
- S ISSUB=1
- F IND=(CLASS1+1):1:(CLASS2-1) D
- . I USRLEVEL(IND)=1 D Q
- .. S ISSUB=0
- Q ISSUB
- ;
- ;======================================================================
- VEXREQ(VALMY) ;Check for valid expand/contract requests.
- N END,START
- S START=$O(VALMY(""))
- S END=$O(VALMY(""),-1)
- I START=END Q 1
- ;
- N ACTION,ACTIND,ACTJND,CIND,CN,IND,JND,USRLEVEL,MSG,TEXT,VALID
- ;Build the level list.
- F IND=START:1:END D
- . S USRLEVEL(IND)=$L(^TMP("USRCLASS",$J,IND,0),"|")
- S VALID=1
- S IND=""
- F S IND=$O(VALMY(IND)) Q:IND="" D
- . S TEXT(IND)=$G(^TMP("USRCLASS",$J,IND,0))
- . S ACTIND=$S(TEXT(IND)["+":"+ ",TEXT(IND)["-":"-",1:"")
- . I ACTIND="" Q
- . S ACTION(IND)=$S(TEXT(IND)["+":"expand ",TEXT(IND)["-":"collapse ",1:"")
- . S JND=IND
- . F S JND=$O(VALMY(JND)) Q:JND="" D
- .. S TEXT(JND)=$G(^TMP("USRCLASS",$J,JND,0))
- .. S ACTJND=$S(TEXT(JND)["+":"+",TEXT(JND)["-":"-",1:"")
- .. I ACTJND="" Q
- .. S ACTION(JND)=$S(TEXT(JND)["+":"expand ",TEXT(JND)["-":"collapse ",1:"")
- .. I $$ISSUB(IND,JND,.USRLEVEL) D
- ... I ACTION(IND)'=ACTION(JND) D Q
- .... S CIND(IND)=$P(^TMP("USRCLASSIDX",$J,IND),U,2)
- .... S CN(IND)=$P(^USR(8930,CIND(IND),0),U,1)
- .... S CIND(JND)=$P(^TMP("USRCLASSIDX",$J,JND),U,2)
- .... S CN(JND)=$P(^USR(8930,CIND(JND),0),U,1)
- .... S MSG="You cannot "_ACTION(IND)_CN(IND)_" and "_ACTION(JND)_CN(JND)
- .... D MSG^VALM10(MSG)
- .... H 4
- .... S VALID=0
- Q VALID
- ;
- USRECCL ; SLC/PKR,MA - Routines for expanding/collapsing class views ;11/25/09
- +1 ;;1.0;AUTHORIZATION/SUBSCRIPTION;**7,18,33**;Jun 20, 1997;Build 5
- +2 ; Patch USR*1*18 additional quit to contract logic in tag EC.
- +3 ; This routine invokes IA #872
- +4 ;======================================================================
- COPYCL(LIST,LSTART,START,END) ;Copy elements of ^TMP("USRCLASS",$J) starting
- +1 ;at START going to END.
- +2 NEW IND,TEXT
- +3 FOR IND=START:1:END
- Begin DoDot:1
- +4 SET LSTART=LSTART+1
- +5 SET TEXT=^TMP("USRCLASS",$JOB,IND,0)
- +6 SET TEXT=$$SETFLD^VALM1(LSTART,TEXT,"NUMBER")
- +7 SET LIST(LSTART)=TEXT_U_$PIECE($GET(^TMP("USRCLASSIDX",$JOB,IND)),U,2)
- End DoDot:1
- +8 QUIT LSTART
- +9 ;
- +10 ;======================================================================
- EC(USRVALMY) ;Expand or contract the list of classes in VALMY.
- +1 ;Make sure the request is valid.
- +2 IF '$$VEXREQ(.USRVALMY)
- QUIT
- +3 NEW ACTION,DIROUT,LISTNUM,REBUILD,START,TSTART,TEXT,USRTMP
- +4 NEW USRDATA,USRI,USRIEN,USRPICK,TMP0
- +5 SET REBUILD=0
- +6 SET START=1
- +7 SET TSTART=0
- +8 SET USRI=""
- +9 FOR
- SET USRI=$ORDER(VALMY(USRI))
- IF +USRI'>0
- QUIT
- Begin DoDot:1
- +10 SET USRDATA=^TMP("USRCLASSIDX",$JOB,USRI)
- +11 SET LISTNUM=$PIECE(USRDATA,U,1)
- +12 SET USRIEN=$PIECE(USRDATA,U,2)
- +13 SET TEXT=$GET(^TMP("USRCLASS",$JOB,LISTNUM,0))
- +14 SET ACTION=$SELECT(TEXT["+":"+",TEXT["-":"-",1:"")
- +15 IF ACTION=""
- QUIT
- +16 ;If ACTION="+" then expand the class, if ACTION="-" shrink the class.
- +17 IF ACTION="+"
- Begin DoDot:2
- +18 SET REBUILD=1
- +19 SET TSTART=$$COPYCL(.USRTMP,TSTART,START,LISTNUM-1)
- +20 SET START=LISTNUM+1
- +21 SET TSTART=TSTART+1
- +22 SET USRTMP(TSTART)=$$SETFLD^VALM1(TSTART,TEXT,"NUMBER")
- +23 SET USRTMP(TSTART)=$TRANSLATE(USRTMP(TSTART),"+","-")
- +24 SET USRTMP(TSTART)=USRTMP(TSTART)_U_USRIEN
- +25 SET TSTART=$$INSSUB(.USRTMP,TSTART,USRIEN)
- End DoDot:2
- +26 ; -- ACTION="-" --
- +27 IF ACTION="-"
- Begin DoDot:2
- +28 NEW TEMP,CONTRACT
- +29 SET REBUILD=1
- +30 SET TSTART=$$COPYCL(.USRTMP,TSTART,START,LISTNUM-1)
- +31 SET TSTART=TSTART+1
- +32 SET USRTMP(TSTART)=$$SETFLD^VALM1(TSTART,TEXT,"NUMBER")
- +33 SET USRLEVEL=$LENGTH(TEXT,"|")
- +34 SET USRTMP(TSTART)=$TRANSLATE(USRTMP(TSTART),"-","+")_U_USRIEN
- +35 SET START=USRI+1
- +36 SET CONTRACT=1
- +37 ; Patch 18 added the second quit.
- +38 FOR
- IF 'CONTRACT
- QUIT
- IF '$DATA(^TMP("USRCLASS",$JOB,START,0))
- QUIT
- Begin DoDot:3
- +39 SET TEMP=^TMP("USRCLASS",$JOB,START,0)
- +40 ;Contract if at a or higher level than the main line
- +41 IF TEMP["|"
- IF $LENGTH(TEMP,"|")>USRLEVEL
- SET START=START+1
- +42 IF '$TEST
- SET CONTRACT=0
- End DoDot:3
- End DoDot:2
- +43 ;
- +44 ;Restore the original video attributes.
- +45 DO RESTORE^VALM10(USRI)
- End DoDot:1
- IF $DATA(DIROUT)
- QUIT
- +46 ;No more classes to expand or contract, add the rest of the list.
- +47 IF 'REBUILD
- QUIT
- +48 SET TMP0=^TMP("USRCLASS",$JOB,0)
- +49 SET LISTNUM=$PIECE(TMP0,U)
- +50 SET TSTART=$$COPYCL(.USRTMP,TSTART,START,LISTNUM)
- +51 ;Rebuild the ^TMP arrays.
- +52 KILL ^TMP("USRCLASS",$JOB),^TMP("USRCLASSIDX",$JOB),^TMP("USRCLASS",$JOB,"PICK")
- +53 SET VALMCNT=0
- +54 SET START=0
- +55 FOR
- SET START=$ORDER(USRTMP(START))
- IF START=""
- QUIT
- Begin DoDot:1
- +56 SET VALMCNT=VALMCNT+1
- +57 SET TEXT=$PIECE(USRTMP(START),U,1)
- +58 SET USRIEN=$PIECE(USRTMP(START),U,2)
- +59 SET ^TMP("USRCLASS",$JOB,START,0)=TEXT
- +60 SET ^TMP("USRCLASS",$JOB,"IDX",START,START)=""
- +61 SET ^TMP("USRCLASSIDX",$JOB,START)=START_U_USRIEN
- End DoDot:1
- +62 SET ^TMP("USRCLASS",$JOB,0)=VALMCNT_U_$PIECE(TMP0,U,2)_$PIECE(TMP0,U,3)_$PIECE(TMP0,U,4)
- +63 SET USRPICK=+$ORDER(^ORD(101,"B","USR ACTION SELECT LIST ELEMENT",0))
- +64 SET ^TMP("USRCLASS",$JOB,"#")=USRPICK_U_"1:"_+$GET(VALMCNT)
- +65 QUIT
- +66 ;
- +67 ;======================================================================
- INSSUB(LIST,TSTART,USRIEN) ;Insert the subclasses into the list.
- +1 NEW ACTIVE,CLN,CLNS,DATA,IND,IEN,USRLEVEL,MSG,TEXT
- +2 ;Determine the level of the subclass and create the appropriate
- +3 ;diagram.
- +4 SET USRLEVEL=$LENGTH(LIST(TSTART),"|")
- +5 IF USRLEVEL=1
- SET CLNS=" "
- +6 IF '$TEST
- SET CLNS=""
- +7 FOR IND=2:1:USRLEVEL
- SET CLNS=CLNS_" | "
- +8 IF USRLEVEL>1
- SET CLNS=CLNS_" |_"
- +9 IF '$TEST
- SET CLNS=CLNS_"|_"
- +10 SET IND=0
- +11 FOR
- SET IND=$ORDER(^USR(8930,USRIEN,1,IND))
- IF +IND=0
- QUIT
- Begin DoDot:1
- +12 SET IEN=^USR(8930,USRIEN,1,IND,0)
- +13 SET DATA=$GET(^USR(8930,IEN,0))
- +14 SET TSTART=TSTART+1
- +15 SET TEXT=$$SETFLD^VALM1(TSTART,"","NUMBER")
- +16 SET CLN=CLNS
- +17 IF $DATA(^USR(8930,IEN,1,0))&$DATA(^USR(8930,IEN,1,"B"))
- SET CLN=CLN_"+"
- +18 IF '$TEST
- SET CLN=CLN_" "
- +19 ; Use .01 name, not dipsplay name
- SET CLN=CLN_$PIECE(DATA,U)
- +20 SET TEXT=$$SETFLD^VALM1(CLN,TEXT,"CLASS NAME")
- +21 SET TEXT=$$SETFLD^VALM1($PIECE(DATA,U,2),TEXT,"ABBREVIATION")
- +22 SET ACTIVE=$$EXTERNAL^DILFD(8930,.03,"",$PIECE(DATA,U,3),"MSG")
- +23 SET TEXT=$$SETFLD^VALM1(ACTIVE,TEXT,"ACTIVE")
- +24 ;NEED USRCLASSIDX INFO
- +25 SET LIST(TSTART)=TEXT_U_IEN
- End DoDot:1
- +26 QUIT TSTART
- +27 ;
- +28 ;======================================================================
- ISSUB(CLASS1,CLASS2,USRLEVEL) ;Return true if CLASS2 is sub to CLASS1.
- +1 NEW IND,ISSUB
- +2 IF USRLEVEL(CLASS1)'<USRLEVEL(CLASS2)
- QUIT 0
- +3 ;Check sublevel links between class1 and class2
- +4 SET ISSUB=1
- +5 FOR IND=(CLASS1+1):1:(CLASS2-1)
- Begin DoDot:1
- +6 IF USRLEVEL(IND)=1
- Begin DoDot:2
- +7 SET ISSUB=0
- End DoDot:2
- QUIT
- End DoDot:1
- +8 QUIT ISSUB
- +9 ;
- +10 ;======================================================================
- VEXREQ(VALMY) ;Check for valid expand/contract requests.
- +1 NEW END,START
- +2 SET START=$ORDER(VALMY(""))
- +3 SET END=$ORDER(VALMY(""),-1)
- +4 IF START=END
- QUIT 1
- +5 ;
- +6 NEW ACTION,ACTIND,ACTJND,CIND,CN,IND,JND,USRLEVEL,MSG,TEXT,VALID
- +7 ;Build the level list.
- +8 FOR IND=START:1:END
- Begin DoDot:1
- +9 SET USRLEVEL(IND)=$LENGTH(^TMP("USRCLASS",$JOB,IND,0),"|")
- End DoDot:1
- +10 SET VALID=1
- +11 SET IND=""
- +12 FOR
- SET IND=$ORDER(VALMY(IND))
- IF IND=""
- QUIT
- Begin DoDot:1
- +13 SET TEXT(IND)=$GET(^TMP("USRCLASS",$JOB,IND,0))
- +14 SET ACTIND=$SELECT(TEXT(IND)["+":"+ ",TEXT(IND)["-":"-",1:"")
- +15 IF ACTIND=""
- QUIT
- +16 SET ACTION(IND)=$SELECT(TEXT(IND)["+":"expand ",TEXT(IND)["-":"collapse ",1:"")
- +17 SET JND=IND
- +18 FOR
- SET JND=$ORDER(VALMY(JND))
- IF JND=""
- QUIT
- Begin DoDot:2
- +19 SET TEXT(JND)=$GET(^TMP("USRCLASS",$JOB,JND,0))
- +20 SET ACTJND=$SELECT(TEXT(JND)["+":"+",TEXT(JND)["-":"-",1:"")
- +21 IF ACTJND=""
- QUIT
- +22 SET ACTION(JND)=$SELECT(TEXT(JND)["+":"expand ",TEXT(JND)["-":"collapse ",1:"")
- +23 IF $$ISSUB(IND,JND,.USRLEVEL)
- Begin DoDot:3
- +24 IF ACTION(IND)'=ACTION(JND)
- Begin DoDot:4
- +25 SET CIND(IND)=$PIECE(^TMP("USRCLASSIDX",$JOB,IND),U,2)
- +26 SET CN(IND)=$PIECE(^USR(8930,CIND(IND),0),U,1)
- +27 SET CIND(JND)=$PIECE(^TMP("USRCLASSIDX",$JOB,JND),U,2)
- +28 SET CN(JND)=$PIECE(^USR(8930,CIND(JND),0),U,1)
- +29 SET MSG="You cannot "_ACTION(IND)_CN(IND)_" and "_ACTION(JND)_CN(JND)
- +30 DO MSG^VALM10(MSG)
- +31 HANG 4
- +32 SET VALID=0
- End DoDot:4
- QUIT
- End DoDot:3
- End DoDot:2
- End DoDot:1
- +33 QUIT VALID
- +34 ;