| 1 | VAQUTL50 ;ALB/JRP - CREATE DATA SEGMENT FROM H.S. COMPONENT;26-OCT-94 | 
|---|
| 2 | ;;1.5;PATIENT DATA EXCHANGE;**11**;NOV 17, 1993 | 
|---|
| 3 | ADDSEG(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 | 
|---|
| 75 | LOWER(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") | 
|---|
| 80 | FIRSTUP(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 | 
|---|