1 | VAQUTL99 ;ALB/JFP,JRP - Various Function Calls;03FEB93
|
---|
2 | ;;1.5;PATIENT DATA EXCHANGE;**2,10,29**;NOV 17, 1993
|
---|
3 | ;
|
---|
4 | FUNCT ; *************** Function Calls ***************
|
---|
5 | ;
|
---|
6 | DASHSSN(SSN) ; -- Returns dash version of SSN
|
---|
7 | ; INPUT : SSN - SSN without dashes
|
---|
8 | ; OUTPUT : N - SSN with dashes
|
---|
9 | Q:($G(SSN)="") ""
|
---|
10 | Q:($E(SSN,10)'="P") $E(SSN,1,3)_"-"_$E(SSN,4,5)_"-"_$E(SSN,6,9)
|
---|
11 | Q $E(SSN,1,3)_"-"_$E(SSN,4,5)_"-"_$E(SSN,6,10)
|
---|
12 | ;
|
---|
13 | AGE(DOB) ; -- Returns age based on date of birth
|
---|
14 | ; INPUT : X1 = DOB - INTERNAL FORMAT
|
---|
15 | ; X2 - TODAYS DATE
|
---|
16 | ; OUTPUT : AGE IN YEARS
|
---|
17 | N X,X1,X2
|
---|
18 | Q:($G(DOB)="") ""
|
---|
19 | S X1=DT,X2=DOB
|
---|
20 | D ^%DTC
|
---|
21 | Q X\365.25
|
---|
22 | ;
|
---|
23 | DOBFMT(IDTE,STYLE) ; -- Returns formatted date
|
---|
24 | ; INPUT : IDTE- INTERNAL FILEMAN DATE
|
---|
25 | ; STYLE - FLAG INDICATING OUTPUT STYLE
|
---|
26 | ; IF 0, OUTPUT IN MM-DD-YYYY FORMAT (DEFAULT)
|
---|
27 | ; IF 1, OUTPUT IN MMM DD, YYYY FORMAT
|
---|
28 | ; (MMM -> FIRST 3 CHARACTERS OF MONTH NAME)
|
---|
29 | ; OUTPUT : EXTERNAL DATE IN SPECIFIED FORMAT
|
---|
30 | S STYLE=+$G(STYLE)
|
---|
31 | Q:($G(IDTE)="") ""
|
---|
32 | ;MM-DD-YYYY
|
---|
33 | Q:('STYLE) $E(IDTE,4,5)_"-"_$E(IDTE,6,7)_"-"_($E(IDTE,1,3)+1700)
|
---|
34 | ;MMM DD, YYYY
|
---|
35 | N Y,%DT
|
---|
36 | S Y=$P(IDTE,".",1)
|
---|
37 | D DD^%DT
|
---|
38 | Q Y
|
---|
39 | ;
|
---|
40 | DATE(EDTE) ; -- Converts external date to internal date format
|
---|
41 | ; INPUT : EXTERNAL DATE (TIME IS OPTIONAL)
|
---|
42 | ; OUTOUT: INTERNAL DATE, STORAGE FORMAT YYYMMMDD
|
---|
43 | ; (TIME WILL BE RETURNED IF INCLUDED WITH INPUT)
|
---|
44 | ;
|
---|
45 | Q:'$D(EDTE) -1
|
---|
46 | N X,%DT,Y
|
---|
47 | S X=EDTE
|
---|
48 | S %DT="TS"
|
---|
49 | D ^%DT
|
---|
50 | Q Y
|
---|
51 | ;
|
---|
52 | NOW(FMFORM,NOTIME) ;RETURNS CURRENT DATE & TIME
|
---|
53 | ;INPUT : FMFORM - Flag indicating if FileMan format should be used
|
---|
54 | ; If 0, return in the format MM-DD-YYYY@HH:MM:SS
|
---|
55 | ; (default)
|
---|
56 | ; If 1, return in FileMan format
|
---|
57 | ; NOTIME - Flag indicating if time should not be included
|
---|
58 | ; If 0, time will be included in output (default)
|
---|
59 | ; If 1, time will not be included in output
|
---|
60 | ;OUTPUT : Current date & time in specified format
|
---|
61 | ;
|
---|
62 | ;CHECK INPUT
|
---|
63 | S FMFORM=+$G(FMFORM)
|
---|
64 | S NOTIME=+$G(NOTIME)
|
---|
65 | ;DECLARE VARIABLES
|
---|
66 | N X,%,%H,%I,OUT
|
---|
67 | S OUT="-1^Error occurred while determining current date and time"
|
---|
68 | ;GET CURRENT DATE/TIME
|
---|
69 | D NOW^%DTC
|
---|
70 | ;FILEMAN FORMAT
|
---|
71 | I (FMFORM) S OUT=$S(NOTIME:X,1:%)
|
---|
72 | ;EXTERNAL FORMAT
|
---|
73 | I ('FMFORM) D
|
---|
74 | .S %=%_"000000"
|
---|
75 | .S X=$E(%,4,5)_"-"_$E(%,6,7)_"-"_(1700+$E(%,1,3))_"@"_$E(%,9,10)_":"_$E(%,11,12)_":"_$E(%,13,14)
|
---|
76 | .S OUT=$S(NOTIME:$P(X,"@",1),1:X)
|
---|
77 | Q OUT
|
---|
78 | ;
|
---|
79 | RES(DOMAIN,SSN) ; -- Determines whether a request is manually or
|
---|
80 | ; automatically processed and returns the reason
|
---|
81 | ;
|
---|
82 | ; INPUT : DOMAIN = E-mail address of facility
|
---|
83 | ; SSN = requested name or SSN in internal
|
---|
84 | ; format
|
---|
85 | ;
|
---|
86 | ; OUTPUT : 1^DFN = automatic process
|
---|
87 | ; -N^Reason = manual process
|
---|
88 | ; where
|
---|
89 | ; -1 = bad input or no input, error
|
---|
90 | ; -2 = patient not found
|
---|
91 | ; -3 = ambiguous patient (not currently used)
|
---|
92 | ; -4 = sensitive patient
|
---|
93 | ; -5 = domain not in work group
|
---|
94 | ;
|
---|
95 | N SENPT,DFN,DOMDA
|
---|
96 | Q:($G(SSN)="") "-1^Did not pass patient's name or SSN"
|
---|
97 | Q:($G(DOMAIN)="") "-1^Did not pass remote domain"
|
---|
98 | ;
|
---|
99 | S DFN=$$GETDFN^VAQUTL97(SSN,1)
|
---|
100 | Q:DFN=-1 "-2^Patient not found"
|
---|
101 | ;
|
---|
102 | S SENPT=$$GETSEN^VAQUTL97(+DFN)
|
---|
103 | Q:SENPT=1 "-4^Sensitive patient"
|
---|
104 | ;
|
---|
105 | S DOMDA=+$$FIND1^DIC(4.2,"","BMX",DOMAIN,"B^C","","ERROR")
|
---|
106 | Q:'$D(^VAT(394.82,"C",DOMDA)) "-5^Domain not in work group"
|
---|
107 | ;
|
---|
108 | Q ("1^"_(+DFN)) ; -- Automatic process
|
---|
109 | ;
|
---|
110 | DA(FLE,DNPT) ; -- Returns entry number in sub file (DA)
|
---|
111 | ;
|
---|
112 | ; INPUT : FLE = Sub file number
|
---|
113 | ; DNPT = Pointer to patient in main file
|
---|
114 | ;
|
---|
115 | ; OUTPUT : DA = Entry number to sub file
|
---|
116 | ; -1 = bad input or no input, error
|
---|
117 | ;
|
---|
118 | N MFLE,GLOBAL,NODE,SUBNO,ENTRY,ND
|
---|
119 | Q:'$D(FLE) -1
|
---|
120 | Q:'$D(DNPT) -1
|
---|
121 | ;
|
---|
122 | S MFLE=$G(^DD(FLE,0,"UP"))
|
---|
123 | S MFLD="",MFLD=$O(^DD(MFLE,"SB",FLE,MFLD))
|
---|
124 | S GLOBAL=$G(^DIC(MFLE,0,"GL"))
|
---|
125 | S NODE=$G(^DD(MFLE,MFLD,0))
|
---|
126 | S SUBNO=$P($P(NODE,U,4),";",1)
|
---|
127 | S ND=GLOBAL_DNPT_","_SUBNO_",0)"
|
---|
128 | S NODE=$G(@ND)
|
---|
129 | S ENTRY=$P(NODE,U,4)
|
---|
130 | Q ENTRY ; -- entry number in subfile
|
---|
131 | ;
|
---|
132 | END ; -- End of code
|
---|
133 | QUIT
|
---|