| 1 | RGRSUTL2 ;ALB/RJS-UTILITIES FOR CIRN ;1/2/97
 | 
|---|
| 2 |  ;;1.0; CLINICAL INFO RESOURCE NETWORK ;;30 Apr 99
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 | SSN(SSN,ARRAY) ;RETURNS DFN'S OF ALL SSN'S OR PSUEDO'S THAT MATCH 
 | 
|---|
| 5 |  ;        THE SSN PASSED
 | 
|---|
| 6 |  ;        CALLING ROUTINE MUST KILL ARRAY BEFORE CALLING THIS
 | 
|---|
| 7 |  ;        FUNCTION
 | 
|---|
| 8 |  Q:$G(SSN)=""!($G(ARRAY)="")
 | 
|---|
| 9 |  N RGDFN S RGDFN=0
 | 
|---|
| 10 |  F  S RGDFN=$O(^DPT("SSN",SSN,RGDFN)) Q:RGDFN'>0  D SET(RGDFN)
 | 
|---|
| 11 |  I $D(@ARRAY) Q 1
 | 
|---|
| 12 |  Q 0
 | 
|---|
| 13 | SET(DFN) ;
 | 
|---|
| 14 |  Q:'$D(^DPT(DFN,0))
 | 
|---|
| 15 |  S @ARRAY@(DFN)=$P(^DPT(DFN,0),"^",1)
 | 
|---|
| 16 |  Q
 | 
|---|
| 17 |  ; This function determines if a word is singular or plural and also
 | 
|---|
| 18 |  ; determines if "no" or a numeric value is placed in front of
 | 
|---|
| 19 |  ; the word (ie no exception(s)).
 | 
|---|
| 20 | SNGPLR(RGNUM,RGSNG,RGPLR) ;
 | 
|---|
| 21 |  N RGZ
 | 
|---|
| 22 |  S RGZ=RGSNG?.E1L.E,RGPLR=$G(RGPLR,RGSNG_$S(RGZ:"s",1:"S"))
 | 
|---|
| 23 |  Q $S('RGNUM:$S(RGZ:"no ",1:"NO ")_RGPLR,RGNUM=1:"1 "_RGSNG,1:RGNUM_" "_RGPLR)
 | 
|---|
| 24 |  ; Display formatted title
 | 
|---|
| 25 | TITLE(RGTTL,RGVER,RGFN) ;
 | 
|---|
| 26 |  I '$D(IOM) N IOM,IOF S IOM=80,IOF="#"
 | 
|---|
| 27 |  S RGVER=$G(RGVER,"1.0")
 | 
|---|
| 28 |  S:RGVER RGVER="Version "_RGVER
 | 
|---|
| 29 |  U $G(IO,$I)
 | 
|---|
| 30 |  W @IOF,$S(IO=IO(0):$C(27,91,55,109),1:""),$C(13)
 | 
|---|
| 31 |  S Y=$$DT^XLFDT X ^DD("DD")
 | 
|---|
| 32 |  W Y,?(IOM-$L(RGTTL)\2),RGTTL,?(IOM-$L(RGVER)),RGVER,!,$S(IO=IO(0):$C(27,91,109),1:$$UND),!
 | 
|---|
| 33 |  W:$D(RGFN) ?(IOM-$L(RGFN)\2),RGFN,!
 | 
|---|
| 34 |  Q
 | 
|---|
| 35 |  ; Pause for user response
 | 
|---|
| 36 | PAUSE(RGP,RGX,RGY) ;
 | 
|---|
| 37 |  Q $$GETCH($G(RGP,"Press RETURN or ENTER to continue..."),U,.RGX,.RGY)
 | 
|---|
| 38 |  ; Single character read
 | 
|---|
| 39 | GETCH(RGP,RGV,RGX,RGY,RGT,RGD) ;
 | 
|---|
| 40 |  N RGZ,RGC
 | 
|---|
| 41 |  W:$D(RGX)!$D(RGY) $$XY($G(RGX,$X),$G(RGY,$Y))
 | 
|---|
| 42 |  W $G(RGP)
 | 
|---|
| 43 |  S RGT=$G(RGT,$G(DTIME,999999999999)),RGD=$G(RGD,U),RGC=""
 | 
|---|
| 44 |  S:$D(RGV) RGV=$$UP^XLFSTR(RGV)_U
 | 
|---|
| 45 |  F  D  Q:'$L(RGZ)
 | 
|---|
| 46 |  .S RGZ=$$READ^XGF(1,RGT)
 | 
|---|
| 47 |  .E  S RGC=RGD Q
 | 
|---|
| 48 |  .W $C(8)
 | 
|---|
| 49 |  .Q:'$L(RGZ)
 | 
|---|
| 50 |  .S RGZ=$$UP^XLFSTR(RGZ)
 | 
|---|
| 51 |  .I $D(RGV) D
 | 
|---|
| 52 |  ..I RGV[RGZ S RGC=RGZ
 | 
|---|
| 53 |  ..E  W $C(7,32,8) S RGC=""
 | 
|---|
| 54 |  .E  S RGC=RGZ
 | 
|---|
| 55 |  W !
 | 
|---|
| 56 |  Q RGC
 | 
|---|
| 57 |  ; Convert X to base Y padded to length L
 | 
|---|
| 58 | BASE(X,Y,L) ;
 | 
|---|
| 59 |  Q:(Y<2)!(Y>62) ""
 | 
|---|
| 60 |  N RGZ,RGZ1
 | 
|---|
| 61 |  S RGZ1="",X=$S(X<0:-X,1:X)
 | 
|---|
| 62 |  F  S RGZ=X#Y,X=X\Y,RGZ1=$C($S(RGZ<10:RGZ+48,RGZ<36:RGZ+55,1:RGZ+61))_RGZ1 Q:'X
 | 
|---|
| 63 |  Q $S('$G(L):RGZ1,1:$$REPEAT^XLFSTR(0,L-$L(RGZ1))_$E(RGZ1,1,L))
 | 
|---|
| 64 |  ;
 | 
|---|
| 65 |  ; Output an underline X bytes long
 | 
|---|
| 66 | UND(X) Q $$REPEAT^XLFSTR("-",$G(X,$G(IOM,80)))
 | 
|---|
| 67 |  ;
 | 
|---|
| 68 |  ; Position cursor
 | 
|---|
| 69 | XY(DX,DY) ;
 | 
|---|
| 70 |  D:$G(IOXY)="" HOME^%ZIS
 | 
|---|
| 71 |  S DX=$S(+$G(DX)>0:+DX,1:0),DY=$S(+$G(DY)>0:+DY,1:0),$X=0
 | 
|---|
| 72 |  X IOXY
 | 
|---|
| 73 |  S $X=DX,$Y=DY
 | 
|---|
| 74 |  ; Send an alert.
 | 
|---|
| 75 |  ;    XQAMSG = Message to send
 | 
|---|
| 76 |  ;    RGUSR  = A semicolon-delimited list of users to receive alert.
 | 
|---|
| 77 | ALERT(XQAMSG,RGUSR) ;
 | 
|---|
| 78 |  N XQA,XQAOPT,XQAFLG,XQAROU,XQADATA,XQAID
 | 
|---|
| 79 |  S @$$TRAP^RGZOSF("EXIT^RGRSUTL2"),RGUSR=$G(RGUSR,"*"),XQAMSG=$TR(XQAMSG,U,"~")
 | 
|---|
| 80 |  D ENTRY(RGUSR,.XQA),SETUP^XQALERT:$D(XQA)
 | 
|---|
| 81 | EXIT Q
 | 
|---|
| 82 |  ; Takes a list of receipients as input and produces an array of
 | 
|---|
| 83 |  ; DUZ's as output.
 | 
|---|
| 84 |  ; Inputs:
 | 
|---|
| 85 |  ;     RGUSR = Semicolon-delimited list of recipients
 | 
|---|
| 86 |  ;     RGLST = Special token list
 | 
|---|
| 87 |  ; Outputs:
 | 
|---|
| 88 |  ;     RGOUT = Local array to receive DUZ list
 | 
|---|
| 89 | ENTRY(RGUSR,RGOUT,RGLST) ;
 | 
|---|
| 90 |  N RGZ,RGZ1,RGZ2
 | 
|---|
| 91 |  K RGOUT
 | 
|---|
| 92 |  F RGZ=1:1:$L(RGUSR,";") S RGZ1=$P(RGUSR,";",RGZ) D:RGZ1'=""  S:RGZ1 RGOUT(+RGZ1)=""
 | 
|---|
| 93 |  .S:$D(RGLST(RGZ1)) RGZ1=RGLST(RGZ1)
 | 
|---|
| 94 |  .Q:RGZ1?.N
 | 
|---|
| 95 |  .I RGZ1?1"-"1.N D MGRP(-RGZ1) S RGZ1=0 Q
 | 
|---|
| 96 |  .S RGZ2=$E(RGZ1,1,2)
 | 
|---|
| 97 |  .I RGZ2="G." D MGRP($E(RGZ1,3,999)) Q
 | 
|---|
| 98 |  .I RGZ2="L." D LIST($E(RGZ1,3,999)) Q
 | 
|---|
| 99 |  .S RGZ1=$$LKP(RGZ1)
 | 
|---|
| 100 |  Q
 | 
|---|
| 101 | LKP(RGNAME) ;
 | 
|---|
| 102 |  N RGZ,RGZ1
 | 
|---|
| 103 |  I $D(^VA(200,"B",RGNAME)) S RGZ=RGNAME G L1
 | 
|---|
| 104 |  S RGZ=$O(^(RGNAME)),RGZ1=$O(^(RGZ))
 | 
|---|
| 105 |  Q:(RGZ="")!(RGNAME'=$E(RGZ,1,$L(RGNAME))) 0
 | 
|---|
| 106 |  Q:(RGZ1'="")&(RGNAME=$E(RGZ1,1,$L(RGNAME))) 0
 | 
|---|
| 107 | L1 S RGZ1=$O(^(RGZ,0)),RGZ=$O(^(RGZ1))
 | 
|---|
| 108 |  Q:'RGZ1!RGZ 0
 | 
|---|
| 109 |  Q RGZ1
 | 
|---|
| 110 |  ; Send a mail message.
 | 
|---|
| 111 | MAIL(RGMSG,XMY,XMSUB,XMDUZ) ;
 | 
|---|
| 112 |  N XMTEXT
 | 
|---|
| 113 |  S:$D(RGMSG)=1 RGMSG(1)=RGMSG
 | 
|---|
| 114 |  S XMTEXT="RGMSG(",@$$TRAP^RGZOSF("EXIT^RGRSUTL2"),XMY=$G(XMY)
 | 
|---|
| 115 |  S:$G(XMSUB)="" XMSUB=RGMSG
 | 
|---|
| 116 |  S:$G(XMDUZ)="" XMDUZ=$G(DUZ)
 | 
|---|
| 117 |  F  Q:'$L(XMY)  S X=$P(XMY,";"),XMY=$P(XMY,";",2,999) S:$L(X) XMY(X)=""
 | 
|---|
| 118 |  D ^XMD:$D(XMY)>9
 | 
|---|
| 119 |  Q
 | 
|---|
| 120 | LIST(RGLIST) ;
 | 
|---|
| 121 |  Q:RGLIST=""
 | 
|---|
| 122 |  S:RGLIST'=+RGLIST RGLIST=+$O(^RGCDSS(993.6,"B",RGLIST,0))
 | 
|---|
| 123 |  S @$$TRAP^RGZOSF("LERR^RGUTUSR")
 | 
|---|
| 124 |  X:$D(^RGCDSS(993.6,RGLIST,1)) ^(1)
 | 
|---|
| 125 | LERR Q
 | 
|---|
| 126 | MGRP(RGMGRP) ;
 | 
|---|
| 127 |  N RGX
 | 
|---|
| 128 |  S RGX(0)=""
 | 
|---|
| 129 |  D MGRP2(RGMGRP)
 | 
|---|
| 130 |  Q
 | 
|---|
| 131 | MGRP2(RGMGRP) ;
 | 
|---|
| 132 |  N RGZ,RGZ1
 | 
|---|
| 133 |  Q:RGMGRP=""
 | 
|---|
| 134 |  S:RGMGRP'=+RGMGRP RGMGRP=+$O(^XMB(3.8,"B",RGMGRP,0))
 | 
|---|
| 135 |  Q:$D(RGX(RGMGRP))
 | 
|---|
| 136 |  S RGX(RGMGRP)=""
 | 
|---|
| 137 |  F RGZ=0:0 S RGZ=+$O(^XMB(3.8,RGMGRP,1,RGZ)) Q:'RGZ  S RGOUT(+^(RGZ,0))=""
 | 
|---|
| 138 |  F RGZ=0:0 S RGZ=+$O(^XMB(3.8,RGMGRP,5,RGZ)) Q:'RGZ  D MGRP2(^(RGZ,0))
 | 
|---|
| 139 |  Q
 | 
|---|