source: FOIAVistA/trunk/r/PATIENT_DATA_EXCHANGE-VAQ/VAQUTL50.m@ 1722

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

initial load of FOIAVistA 6/30/08 version

File size: 4.0 KB
Line 
1VAQUTL50 ;ALB/JRP - CREATE DATA SEGMENT FROM H.S. COMPONENT;26-OCT-94
2 ;;1.5;PATIENT DATA EXCHANGE;**11**;NOV 17, 1993
3ADDSEG(HSPTR,MAXTIME,MAXOCCUR) ;ADD NEW DATA SEGMENT USING H.S. COMPONENT
4 ;INPUT : HSPTR - Pointer to HEALTH SUMMARY COMPONENT file (#142.1)
5 ; MAXTIME - Max time limit allowed for auto processing
6 ; MAXOCCUR - Max occurrence limit allowed for auto processing
7 ;OUTPUT : X - Pointer to VAQ - DATA SEGMENT file (#394.71) that
8 ; was created
9 ; -1^ErrorText - Entry not created
10 ;NOTES : If time and/or occurrence limits do not apply to the
11 ; component, MAXTIME and/or MAXOCCUR are not required.
12 ; : If time and/or occurrence limits apply to the component,
13 ; default values will be taken from the VAQ - PARAMETER
14 ; file (#394.81). If parameter file does not contain these
15 ; values, a default of 1 year and 10 occurrences will be used.
16 ; : If a maximum limit is not valid, the default limit will
17 ; be used.
18 ;
19 ;CHECK INPUT
20 S HSPTR=+$G(HSPTR)
21 Q:('HSPTR) "-1^Did not pass pointer to HEALTH SUMMARY COMPONENT file"
22 Q:('$D(^GMT(142.1,HSPTR,0))) "-1^Did not pass valid pointer to HEALTH SUMMARY COMPONENT file"
23 S MAXTIME=$G(MAXTIME)
24 S MAXOCCUR=$G(MAXOCCUR)
25 ;DECLARE VARIABLES
26 N NAME,ABB,TIME,OCCUR,TMP,DEFTIME,DEFOCCUR
27 N X,Y,DIC,DINUM,DA,DIE,DR
28 ;GET COMPONENT NAME & ABBREVIATION
29 S TMP=$G(^GMT(142.1,HSPTR,0))
30 S NAME=$P(TMP,"^",1)
31 Q:(NAME="") "-1^Entry in HEALTH SUMMARY COMPONENT file did not contain a name"
32 S ABB=$P(TMP,"^",4)
33 Q:(ABB="") "-1^Entry in HEALTH SUMMARY COMPONENT file did not contain an abbreviation"
34 ;CONVERT NAME SO ONLY FIRST CHARACTER OF EVERY WORD IS IN UPPERCASE
35 S NAME=$$FIRSTUP(NAME)
36 ;SEE IF NAME OR ABBREVIATION ALREADY EXIST IN DATA SEGMENT FILE
37 Q:($D(^VAT(394.71,"B",NAME))) "-1^"_NAME_" already exists in VAQ - DATA SEGMENT file"
38 Q:($D(^VAT(394.71,"CAPS",NAME))) "-1^"_NAME_" already exists in VAQ - DATA SEGMENT file"
39 Q:($D(^VAT(394.71,"C",ABB))) "-1^Abbreviation of "_ABB_" already used in VAQ - DATA SEGMENT file"
40 ;GET DEFAULT TIME AND OCCURRENCE LIMITS
41 S X=+$O(^VAT(394.81,0))
42 S TMP=$G(^VAT(394.81,X,"LIMITS"))
43 S DEFTIME=$P(TMP,"^",1)
44 S:(DEFTIME="") DEFTIME="1Y"
45 S DEFOCCUR=$P(TMP,"^",2)
46 S:(DEFOCCUR="") DEFOCCUR=10
47 ;DETERMINE IF TIME AND/OR OCCURRENCE LIMITS APPLY
48 S TMP=$$LIMITS^VAQDBIH3(HSPTR)
49 S TIME=+TMP
50 S OCCUR=+$P(TMP,"^",2)
51 ;SET MAX LIMITS
52 I (TIME) S:($$VALOCC^VAQDBIH2(MAXTIME,0)<0) MAXTIME=DEFTIME
53 I ('TIME) S MAXTIME=""
54 I (OCCUR) S:($$VALOCC^VAQDBIH2(MAXOCCUR,1)<0) MAXOCCUR=DEFOCCUR
55 I ('OCCUR) S MAXOCCUR=""
56 ;SET UP CALL TO FILEMAN & CREATE STUB
57 K DD,DO
58 S DIC="^VAT(394.71,"
59 S DIC(0)="L"
60 S X=NAME
61 D FILE^DICN
62 S DA=+Y
63 Q:(DA<0) "-1^Unable to create entry in VAQ - DATA SEGMENT file"
64 ;SET UP CALL TO FILEMAN & FINISH ENTRY
65 S DIE="^VAT(394.71,"
66 S DR=".02///^S X=ABB"
67 S DR(1,394.71,.03)=".03///YES"
68 S DR(1,394.71,.04)=".04////"_HSPTR
69 S DR(1,394.71,.05)=".05///^S X=MAXTIME"
70 S DR(1,394.71,.06)=".06///^S X=MAXOCCUR"
71 S DR(1,394.71,10)="10///$$GET^GMTSPDX(TRAN,DFN,SEGPTR,ROOT,(OFFSET-1),TIMLIM,OCCLIM)"
72 S DR(1,394.71,20)="20///@"
73 D ^DIE
74 Q 0
75LOWER(STRING) ;CONVERT UPPERCASE TO LOWERCASE
76 ;INPUT : STRING - Text string to convert
77 ;OUTPUT : string - Same text string in all lowercase
78 ;
79 Q $TR($G(STRING),"ABCDEFGHIJKLMNOPQRSTUVWXYZ","abcdefghijklmnopqrstuvwxyz")
80FIRSTUP(TEXT) ;FIRST CHARACTER EVERY WORD UPPER
81 ;INPUT : TEXT - Text string to convert
82 ;OUTPUT : Text - Same text string with beginning of every word
83 ; in uppercase and all other characters in lowercase
84 ;
85 ;CHECK INPUT
86 Q:($G(TEXT)="") ""
87 ;DECLARE VARIABLES
88 N OUTTEXT,SPOT,UPCHAR,X,Y,LEN
89 ;CONVERT TO LOWERCASE
90 S OUTTEXT=$$LOWER(TEXT)
91 ;CAPITALIZE FIRST WORD
92 S X=$E(OUTTEXT,1)
93 X ^%ZOSF("UPPERCASE")
94 S OUTTEXT=Y_$E(OUTTEXT,2,$L(OUTTEXT))
95 ;CAPITALIZE REST OF WORDS
96 S SPOT=1
97 S LEN=$L(OUTTEXT)
98 F S SPOT=$F(OUTTEXT," ",SPOT) Q:('SPOT) D
99 .S X=$E(OUTTEXT,SPOT)
100 .X ^%ZOSF("UPPERCASE")
101 .S OUTTEXT=$E(OUTTEXT,1,(SPOT-1))_Y_$E(OUTTEXT,(SPOT+1),LEN)
102 Q OUTTEXT
Note: See TracBrowser for help on using the repository browser.