source: FOIAVistA/tag/r/HEALTH_LEVEL_SEVEN-HL/HLOUSR4.m@ 636

Last change on this file since 636 was 628, checked in by George Lilly, 14 years ago

initial load of FOIAVistA 6/30/08 version

File size: 2.7 KB
Line 
1HLOUSR4 ;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 ;
6EN ;
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
18HDR ;
19 S (HLSCREEN,VALMSG)="Sequence Queues"
20 Q
21 ;
22SEARCH(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)
40END S VALMBCK="R"
41 ;
42 Q
43ADDTO(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 ;
53LJ(STRING,LEN) ;
54 Q $$LJ^XLFSTR(STRING,LEN)
55 ;
56RJ(STRING,LEN) ;
57 Q $$RJ^XLFSTR(STRING,LEN)
58 ;
59I() ;
60 S VALMCNT=VALMCNT+1
61 Q VALMCNT
62 ;
63ASK(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 ;
74ASKMIN() ;
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
84ASKQUE() ;
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 ;
93ADVANCE ;
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
Note: See TracBrowser for help on using the repository browser.