source: FOIAVistA/trunk/r/IMAGING-MAG-ZMAG/MAGDTRLU.m@ 1589

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

initial load of FOIAVistA 6/30/08 version

File size: 4.4 KB
Line 
1MAGDTRLU ;WOIFO/OHH/PMK - Report discrepancies between files #2006.5849 & #123 and correct them ; 10/11/2006 08:53
2 ;;3.0;IMAGING;**46**;16-February-2007;;Build 1023
3 ;; Per VHA Directive 2004-038, this routine should not be modified.
4 ;; +---------------------------------------------------------------+
5 ;; | Property of the US Government. |
6 ;; | No permission to copy or redistribute this software is given. |
7 ;; | Use of unreleased versions of this software requires the user |
8 ;; | to execute a written test agreement with the VistA Imaging |
9 ;; | Development Office of the Department of Veterans Affairs, |
10 ;; | telephone (301) 734-0100. |
11 ;; | The Food and Drug Administration classifies this software as |
12 ;; | a medical device. As such, it may not be changed in any way. |
13 ;; | Modifications to this software may result in an adulterated |
14 ;; | medical device under 21CFR820, the use of which is considered |
15 ;; | to be a violation of US Federal Statutes. |
16 ;; +---------------------------------------------------------------+
17 ;;
18 ; This routine automatically checks the data in file telereader
19 ; read/unread list (file 2006.5849)and compares it with the
20 ; request/consultation (file #123). If a telereader study is locked
21 ; or unread and in the request/consult file it is completed or
22 ; cancelled, then it updates the status of the study in the telereader
23 ; read/unread list file, the "D" cross reference, and the reading
24 ; start field is updated.
25 Q
26 ;
27REPORT ; report problems with the Unread List
28 D PASS("REPORT")
29 Q
30 ;
31REPAIR ; repair problems with the Unread List
32 D PASS("REPAIR")
33 Q
34 ;
35PASS(MODE) ; report/repair problems for LOCKED and UNREAD studies
36 N MSG
37 S (MSG(1),MSG(3))=""
38 ;
39 ; PASS 1 - search for LOCKED cases that are completed/cancelled.
40 S MSG(2)="Check for completed studies that have LOCKED status"
41 I MODE="REPAIR" S MSG(2)=MSG(2)_" and correct them"
42 W !! D HEADING^MAGDTRDX(.MSG)
43 D SEARCH("LOCKED",MODE)
44 ;
45 ; PASS 2 - search for UNREAD cases that are completed/cancelled.
46 S MSG(2)="Now check for completed studies that have UNREAD status"
47 I MODE="REPAIR" S MSG(2)=MSG(2)_" and correct them"
48 W !! D HEADING^MAGDTRDX(.MSG)
49 D SEARCH("UNREAD",MODE)
50 Q
51 ;
52SEARCH(STATUS,MODE) ; go through studies for each site, specialty and procedure
53 N ACQSITE ; -- acquisition division number
54 N ISPECIDX ; - image index for specialty
55 N IPROCIDX ; - image index for procedure
56 N UNREAD ; --- IEN of file telereader read/undread file #2006.5849
57 N XREF ; ----- "D" cross reference: "L" for locked, "U" for unread
58 N I
59 ;
60 S XREF=$E(STATUS)
61 S ACQSITE=""
62 F S ACQSITE=$O(^MAG(2006.5849,"D",ACQSITE)) Q:ACQSITE="" D
63 . W !!,$$W("Acquisition Site:"),$$GET1^DIQ(4,ACQSITE,.01)
64 . S ISPECIDX=""
65 . F S ISPECIDX=$O(^MAG(2006.5849,"D",ACQSITE,ISPECIDX)) Q:ISPECIDX="" D
66 . . W !,$$W("Specialty:"),$$GET1^DIQ(2005.84,ISPECIDX,.01)
67 . . S IPROCIDX=""
68 . . F S IPROCIDX=$O(^MAG(2006.5849,"D",ACQSITE,ISPECIDX,IPROCIDX)) Q:IPROCIDX="" D
69 . . . N COUNT ; -- array of counts of problems
70 . . . W !,$$W("Procedure:"),$$GET1^DIQ(2005.85,IPROCIDX,.01) D
71 . . . S UNREAD=""
72 . . . F S UNREAD=$O(^MAG(2006.5849,"D",ACQSITE,ISPECIDX,IPROCIDX,XREF,UNREAD)) Q:UNREAD="" D CHECK
73 . . . I '$D(COUNT) D Q
74 . . . . W !,$$W(""),"No inconsistencies were found.",!
75 . . . . Q
76 . . . S I="" F S I=$O(COUNT(I)) Q:I="" D
77 . . . . W !,$$W($S(MODE="REPORT":"Problem:",1:"Repaired:"))
78 . . . . W "Number of consults that have ",I," status in CPRS: ",COUNT(I)
79 . . . . W !
80 . . . . Q
81 . . . Q
82 . . Q
83 . Q
84 Q
85 ;
86CHECK ;check Unread List entry against that in CPRS Consult Requst Tracking
87 N GMRCIEN ; -- IEN of file request/consultation (file #123)
88 N GMRCSTS ; -- status of consult request - from ^ORD(100.01)
89 ;
90 S GMRCIEN=$P(^MAG(2006.5849,UNREAD,0),"^",1)
91 S GMRCSTS=$$GET1^DIQ(123,GMRCIEN,8) ; cprs status
92 I "^COMPLETE^CANCELLED^DISCONTINUED^DISCONTINUED/EDIT^EXPIRED^"[("^"_GMRCSTS_"^") D
93 . S COUNT(GMRCSTS)=$G(COUNT(GMRCSTS))+1
94 . I MODE="REPORT" D
95 . . W !,$$W(""),"Consult # ",GMRCIEN," has the status of ",GMRCSTS," in CPRS"
96 . . Q
97 . E I MODE="REPAIR" D ; correct the entry
98 . . W !,$$W("Fix:"),"Consult # ",GMRCIEN," which has the status of ",GMRCSTS," in CPRS"
99 . . ; Note: The variable & value MODE="REPAIR" are used in ^MAGDTR03
100 . . I GMRCSTS="COMPLETE" D
101 . . . D COMPLETE^MAGDTR03
102 . . . Q
103 . . E D CANCEL^MAGDTR03
104 . . Q
105 . Q
106 Q
107 ;
108W(PROMPT) ; output prompt
109 Q $J(PROMPT,16)_" "
Note: See TracBrowser for help on using the repository browser.