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

RGUTLK2.m

Go to the documentation of this file.
  1. RGUTLK2 ;CAIRO/DKM - Continuation of RGUTLKP;04-Sep-1998 11:26;DKM
  1. ;;2.1;RUN TIME LIBRARY;;Mar 22, 1999
  1. LKP(%RGDX) ;
  1. N %RGD,%RGZ,%RGN
  1. S %RGXRN=0,%RGTRUNC=0,%RGIEN="",%RGSCT=0,%RGD=%RGDX
  1. W:'%RGHTML $$XY(%RGX+$L(%RGPRMPT),%RGY),$S(%RGOPT["X":"",1:%RGD),%RGEOS,!,"Searching"_$S(%RGOPT[U:" (press ^ to abort)",1:"")_"...",*13
  1. I $E(%RGD)="`" S %RGSLCT=%RGD G:'%RGHTML NR5 D SHOW($E(%RGD,2,999)) Q 1
  1. NXTREF S %RGXRN=%RGXRN+1,%RGXRF=$P(%RGXRFS,U,%RGXRN),%RGD=%RGDX
  1. I %RGXRF="" G:%RGSCT NR3 W:'%RGHTML *7,*13,%RGEOL,"Not found"_$S(%RGD="":".",1:": ")_$S(%RGD'=+%RGD:%RGD,%RGOPT["D":$$ENTRY^RGUTDT(%RGD),1:%RGD) S %RGD1=$S(%RGOPT["X":U,1:"") Q ""
  1. S %RGOPT(0)=%RGOPT_%RGXRFS(%RGXRF)
  1. I %RGOPT(0)["D",$L(%RGDX) D G:%RGD<1 NXTREF
  1. .S %RGD=$$%DT^RGUT(%RGDX)
  1. I %RGOPT(0)["W" D MTL G NXTREF
  1. S %RGKEY=$S(%RGOPT(0)["P":$P(%RGD," "),1:%RGD)_$S(%RGDIR<0:$C(255),1:""),%RGNUM=$S(%RGKEY=+%RGKEY:%RGKEY,1:"")
  1. I %RGD'="",$D(@%RGDIC@(%RGXRF,%RGD)) S %=%RGSCT+1 D ADD(%RGD) I %RGSCT=%,%RGOPT(0)["A" D SLCT(%RGSCT) Q %RGIEN
  1. NR2 I %RGOPT(0)[U R %#1:0 I %=U S %RGTRUNC=1 G NR3:%RGSCT Q ""
  1. S %RGKEY=$O(@%RGDIC@(%RGXRF,%RGKEY),%RGDIR)
  1. I (%RGNUM="")=(%RGKEY=+%RGKEY),%RGD'="" S %RGKEY=""
  1. I %RGKEY'="",%RGOPT(0)["P",%RGKEY'=%RGD S %=$$PARTIAL(%RGD,%RGKEY) D ADD(%RGKEY):%>0 G:%'<0 NR2:%RGSCT<100
  1. I %RGKEY'="",%RGOPT(0)'["P",$E(%RGKEY,1,$L(%RGD))=%RGD D ADD(%RGKEY) G:%RGSCT<100 NR2
  1. I %RGNUM'="" S %RGKEY=%RGNUM_$C($S(%RGDIR<0:255,1:1)),%RGNUM="" G NR2
  1. I %RGSCT'<100 W:'%RGHTML *7 S %RGXRALL=0,%RGTRUNC=1
  1. G:'%RGSCT!%RGXRALL NXTREF
  1. NR3 I %RGSCT=1,%RGOPT(0)[1,'%RGTRUNC D SLCT(1) Q %RGIEN
  1. S %RGKEY=%RGSLT,%RGSLT=1,%RGSMAX=$S(%RGHTML:99999,1:17-%RGY)
  1. NR4 W:'%RGHTML $$XY(0,%RGY+1),%RGEOS,!
  1. F %RGN=%RGKEY:1:%RGKEY+%RGSMAX-1 D Q:%RGN=%RGSCT
  1. .F %RGZ=0:1:%RGCOL-1 D
  1. ..S %1=IOM/%RGCOL*%RGZ\1,%RGLAST=%RGZ*%RGSMAX+%RGN
  1. ..Q:%RGLAST>%RGSCT
  1. ..W:'%RGHTML $$XY(%1,$Y),%RGEOL,%RGLAST,?5
  1. ..D SHOW(^TMP(%RGPID,%RGLAST),%1+4)
  1. .W:'%RGQUIET !
  1. Q:%RGHTML $S(%RGTRUNC:-%RGSCT,1:%RGSCT)
  1. W:%RGLAST<%RGSCT !,%RGSCT-%RGLAST," more choice(s)..."
  1. W:%RGTRUNC " (list was truncated)",!
  1. W %RGEOS_%RGBEL,!!
  1. R "Enter selection: ",%RGSLCT:DTIME
  1. S:'$T %RGSLCT=U
  1. W *13
  1. I %RGOPT["K",%RGSLCT="" Q -1
  1. I "Nn"[%RGSLCT S %RGKEY=$S(%RGLAST<%RGSCT:%RGLAST+1,1:1) G NR4
  1. I "Bb"[%RGSLCT S %RGKEY=$S(%RGKEY=1:%RGSCT-%RGSMAX+1,%RGKEY'>%RGSMAX:1,1:%RGKEY-%RGSMAX) S:%RGKEY<1 %RGKEY=1 G NR4
  1. I "?"[%RGSLCT D HELP2 G NR4
  1. I "^^"[%RGSLCT S %RGD2="",%RGD1=$S(%RGOPT(0)["X":%RGSLCT,%RGSLCT="^^":%RGSLCT,1:"") Q ""
  1. NR5 F D Q:%RGSLCT=""
  1. .I %RGOPT(0)["M" S %RGD=$P(%RGSLCT,";"),%RGSLCT=$P(%RGSLCT,";",2,999)
  1. .E S %RGD=%RGSLCT,%RGSLCT=""
  1. .Q:'$L(%RGD)
  1. .I %RGD?1.N D SLCT(%RGD) Q
  1. .I %RGOPT(0)["M",%RGD?1.N1"-".N D Q
  1. ..N %1,%2
  1. ..S %1=+%RGD,%2=+$P(%RGD,"-",2)
  1. ..S:'%2 %2=%RGSCT
  1. ..S:%1>%2 %RGD=%1,%1=%2,%2=%RGD
  1. ..S:%2>%RGSCT %2=%RGSCT
  1. ..F %=%1:1:%2 D SLCT(%)
  1. .I %RGOPT["X",%RGOPT'["L" S (%RGSLCT,%RGD1,%RGIEN)="" Q
  1. .I $E(%RGD)="`" D Q
  1. ..S %RGD=+$E(%RGD,2,999)
  1. ..I $$VALD(%RGD) D DISV(%RGD) S %RGIEN=%RGD
  1. .S %RGD1=%RGD1_";"_%RGD
  1. W $$XY(0,%RGY+1),%RGEOS,!
  1. Q %RGIEN
  1. ; Add list selection to output
  1. SLCT(%RGSLCT) ;
  1. I %RGSLCT>0,%RGSLCT'>%RGSCT D
  1. .S %RGIEN=+^TMP(%RGPID,+%RGSLCT)
  1. .D DISV(%RGIEN)
  1. Q
  1. ; Add IEN to output
  1. DISV(%RGIEN) ;
  1. Q:%RGIEN=""
  1. I %RGMUL'="",'$D(@%RGMUL@(%RGIEN)) S @%RGMUL@(%RGIEN)="" D:'%RGQUIET APP(%RGIEN)
  1. D:%RGMUL="" APP(%RGIEN)
  1. Q:%RGOPT(0)["F"
  1. K:%RGSAME ^DISV(DUZ,%RGDISV)
  1. S %RGSAME=0,^DISV(DUZ,%RGDISV)=%RGIEN,^(%RGDISV,%RGIEN)=""
  1. Q
  1. ; Append primary key to key list
  1. APP(%RGIEN) ;
  1. N %RGKEY
  1. S %RGKEY=$S(%RGIEN=+%RGIEN:$P($G(@%RGDIC@(%RGIEN,0)),U),1:%RGIEN)
  1. S %RGKEY=$$FMT(%RGIEN,%RGKEY)
  1. Q:'$L(%RGKEY)!($L(%RGKEY)+$L(%RGD2)'<250)
  1. S %RGD2=%RGD2_$S($L(%RGD2):";",1:"")_%RGKEY
  1. I %RGOPT(0)'["J",%RGOPT(0)'["M" S %RGD2=%RGD2_" "_$$SID(%RGIEN)
  1. Q
  1. ; Multi-term lookup
  1. MTL N %
  1. S %=$S(%RGDIC[")":$TR(%RGDIC,")",","),1:%RGDIC_"(")_"%RGXRF)"
  1. S %=$$LKP^RGUTMTL(%,%RGD,"^TMP(""MTL"",%RGPID)",%RGOPT(0)[U)
  1. S:%<0 %RGTRUNC=1
  1. D:% ADD(%RGPID,"^TMP","MTL")
  1. K ^TMP("MTL",%RGPID)
  1. Q
  1. ; Add key to selection list
  1. ADD(%RGKEY,%RGIDX,%RGSUB) ;
  1. N %S
  1. S:'$D(%RGIDX) %RGIDX=%RGDIC,%RGSUB=%RGXRF
  1. F %S=0:0 S %S=$O(@%RGIDX@(%RGSUB,%RGKEY,%S)) Q:'%S D
  1. .I %RGOPT(0)["O",$D(^TMP(%RGPID,0,%S)) Q
  1. .I $$VALD(%S) D
  1. ..S %RGSCT=%RGSCT+1,^TMP(%RGPID,%RGSCT)=%S_U_$S(%RGOPT(0)["W":"",1:%RGKEY),^(0,%S)=""
  1. ..I %RGOPT(0)["S",$G(^DISV(DUZ,%RGDISV))=%S S %RGSLT=%RGSCT
  1. Q
  1. ; Check entry against screening criteria
  1. VALD(%S) Q:'$D(@%RGDIC@(%S))!'%S 0
  1. Q:%RGSCN="" 1
  1. N %,%1
  1. S %1=1,@$$TRAP^RGUTOS("V3^RGUTLK2")
  1. F %=0:0 S %=$O(@%RGSCN@(%)) Q:'% D Q:%1
  1. .S %1=0,@$$TRAP^RGUTOS("V2^RGUTLK2")
  1. .X "S %1="_@%RGSCN@(%)
  1. V2 .Q
  1. Q %1
  1. V3 Q 0
  1. ; Show the specified selection
  1. SHOW(%RGSLCT,%RGCOL1,%RGCOL2) ;
  1. N %S,%Z,%P,%I
  1. S %S=+%RGSLCT,%Z=$G(@%RGDIC@(%S,0)),%P=$$FMT(%S,$S(%RGOPT["I":$P(%RGSLCT,U,2),1:$P(%Z,U)))
  1. ;S %I=$$SID(%S,$P(%RGSLCT,U,2)),%I=$S(%I="":%P,1:%I)
  1. S %I=$$SID(%S,%P),%I=$S(%I="":%P,1:%I)
  1. I %RGHTML D Q
  1. .I '%RGQUIET W $$MSG^RGUT(%RGPRMPT,"|"),!
  1. .E D DISV(%S)
  1. S %RGCOL1=+$G(%RGCOL1,$X)
  1. I %RGOPT(0)["Y" S %RGCOL2=+$G(%RGCOL2,IOM\%RGCOL+%RGCOL1-8-$L(%I))
  1. E S %RGCOL2=+$G(%RGCOL2,IOM\%RGCOL\$S(%RGOPT(0)["D":3,1:2)-3+%RGCOL1)
  1. W $$XY(%RGCOL1,$Y)
  1. I %RGOPT(0)'["J",%I'=%P W $$TRUNC^RGUT(%P,IOM\%RGCOL-6),?%RGCOL2," "_$$TRUNC^RGUT(%I,IOM-%RGCOL2-2)
  1. E W $$TRUNC^RGUT(%I,IOM\%RGCOL-6)
  1. Q
  1. ; Return external form of result
  1. FMT(%S,%RGKEY) ;
  1. Q:%RGKEY="" %RGKEY
  1. I %RGTRP'="",$D(@%RGTRP@(%RGKEY)) Q @%RGTRP@(%RGKEY)
  1. S:%RGOPT(0)["D" %RGKEY=$$ENTRY^RGUTDT(%RGKEY)
  1. I %RGOPT(0)["Z",%RGSCN'="",$G(@%RGSCN)'="" S @("%RGKEY="_@%RGSCN)
  1. S:%RGOPT["J" %RGKEY=$$SID(%S,%RGKEY)
  1. Q %RGKEY
  1. ; Return secondary identifier
  1. SID(%S,%RGKEY) ;
  1. S %RGKEY=$G(%RGKEY)
  1. N %Z
  1. S %Z=$G(@%RGDIC@(%S,0)),@("%Z="_$S(%RGSID<0:$S(%RGKEY=$$UP^XLFSTR($P(%Z,U)):"""""",1:"%RGKEY"),%RGSID="":"%RGSID",1:%RGSID))
  1. Q %Z
  1. ; Partial key lookup
  1. PARTIAL(%RGD,%RGKEY) ;
  1. N %,%1,%2
  1. S (%(1),%(2))=0,%1(1)=%RGD,%1(2)=%RGKEY
  1. F %=1,2 S %1(%)=$TR(%1(%),".,;:?/!-"," ")
  1. P1 S (%2(1),%2(2))=""
  1. F %=1,2 D
  1. .F %(%)=%(%)+1:1:$L(%1(%)," ") S %2(%)=$P(%1(%)," ",%(%)) Q:%2(%)'=""
  1. Q:%2(1)="" 1
  1. Q:%2(1)'=$E(%2(2),1,$L(%2(1))) -(%(1)=1)
  1. G P1
  1. HELP(X) ; Application-specific help
  1. N %
  1. S %=""
  1. F S %=$O(X(%)) Q:%="" D:$Y>20 PAUSE W $G(X(%)),!
  1. Q
  1. ; Generic help
  1. HELP1 N %
  1. W !!
  1. D:%RGHLP'="" @%RGHLP
  1. W !,"Enter a blank line for default action.",!
  1. D:$Y>20 PAUSE
  1. W:%RGOPT'["W" "Enter ?? to see all possible selections.",!
  1. D:$Y>20 PAUSE
  1. W "Enter a space to retrieve previous selection.",!
  1. D:$Y>20 PAUSE
  1. W "Enter a valid identifier for lookup."
  1. W:(%RGOPT'["*")&(%RGXRFS[U) " Append a * to include all indices."
  1. W !
  1. I %RGOPT["M" D
  1. .D:$Y>20 PAUSE
  1. .W "Separate multiple selections by semicolons."
  1. R !!,"Press any key to continue...",*%:DTIME
  1. Q
  1. ; Help at choice prompt
  1. HELP2 N %
  1. W $$XY(0,16),%RGEOS,!
  1. W $S(%RGOPT(0)["K":"Enter N for next choices.",1:"Press RETURN for more choices.")
  1. W ?35,"Enter B for previous choices.",!
  1. W "Enter ^ to abort lookup.",?35,"Enter choice number to select.",!
  1. W "Any other entry = new lookup."
  1. W:%RGOPT(0)["M" ?35,"Separate multiple selections by semicolons."
  1. R !!,"Press any key to continue...",*%:DTIME
  1. Q
  1. PAUSE N %
  1. R !,"Press any key for more...",*%:DTIME
  1. W $$XY(0,%RGY+2),%RGEOS
  1. Q
  1. XY(X,Y) Q $S(%RGRS:"",1:$$XY^RGUT(X,Y))