3 * StatusNet - the distributed open-source microblogging tool
4 * Copyright (C) 2011, StatusNet, Inc.
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU Affero General Public License as published by
8 * the Free Software Foundation, either version 3 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 Affero General Public License for more details.
16 * You should have received a copy of the GNU Affero General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
20 if (!defined('STATUSNET')) {
25 * Class to represent extended profile data
34 * @param Profile $profile
36 function __construct(Profile $profile)
38 $this->profile = $profile;
39 $this->user = $profile->getUser();
40 $this->fields = $this->loadFields();
41 $this->sections = $this->getSections();
42 //common_debug(var_export($this->sections, true));
44 //common_debug(var_export($this->fields, true));
48 * Load extended profile fields
50 * @return array $fields the list of fields
54 $detail = new Profile_detail();
55 $detail->profile_id = $this->profile->id;
60 while ($detail->fetch()) {
61 $fields[$detail->field_name][] = clone($detail);
68 * Get a the self-tags associated with this profile
70 * @return string the concatenated string of tags
74 return implode(' ', $this->user->getSelfTags());
78 * Return a simple string value. Checks for fields that should
79 * be stored in the regular profile and returns values from it
82 * @param string $name name of the detail field to get the
85 * @return string the value
87 function getTextValue($name)
89 $key = strtolower($name);
90 $profileFields = array('fullname', 'location', 'bio');
92 if (in_array($key, $profileFields)) {
93 return $this->profile->$name;
94 } else if (array_key_exists($key, $this->fields)) {
95 return $this->fields[$key][0]->field_value;
103 $phones = $this->fields['phone'];
106 if (empty($phones)) {
108 'label' => _m('Phone'),
115 for ($i = 0; $i < sizeof($phones); $i++) {
117 'label' => _m('Phone'),
119 'index' => intva($phones[$i]->value_index),
120 'rel' => $phones[$i]->rel,
121 'value' => $phones[$i]->field_value,
124 // Last phone record should allow adding more
125 if ($i == sizeof($phones) - 1) {
135 * Return all the sections of the extended profile
137 * @return array the big list of sections and fields
139 function getSections()
143 'label' => _m('Personal'),
146 'label' => _m('Full name'),
147 'profile' => 'fullname',
151 'label' => _m('Title'),
155 'label' => _m('Manager'),
157 'vcard' => 'x-manager',
160 'label' => _m('Location'),
161 'profile' => 'location'
164 'label' => _m('Bio'),
165 'type' => 'textarea',
169 'label' => _m('Tags'),
176 'label' => _m('Contact'),
178 'phone' => $this->getPhones(),
185 'label' => _m('Websites'),
192 'label' => _m('Personal'),
195 'label' => _m('Birthday'),
200 'label' => _m('Spouse\'s name'),
201 'vcard' => 'x-spouse',
204 'label' => _m('Kids\' names')
208 'experience' => array(
209 'label' => _m('Work experience'),
211 'experience' => array(
212 'type' => 'experience',
213 'label' => _m('Employer'),
217 'education' => array(
218 'label' => _m('Education'),
220 'education' => array(
221 'type' => 'education',
222 'label' => _m('Institution'),