]> git.mxchange.org Git - quix0rs-gnu-social.git/blob - actions/attachment_ajax.php
Attachments and their list now provide "ajax" view. Also added a few sidebars relatin...
[quix0rs-gnu-social.git] / actions / attachment_ajax.php
1 <?php
2 /**
3  * Laconica, the distributed open-source microblogging tool
4  *
5  * Show notice attachments
6  *
7  * PHP version 5
8  *
9  * LICENCE: This program is free software: you can redistribute it and/or modify
10  * it under the terms of the GNU Affero General Public License as published by
11  * the Free Software Foundation, either version 3 of the License, or
12  * (at your option) any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU Affero General Public License for more details.
18  *
19  * You should have received a copy of the GNU Affero General Public License
20  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
21  *
22  * @category  Personal
23  * @package   Laconica
24  * @author    Evan Prodromou <evan@controlyourself.ca>
25  * @copyright 2008-2009 Control Yourself, Inc.
26  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
27  * @link      http://laconi.ca/
28  */
29
30 if (!defined('LACONICA')) {
31     exit(1);
32 }
33
34 require_once INSTALLDIR.'/actions/attachment.php';
35
36 /**
37  * Show notice attachments
38  *
39  * @category Personal
40  * @package  Laconica
41  * @author   Evan Prodromou <evan@controlyourself.ca>
42  * @license  http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
43  * @link     http://laconi.ca/
44  */
45
46 class Attachment_ajaxAction extends AttachmentAction
47 {
48     /**
49      * Load attributes based on database arguments
50      *
51      * Loads all the DB stuff
52      *
53      * @param array $args $_REQUEST array
54      *
55      * @return success flag
56      */
57
58     function prepare($args)
59     {
60         parent::prepare($args);
61         if (!$this->attachment) {
62             $this->clientError(_('No such attachment.'), 404);
63             return false;
64         }
65         return true;
66     }
67
68     /**
69      * Show page, a template method.
70      *
71      * @return nothing
72      */
73     function showPage()
74     {
75         if (Event::handle('StartShowBody', array($this))) {
76             $this->showCore();
77             Event::handle('EndShowBody', array($this));
78         }
79     }
80
81     /**
82      * Show core.
83      *
84      * Shows local navigation, content block and aside.
85      *
86      * @return nothing
87      */
88     function showCore()
89     {
90         $this->elementStart('div', array('id' => 'core'));
91         if (Event::handle('StartShowContentBlock', array($this))) {
92             $this->showContentBlock();
93             Event::handle('EndShowContentBlock', array($this));
94         }
95         $this->elementEnd('div');
96     }
97
98
99
100     /**
101      * Last-modified date for page
102      *
103      * When was the content of this page last modified? Based on notice,
104      * profile, avatar.
105      *
106      * @return int last-modified date as unix timestamp
107      */
108 /*
109     function lastModified()
110     {
111         return max(strtotime($this->notice->created),
112                    strtotime($this->profile->modified),
113                    ($this->avatar) ? strtotime($this->avatar->modified) : 0);
114     }
115 */
116
117     /**
118      * An entity tag for this page
119      *
120      * Shows the ETag for the page, based on the notice ID and timestamps
121      * for the notice, profile, and avatar. It's weak, since we change
122      * the date text "one hour ago", etc.
123      *
124      * @return string etag
125      */
126 /*
127     function etag()
128     {
129         $avtime = ($this->avatar) ?
130           strtotime($this->avatar->modified) : 0;
131
132         return 'W/"' . implode(':', array($this->arg('action'),
133                                           common_language(),
134                                           $this->notice->id,
135                                           strtotime($this->notice->created),
136                                           strtotime($this->profile->modified),
137                                           $avtime)) . '"';
138     }
139 */
140 }
141