1 | HLOUSR4 ;ALB/CJM -ListManager screen for reporting sequence queues;12 JUN 1997 10:00 am ;08/14/2007
|
---|
2 | ;;1.6;HEALTH LEVEL SEVEN;**137**;Oct 13, 1995;Build 21
|
---|
3 | ;Per VHA Directive 2004-038, this routine should not be modified.
|
---|
4 | ;
|
---|
5 | ;
|
---|
6 | EN ;
|
---|
7 | K HLPARMS ;not newed so they'll be left for realtime mode
|
---|
8 | N OLDRFRSH
|
---|
9 | S OLDRFRSH=$G(HLRFRSH)
|
---|
10 | D CLEAN^VALM10
|
---|
11 | D FULL^VALM1
|
---|
12 | S HLRFRSH="SEARCH^HLOUSR4(.HLPARMS)"
|
---|
13 | I '$$ASK(.HLPARMS) S VALMBCK="R" Q
|
---|
14 | D EN^VALM("HLO SEQUENCE QUEUES")
|
---|
15 | S HLRFRSH=OLDRFRSH
|
---|
16 | I $L(HLRFRSH) D @HLRFRSH
|
---|
17 | Q
|
---|
18 | HDR ;
|
---|
19 | S (HLSCREEN,VALMSG)="Sequence Queues"
|
---|
20 | Q
|
---|
21 | ;
|
---|
22 | SEARCH(HLPARMS) ;
|
---|
23 | N MIN,LATEONLY,NS,QUE,ARY,COUNT,NOW,IEN,TIME,NODE
|
---|
24 | S MIN=+$G(HLPARMS("MIN")),LATEONLY=+$G(HLPARMS("LATEONLY")),NS=$G(HLPARMS("NS"))
|
---|
25 | S VALMCNT=0
|
---|
26 | S NOW=$$NOW^XLFDT
|
---|
27 | D CLEAN^VALM10
|
---|
28 | ;
|
---|
29 | S ARY="^HLB(""QUEUE"",""SEQUENCE"")"
|
---|
30 | S QUE=NS
|
---|
31 | D:$L(NS) F S QUE=$O(@ARY@(QUE)) Q:QUE="" Q:'($E(QUE,1,$L(NS))=NS) D
|
---|
32 | .S NODE=$G(@ARY@(QUE))
|
---|
33 | .S TIME=$P(NODE,"^",2)
|
---|
34 | .I LATEONLY Q:'TIME Q:TIME>NOW
|
---|
35 | .S IEN=0
|
---|
36 | .S COUNT=$S($L($P(NODE,"^")):1,1:0)
|
---|
37 | .F S IEN=$O(@ARY@(QUE,IEN)) Q:'IEN S COUNT=COUNT+1
|
---|
38 | .I MIN,COUNT<MIN,'(TIME&(TIME<NOW)) Q
|
---|
39 | .D ADDTO(QUE,COUNT,NODE)
|
---|
40 | END S VALMBCK="R"
|
---|
41 | ;
|
---|
42 | Q
|
---|
43 | ADDTO(QUE,COUNT,NODE) ;
|
---|
44 | N LINE,MSGID
|
---|
45 | ;
|
---|
46 | S MSGID=""
|
---|
47 | I $P(NODE,"^") S MSGID=$P($G(^HLB(+NODE,0)),"^",1)
|
---|
48 | S LINE=$$LJ(QUE,30)_$$RJ(COUNT,7)_" "_$$LJ(MSGID,18)
|
---|
49 | I $P(NODE,"^",2),$P(NODE,"^",2)<NOW S LINE=LINE_$$FMTE^XLFDT($P(NODE,"^",2),"2FM")_" "_$S($P(NODE,"^",3):"YES",1:"NO")
|
---|
50 | S @VALMAR@($$I,0)=LINE
|
---|
51 | Q
|
---|
52 | ;
|
---|
53 | LJ(STRING,LEN) ;
|
---|
54 | Q $$LJ^XLFSTR(STRING,LEN)
|
---|
55 | ;
|
---|
56 | RJ(STRING,LEN) ;
|
---|
57 | Q $$RJ^XLFSTR(STRING,LEN)
|
---|
58 | ;
|
---|
59 | I() ;
|
---|
60 | S VALMCNT=VALMCNT+1
|
---|
61 | Q VALMCNT
|
---|
62 | ;
|
---|
63 | ASK(PARMS) ;
|
---|
64 | N SUB
|
---|
65 | F SUB="NS","MIN","LATEONLY" S PARMS(SUB)=""
|
---|
66 | S PARMS("NS")=$$ASKQUE
|
---|
67 | Q:(PARMS("NS")=-1) 0
|
---|
68 | S PARMS("LATEONLY")=$$ASKYESNO^HLOUSR2("Include only queues that are late","NO")
|
---|
69 | Q:(PARMS("LATEONLY")=-1) 0
|
---|
70 | S PARMS("MIN")=$$ASKMIN
|
---|
71 | Q:(PARMS("MIN")<0) 0
|
---|
72 | Q 1
|
---|
73 | ;
|
---|
74 | ASKMIN() ;
|
---|
75 | N DIR
|
---|
76 | S DIR(0)="N^1:999999:0"
|
---|
77 | S DIR("A")="Minimum Queue Size"
|
---|
78 | S DIR("B")=1
|
---|
79 | S DIR("?",1)="If you would like to limit the report to include only the"
|
---|
80 | S DIR("?")="longer queues then you must specify the minimum size to include."
|
---|
81 | D ^DIR
|
---|
82 | Q:$D(DTOUT)!$D(DUOUT) -1
|
---|
83 | Q X
|
---|
84 | ASKQUE() ;
|
---|
85 | N DIR
|
---|
86 | S DIR(0)="FO^0:40"
|
---|
87 | S DIR("A")="Sequence Queue Namespace"
|
---|
88 | S DIR("?")="Enter the namespace for the queues, or '^' to exit."
|
---|
89 | D ^DIR
|
---|
90 | Q:$D(DTOUT)!$D(DUOUT) -1
|
---|
91 | Q X
|
---|
92 | ;
|
---|
93 | ADVANCE ;
|
---|
94 | N DIR,QUE,MSG,RET
|
---|
95 | S VALMBCK="R"
|
---|
96 | S DIR(0)="FO^0:40"
|
---|
97 | S DIR("A")="Sequence Queue"
|
---|
98 | S DIR("?")="Enter the full name of the queue, or '^' to exit."
|
---|
99 | D ^DIR K DIR
|
---|
100 | Q:$D(DTOUT)!$D(DUOUT)
|
---|
101 | S QUE=X
|
---|
102 | Q:'$L(QUE)
|
---|
103 | S MSG=$$PICKMSG^HLOUSR1()
|
---|
104 | Q:'MSG
|
---|
105 | S RET=$$ADVANCE^HLOQUE(QUE,MSG)
|
---|
106 | I 'RET D
|
---|
107 | .W !,"Sorry, that queue was not pending that message!" D PAUSE^VALM1
|
---|
108 | E D
|
---|
109 | .W !,"The queue has been advanced!" D PAUSE^VALM1
|
---|
110 | ;
|
---|
111 | D SEARCH(.HLPARMS)
|
---|
112 | Q
|
---|