]> git.mxchange.org Git - quix0rs-gnu-social.git/blob - lib/groupprofileblock.php
Merge remote-tracking branch 'origin/1.0.x' into 1.0.x
[quix0rs-gnu-social.git] / lib / groupprofileblock.php
1 <?php
2 /**
3  * StatusNet - the distributed open-source microblogging tool
4  * Copyright (C) 2011, StatusNet, Inc.
5  *
6  * Profile block to show for a group
7  *
8  * PHP version 5
9  *
10  * This program is free software: you can redistribute it and/or modify
11  * it under the terms of the GNU Affero General Public License as published by
12  * the Free Software Foundation, either version 3 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU Affero General Public License for more details.
19  *
20  * You should have received a copy of the GNU Affero General Public License
21  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
22  *
23  * @category  Widget
24  * @package   StatusNet
25  * @author    Evan Prodromou <evan@status.net>
26  * @copyright 2011 StatusNet, Inc.
27  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
28  * @link      http://status.net/
29  */
30
31 if (!defined('STATUSNET')) {
32     // This check helps protect against security problems;
33     // your code file can't be executed directly from the web.
34     exit(1);
35 }
36
37 /**
38  * Profile block to show for a group
39  *
40  * @category  Widget
41  * @package   StatusNet
42  * @author    Evan Prodromou <evan@status.net>
43  * @copyright 2011 StatusNet, Inc.
44  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
45  * @link      http://status.net/
46  */
47 class GroupProfileBlock extends ProfileBlock
48 {
49     protected $group = null;
50
51     function __construct($out, $group)
52     {
53         parent::__construct($out);
54         $this->group = $group;
55     }
56
57     function avatar()
58     {
59         return ($this->group->homepage_logo) ?
60             $this->group->homepage_logo : User_group::defaultLogo(AVATAR_PROFILE_SIZE);
61     }
62
63     function name()
64     {
65         return $this->group->getBestName();
66     }
67
68     function url()
69     {
70         return $this->group->homeUrl();
71     }
72
73     function location()
74     {
75         return $this->group->location;
76     }
77
78     function homepage()
79     {
80         return $this->group->homepage;
81     }
82
83     function description()
84     {
85         return $this->group->description;
86     }
87
88     function showActions()
89     {
90         $cur = common_current_user();
91         $this->out->elementStart('div', 'entity_actions');
92         // TRANS: Group actions header (h2). Text hidden by default.
93         $this->out->element('h2', null, _('Group actions'));
94         $this->out->elementStart('ul');
95         if (Event::handle('StartGroupActionsList', array($this, $this->group))) {
96             $this->out->elementStart('li', 'entity_subscribe');
97             if (Event::handle('StartGroupSubscribe', array($this, $this->group))) {
98                 if ($cur) {
99                     $profile = $cur->getProfile();
100                     if ($profile->isMember($this->group)) {
101                         $lf = new LeaveForm($this->out, $this->group);
102                         $lf->show();
103                     } else if ($profile->isPendingMember($this->group)) {
104                         $cf = new CancelGroupForm($this->out, $this->group);
105                         $cf->show();
106                     } else if (!Group_block::isBlocked($this->group, $profile)) {
107                         $jf = new JoinForm($this->out, $this->group);
108                         $jf->show();
109                     }
110                 }
111                 Event::handle('EndGroupSubscribe', array($this, $this->group));
112             }
113             $this->out->elementEnd('li');
114             if ($cur && $cur->isAdmin($this->group)) {
115                 $this->out->elementStart('li', 'entity_edit');
116                 $this->out->element('a', array('href' => common_local_url('editgroup',
117                                                                           array('nickname' => $this->group->nickname)),
118                                                // TRANS: Tooltip for menu item in the group navigation page. Only shown for group administrators.
119                                                // TRANS: %s is the nickname of the group.
120                                                'title' => sprintf(_m('TOOLTIP','Edit %s group properties'), $nickname)),
121                                     // TRANS: Link text for link on user profile.
122                                     _m('BUTTON','Edit'));
123                 $this->out->elementEnd('li');
124                 $this->out->elementStart('li', 'entity_edit');
125                 $this->out->element('a', array('href' => common_local_url('grouplogo',
126                                                                           array('nickname' => $this->group->nickname)),
127                                                // TRANS: Tooltip for menu item in the group navigation page. Only shown for group administrators.
128                                                // TRANS: %s is the nickname of the group.
129                                                'title' => sprintf(_m('TOOLTIP','Add or edit %s logo'), $nickname)),
130                                     // TRANS: Link text for link on user profile.
131                                     _m('MENU','Logo'));
132                 $this->out->elementEnd('li');
133             }
134             if ($cur && $cur->hasRight(Right::DELETEGROUP)) {
135                 $this->out->elementStart('li', 'entity_delete');
136                 $df = new DeleteGroupForm($this->out, $this->group);
137                 $df->show();
138                 $this->out->elementEnd('li');
139             }
140
141             Event::handle('EndGroupActionsList', array($this, $this->group));
142         }
143         $this->out->elementEnd('ul');
144         $this->out->elementEnd('div');
145     }
146
147     function show()
148     {
149         $this->out->elementStart('div', 'profile_block group_profile_block section');
150         if (Event::handle('StartShowGroupProfileBlock', array($this->out, $this->group))) {
151             parent::show();
152             Event::handle('EndShowGroupProfileBlock', array($this->out, $this->group));
153         }
154         $this->out->elementEnd('div');
155     }
156 }