2 /***************************************************************************
3 * Copyright (C) 2003-2011 Polytechnique.org *
4 * http://opensource.polytechnique.org/ *
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. *
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. *
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 *
19 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *
20 ***************************************************************************/
22 class VCard
extends PlVCard
24 private $profile_list = array();
26 private $freetext = null
;
27 private $photos = true
;
29 public function __construct($photos = true
, $freetext = null
)
31 PlVCard
::$folding = false
;
32 $this->freetext
= $freetext;
33 $this->photos
= $photos;
36 public function addProfile($profile)
38 $profile = Profile
::get($profile, Profile
::FETCH_ALL
);
40 $this->profile_list
[] = $profile;
45 public function addProfiles(array $profiles) {
46 foreach ($profiles as $profile) {
47 $this->addProfile($profile);
51 protected function fetch()
53 return PlIteratorUtils
::fromArray($this->profile_list
);
56 protected function buildEntry($pf)
61 $entry = new PlVCardEntry($pf->firstNames(), $pf->lastNames(), null
, null
, $pf->nickname
);
66 $freetext = '(' . $pf->promo
. ')';
67 if ($this->freetext
) {
68 $freetext .= "\n" . $this->freetext
;
70 $entry->set('NOTE', $freetext);
72 $entry->addTel(null
, $pf->mobile
, false
, true
, true
, false
, true
, true
);
76 if (!is_null($user)) {
77 $entry->addMail(null
, $user->bestalias
, true
);
78 $entry->addMail(null
, $user->bestalias_alternate
);
79 if ($user->forlife
!= $user->bestalias
) {
80 $entry->addMail(null
, $user->forlife
);
81 $entry->addMail(null
, $user->forlife_alternate
);
86 $adrs = $pf->iterAddresses(Profile
::ADDRESS_PERSO
);
87 while ($adr = $adrs->next()) {
88 if (!$adr->postalCode ||
!$adr->locality ||
!$adr->country
) {
89 $group = $entry->addHome($adr->text
, null
, null
, null
,
90 null
, $adr->administrativeArea
, null
,
91 $adr->hasFlag('current'), $adr->hasFlag('mail'), $adr->hasFlag('mail'));
93 $group = $entry->addHome(trim(Geocoder
::getFirstLines($adr->text
, $adr->postalCode
, 4)), null
, null
, $adr->postalCode
,
94 $adr->locality
, $adr->administrativeArea
, $adr->country
,
95 $adr->hasFlag('current'), $adr->hasFlag('mail'), $adr->hasFlag('mail'));
97 foreach ($adr->phones() as $phone) {
98 if ($phone->link_type
== Phone
::TYPE_FIXED
) {
99 $entry->addTel($group, $phone->display
, false
, true
, true
, false
, false
,
100 $adr->hasFlag('current') && empty($pf->mobile
));
101 } else if ($phone->link_type
== Phone
::TYPE_FAX
) {
102 $entry->addTel($group, $phone->display
, true
, false
, false
, false
, false
, false
);
108 $jobs = $pf->getJobs();
109 foreach ($jobs as $job) {
110 $terms_array = array();
111 foreach ($job->terms
as $term) {
112 $terms_array[] = $term->full_name
;
114 $terms = implode(', ', $terms_array);
116 if (!$job->address
->postalCode ||
!$job->address
->locality ||
!$job->address
->country
) {
117 $group = $entry->addWork($job->company
->name
, null
, $job->description
, $terms,
118 $job->address
->text
, null
, null
, null
,
119 null
, $job->address
->administrativeArea
, null
);
121 $group = $entry->addWork($job->company
->name
, null
, $job->description
, $terms,
122 trim(Geocoder
::getFirstLines($job->address
->text
, $job->address
->postalCode
, 4)),
123 null
, null
, $job->address
->postalCode
,
124 $job->address
->locality
, $job->address
->administrativeArea
, $job->address
->country
);
127 $group = $entry->addWork($job->company
->name
, null
, $job->description
, $terms,
128 null
, null
, null
, null
,
131 if ($job->user_email
) {
132 $entry->addMail($group, $job->user_email
);
134 foreach ($job->phones
as $phone) {
135 if ($phone->type
== Phone
::TYPE_MOBILE
) {
136 $entry->addTel($group, $phone->display
, false
, true
, true
, false
, true
);
137 } else if ($phone->type
== Phone
::TYPE_FAX
) {
138 $entry->addTel($group, $phone->display
, true
);
140 $entry->addTel($group, $phone->display
, false
, true
, true
);
146 if (!is_null($user)) {
147 $alias = $user->emailAliases();
148 if (!is_null($alias) && $pf->alias_pub
== 'public') {
149 $entry->addMail(null
, $alias);
154 if (!is_null($user)) {
155 $groups = $user->groups(true
, true
);
156 if (count($groups)) {
157 $gn = DirEnum
::getOptions(DirEnum
::GROUPESX
);
159 foreach (array_keys($groups) as $gid) {
160 $gns[$gid] = $gn[$gid];
162 $entry->set('X-GROUPS', join(', ', $gns));
166 $binets = $pf->getBinets();
168 if (count($binets)) {
169 $bn = DirEnum
::getOptions(DirEnum
::BINETS
);
171 foreach ($binets as $bid) {
172 $bns[$bid] = $bn[$bid];
174 $entry->set('X-BINETS', join(', ', $bns));
176 if (!empty($pf->section
)) {
177 $entry->set('X-SECTION', $pf->section
);
183 "SELECT attach, attachmime
184 FROM profile_photos AS p
185 WHERE p.pid = {?}", $pf->id());
186 if ($res->numRows()) {
187 list($data, $type) = $res->fetchOneRow();
188 $entry->setPhoto($data, strtoupper($type));
195 // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: