lib.php 7.92 KB
Newer Older
1
2
3
4
5
<?php
/**
 *
 * @package    mahara
 * @subpackage blocktype-blogpost
6
 * @author     Catalyst IT Ltd
7
8
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL version 3 or later
 * @copyright  For copyright information on Mahara, please see the README file distributed with this software.
9
10
11
12
13
14
15
16
17
18
19
20
 *
 */

defined('INTERNAL') || die();

class PluginBlocktypeBlogpost extends PluginBlocktype {

    public static function get_title() {
        return get_string('title', 'blocktype.blog/blogpost');
    }

    /**
Aaron Wells's avatar
Aaron Wells committed
21
     * Optional method. If exists, allows this class to decide the title for
22
23
24
25
26
27
     * all blockinstances of this type
     */
    public static function get_instance_title(BlockInstance $bi) {
        $configdata = $bi->get('configdata');

        if (!empty($configdata['artefactid'])) {
28
            return $bi->get_artefact_instance($configdata['artefactid'])->get('title');
29
30
31
32
33
34
35
36
37
        }
        return '';
    }

    public static function get_description() {
        return get_string('description', 'blocktype.blog/blogpost');
    }

    public static function get_categories() {
38
        return array('blog' => 11000);
39
40
    }

41
    public static function render_instance(BlockInstance $instance, $editing=false) {
42
43
44
        $configdata = $instance->get('configdata');

        $result = '';
45
46
        $artefactid = isset($configdata['artefactid']) ? $configdata['artefactid'] : null;
        if ($artefactid) {
47
            require_once(get_config('docroot') . 'artefact/lib.php');
48
            $artefact = $instance->get_artefact_instance($artefactid);
49
            $configdata['hidetitle'] = true;
50
            $configdata['countcomments'] = true;
51
            $configdata['viewid'] = $instance->get('view');
52
            $configdata['blockid'] = $instance->get('id');
53
            $result = $artefact->render_self($configdata);
54
            $result = $result['html'];
55
56
57
            require_once(get_config('docroot') . 'artefact/comment/lib.php');
            require_once(get_config('docroot') . 'lib/view.php');
            $view = new View($configdata['viewid']);
58
            list($commentcount, $comments) = ArtefactTypeComment::get_artefact_comments_for_view($artefact, $view, $instance->get('id'), true, $editing);
59
60
        }

61
62
63
64
65
66
67
        $smarty = smarty_core();
        if ($artefactid) {
            $smarty->assign('commentcount', $commentcount);
            $smarty->assign('comments', $comments);
        }
        $smarty->assign('html', $result);
        return $smarty->fetch('blocktype:blogpost:blogpost.tpl');
68
69
    }

70
71
72
    /**
     * Returns a list of artefact IDs that are in this blockinstance.
     *
Aaron Wells's avatar
Aaron Wells committed
73
74
75
76
77
     * Normally this would just include the blogpost ID itself (children such
     * as attachments don't need to be included here, they're handled by the
     * artefact parent cache). But people might just link to artefacts without
     * using the attachment facility. There's nothing wrong with them doing
     * that, so if they do we should scrape the post looking for such links and
78
79
     * include those artefacts as being part of this blockinstance.
     *
Aaron Wells's avatar
Aaron Wells committed
80
81
82
83
     * @return array List of artefact IDs that are 'in' this blogpost - all
     *               the blogpost ID plus links to other artefacts that are
     *               part of the blogpost text. Note that proper artefact
     *               children, such as blog post attachments, aren't included -
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
     *               the artefact parent cache is used for them
     * @see PluginBlocktypeBlog::get_artefacts()
     */
    public static function get_artefacts(BlockInstance $instance) {
        $configdata = $instance->get('configdata');
        $artefacts = array();
        if (isset($configdata['artefactid'])) {
            $artefacts[] = $configdata['artefactid'];

            // Add all artefacts found in the blogpost text
            $blogpost = $instance->get_artefact_instance($configdata['artefactid']);
            $artefacts = array_unique(array_merge($artefacts, $blogpost->get_referenced_artefacts_from_postbody()));
        }
        return $artefacts;
    }

100
101
102
103
    public static function has_instance_config() {
        return true;
    }

Son Nguyen's avatar
Son Nguyen committed
104
    public static function instance_config_form(BlockInstance $instance) {
105
        global $USER;
106
        safe_require('artefact', 'blog');
107
        $configdata = $instance->get('configdata');
108
109
110
111
112
113
114

        if (!empty($configdata['artefactid'])) {
            $blog = $instance->get_artefact_instance($configdata['artefactid']);
        }

        $elements = array();

Aaron Wells's avatar
Aaron Wells committed
115
116
117
118
        // If the blog post in this block is owned by the owner of the View,
        // then the block can be configured. Otherwise, the blog post was
        // copied in from another View. We won't confuse users by asking them to
        // choose a blog post to put in this block, when the one that is
119
120
        // currently in it isn't choosable.
        //
Aaron Wells's avatar
Aaron Wells committed
121
        // Note: the owner check will have to change when we do group/site
122
123
        // blogs
        if (empty($configdata['artefactid']) || $blog->get('owner') == $USER->get('id')) {
124
125
126
127
128
129
            $publishedposts = get_column_sql('
                SELECT a.id
                FROM {artefact} a
                    INNER JOIN {artefact_blog_blogpost} p ON p.blogpost = a.id
                WHERE p.published = 1 AND a.owner= ?', array($USER->get('id')));
            $elements[] = self::artefactchooser_element((isset($configdata['artefactid'])) ? $configdata['artefactid'] : null, $publishedposts);
130
            $elements[] = PluginArtefactBlog::block_advanced_options_element($configdata, 'blogpost');
131
132
133
134
135
136
137
138
139
        }
        else {
            $elements[] = array(
                'type' => 'html',
                'name' => 'notice',
                'value' => '<div class="message">' . get_string('blogcopiedfromanotherview', 'artefact.blog', get_string('blogpost', 'artefact.blog')) . '</div>',
            );
        }
        return $elements;
140
141
    }

142
    public static function artefactchooser_element($default=null, $publishedposts=array()) {
143
        $element = array(
144
145
146
            'name'  => 'artefactid',
            'type'  => 'artefactchooser',
            'title' => get_string('blogpost', 'artefact.blog'),
147
            'description' => get_string('choosepublishedblogpostsdescription', 'blocktype.blog/blogpost'),
148
149
            'defaultvalue' => $default,
            'blocktype' => 'blogpost',
150
            'limit'     => 10,
151
152
153
            'selectone' => true,
            'artefacttypes' => array('blogpost'),
            'template'  => 'artefact:blog:artefactchooser-element.tpl',
154
            'extraselect' => !empty($publishedposts) ? array(array('fieldname' => 'id', 'type' => 'int', 'values' => $publishedposts)) : null,
155
        );
156
        return $element;
157
    }
158
159

    /**
Aaron Wells's avatar
Aaron Wells committed
160
     * Optional method. If specified, allows the blocktype class to munge the
161
162
163
164
165
166
167
168
169
     * artefactchooser element data before it's templated
     */
    public static function artefactchooser_get_element_data($artefact) {
        static $blognames = array();

        if (!isset($blognames[$artefact->parent])) {
            $blognames[$artefact->parent] = get_field('artefact', 'title', 'id', $artefact->parent);
        }
        $artefact->blog = $blognames[$artefact->parent];
170
        $artefact->description = str_shorten_html($artefact->description, 50, true);
171
172
173
174
175
176
177
178
179
180

        return $artefact;
    }

    /**
     * Optional method. If specified, changes the order in which the artefacts are sorted in the artefact chooser.
     *
     * This is a valid SQL string for the ORDER BY clause. Fields you can sort on are as per the artefact table
     */
    public static function artefactchooser_get_sort_order() {
181
182
        return array(array('fieldname' => 'parent'),
                     array('fieldname' => 'ctime', 'order' => 'DESC'));
183
    }
Richard Mansfield's avatar
Richard Mansfield committed
184

185
186
187
188
    public static function default_copy_type() {
        return 'nocopy';
    }

189
    /**
Aaron Wells's avatar
Aaron Wells committed
190
     * Blogpost blocktype is only allowed in personal views, because currently
191
192
193
194
195
196
     * there's no such thing as group/site blogs
     */
    public static function allowed_in_view(View $view) {
        return $view->get('owner') != null;
    }

197
}