Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: XUSER1

XUSER1.m

Go to the documentation of this file.
  1. XUSER1 ;ISF/RWF - User file Utilities ;09/30/09 16:38
  1. ;;8.0;KERNEL;**169,210,222,514**;Jul 10, 1995;Build 14
  1. Q
  1. ;
  1. PAGE() ;Do a page break; Return 0 if ok to continue, 1 if to abort
  1. N DIR
  1. S DIR(0)="E" D ^DIR:($E(IOST,1,2)["C-")
  1. Q:$D(DIRUT) 1 W @IOF S ($X,$Y)=0
  1. Q 0
  1. ;
  1. GKEYS(IE,XUA) ;Get the keys held. IE=user
  1. N %,V,XUB
  1. S %=0 ;Sort list alphabetical
  1. F S %=$O(^VA(200,IE,51,%)) Q:(%'>0) S V=$P($G(^DIC(19.1,%,0)),U,1) I $L(V) S XUB(V)=""
  1. S V="" ;return to user
  1. F %=1:1 S V=$O(XUB(V)) Q:'$L(V) S XUA(%)=V
  1. Q
  1. ;
  1. SHLIST(ARRAY,LM,SP) ; Show a list, Array=list, LM=Left Margin, SP=spacing
  1. ;Set DN=0 to get FM22 to stop the print
  1. N %,Y2,Y4,Y5,Y6,DIR
  1. I $Y+4>IOSL,$$PAGE S DN=0 Q
  1. S Y4=-1,%=0,Y2=IOM-LM\SP,Y5=0
  1. F S %=$O(ARRAY(%)),Y4=Y4+1 Q:(%'>0)!$D(DIRUT) S Y6=$G(ARRAY(%)) D:$L(Y6)
  1. . S:Y4'<SP Y4=0 S Y5=(Y4*Y2+LM)
  1. . I $X>0,Y5+$L(Y6)'<IOM S Y4=0,Y5=(Y4*Y2+LM)
  1. . I 'Y4 W ! I $Y+3>IOSL S Y4=0,Y5=(Y4*Y2+LM) I $$PAGE S DN=0 Q
  1. . W ?Y5,Y6 S:(($X+1)>(Y5+Y2)) Y4=Y4+1
  1. . Q
  1. Q
  1. ;
  1. SHPC(IE) ;Show the Person Class
  1. N %,Y S:'$D(DT) DT=$$DT^XLFDT
  1. S %=$X,Y=$$GET^XUA4A72(IE,DT)
  1. I $L(Y) W $P(Y,U,2) I $L($P(Y,U,3)) W !,?(%+2),$P(Y,U,3) I $L($P(Y,U,4)) W !,?(%+4),$P(Y,U,4)
  1. Q
  1. GMG(IE,XUA) ;Get mail groups
  1. N %,Y,XUI,Y4,Y2,XUK
  1. S %=0
  1. F S %=$O(^XMB(3.8,"AB",IE,%)) Q:%'>0 S XUA(%)=$P($G(^XMB(3.8,%,0)),U,1)
  1. Q
  1. GPARAM(IE,PRAM,XUA) ;Get an entry from the Parameter tool
  1. ;IE is the user to get the list for. PARAM what parameter, XUA return array.
  1. N XUENT,XUX,XUERR,XU1
  1. S XUENT=IE_";VA(200,"_$S($G(^VA(200,IE,5)):"^SRV.`"_+$G(^(5)),1:""),XUA=""
  1. D GETLST^XPAR(.XUX,XUENT,PRAM,"E",.XUERR)
  1. Q:XUX'>0
  1. S XUA(.5)=PRAM_":"
  1. F %=1:1:XUX S XUA(%)=$P(XUX(%),U,2)
  1. Q
  1. ;
  1. DIVCHG ;Allow user to change Division [DUZ(2)] value
  1. ;Called from option: XUSER DIV CHG
  1. N Y,X,DIC,I,CD
  1. I '$D(^VA(200,+$G(DUZ),0))#2 W !,"You are not a valid user.",!!,$C(7) Q
  1. I $G(DUZ(2))="" D ;Should not happen
  1. . N XOPT D XOPT^XUS1A S DUZ(2)=$P(XOPT,U,17)
  1. S CD=$$NS^XUAF4(DUZ(2))
  1. W !,"Your current Division is ",$P(CD,U)_" "_$P(CD,U,2)
  1. S X=+$O(^VA(200,DUZ,2,0)),Y=+$O(^(X))
  1. I 'Y W !,"You do not have any choices. ",!," Change is not possible.",!! Q
  1. K DIC S DIC="^VA(200,DUZ,2,",DIC(0)="AEMNQ"
  1. S DIC("S")="I $G(^DIC(4,+Y,99))"
  1. ;Check if user has a default
  1. S X=$O(^VA(200,DUZ,2,"AX1",1,0)) S:X>0 DIC("B")=$P($$NS^XUAF4(X),U)
  1. D ^DIC K DIC
  1. I Y'>0 D Q
  1. .W !,$C(7),"Division Unchanged - Currently you are assigned to "
  1. .W $P(CD,U)_" "_$P(CD,U,2),!
  1. S DUZ(2)=+Y,CD=$$NS^XUAF4(DUZ(2))
  1. W !?5,"Division is now set to [ ",$P(CD,U)_" "_$P(CD,U,2)," ]",!
  1. Q
  1. ;
  1. NETNM(NM,IEN) ;Check NetName, Called from input transform for field 501.1 NPF.
  1. ;Return 1 to abort, 0 to allow
  1. N NPF,OV
  1. S NPF(0)=$P($G(^VA(200,IEN,0)),U,1),OV=0
  1. I $E(NM,1,3)'="VHA" D EN^DDIOL("WARNING: Prefix not VHA.","") S OV=1
  1. S NPF(1)=$E($P(NPF(0),","),1,5)_$E($P(NPF(0),",",2),1)
  1. I $E(NM,7,6+$L(NPF(1)))'=NPF(1) D EN^DDIOL("WARNING: Missing "_NPF(1)_" from username.","") S OV=1
  1. I OV S OV='((DUZ(0)["@")!$D(^XUSEC("XUMGR",DUZ)))
  1. Q OV
  1. ;