1 | DVBCADR ;ALB/JLU-editing the address ;1/28/93
|
---|
2 | ;;2.7;AMIE;**19**;Apr 10, 1995
|
---|
3 | ;
|
---|
4 | EN ;driver of the program
|
---|
5 | S DVBCSTP=0
|
---|
6 | F DO Q:DVBCSTP
|
---|
7 | .D PAT Q:DVBCSTP
|
---|
8 | .D INIT Q:DVBCSTP
|
---|
9 | .F D GUTS Q:DVBCSTP1
|
---|
10 | .I DVBCMAL D MAIL
|
---|
11 | D EXIT
|
---|
12 | Q
|
---|
13 | ;
|
---|
14 | GUTS ;this is the interloop or guts of the driver
|
---|
15 | D DISPL
|
---|
16 | D ASK
|
---|
17 | I 'Y S DVBCSTP1=1 Q
|
---|
18 | D QUES^DGRPU1(DVBCDFN,"ADD1")
|
---|
19 | I DGERR D ERROR Q
|
---|
20 | I DGCHANGE S DVBCMAL=1
|
---|
21 | D VDPTP
|
---|
22 | Q
|
---|
23 | ;
|
---|
24 | EXIT ;cleans variables
|
---|
25 | K %H,DFN,DGCHANGE,DGERR,DIC,DIR,DVBC,DVBCDATE,DVBCDFN,DVBCLINE,DVBCMAL,DVBCPATN,DVBCSSN,DVBCSTP,DVBCSTP1,VAERR,VAPA,Y,XMTEXT,XMY,XMB,XMDUZ,XMSUB,DVBCX,DVBCML,DVBCSP,DVBCSP1,ER,J,C,PNAM,SSN,DVBCSSNO
|
---|
26 | K DVBTMP,XMBTEXT
|
---|
27 | Q
|
---|
28 | ;
|
---|
29 | ERROR ;this is an erro printing subroutine
|
---|
30 | I DGERR W !,*7
|
---|
31 | Q
|
---|
32 | ;
|
---|
33 | INIT ;initialize variables
|
---|
34 | I '$D(IOF) D HOME^%ZIS
|
---|
35 | K VAPA,DVBTMP,DVBC
|
---|
36 | S %H=$H
|
---|
37 | D YX^%DTC
|
---|
38 | S DVBCDATE=$P(Y,"@",1)
|
---|
39 | S $P(DVBCLINE,"_",80)=""
|
---|
40 | S SSN=$P(^DPT(DVBCDFN,0),U,9)
|
---|
41 | D SSNOUT^DVBCUTIL
|
---|
42 | S DVBCSSN=DVBCSSNO
|
---|
43 | D VDPTTMP
|
---|
44 | I VAERR S DVBCSTP=1 Q
|
---|
45 | I +VAPA(9) DO
|
---|
46 | .D STORTMP
|
---|
47 | .K VAPA
|
---|
48 | .D VDPTP
|
---|
49 | I VAERR S DVBCSTP=1 Q
|
---|
50 | D STORE
|
---|
51 | S (DVBCSTP1,DVBCMAL)=0
|
---|
52 | Q
|
---|
53 | ;
|
---|
54 | PAT ;get the patient
|
---|
55 | S DIC="^DPT(",DIC(0)="AEMQ"
|
---|
56 | D ^DIC
|
---|
57 | I Y<0 S DVBCSTP=1 Q
|
---|
58 | S DVBCDFN=+Y,(PNAM,DVBCPATN)=$P(Y,U,2)
|
---|
59 | Q
|
---|
60 | ;
|
---|
61 | DISPL ;the display subroutine
|
---|
62 | W @IOF
|
---|
63 | W "Edit Address Information",?35,$$SITE^DVBCUTL4,?67,DVBCDATE
|
---|
64 | W !,"Name: ",DVBCPATN,?54,"SSN: ",DVBCSSN
|
---|
65 | W !,DVBCLINE
|
---|
66 | W !,?9,"Permanent"
|
---|
67 | I $D(DVBTMP) DO
|
---|
68 | .W ?40,"Temporary: ",$P(DVBTMP(9),U,2)
|
---|
69 | .I $P(DVBTMP(10),U,2)]"" W " to ",$P(DVBTMP(10),U,2)
|
---|
70 | W !,"Address: ",$E(VAPA(1),1,29)
|
---|
71 | I $D(DVBTMP) W ?40,$E(DVBTMP(1),1,29)
|
---|
72 | W !,?9,$E(VAPA(2),1,29)
|
---|
73 | I $D(DVBTMP) W ?40,$E(DVBTMP(2),1,29)
|
---|
74 | W !,?9,$E(VAPA(3),1,29)
|
---|
75 | I $D(DVBTMP) W ?40,$E(DVBTMP(3),1,29)
|
---|
76 | W !,"City:",?9,VAPA(4)
|
---|
77 | I $D(DVBTMP) W ?40,DVBTMP(4)
|
---|
78 | W !,"State:",?9,$P(VAPA(5),U,2)
|
---|
79 | I $D(DVBTMP) W ?40,$P(DVBTMP(5),U,2)
|
---|
80 | W !,"Zip+4:",?9,$S($D(VAPA(11)):$P(VAPA(11),"^",2),1:"")
|
---|
81 | I $D(DVBTMP) W ?40,DVBTMP(11)
|
---|
82 | W !,"County:",?9,$P(VAPA(7),U,2)
|
---|
83 | I $D(DVBTMP) W ?40,$P(DVBTMP(7),U,2)
|
---|
84 | W !,"Phone:",?9,VAPA(8)
|
---|
85 | I $D(DVBTMP) W ?40,DVBTMP(8)
|
---|
86 | W !,"Office:",?9,VAPA(9999)
|
---|
87 | W !,DVBCLINE
|
---|
88 | Q
|
---|
89 | ;
|
---|
90 | ASK ;ask if yes or no
|
---|
91 | S DIR(0)="Y",DIR("A")="Do you wish to edit this address:",DIR("B")="YES"
|
---|
92 | D ^DIR
|
---|
93 | Q
|
---|
94 | ;
|
---|
95 | STORE ;store original address fro possible bulletin
|
---|
96 | S DVBC(1)=VAPA(1),DVBC(2)=VAPA(2),DVBC(3)=VAPA(3)
|
---|
97 | S DVBC(4)=VAPA(4),DVBC(5)=$P(VAPA(5),U,2)
|
---|
98 | S DVBC(11)=$S($D(VAPA(11)):$P(VAPA(11),"^",2),1:"")
|
---|
99 | S DVBC(7)=$P(VAPA(7),U,2),DVBC(8)=VAPA(8)
|
---|
100 | S DVBC(9999)=VAPA(9999)
|
---|
101 | Q
|
---|
102 | ;
|
---|
103 | VDPTP ;gets the permanent address
|
---|
104 | S VAPA("P")=""
|
---|
105 | VDPTTMP ;gets the temporary address if one
|
---|
106 | S DFN=DVBCDFN
|
---|
107 | D ADD^VADPT
|
---|
108 | S VAPA(9999)=$S($D(^DPT(DFN,.13)):$P(^(.13),U,2),1:"")
|
---|
109 | Q
|
---|
110 | ;
|
---|
111 | STORTMP ;saves the active temporary address
|
---|
112 | S DVBTMP(1)=VAPA(1),DVBTMP(2)=VAPA(2),DVBTMP(3)=VAPA(3),DVBTMP(4)=VAPA(4)
|
---|
113 | S DVBTMP(5)=VAPA(5),DVBTMP(11)=$S($D(VAPA(11)):$P(VAPA(11),"^",2),1:"")
|
---|
114 | S DVBTMP(7)=VAPA(7),DVBTMP(8)=VAPA(8)
|
---|
115 | S DVBTMP(9)=VAPA(9),DVBTMP(10)=VAPA(10)
|
---|
116 | Q
|
---|
117 | ;
|
---|
118 | MAIL ;to fire a bulletin if necessary
|
---|
119 | S XMDUZ="AMIE Package",XMSUB="Edit of patient address"
|
---|
120 | S XMB(1)=DVBCPATN_" SSN: "_DVBCSSN,XMB(2)=DVBCDATE,XMB(3)=$P(^VA(200,DUZ,0),U,1)
|
---|
121 | S XMB="DVBA C EDIT ADDRESS"
|
---|
122 | D XMT
|
---|
123 | S XMTEXT="DVBCML("
|
---|
124 | D ^XMB
|
---|
125 | K XMBTEXT,XMTEXT,XMB,XMSUB
|
---|
126 | W !!,"A bulletin has been sent to the appropriate mail group regarding this",!,"address change!"
|
---|
127 | Q
|
---|
128 | ;
|
---|
129 | XMT ;make the text of the bulletin
|
---|
130 | S DVBCX=1 D LIN
|
---|
131 | S DVBCML(1)="ADDR.: "_DVBC(1)_DVBCSP_VAPA(1)
|
---|
132 | S DVBCX=2 D LIN
|
---|
133 | S DVBCML(2)=" "_DVBC(2)_DVBCSP_VAPA(2)
|
---|
134 | S DVBCX=3 D LIN
|
---|
135 | S DVBCML(3)=" "_DVBC(3)_DVBCSP_VAPA(3)
|
---|
136 | S DVBCX=4 D LIN
|
---|
137 | S DVBCML(4)="City: "_DVBC(4)_DVBCSP_VAPA(4)
|
---|
138 | S DVBCX=5 D LIN
|
---|
139 | S DVBCML(5)="State: "_DVBC(5)_DVBCSP_$P(VAPA(5),U,2)
|
---|
140 | S DVBCX=11 D LIN
|
---|
141 | S DVBCML(6)="Zip+4: "_DVBC(11)_DVBCSP_$S($D(VAPA(11)):$P(VAPA(11),"^",2),1:"")
|
---|
142 | S DVBCX=7 D LIN
|
---|
143 | S DVBCML(7)="County: "_DVBC(7)_DVBCSP_$P(VAPA(7),U,2)
|
---|
144 | S DVBCX=8 D LIN
|
---|
145 | S DVBCML(8)="Phone: "_DVBC(8)_DVBCSP_VAPA(8)
|
---|
146 | S DVBCX=9999 D LIN
|
---|
147 | S DVBCML(9)="Office: "_DVBC(9999)_DVBCSP_VAPA(9999)
|
---|
148 | Q
|
---|
149 | ;
|
---|
150 | LIN ;makes spaces
|
---|
151 | K DVBCSP,DVBCSP1
|
---|
152 | S DVBCSP1=37-$L(DVBC(DVBCX))
|
---|
153 | S $P(DVBCSP," ",DVBCSP1)=""
|
---|
154 | Q
|
---|