1 | VWREGIT ;Portland,OR/Jim Bell, et al Patient Registration Utility August 2015
|
---|
2 | ;;2.0;B/FProductions,LLC,WORLD VISTA;**LOCAL**;;Build 2
|
---|
3 | ;*******************************************************************
|
---|
4 | ;* VW Registration is designed for patient specific fields as *
|
---|
5 | ;* defined in Fileman Input Templates or ad hoc field selection. *
|
---|
6 | ;* Copyright Martius/MMXV ad infinitum (GNU License: See GPLv3.txt)*
|
---|
7 | ;*******************************************************************
|
---|
8 | ;;NO FALL THROUGH - JEB
|
---|
9 | Q
|
---|
10 | ;
|
---|
11 | TFM(XF) ;TemplateField Management
|
---|
12 | ;***********************************************
|
---|
13 | ;* Check primary field entries for "parentage" *
|
---|
14 | ;* Add an "*" to gain all sub-fields of the *
|
---|
15 | ;* parent *
|
---|
16 | ;* REMEMBER: All fields pertain to file 2 only *
|
---|
17 | ;***********************************************
|
---|
18 | N I,N,FIELD
|
---|
19 | K FARRAY
|
---|
20 | I '$L(XF),'$G(TNUM) Q ""
|
---|
21 | I '$L(XF),+$G(TNUM) S XF=^DIE(TNUM,"DR",1,2)
|
---|
22 | F I=1:1:$L(XF,";") S:$L($P(XF,";",I)) FARRAY(I)=+$P(XF,";",I)
|
---|
23 | S N=0 F I=1:1 S N=$O(FARRAY(N)) Q:'+N D
|
---|
24 | . S FIELD=FARRAY(N)
|
---|
25 | . I +$P(^DD(2,FIELD,0),"^",2) S FIELD=FIELD_"*",FMARRAY(FIELD)=$P(^(0),"^",4) K FARRAY(N)
|
---|
26 | S XF="",N=0 F S N=$O(FARRAY(N)) Q:'+N S XF=XF_FARRAY(N)_";"
|
---|
27 | Q XF
|
---|
28 | ;
|
---|
29 | CHECK() ;
|
---|
30 | Q ""
|
---|
31 | ;
|
---|
32 | INR() Q $O(RESULT(" "),-1)+1
|
---|
33 | ;
|
---|
34 | EN(RESULT) ;Template name and ID labels
|
---|
35 | ;Get the input template list
|
---|
36 | ;housekeeping
|
---|
37 | S DTIME=99999
|
---|
38 | ;ZSY "chmod 777 "_$ZD_"regparam/*.txt" ;Moved to post-install
|
---|
39 | ;end housekeeping
|
---|
40 | ;
|
---|
41 | K AR,RESULT
|
---|
42 | N N,HD,FILE,LOC,P4,P5,%ZISHF,%ZISHO,DEFST,XTMP,X
|
---|
43 | S RESULT(0)=1
|
---|
44 | S DEFST="";
|
---|
45 | ;S DEFTMP=$O(^DIE("B","FAU_EDU",0)) ;For Florida College only
|
---|
46 | S RESULT(0)=$$CONTROL^VWREGITU()
|
---|
47 | S RESULT(1)="-1^No templates found"
|
---|
48 | S DEFST=$$GET^XPAR("ALL","VW REG DEFAULT STATE")
|
---|
49 | S DEFTMP=$$GET^XPAR("ALL","VW REG RDNPT")
|
---|
50 | S HD=$$GET^XPAR("ALL","VW GUI REG TEMPLATE DIRECTORY")
|
---|
51 | I '$L(HD) K RESULT D Q
|
---|
52 | . S RESULT($$INR)="-1^NO HOME DIRECTORY - refer to IT support, if necessary."
|
---|
53 | . S RESULT($$INR)="No home directory has been supplied which indicates"
|
---|
54 | . S RESULT($$INR)="the VWREG installation is incomplete. See the Help manual"
|
---|
55 | . S RESULT($$INR)="for installation and Enter/Editing parameter values."
|
---|
56 | . S RESULT($$INR)="Thank you,"
|
---|
57 | . S RESULT($$INR)=" The Management."
|
---|
58 | S FILE="regit.txt"
|
---|
59 | S P4=1
|
---|
60 | S P5=""
|
---|
61 | S X=$$FTG^%ZISH(HD,FILE,$NA(AR(1)),P4,P5)
|
---|
62 | D:+RESULT(0)
|
---|
63 | . S $P(RESULT(0),"^",2)=$G(HD)
|
---|
64 | . S $P(RESULT(0),"^",3)=$S(DEFST:$P(^DIC(5,DEFST,0),"^")_"("_DEFST_")",1:"")
|
---|
65 | . S $P(RESULT(0),"^",4)=$S(+DEFTMP:$P(^DIE(DEFTMP,0),"^")_"("_DEFTMP_")",1:DEFTMP)
|
---|
66 | . S $P(RESULT(0),"^",5)=DUZ
|
---|
67 | I $O(AR(0)) S RESULT(1)="[TEMPLATES]"
|
---|
68 | S N=0 F S N=$O(AR(N)) Q:'+N D
|
---|
69 | . Q:$E(AR(N))="*"
|
---|
70 | . Q:'+$P(AR(N),"(",2)
|
---|
71 | . Q:$P($G(^DIE(+$P(AR(N),"(",2),0)),"^",4)'=2 ;must be pat file
|
---|
72 | . S RESULT($$INR)=AR(N)
|
---|
73 | S RESULT($$INR)="[ID]"
|
---|
74 | ;S N=0 F S N=$O(^DIZ(64850003,N)) Q:'+N S RESULT($$INR)=$P(^(N,0),"^",2)_"("_$P(^(0),"^")_")"
|
---|
75 | ;S N=0 F S N=$O(RESULT(N)) Q:'+N K:RESULT(N)="" RESULT(N)
|
---|
76 | I '$O(RESULT(0)) S RESULT(1)="-1^No PATIENT FILE templates found"
|
---|
77 | K AR
|
---|
78 | Q
|
---|
79 | ;
|
---|
80 | NPT(RESULT,TNAME) ;
|
---|
81 | ; *************************************************
|
---|
82 | ; * Incoming: DFN^TEMPLATE NAME(IEN) *
|
---|
83 | ; * Process : Get template fields plus any help *
|
---|
84 | ; * If +TNAME (a DFN), get DFN data for *
|
---|
85 | ; * the template fields (Put data in *
|
---|
86 | ; * $P(RESULT(N),"^",3)) *
|
---|
87 | ; * Return : RESULT(N), etc *
|
---|
88 | ; *************************************************
|
---|
89 | ;W " ;Intentional bust for debugging
|
---|
90 | N N,TNUM,FIELDS,F,FNAME,FVALUE,FHELP,FPSC,FNUM
|
---|
91 | S TNUM=+$P(TNAME,"(",2),DFN=+TNAME
|
---|
92 | I 'TNUM S RESULT(0)="0^new patient Template not found" Q
|
---|
93 | S TNAME=$P($P(TNAME,"^",2),"(")
|
---|
94 | S TNAME=$TR(TNAME,"$&*","") ;Clean out TMENU chars
|
---|
95 | I TNAME="GENERIC INS. FRM [WorldVistA]" G GIF
|
---|
96 | S FIELDS=$G(^DIE(TNUM,"DR",1,2))
|
---|
97 | I '$L(FIELDS) Q
|
---|
98 | K RESULT S (FNUM,FCAP)=""
|
---|
99 | F I=1:1:$L(FIELDS,";")-1 D
|
---|
100 | . S F=$P(FIELDS,";",I)
|
---|
101 | . Q:'$D(^DD(2,F)) ;Not existing in this patient file
|
---|
102 | . I F["~" S FNUM=+F,FNAME=$P($P(F,"~"),FNUM,2),F=FNUM K FNUM
|
---|
103 | . S FNAME=$S($L($G(FNAME)):FNAME,$L($G(^DD(2,F,.1))):$P(^(.1),"^"),1:$P(^DD(2,F,0),"^"))
|
---|
104 | . S FVALUE="" ;Patient Data
|
---|
105 | . S FHELP=$G(^DD(2,F,3))
|
---|
106 | . I F'=27.02,'$L(FHELP) S N=0 F S N=$O(^DD(2,F,21,N)) Q:'+N S FHELP=FHELP_^(N,0)
|
---|
107 | . S FHELP=$TR(FHELP,"'","`")
|
---|
108 | . S FPSC=$P(^DD(2,F,0),"^",3)
|
---|
109 | . S SUBDIC=+$P(^DD(2,F,0),"^",2)
|
---|
110 | . S RESULT($$INR)=FNAME_"^"_F_"^"_FVALUE_"^"_FHELP_"^"_FPSC_$S(SUBDIC:"^1",1:"^0")
|
---|
111 | . S (FNAME,FVALUE,FHELP,FPSC)=""
|
---|
112 | G NPTX:'DFN
|
---|
113 | I DFN D GETS^DIQ(2,DFN_",","**","EN","AR") ;,RESULT(0)=$$DFNID^VWREGITU
|
---|
114 | K FIELD S N=0 F S N=$O(RESULT(N)) Q:'+N S FIELD($P(RESULT(N),"^",2))=""
|
---|
115 | S X="AR" F S X=$Q(@X) Q:X="" D
|
---|
116 | . S FILE=+$P(X,"(",2)
|
---|
117 | . S FIELD=+$P(X,",",$L(X,",")-1)
|
---|
118 | . I $D(FIELD(FIELD)) S FIELD(FIELD)=@X
|
---|
119 | S N=0 F S N=$O(FIELD(N)) Q:'+N D
|
---|
120 | . S N2=0 F S N2=$O(RESULT(N2)) Q:'+N2 I $P(RESULT(N2),"^",2)=N S $P(RESULT(N2),"^",3)=FIELD(N)
|
---|
121 | . S RESULT(0)=$$DFNID^VWREGITU()
|
---|
122 | NPTX K FIELD,AR,FCAP,FILE,SUBDIC,N,N2,DFN
|
---|
123 | Q
|
---|
124 | ;
|
---|
125 | PF(RESULT,XPF) ;Pointer file - get the stuff
|
---|
126 | K RESULT,AR
|
---|
127 | N X,N
|
---|
128 | I '$L(XPF) S RESULT(0)="???" Q
|
---|
129 | S XPF="^"_XPF
|
---|
130 | I +$P(XPF,"(",2)=.85 G NAUTPF ;Naughty file!
|
---|
131 | S N=0 F S N=$O(@(XPF_N_")")) Q:'+N S X=$P(^(N,0),"^"),AR(X,N)=X_"("_N_")"
|
---|
132 | S X="AR" F S X=$Q(@X) Q:X="" S RESULT($$INR)=@X
|
---|
133 | K AR
|
---|
134 | Q
|
---|
135 | ;
|
---|
136 | NAUTPF ;The "NAUGHTY" pointer file - has a numeric .01 - Bad file !!!
|
---|
137 | S N=0 F S N=$O(@(XPF_N_")")) Q:'+N S X=$P(^(N,0),"^") D
|
---|
138 | . S LANG=$P(^(0),"^",2)
|
---|
139 | . S AR(LANG,N)=LANG_"("_N_")"
|
---|
140 | S X="AR" F S X=$Q(@X) Q:X="" S RESULT($$INR)=@X
|
---|
141 | Q
|
---|
142 | GIF ;Generic Insurance form
|
---|
143 | K RESULT
|
---|
144 | S RESULT($$INR)="Insurance Company^2.312;.01^^^DIC(36,^0"
|
---|
145 | S RESULT($$INR)="Group Plan^2.312;.18^^^IBA(355.3,^0"
|
---|
146 | S RESULT($$INR)="Policy No.^2.312;1^^^^0"
|
---|
147 | ;S RESULT($$INR)="Type of Plan^^^^^0"
|
---|
148 | S RESULT($$INR)="Coverage^355.33;40.09^^^IBE(355.1,^0"
|
---|
149 | S RESULT($$INR)="Effective Date^2.312;8^^^^0"
|
---|
150 | S RESULT($$INR)="Expiration Date^.3121;^^^^0"
|
---|
151 | S RESULT($$INR)="Guarantor^^^^^0"
|
---|
152 | S RESULT($$INR)="Signature on File^^^^0:NO;1:YES^0"
|
---|
153 | S RESULT($$INR)="Employer^2.312;2.015^^^^0"
|
---|
154 | S RESULT($$INR)="Billing Address^2.312;2.02^^^^0"
|
---|
155 | S RESULT($$INR)="Billing Address(cont)^2.312;2.03^^^^0"
|
---|
156 | S RESULT($$INR)="Postal Code^2.312;2.07^^^^0"
|
---|
157 | S RESULT($$INR)="City^2.312;2.05^^^^0"
|
---|
158 | S RESULT($$INR)="County/Region/Area^^^^^0"
|
---|
159 | S RESULT($$INR)="State/Province/Region^2.312;2.06^^^DIC(5,^0"
|
---|
160 | Q
|
---|
161 | ;
|
---|
162 |
|
---|