[613] | 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
|
---|