source: FOIAVistA/trunk/r/IMAGING-MAG-ZMAG/MAGGSIU2.m@ 1800

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

initial load of FOIAVistA 6/30/08 version

File size: 4.6 KB
Line 
1MAGGSIU2 ;WOIFO/GEK - Utilities for Image Add/Modify ; [ 12/27/2000 10:49 ]
2 ;;3.0;IMAGING;**7,8,85,59**;Nov 27, 2007;Build 20
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 ;; | |
12 ;; | The Food and Drug Administration classifies this software as |
13 ;; | a medical device. As such, it may not be changed in any way. |
14 ;; | Modifications to this software may result in an adulterated |
15 ;; | medical device under 21CFR820, the use of which is considered |
16 ;; | to be a violation of US Federal Statutes. |
17 ;; +---------------------------------------------------------------+
18 ;;
19 Q
20MAKEFDA(MAGGFDA,MAGARRAY,MAGACT,MAGCHLD,MAGGRP,MAGGWP) ;
21 ; Create the FileMan FDA Array
22 ; Create Imaging Action Codes Array (for Pre and Post processing)
23 N MAGGFLD,MAGGDAT,GRPCT,WPCT,Z
24 S Z="" F S Z=$O(MAGARRAY(Z)) Q:Z="" D I $L(MAGERR) Q
25 . S MAGGFLD=$P(MAGARRAY(Z),U,1),MAGGDAT=$P(MAGARRAY(Z),U,2,99)
26 . ; If this entry is one of the action codes, store it in the action array.
27 . I $$ACTCODE^MAGGSIV(MAGGFLD) S MAGACT(MAGGFLD)=MAGGDAT Q
28 . ;
29 . ; If we are Creating a Group Entry, add any Images that are to be members of this group.
30 . I MAGGFLD=2005.04 D Q
31 . . S MAGGRP=1
32 . . I '+MAGGDAT Q ; making a group entry, with no group entries yet. This is OK.
33 . . S MAGCHLD(MAGGDAT)=""
34 . . S GRPCT=GRPCT+1
35 . . S MAGGFDA(2005.04,"+"_GRPCT_",+1,",.01)=MAGGDAT
36 . ;
37 . ; if we are getting a WP for Long Desc, set array to pass.
38 . I MAGGFLD=11 D ; this is one line of the WP Long Desc field.
39 . . S WPCT=WPCT+1,MAGGWP(WPCT)=MAGGDAT
40 . . S MAGGFDA(2005,"+1,",11)="MAGGWP"
41 . ; Set the Node for the UPDATE^DIC Call.
42 . S MAGGFDA(2005,"+1,",MAGGFLD)=MAGGDAT
43 . Q
44 ; Patch 8. Special processing for field 107 (ACQUISITION DEVICE)
45 ; We'll change any MAGGFDA(2005,"+1,",107) to MAGACT("ACQD")
46 ; This way the PRE processing of the array will check and create a new
47 ; ACQUISITION DEVICE file entry, if needed.
48 I $D(MAGACT("107")) S MAGACT("ACQD")=MAGACT("107") K MAGACT("107")
49 I $D(MAGGFDA(2005,"+1,",107)) S MAGACT("ACQD")=MAGGFDA(2005,"+1,",107) K MAGGFDA(2005,"+1,",107)
50 Q
51REQPARAM() ;Do required parameters have values. Called from MAGGSIUI
52 ; VARIABLES ARE SET AND KILLED IN THAT ROUTINE.
53 N CT
54 S CT=0
55 S MAGRY(0)="1^Checking for Required parameter values..."
56 I IDFN="" S CT=CT+1,MAGRY(CT)="DFN is Required. !"
57 I '$D(IMAGES),'CMTH S CT=CT+1,MAGRY(CT)="List of Images is Required. !"
58 ;
59 I (PXPKG=""),(DOCCTG=""),(IXTYPE="") S CT=CT+1,MAGRY(CT)="Procedure or Category or Index Type is Required. !"
60 I (PXPKG'=""),(DOCCTG'="") S CT=CT+1,MAGRY(CT)="Procedure OR Document Category. Not BOTH. !"
61 ;
62 I (PXPKG'=""),(PXIEN="") S CT=CT+1,MAGRY(CT)="Procedure IEN is Required. !"
63 I (PXPKG=""),(PXIEN'="") S CT=CT+1,MAGRY(CT)="Procedure Package is Required. !"
64 I (PXPKG'=""),(PXDT="") S CT=CT+1,MAGRY(CT)="Procedure Date is Required. !"
65 ;
66 ;Patch 8 index field check... could be using Patch 7 or Patch 8.
67 ; We're this far, so either PXIEN or DOCCTG is defined
68 I (IXTYPE'=""),(DOCCTG'="") S CT=CT+1,MAGRY(CT)="Image Type OR Document Category. Not BOTH. !"
69 ; MAGGSIA computes PACKAGE #40 and CLASS #41 when adding an Image (2005) entry.
70 ;
71 I TRKID="" S CT=CT+1,MAGRY(CT)="Tracking ID is Required. !"
72 I ACQD="" S CT=CT+1,MAGRY(CT)="Acquisition Device is Required. !"
73 ; ACQS ( could ? ) default to users institution i.e. DUZ(2)
74 I (ACQS="")&(ACQN="") S CT=CT+1,MAGRY(CT)="Acquisition Site IEN or Station Number is Required. !"
75 I (ACQS]"")&(ACQN]"") S CT=CT+1,MAGRY(CT)="Station IEN or Station Number, Not BOTH. !"
76 ;
77 I STSCB="" S CT=CT+1,MAGRY(CT)="Status Handler (TAG^ROUTINE) is Required. !"
78 ;
79 I (DOCCTG'=""),(DOCDT="") S CT=CT+1,MAGRY(CT)="Document Date is Required. !"
80 ;
81 I (CT>0) S MAGRY(0)="0^Required parameter is null" Q MAGRY(0)
82 ;Checks to stop Duplicate or incorrect Tracking ID's
83 ; //TODO: ?? check the Queue File, is this Tracking ID already Queued.
84 I (TRKID'="") I $D(^MAG(2005,"ATRKID",TRKID)) S MAGRY(0)="0^Tracking ID Must be Unique !"
85 I (TRKID'="") I ($L(TRKID,";")<2) S MAGRY(0)="0^Tracking ID Must have "";"" Delimiter"
86 ;
87 Q MAGRY(0)
Note: See TracBrowser for help on using the repository browser.