0337d704 |
1 | <?php |
2 | /*************************************************************************** |
5ddeb07c |
3 | * Copyright (C) 2003-2007 Polytechnique.org * |
0337d704 |
4 | * http://opensource.polytechnique.org/ * |
5 | * * |
6 | * This program is free software; you can redistribute it and/or modify * |
7 | * it under the terms of the GNU General Public License as published by * |
8 | * the Free Software Foundation; either version 2 of the License, or * |
9 | * (at your option) any later version. * |
10 | * * |
11 | * This program is distributed in the hope that it will be useful, * |
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of * |
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * |
14 | * GNU General Public License for more details. * |
15 | * * |
16 | * You should have received a copy of the GNU General Public License * |
17 | * along with this program; if not, write to the Free Software * |
18 | * Foundation, Inc., * |
19 | * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * |
20 | ***************************************************************************/ |
21 | |
22 | define ('FPDF_FONTPATH', dirname(__FILE__).'/fonts/'); |
63528107 |
23 | require_once '/usr/share/fpdf/fpdf.php'; |
c83168b1 |
24 | |
25 | VarStream::init(); |
0337d704 |
26 | |
27 | class ContactsPDF extends FPDF |
28 | { |
c83168b1 |
29 | public $title = "Mes contacts sur Polytechnique.org"; |
30 | |
31 | private $col = 0; |
32 | private $y0; |
0337d704 |
33 | |
c83168b1 |
34 | private $broken = false; |
35 | private $error = false; |
0337d704 |
36 | |
c83168b1 |
37 | private $report = 0; |
93c099e1 |
38 | |
0337d704 |
39 | function ContactsPDF() |
40 | { |
93c099e1 |
41 | $this->report = error_reporting(0); |
0337d704 |
42 | parent::FPDF(); |
93c099e1 |
43 | error_reporting($this->report); |
44 | |
0337d704 |
45 | $this->AddFont('Vera Sans', '', 'Vera.php'); |
46 | $this->AddFont('Vera Sans', 'I', 'VeraIt.php'); |
47 | $this->AddFont('Vera Sans', 'B', 'VeraBd.php'); |
b48a0758 |
48 | |
0337d704 |
49 | $this->AddFont('Vera Mono', '', 'VeraMono.php'); |
b48a0758 |
50 | |
0337d704 |
51 | $this->SetTitle($this->title); |
52 | $this->SetCreator('Site Polytechnique.org'); |
53 | $this->AddPage(); |
54 | } |
55 | |
93c099e1 |
56 | function Output($name='mescontacts.pdf', $dest='I') |
0337d704 |
57 | { |
58 | Header('Pragma: public'); |
93c099e1 |
59 | error_reporting(0); |
60 | parent::Output($name, $dest); |
61 | error_reporting($this->report); |
0337d704 |
62 | } |
63 | |
93c099e1 |
64 | function Rotate($angle, $x=-1, $y=-1) |
0337d704 |
65 | { |
e54098b8 |
66 | if ($x==-1) { |
0337d704 |
67 | $x = $this->x; |
68 | } |
e54098b8 |
69 | if ($y==-1) { |
0337d704 |
70 | $y=$this->y; |
71 | } |
93c099e1 |
72 | if (!empty($this->angle)) { |
0337d704 |
73 | $this->_out('Q'); |
74 | } |
75 | $this->angle = $angle; |
93c099e1 |
76 | if ($angle != 0) { |
0337d704 |
77 | $angle*=M_PI/180; |
78 | $c = cos($angle); |
79 | $s = sin($angle); |
80 | $cx = $x*$this->k; |
81 | $cy = ($this->h-$y)*$this->k; |
93c099e1 |
82 | $this->_out(sprintf('q %.5f %.5f %.5f %.5f %.2f %.2f cm 1 0 0 1 %.2f %.2f cm', |
83 | $c, $s, -$s, $c, $cx, $cy, -$cx, -$cy)); |
0337d704 |
84 | } |
85 | } |
b48a0758 |
86 | |
0337d704 |
87 | function Header() |
88 | { |
89 | |
90 | $this->SetFont('Vera Sans', 'B', 20); |
91 | $this->SetTextColor(230); |
93c099e1 |
92 | $this->Rotate(45, 55, 190); |
ac73e294 |
93 | $this->Text(55, 190, utf8_decode("informations limitées à un usage")); |
94 | $this->Text(40, 210, utf8_decode("strictement personnel et non commercial")); |
0337d704 |
95 | $this->Rotate(0); |
b48a0758 |
96 | |
0337d704 |
97 | $this->setLeftMargin(5); |
98 | $this->setRightMargin(5); |
99 | $this->SetFont('Vera Sans', 'B', 16); |
100 | $this->SetY(5); |
93c099e1 |
101 | $this->SetTextColor(51, 102, 153); |
102 | $this->SetDrawColor(102, 153, 204); |
0337d704 |
103 | $this->SetLineWidth(0.2); |
104 | $this->SetFillColor(245, 248, 252); |
105 | $this->Cell(200, 10, $this->title, 1, 1, 'C', 1); |
93c099e1 |
106 | $this->Image(dirname(__FILE__).'/../../htdocs/images/logo.png', |
107 | 5, 5, 10, 10, 'png', 'https://www.polytechnique.org/'); |
b48a0758 |
108 | |
0337d704 |
109 | $this->Ln(10); |
110 | $this->y0 = $this->GetY(); |
111 | $this->ColSetup(false); |
112 | } |
113 | |
114 | function Footer() |
115 | { |
116 | $this->setLeftMargin(5); |
117 | $this->setRightMargin(5); |
118 | $this->SetY(-15); |
93c099e1 |
119 | $this->SetFont('Vera Sans', 'I', 8); |
0337d704 |
120 | $this->SetTextColor(128); |
121 | $this->Cell(0, 10, 'Page '.$this->PageNo(), 0, 0, 'C'); |
7d804f13 |
122 | $this->Cell(0, 10, '(en date du '.strftime('%d %B %Y').')', 0, 0, 'R'); |
0337d704 |
123 | } |
124 | |
125 | function ColSetup($col) |
126 | { |
127 | $this->col = $col; |
128 | $x = 10 + $this->col * 100; |
129 | $this->SetLeftMargin($x); |
130 | $this->SetRightMargin(120 - $x); |
131 | $this->SetX($x); |
132 | $this->SetY($this->y0); |
133 | } |
134 | |
135 | function NextCol() |
136 | { |
137 | $this->ColSetup(1 - $this->col); |
e54098b8 |
138 | if ($this->col == 0) { |
139 | $this->AddPage(); |
140 | } |
0337d704 |
141 | } |
142 | |
143 | function AcceptPageBreak() |
144 | { |
145 | $this->broken = true; |
146 | } |
147 | |
148 | function Space($w=0.1, $h=0.5) |
149 | { |
150 | $x = $this->getX(); |
151 | $y = $this->getY(); |
152 | $this->SetLineWidth($w); |
153 | $this->Line($x, $y, $x+90, $y); |
154 | $this->Ln($h); |
155 | } |
156 | |
157 | function TableRow($l, $r, $font = 'Sans') |
158 | { |
159 | $this->SetFont('Vera Sans', 'B', 8); |
160 | $y = $this->getY(); |
161 | $x = $this->getX(); |
162 | $this->MultiCell(25, 4, $l, '', 1); |
163 | $y1 = $this->getY(); |
164 | |
165 | $this->SetFont('Vera '.$font, '', 8); |
166 | $this->setY($y); |
167 | $first = 1; |
b48a0758 |
168 | |
0337d704 |
169 | $this->setX($x+25); |
170 | $this->MultiCell(65, 4, $r, '', 1); |
b48a0758 |
171 | |
0337d704 |
172 | $this->setY(max($y1, $this->getY())+0.5); |
173 | $this->setX($x); |
174 | } |
175 | |
176 | function Address($a) |
177 | { |
178 | $l = "adresse\n"; |
179 | if ($a['active']) { |
180 | $l .= 'actuelle'; |
181 | } elseif ($a['secondaire']) { |
182 | $l .= 'secondaire'; |
183 | } else { |
184 | $l .= 'principale'; |
185 | } |
186 | |
187 | $r = ''; |
188 | $r = trim("$r\n".$a['adr1']); |
189 | $r = trim("$r\n".$a['adr2']); |
190 | $r = trim("$r\n".$a['adr3']); |
191 | $r = trim("$r\n".trim($a['postcode'].' '.$a['city'])); |
192 | |
193 | $this->TableRow($l, $r); |
194 | |
93c099e1 |
195 | if (!empty($a['tels'])) { |
196 | foreach ($a['tels'] as $tel) { |
197 | if (!empty($tel['tel'])) { |
2566d94c |
198 | $this->TableRow(utf8_decode($tel['tel_type']), $tel['tel'], 'Mono'); |
93c099e1 |
199 | } |
79a5acea |
200 | } |
93c099e1 |
201 | } |
0337d704 |
202 | } |
203 | |
204 | function AddressPro($a) |
205 | { |
206 | if ($a['entreprise']) { |
207 | $this->TableRow('Entreprise', $a['entreprise']); |
208 | } |
b48a0758 |
209 | |
0337d704 |
210 | if ($a['adr1'] || $a['adr2'] || $a['adr3'] || $a['postcode'] || $a['city']) { |
211 | $r = ''; |
212 | $r = trim("$r\n".$a['adr1']); |
213 | $r = trim("$r\n".$a['adr2']); |
214 | $r = trim("$r\n".$a['adr3']); |
215 | $r = trim("$r\n".trim($a['postcode'].' '.$a['city'])); |
216 | $this->TableRow('adresse pro', $r); |
217 | } |
218 | |
219 | if ($a['tel']) { |
8029c315 |
220 | $this->TableRow(utf8_decode('Téléphone'), $a['tel'], 'Mono'); |
0337d704 |
221 | } |
222 | if ($a['fax']) { |
223 | $this->TableRow('Fax', $a['fax'], 'Mono'); |
224 | } |
225 | } |
226 | |
93c099e1 |
227 | function Error($msg) |
0337d704 |
228 | { |
229 | $this->error = true; |
230 | } |
231 | |
232 | function wordwrap($text, $maxwidth = 90) { |
233 | $text = trim($text); |
234 | if ($text==='') { return 0; } |
235 | $space = $this->GetStringWidth(' '); |
236 | $lines = explode("\n", $text); |
237 | $text = ''; |
238 | $count = 0; |
239 | |
e54098b8 |
240 | foreach ($lines as $line) { |
0337d704 |
241 | $words = preg_split('/ +/', $line); |
242 | $width = 0; |
243 | |
e54098b8 |
244 | foreach ($words as $word) { |
0337d704 |
245 | $wordwidth = $this->GetStringWidth($word); |
e54098b8 |
246 | if ($width + $wordwidth <= $maxwidth) { |
0337d704 |
247 | $width += $wordwidth + $space; |
248 | $text .= $word.' '; |
e54098b8 |
249 | } else { |
0337d704 |
250 | $width = $wordwidth + $space; |
e54098b8 |
251 | $text = rtrim($text)."\n".$word.' '; |
0337d704 |
252 | $count++; |
253 | } |
254 | } |
255 | $text = rtrim($text)."\n"; |
256 | $count++; |
257 | } |
258 | $text = rtrim($text); |
259 | return $count; |
260 | } |
261 | |
93c099e1 |
262 | static function AddContact($self, $x, $wp = true) |
0337d704 |
263 | { |
0337d704 |
264 | /* infamous hack : |
265 | 1- we store the current state. |
266 | 2- at the end, we find out if we triggered the page break, |
267 | -> no ? ok |
268 | -> yes ? then we have to create a col, and add the contact again. |
269 | */ |
93c099e1 |
270 | $old = clone $self; |
0337d704 |
271 | |
93c099e1 |
272 | $self->SetFont('Vera Sans', '', 10); |
273 | $self->SetDrawColor(0); |
274 | $self->SetFillColor(245, 248, 252); |
275 | $self->SetLineWidth(0.4); |
0337d704 |
276 | |
93c099e1 |
277 | $nom = $x['prenom'].' ' |
278 | .($x['nom_usage'] ? "{$x['nom_usage']} ({$x['nom']})" : $x['nom']) |
279 | ." ({$x['promo']})"; |
0337d704 |
280 | $ok = false; |
281 | |
282 | if ($wp) { |
93c099e1 |
283 | $res = XDB::query("SELECT * FROM photo WHERE attachmime IN ('jpeg', 'png') AND uid={?}", |
284 | $x['user_id']); |
0337d704 |
285 | if ($i = $res->numRows()) { |
93c099e1 |
286 | $old2 = clone $self; |
0337d704 |
287 | $photo = $res->fetchOneAssoc(); |
288 | $width = $photo['x'] * 20/$photo['y']; |
289 | $GLOBALS["p{$x['user_id']}"] = $photo['attach']; |
b48a0758 |
290 | |
93c099e1 |
291 | $_x = $self->getX(); |
292 | $_y = $self->getY(); |
293 | $self->Cell(0, 20, '', '', 0, '', 1); |
294 | error_reporting(0); |
295 | $self->Image("var://p{$x['user_id']}", $_x, $_y, $width, 20, $photo['attachmime']); |
296 | error_reporting($self->report); |
b48a0758 |
297 | |
93c099e1 |
298 | if ($self->error) { |
299 | $self = clone $old2; |
0337d704 |
300 | } else { |
93c099e1 |
301 | $self->setX($_x); |
302 | $self->Cell($width, 20, '', "T"); |
303 | $h = 20 / $self->wordwrap($nom, 90-$width); |
304 | $self->MultiCell(0, $h, $nom, 'T', 'C'); |
0337d704 |
305 | $ok = true; |
306 | } |
307 | } |
308 | } |
309 | if (!$ok) { |
93c099e1 |
310 | $self->MultiCell(0, 6, $nom, "T", 'C', 1); |
0337d704 |
311 | } |
b48a0758 |
312 | |
0337d704 |
313 | if ($x['mobile']) { |
93c099e1 |
314 | $self->Space(); |
315 | $self->TableRow('mobile', $x['mobile'], 'Mono'); |
0337d704 |
316 | } |
317 | |
318 | foreach ($x['adr'] as $a) { |
93c099e1 |
319 | $self->Space(); |
ac73e294 |
320 | foreach ($a as &$value) { |
321 | if (is_utf8($value)) { |
322 | $value = utf8_decode($value); |
323 | } |
324 | } |
93c099e1 |
325 | $self->Address($a); |
0337d704 |
326 | } |
b48a0758 |
327 | |
93c099e1 |
328 | if (!empty($x['adr_pro'])) { |
329 | foreach ($x['adr_pro'] as $a) { |
330 | if ( ! ($a['entreprise'] || $a['tel'] || $a['fax'] |
331 | || $a['adr1'] || $a['adr2'] || $a['adr3'] || $a['postcode'] || $a['city']) ) |
332 | { |
333 | continue; |
334 | } |
ac73e294 |
335 | foreach ($a as &$value) { |
336 | if (is_utf8($value)) { |
337 | $value = utf8_decode($value); |
338 | } |
339 | } |
93c099e1 |
340 | $self->Space(); |
341 | $self->AddressPro($a); |
0337d704 |
342 | } |
0337d704 |
343 | } |
344 | |
93c099e1 |
345 | $self->Space(0.4, 5); |
0337d704 |
346 | |
93c099e1 |
347 | if ($self->broken) { |
0337d704 |
348 | $old->NextCol(); |
93c099e1 |
349 | $self = ContactsPDF::AddContact($old, $x, $wp); |
0337d704 |
350 | } |
93c099e1 |
351 | |
352 | return $self; |
0337d704 |
353 | } |
0337d704 |
354 | } |
355 | |
a7de4ef7 |
356 | // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: |
0337d704 |
357 | ?> |