Dotclear

source: admin/blog_pref.php @ 3982:2e148694914d

Revision 3982:2e148694914d, 36.9 KB checked in by franck <carnet.franck.paul@…>, 6 years ago (diff)

Switching from inline JS variables to JSON script, blog parameters page

Line 
1<?php
2/**
3 * @package Dotclear
4 * @subpackage Backend
5 *
6 * @copyright Olivier Meunier & Association Dotclear
7 * @copyright GPL-2.0-only
8 */
9
10$standalone = !isset($edit_blog_mode);
11
12$blog_id = false;
13
14if ($standalone) {
15    require dirname(__FILE__) . '/../inc/admin/prepend.php';
16    dcPage::check('admin');
17    $blog_id       = $core->blog->id;
18    $blog_status   = $core->blog->status;
19    $blog_name     = $core->blog->name;
20    $blog_desc     = $core->blog->desc;
21    $blog_settings = $core->blog->settings;
22    $blog_url      = $core->blog->url;
23
24    $action = $core->adminurl->get("admin.blog.pref");
25    $redir  = $core->adminurl->get("admin.blog.pref");
26} else {
27    dcPage::checkSuper();
28    try
29    {
30        if (empty($_REQUEST['id'])) {
31            throw new Exception(__('No given blog id.'));
32        }
33        $rs = $core->getBlog($_REQUEST['id']);
34
35        if (!$rs) {
36            throw new Exception(__('No such blog.'));
37        }
38
39        $blog_id       = $rs->blog_id;
40        $blog_status   = $rs->blog_status;
41        $blog_name     = $rs->blog_name;
42        $blog_desc     = $rs->blog_desc;
43        $blog_settings = new dcSettings($core, $blog_id);
44        $blog_url      = $rs->blog_url;
45    } catch (Exception $e) {
46        $core->error->add($e->getMessage());
47    }
48
49    $action = $core->adminurl->get("admin.blog");
50    $redir  = $core->adminurl->get("admin.blog", ['id' => "%s"], '&', true);
51}
52
53# Language codes
54$lang_combo = dcAdminCombos::getAdminLangsCombo();
55
56# Status combo
57$status_combo = dcAdminCombos::getBlogStatusescombo();
58
59# Date format combo
60$now                = time();
61$date_formats       = $blog_settings->system->date_formats;
62$time_formats       = $blog_settings->system->time_formats;
63$date_formats_combo = ['' => ''];
64foreach ($date_formats as $format) {
65    $date_formats_combo[dt::str($format, $now)] = $format;
66}
67$time_formats_combo = ['' => ''];
68foreach ($time_formats as $format) {
69    $time_formats_combo[dt::str($format, $now)] = $format;
70}
71
72# URL scan modes
73$url_scan_combo = [
74    'PATH_INFO'    => 'path_info',
75    'QUERY_STRING' => 'query_string'
76];
77
78# Post URL combo
79$post_url_combo = [
80    __('year/month/day/title') => '{y}/{m}/{d}/{t}',
81    __('year/month/title')     => '{y}/{m}/{t}',
82    __('year/title')           => '{y}/{t}',
83    __('title')                => '{t}',
84    __('post id/title')        => '{id}/{t}',
85    __('post id')              => '{id}'
86];
87if (!in_array($blog_settings->system->post_url_format, $post_url_combo)) {
88    $post_url_combo[html::escapeHTML($blog_settings->system->post_url_format)] = html::escapeHTML($blog_settings->system->post_url_format);
89}
90
91# Note title tag combo
92$note_title_tag_combo = [
93    __('H4') => 0,
94    __('H3') => 1,
95    __('P')  => 2
96];
97
98# Image title combo
99$img_title_combo = [
100    __('(none)')                     => '',
101    __('Title')                      => 'Title ;; separator(, )',
102    __('Title, Date')                => 'Title ;; Date(%b %Y) ;; separator(, )',
103    __('Title, Country, Date')       => 'Title ;; Country ;; Date(%b %Y) ;; separator(, )',
104    __('Title, City, Country, Date') => 'Title ;; City ;; Country ;; Date(%b %Y) ;; separator(, )'
105];
106if (!in_array($blog_settings->system->media_img_title_pattern, $img_title_combo)) {
107    $img_title_combo[html::escapeHTML($blog_settings->system->media_img_title_pattern)] = html::escapeHTML($blog_settings->system->media_img_title_pattern);
108}
109
110# Image default size combo
111$img_default_size_combo = [];
112try {
113    $media                                  = new dcMedia($core);
114    $img_default_size_combo[__('original')] = 'o';
115    foreach ($media->thumb_sizes as $code => $size) {
116        $img_default_size_combo[__($size[2])] = $code;
117    }
118} catch (Exception $e) {
119    $core->error->add($e->getMessage());
120}
121
122# Image default alignment combo
123$img_default_alignment_combo = [
124    __('None')   => 'none',
125    __('Left')   => 'left',
126    __('Right')  => 'right',
127    __('Center') => 'center'
128];
129
130# Image default legend and title combo
131$img_default_legend_combo = [
132    __('Legend and title') => 'legend',
133    __('Title')            => 'title',
134    __('None')             => 'none'
135];
136
137# Robots policy options
138$robots_policy_options = [
139    'INDEX,FOLLOW'               => __("I would like search engines and archivers to index and archive my blog's content."),
140    'INDEX,FOLLOW,NOARCHIVE'     => __("I would like search engines and archivers to index but not archive my blog's content."),
141    'NOINDEX,NOFOLLOW,NOARCHIVE' => __("I would like to prevent search engines and archivers from indexing or archiving my blog's content.")
142];
143
144# jQuery available versions
145$jquery_root           = dirname(__FILE__) . '/../inc/js/jquery';
146$jquery_versions_combo = [__('Default') . ' (' . DC_DEFAULT_JQUERY . ')' => DC_DEFAULT_JQUERY];
147if (is_dir($jquery_root) && is_readable($jquery_root)) {
148    if (($d = @dir($jquery_root)) !== false) {
149        while (($entry = $d->read()) !== false) {
150            if ($entry != '.' && $entry != '..' && substr($entry, 0, 1) != '.' && is_dir($jquery_root . '/' . $entry)) {
151                if ($entry != DC_DEFAULT_JQUERY) {
152                    $jquery_versions_combo[$entry] = $entry;
153                }
154            }
155        }
156    }
157}
158
159# Update a blog
160if ($blog_id && !empty($_POST) && $core->auth->check('admin', $blog_id)) {
161    $cur            = $core->con->openCursor($core->prefix . 'blog');
162    $cur->blog_id   = $_POST['blog_id'];
163    $cur->blog_url  = preg_replace('/\?+$/', '?', $_POST['blog_url']);
164    $cur->blog_name = $_POST['blog_name'];
165    $cur->blog_desc = $_POST['blog_desc'];
166
167    if ($core->auth->isSuperAdmin() && in_array($_POST['blog_status'], $status_combo)) {
168        $cur->blog_status = (int) $_POST['blog_status'];
169    }
170
171    $media_img_t_size = (integer) $_POST['media_img_t_size'];
172    if ($media_img_t_size < 0) {$media_img_t_size = 100;}
173
174    $media_img_s_size = (integer) $_POST['media_img_s_size'];
175    if ($media_img_s_size < 0) {$media_img_s_size = 240;}
176
177    $media_img_m_size = (integer) $_POST['media_img_m_size'];
178    if ($media_img_m_size < 0) {$media_img_m_size = 448;}
179
180    $media_video_width = (integer) $_POST['media_video_width'];
181    if ($media_video_width < 0) {$media_video_width = 400;}
182
183    $media_video_height = (integer) $_POST['media_video_height'];
184    if ($media_video_height < 0) {$media_video_height = 300;}
185
186    $nb_post_for_home = abs((integer) $_POST['nb_post_for_home']);
187    if ($nb_post_for_home < 1) {$nb_post_for_home = 1;}
188
189    $nb_post_per_page = abs((integer) $_POST['nb_post_per_page']);
190    if ($nb_post_per_page < 1) {$nb_post_per_page = 1;}
191
192    $nb_post_per_feed = abs((integer) $_POST['nb_post_per_feed']);
193    if ($nb_post_per_feed < 1) {$nb_post_per_feed = 1;}
194
195    $nb_comment_per_feed = abs((integer) $_POST['nb_comment_per_feed']);
196    if ($nb_comment_per_feed < 1) {$nb_comment_per_feed = 1;}
197
198    try
199    {
200        if ($cur->blog_id != null && $cur->blog_id != $blog_id) {
201            $rs = $core->getBlog($cur->blog_id);
202
203            if ($rs) {
204                throw new Exception(__('This blog ID is already used.'));
205            }
206        }
207
208        # --BEHAVIOR-- adminBeforeBlogUpdate
209        $core->callBehavior('adminBeforeBlogUpdate', $cur, $blog_id);
210
211        if (!preg_match('/^[a-z]{2}(-[a-z]{2})?$/', $_POST['lang'])) {
212            throw new Exception(__('Invalid language code'));
213        }
214
215        $core->updBlog($blog_id, $cur);
216
217        # --BEHAVIOR-- adminAfterBlogUpdate
218        $core->callBehavior('adminAfterBlogUpdate', $cur, $blog_id);
219
220        if ($cur->blog_id != null && $cur->blog_id != $blog_id) {
221            if ($blog_id == $core->blog->id) {
222                $core->setBlog($cur->blog_id);
223                $_SESSION['sess_blog_id'] = $cur->blog_id;
224                $blog_settings            = $core->blog->settings;
225            } else {
226                $blog_settings = new dcSettings($core, $cur->blog_id);
227            }
228
229            $blog_id = $cur->blog_id;
230        }
231
232        $blog_settings->addNameSpace('system');
233
234        $blog_settings->system->put('editor', $_POST['editor']);
235        $blog_settings->system->put('copyright_notice', $_POST['copyright_notice']);
236        $blog_settings->system->put('post_url_format', $_POST['post_url_format']);
237        $blog_settings->system->put('lang', $_POST['lang']);
238        $blog_settings->system->put('blog_timezone', $_POST['blog_timezone']);
239        $blog_settings->system->put('date_format', $_POST['date_format']);
240        $blog_settings->system->put('time_format', $_POST['time_format']);
241        $blog_settings->system->put('comments_ttl', abs((integer) $_POST['comments_ttl']));
242        $blog_settings->system->put('trackbacks_ttl', abs((integer) $_POST['trackbacks_ttl']));
243        $blog_settings->system->put('allow_comments', !empty($_POST['allow_comments']));
244        $blog_settings->system->put('allow_trackbacks', !empty($_POST['allow_trackbacks']));
245        $blog_settings->system->put('comments_pub', empty($_POST['comments_pub']));
246        $blog_settings->system->put('trackbacks_pub', empty($_POST['trackbacks_pub']));
247        $blog_settings->system->put('comments_nofollow', !empty($_POST['comments_nofollow']));
248        $blog_settings->system->put('wiki_comments', !empty($_POST['wiki_comments']));
249        $blog_settings->system->put('comment_preview_optional', !empty($_POST['comment_preview_optional']));
250        $blog_settings->system->put('enable_xmlrpc', !empty($_POST['enable_xmlrpc']));
251        $blog_settings->system->put('note_title_tag', $_POST['note_title_tag']);
252        $blog_settings->system->put('nb_post_for_home', $nb_post_for_home);
253        $blog_settings->system->put('nb_post_per_page', $nb_post_per_page);
254        $blog_settings->system->put('use_smilies', !empty($_POST['use_smilies']));
255        $blog_settings->system->put('no_search', !empty($_POST['no_search']));
256        $blog_settings->system->put('inc_subcats', !empty($_POST['inc_subcats']));
257        $blog_settings->system->put('media_img_t_size', $media_img_t_size);
258        $blog_settings->system->put('media_img_s_size', $media_img_s_size);
259        $blog_settings->system->put('media_img_m_size', $media_img_m_size);
260        $blog_settings->system->put('media_video_width', $media_video_width);
261        $blog_settings->system->put('media_video_height', $media_video_height);
262        $blog_settings->system->put('media_img_title_pattern', $_POST['media_img_title_pattern']);
263        $blog_settings->system->put('media_img_use_dto_first', !empty($_POST['media_img_use_dto_first']));
264        $blog_settings->system->put('media_img_no_date_alone', !empty($_POST['media_img_no_date_alone']));
265        $blog_settings->system->put('media_img_default_size', $_POST['media_img_default_size']);
266        $blog_settings->system->put('media_img_default_alignment', $_POST['media_img_default_alignment']);
267        $blog_settings->system->put('media_img_default_link', !empty($_POST['media_img_default_link']));
268        $blog_settings->system->put('media_img_default_legend', $_POST['media_img_default_legend']);
269        $blog_settings->system->put('nb_post_per_feed', $nb_post_per_feed);
270        $blog_settings->system->put('nb_comment_per_feed', $nb_comment_per_feed);
271        $blog_settings->system->put('short_feed_items', !empty($_POST['short_feed_items']));
272        if (isset($_POST['robots_policy'])) {
273            $blog_settings->system->put('robots_policy', $_POST['robots_policy']);
274        }
275        $blog_settings->system->put('jquery_version', $_POST['jquery_version']);
276        $blog_settings->system->put('prevents_clickjacking', !empty($_POST['prevents_clickjacking']));
277
278        # --BEHAVIOR-- adminBeforeBlogSettingsUpdate
279        $core->callBehavior('adminBeforeBlogSettingsUpdate', $blog_settings);
280
281        if ($core->auth->isSuperAdmin() && in_array($_POST['url_scan'], $url_scan_combo)) {
282            $blog_settings->system->put('url_scan', $_POST['url_scan']);
283        }
284        dcPage::addSuccessNotice(__('Blog has been successfully updated.'));
285
286        http::redirect(sprintf($redir, $blog_id));
287    } catch (Exception $e) {
288        $core->error->add($e->getMessage());
289    }
290}
291
292// Display
293
294if ($standalone) {
295    $breadcrumb = dcPage::breadcrumb(
296        [
297            html::escapeHTML($blog_name) => '',
298            __('Blog settings')          => ''
299        ]
300    );
301} else {
302    $breadcrumb = dcPage::breadcrumb(
303        [
304            __('System')                                               => '',
305            __('Blogs')                                                => $core->adminurl->get("admin.blogs"),
306            __('Blog settings') . ' : ' . html::escapeHTML($blog_name) => ''
307        ]);
308}
309
310$desc_editor = $core->auth->getOption('editor');
311$rte_flag    = true;
312$rte_flags   = @$core->auth->user_prefs->interface->rte_flags;
313if (is_array($rte_flags) && in_array('blog_descr', $rte_flags)) {
314    $rte_flag = $rte_flags['blog_descr'];
315}
316
317dcPage::open(__('Blog settings'),
318    dcPage::jsJson('blog_pref', [
319        'warning_path_info'    => __('Warning: except for special configurations, it is generally advised to have a trailing "/" in your blog URL in PATH_INFO mode.'),
320        'warning_query_string' => __('Warning: except for special configurations, it is generally advised to have a trailing "?" in your blog URL in QUERY_STRING mode.')
321    ]) .
322    dcPage::jsConfirmClose('blog-form') .
323    ($rte_flag ? $core->callBehavior('adminPostEditor', $desc_editor['xhtml'], 'blog_desc', ['#blog_desc'], 'xhtml') : '') .
324    dcPage::jsLoad('js/_blog_pref.js') .
325
326    # --BEHAVIOR-- adminBlogPreferencesHeaders
327    $core->callBehavior('adminBlogPreferencesHeaders') .
328
329    dcPage::jsPageTabs(),
330    $breadcrumb
331);
332
333if ($blog_id) {
334    if (!empty($_GET['add'])) {
335        dcPage::success(__('Blog has been successfully created.'));
336    }
337
338    if (!empty($_GET['upd'])) {
339        dcPage::success(__('Blog has been successfully updated.'));
340    }
341
342    echo
343    '<div class="multi-part" id="params" title="' . __('Parameters') . '">' .
344    '<div id="standard-pref"><h3>' . __('Blog parameters') . '</h3>' .
345        '<form action="' . $action . '" method="post" id="blog-form">';
346
347    echo
348    '<div class="fieldset"><h4>' . __('Blog details') . '</h4>' .
349    $core->formNonce();
350
351    echo
352    '<p><label for="blog_name" class="required"><abbr title="' . __('Required field') . '">*</abbr> ' . __('Blog name:') . '</label>' .
353    form::field('blog_name', 30, 255,
354        [
355            'default'    => html::escapeHTML($blog_name),
356            'extra_html' => 'required placeholder="' . __('Blog name') . ' lang="' . $blog_settings->system->lang .
357            '" spellcheck="true"'
358        ]
359    ) . '</p>';
360
361    echo
362    '<p class="area"><label for="blog_desc">' . __('Blog description:') . '</label>' .
363    form::textarea('blog_desc', 60, 5,
364        [
365            'default'    => html::escapeHTML($blog_desc),
366            'extra_html' => 'lang="' . $blog_settings->system->lang . '" spellcheck="true"'
367        ]) . '</p>';
368
369    if ($core->auth->isSuperAdmin()) {
370        echo
371        '<p><label for="blog_status">' . __('Blog status:') . '</label>' .
372        form::combo('blog_status', $status_combo, $blog_status) . '</p>';
373
374    } else {
375        /*
376        Only super admins can change the blog ID and URL, but we need to pass
377        their values to the POST request via hidden html input values  so as
378        to allow admins to update other settings.
379        Otherwise dcCore::getBlogCursor() throws an exception.
380         */
381        echo
382        form::hidden('blog_id', html::escapeHTML($blog_id)) .
383        form::hidden('blog_url', html::escapeHTML($blog_url));
384    }
385
386    echo '</div>';
387
388    echo
389    '<div class="fieldset"><h4>' . __('Blog configuration') . '</h4>' .
390
391    '<p><label for="editor">' . __('Blog editor name:') . '</label>' .
392    form::field('editor', 30, 255, html::escapeHTML($blog_settings->system->editor)) .
393    '</p>' .
394
395    '<p><label for="lang">' . __('Default language:') . '</label>' .
396    form::combo('lang', $lang_combo, $blog_settings->system->lang, 'l10n') .
397    '</p>' .
398
399    '<p><label for="blog_timezone">' . __('Blog timezone:') . '</label>' .
400    form::combo('blog_timezone', dt::getZones(true, true), html::escapeHTML($blog_settings->system->blog_timezone)) .
401    '</p>' .
402
403    '<p><label for="copyright_notice">' . __('Copyright notice:') . '</label>' .
404    form::field('copyright_notice', 30, 255,
405        [
406            'default'    => html::escapeHTML($blog_settings->system->copyright_notice),
407            'extra_html' => 'lang="' . $blog_settings->system->lang . '" spellcheck="true"'
408        ]) .
409        '</p>' .
410
411        '</div>';
412
413    echo
414    '<div class="fieldset"><h4>' . __('Comments and trackbacks') . '</h4>' .
415
416    '<div class="two-cols">' .
417
418    '<div class="col">' .
419    '<p><label for="allow_comments" class="classic">' .
420    form::checkbox('allow_comments', '1', $blog_settings->system->allow_comments) .
421    __('Accept comments') . '</label></p>' .
422    '<p><label for="comments_pub" class="classic">' .
423    form::checkbox('comments_pub', '1', !$blog_settings->system->comments_pub) .
424    __('Moderate comments') . '</label></p>' .
425    '<p><label for="comments_ttl" class="classic">' . sprintf(__('Leave comments open for %s days') . '.',
426        form::number('comments_ttl', [
427            'min'     => 0,
428            'max'     => 999,
429            'default' => $blog_settings->system->comments_ttl]
430        )) .
431    '</label></p>' .
432    '<p class="form-note">' . __('No limit: leave blank.') . '</p>' .
433    '<p><label for="wiki_comments" class="classic">' .
434    form::checkbox('wiki_comments', '1', $blog_settings->system->wiki_comments) .
435    __('Wiki syntax for comments') . '</label></p>' .
436    '<p><label for="comment_preview_optional" class="classic">' .
437    form::checkbox('comment_preview_optional', '1', $blog_settings->system->comment_preview_optional) .
438    __('Preview of comment before submit is not mandatory') . '</label></p>' .
439    '</div>' .
440
441    '<div class="col">' .
442    '<p><label for="allow_trackbacks" class="classic">' .
443    form::checkbox('allow_trackbacks', '1', $blog_settings->system->allow_trackbacks) .
444    __('Accept trackbacks') . '</label></p>' .
445    '<p><label for="trackbacks_pub" class="classic">' .
446    form::checkbox('trackbacks_pub', '1', !$blog_settings->system->trackbacks_pub) .
447    __('Moderate trackbacks') . '</label></p>' .
448    '<p><label for="trackbacks_ttl" class="classic">' . sprintf(__('Leave trackbacks open for %s days') . '.',
449        form::number('trackbacks_ttl', [
450            'min'     => 0,
451            'max'     => 999,
452            'default' => $blog_settings->system->trackbacks_ttl]
453        )) .
454    '</label></p>' .
455    '<p class="form-note">' . __('No limit: leave blank.') . '</p>' .
456    '<p><label for="comments_nofollow" class="classic">' .
457    form::checkbox('comments_nofollow', '1', $blog_settings->system->comments_nofollow) .
458    __('Add "nofollow" relation on comments and trackbacks links') . '</label></p>' .
459    '</div>' .
460    '<br class="clear" />' . //Opera sucks
461
462    '</div>' .
463    '<br class="clear" />' . //Opera sucks
464    '</div>';
465
466    echo
467    '<div class="fieldset"><h4>' . __('Blog presentation') . '</h4>' .
468    '<div class="two-cols">' .
469    '<div class="col">' .
470    '<p><label for="date_format">' . __('Date format:') . '</label> ' .
471    form::field('date_format', 30, 255, html::escapeHTML($blog_settings->system->date_format)) .
472    form::combo('date_format_select', $date_formats_combo, ['extra_html' => 'title="' . __('Pattern of date') . '"']) .
473    '</p>' .
474    '<p class="chosen form-note">' . __('Sample:') . ' ' . dt::str(html::escapeHTML($blog_settings->system->date_format)) . '</p>' .
475
476    '<p><label for="time_format">' . __('Time format:') . '</label>' .
477    form::field('time_format', 30, 255, html::escapeHTML($blog_settings->system->time_format)) .
478    form::combo('time_format_select', $time_formats_combo, ['extra_html' => 'title="' . __('Pattern of time') . '"']) .
479    '</p>' .
480    '<p class="chosen form-note">' . __('Sample:') . ' ' . dt::str(html::escapeHTML($blog_settings->system->time_format)) . '</p>' .
481
482    '<p><label for="use_smilies" class="classic">' .
483    form::checkbox('use_smilies', '1', $blog_settings->system->use_smilies) .
484    __('Display smilies on entries and comments') . '</label></p>' .
485
486    '<p><label for="no_search" class="classic">' .
487    form::checkbox('no_search', '1', $blog_settings->system->no_search) .
488    __('Disable internal search system') . '</label></p>' .
489    '</div>' .
490
491    '<div class="col">' .
492    '<p><label for="nb_post_for_home" class="classic">' . sprintf(__('Display %s entries on home page'),
493        form::number('nb_post_for_home', [
494            'min'     => 1,
495            'max'     => 999,
496            'default' => $blog_settings->system->nb_post_for_home]
497        )) .
498    '</label></p>' .
499
500    '<p><label for="nb_post_per_page" class="classic">' . sprintf(__('Display %s entries per page'),
501        form::number('nb_post_per_page', [
502            'min'     => 1,
503            'max'     => 999,
504            'default' => $blog_settings->system->nb_post_per_page]
505        )) .
506    '</label></p>' .
507
508    '<p><label for="nb_post_per_feed" class="classic">' . sprintf(__('Display %s entries per feed'),
509        form::number('nb_post_per_feed', [
510            'min'     => 1,
511            'max'     => 999,
512            'default' => $blog_settings->system->nb_post_per_feed]
513        )) .
514    '</label></p>' .
515
516    '<p><label for="nb_comment_per_feed" class="classic">' . sprintf(__('Display %s comments per feed'),
517        form::number('nb_comment_per_feed', [
518            'min'     => 1,
519            'max'     => 999,
520            'default' => $blog_settings->system->nb_comment_per_feed]
521        )) .
522    '</label></p>' .
523
524    '<p><label for="short_feed_items" class="classic">' .
525    form::checkbox('short_feed_items', '1', $blog_settings->system->short_feed_items) .
526    __('Truncate feeds') . '</label></p>' .
527
528    '<p><label for="inc_subcats" class="classic">' .
529    form::checkbox('inc_subcats', '1', $blog_settings->system->inc_subcats) .
530    __('Include sub-categories in category page and category posts feed') . '</label></p>' .
531    '</div>' .
532    '</div>' .
533    '<br class="clear" />' . //Opera sucks
534    '</div>';
535
536    echo
537    '<div class="fieldset"><h4 id="medias-settings">' . __('Media and images') . '</h4>' .
538    '<p class="form-note warning">' .
539    __('Please note that if you change current settings bellow, they will now apply to all new images in the media manager.') .
540    ' ' . __('Be carefull if you share it with other blogs in your installation.') . '<br />' .
541    __('Set -1 to use the default size, set 0 to ignore this thumbnail size (images only).') . '</p>' .
542
543    '<div class="two-cols">' .
544    '<div class="col">' .
545    '<h5>' . __('Generated image sizes (max dimension in pixels)') . '</h5>' .
546    '<p class="field"><label for="media_img_t_size">' . __('Thumbnail') . '</label> ' .
547    form::number('media_img_t_size', [
548        'min'     => -1,
549        'max'     => 999,
550        'default' => $blog_settings->system->media_img_t_size
551    ]) .
552    '</p>' .
553
554    '<p class="field"><label for="media_img_s_size">' . __('Small') . '</label> ' .
555    form::number('media_img_s_size', [
556        'min'     => -1,
557        'max'     => 999,
558        'default' => $blog_settings->system->media_img_s_size
559    ]) .
560    '</p>' .
561
562    '<p class="field"><label for="media_img_m_size">' . __('Medium') . '</label> ' .
563    form::number('media_img_m_size', [
564        'min'     => -1,
565        'max'     => 999,
566        'default' => $blog_settings->system->media_img_m_size
567    ]) .
568    '</p>' .
569
570    '<h5>' . __('Default size of the inserted video (in pixels)') . '</h5>' .
571    '<p class="field"><label for="media_video_width">' . __('Width') . '</label> ' .
572    form::number('media_video_width', [
573        'min'     => -1,
574        'max'     => 999,
575        'default' => $blog_settings->system->media_video_width
576    ]) .
577    '</p>' .
578
579    '<p class="field"><label for="media_video_height">' . __('Height') . '</label> ' .
580    form::number('media_video_height', [
581        'min'     => -1,
582        'max'     => 999,
583        'default' => $blog_settings->system->media_video_height
584    ]) .
585    '</p>' .
586    '</div>' .
587
588    '<div class="col">' .
589    '<h5>' . __('Default image insertion attributes') . '</h5>' .
590    '<p class="vertical-separator"><label for="media_img_title_pattern">' . __('Inserted image title') . '</label>' .
591    form::combo('media_img_title_pattern', $img_title_combo, html::escapeHTML($blog_settings->system->media_img_title_pattern)) . '</p>' .
592    '<p><label for="media_img_use_dto_first" class="classic">' .
593    form::checkbox('media_img_use_dto_first', '1', $blog_settings->system->media_img_use_dto_first) .
594    __('Use original media date if possible') . '</label></p>' .
595    '<p><label for="media_img_no_date_alone" class="classic">' .
596    form::checkbox('media_img_no_date_alone', '1', $blog_settings->system->media_img_no_date_alone) .
597    __('Do not display date if alone in title') . '</label></p>' .
598    '<p class="form-note info">' . __('It is retrieved from the picture\'s metadata.') . '</p>' .
599
600    '<p class="field vertical-separator"><label for="media_img_default_size">' . __('Size of inserted image:') . '</label>' .
601    form::combo('media_img_default_size', $img_default_size_combo,
602        (html::escapeHTML($blog_settings->system->media_img_default_size) != '' ? html::escapeHTML($blog_settings->system->media_img_default_size) : 'm')) .
603    '</p>' .
604    '<p class="field"><label for="media_img_default_alignment">' . __('Image alignment:') . '</label>' .
605    form::combo('media_img_default_alignment', $img_default_alignment_combo, html::escapeHTML($blog_settings->system->media_img_default_alignment)) .
606    '</p>' .
607    '<p><label for="media_img_default_link">' .
608    form::checkbox('media_img_default_link', '1', $blog_settings->system->media_img_default_link) .
609    __('Insert a link to the original image') . '</label></p>' .
610    '<p class="field"><label for="media_img_default_legend">' . __('Image legend and title:') . '</label>' .
611    form::combo('media_img_default_legend', $img_default_legend_combo, html::escapeHTML($blog_settings->system->media_img_default_legend)) .
612    '</p>' .
613    '</div>' .
614    '</div>' .
615    '<br class="clear" />' . //Opera sucks
616
617    '</div>' .
618        '</div>';
619
620    echo '<div id="advanced-pref"><h3>' . __('Advanced parameters') . '</h3>';
621
622    if ($core->auth->isSuperAdmin()) {
623        echo '<div class="fieldset"><h4>' . __('Blog details') . '</h4>';
624        echo
625        '<p><label for="blog_id" class="required"><abbr title="' . __('Required field') . '">*</abbr> ' . __('Blog ID:') . '</label>' .
626        form::field('blog_id', 30, 32, html::escapeHTML($blog_id), '', '', false, 'required placeholder="' . __('Blog ID') . '"') . '</p>' .
627        '<p class="form-note">' . __('At least 2 characters using letters, numbers or symbols.') . '</p> ' .
628        '<p class="form-note warn">' . __('Please note that changing your blog ID may require changes in your public index.php file.') . '</p>';
629
630        echo
631        '<p><label for="blog_url" class="required"><abbr title="' . __('Required field') . '">*</abbr> ' . __('Blog URL:') . '</label>' .
632        form::url('blog_url', [
633            'size'       => 50,
634            'max'        => 255,
635            'default'    => html::escapeHTML($blog_url),
636            'extra_html' => 'required placeholder="' . __('Blog URL') . '"'
637        ]) .
638        '</p>' .
639
640        '<p><label for="url_scan">' . __('URL scan method:') . '</label>' .
641        form::combo('url_scan', $url_scan_combo, $blog_settings->system->url_scan) . '</p>';
642
643        try
644        {
645            # Test URL of blog by testing it's ATOM feed
646            $file    = $blog_url . $core->url->getURLFor('feed', 'atom');
647            $path    = '';
648            $status  = '404';
649            $content = '';
650
651            $client = netHttp::initClient($file, $path);
652            if ($client !== false) {
653                $client->setTimeout(4);
654                $client->setUserAgent($_SERVER['HTTP_USER_AGENT']);
655                $client->get($path);
656                $status  = $client->getStatus();
657                $content = $client->getContent();
658            }
659            if ($status != '200') {
660                // Might be 404 (URL not found), 670 (blog not online), ...
661                echo
662                '<p class="form-note warn">' .
663                sprintf(__('The URL of blog or the URL scan method might not be well set (<code>%s</code> return a <strong>%s</strong> status).'),
664                    html::escapeHTML($file), $status) .
665                    '</p>';
666            } else {
667                if (substr($content, 0, 6) != '<?xml ') {
668                    // Not well formed XML feed
669                    echo
670                    '<p class="form-note warn">' .
671                    sprintf(__('The URL of blog or the URL scan method might not be well set (<code>%s</code> does not return an ATOM feed).'),
672                        html::escapeHTML($file)) .
673                        '</p>';
674                }
675            }
676        } catch (Exception $e) {
677            $core->error->add($e->getMessage());
678        }
679        echo '</div>';
680    }
681
682    echo
683    '<div class="fieldset"><h4>' . __('Blog configuration') . '</h4>' .
684
685    '<p><label for="post_url_format">' . __('New post URL format:') . '</label>' .
686    form::combo('post_url_format', $post_url_combo, html::escapeHTML($blog_settings->system->post_url_format)) .
687    '</p>' .
688    '<p class="chosen form-note">' . __('Sample:') . ' ' . $core->blog->getPostURL('', date('Y-m-d H:i:00', $now), __('Dotclear'), 42) . '</p>' .
689    '</p>' .
690
691    '<p><label for="note_title_tag">' . __('HTML tag for the title of the notes on the blog:') . '</label>' .
692    form::combo('note_title_tag', $note_title_tag_combo, $blog_settings->system->note_title_tag) .
693    '</p>' .
694
695    '<p><label for="enable_xmlrpc" class="classic">' .
696    form::checkbox('enable_xmlrpc', '1', $blog_settings->system->enable_xmlrpc) .
697    __('Enable XML/RPC interface') . '</label>' . '</p>' .
698    '<p class="form-note info">' . __('XML/RPC interface allows you to edit your blog with an external client.') . '</p>';
699
700    if ($blog_settings->system->enable_xmlrpc) {
701        echo
702        '<p>' . __('XML/RPC interface is active. You should set the following parameters on your XML/RPC client:') . '</p>' .
703        '<ul>' .
704        '<li>' . __('Server URL:') . ' <strong><code>' .
705        sprintf(DC_XMLRPC_URL, $core->blog->url, $core->blog->id) .
706        '</code></strong></li>' .
707        '<li>' . __('Blogging system:') . ' <strong><code>Movable Type</code></strong></li>' .
708        '<li>' . __('User name:') . ' <strong><code>' . $core->auth->userID() . '</code></strong></li>' .
709        '<li>' . __('Password:') . ' <strong><code>&lt;' . __('your password') . '&gt;</code></strong></li>' .
710        '<li>' . __('Blog ID:') . ' <strong><code>1</code></strong></li>' .
711            '</ul>';
712    }
713
714    echo
715        '</div>';
716
717    // Search engines policies
718    echo '<div class="fieldset"><h4>' . __('Search engines robots policy') . '</h4>';
719
720    $i = 0;
721    foreach ($robots_policy_options as $k => $v) {
722        echo '<p><label for="robots_policy-' . $i . '" class="classic">' .
723        form::radio(['robots_policy', 'robots_policy-' . $i], $k, $blog_settings->system->robots_policy == $k) . ' ' . $v . '</label></p>';
724        $i++;
725    }
726
727    echo '</div>';
728
729    echo '<div class="fieldset"><h4>' . __('jQuery javascript library') . '</h4>' .
730
731    '<p><label for="jquery_version" class="classic">' . __('jQuery version to be loaded for this blog:') . '</label>' . ' ' .
732    form::combo('jquery_version', $jquery_versions_combo, $blog_settings->system->jquery_version) .
733    '</p>' .
734    '<br class="clear" />' . //Opera sucks
735
736    '</div>';
737
738    echo '<div class="fieldset"><h4>' . __('Blog security') . '</h4>' .
739
740    '<p><label for="prevents_clickjacking" class="classic">' .
741    form::checkbox('prevents_clickjacking', '1', $blog_settings->system->prevents_clickjacking) .
742    __('Protect the blog from Clickjacking (see <a href="https://en.wikipedia.org/wiki/Clickjacking">Wikipedia</a>)') . '</label></p>' .
743    '<br class="clear" />' . //Opera sucks
744
745    '</div>';
746
747    echo '</div>'; // End advanced
748
749    echo '<div id="plugins-pref"><h3>' . __('Plugins parameters') . '</h3>';
750
751    # --BEHAVIOR-- adminBlogPreferencesForm
752    $core->callBehavior('adminBlogPreferencesForm', $core, $blog_settings);
753
754    echo '</div>'; // End 3rd party, aka plugins
755
756    echo
757    '<p><input type="submit" accesskey="s" value="' . __('Save') . '" />' .
758        (!$standalone ? form::hidden('id', $blog_id) : '') .
759        '</p>' .
760        '</form>';
761
762    if ($core->auth->isSuperAdmin() && $blog_id != $core->blog->id) {
763        echo
764        '<form action="' . $core->adminurl->get("admin.blog.del") . '" method="post">' .
765        '<p><input type="submit" class="delete" value="' . __('Delete this blog') . '" />' .
766        form::hidden(['blog_id'], $blog_id) .
767        $core->formNonce() . '</p>' .
768            '</form>';
769    } else {
770        if ($blog_id == $core->blog->id) {
771            echo '<p class="message">' . __('The current blog cannot be deleted.') . '</p>';
772        } else {
773            echo '<p class="message">' . __('Only superadmin can delete a blog.') . '</p>';
774        }
775    }
776
777    echo '</div>';
778
779    #
780    # Users on the blog (with permissions)
781
782    $blog_users = $core->getBlogPermissions($blog_id, $core->auth->isSuperAdmin());
783    $perm_types = $core->auth->getPermissionsTypes();
784
785    echo
786    '<div class="multi-part" id="users" title="' . __('Users') . '">' .
787    '<h3 class="out-of-screen-if-js">' . __('Users on this blog') . '</h3>';
788
789    if (empty($blog_users)) {
790        echo '<p>' . __('No users') . '</p>';
791    } else {
792        if ($core->auth->isSuperAdmin()) {
793            $user_url_p = '<a href="' . $core->adminurl->get("admin.user", ['id' => '%1$s'], '&amp;', true) . '">%1$s</a>';
794        } else {
795            $user_url_p = '%1$s';
796        }
797
798        # Sort users list on user_id key
799        dcUtils::lexicalKeySort($blog_users);
800
801        $post_type       = $core->getPostTypes();
802        $current_blog_id = $core->blog->id;
803        if ($blog_id != $core->blog->id) {
804            $core->setBlog($blog_id);
805        }
806
807        echo '<div>';
808        foreach ($blog_users as $k => $v) {
809            if (count($v['p']) > 0) {
810                echo
811                '<div class="user-perm' . ($v['super'] ? ' user_super' : '') . '">' .
812                '<h4>' . sprintf($user_url_p, html::escapeHTML($k)) .
813                ' (' . html::escapeHTML(dcUtils::getUserCN(
814                    $k, $v['name'], $v['firstname'], $v['displayname']
815                )) . ')</h4>';
816
817                if ($core->auth->isSuperAdmin()) {
818                    echo
819                    '<p>' . __('Email:') . ' ' .
820                        ($v['email'] != '' ? '<a href="mailto:' . $v['email'] . '">' . $v['email'] . '</a>' : __('(none)')) .
821                        '</p>';
822                }
823
824                echo
825                '<h5>' . __('Publications on this blog:') . '</h5>' .
826                    '<ul>';
827                foreach ($post_type as $type => $pt_info) {
828                    $params = [
829                        'post_type' => $type,
830                        'user_id'   => $k
831                    ];
832                    echo '<li>' . sprintf(__('%1$s: %2$s'), __($pt_info['label']), $core->blog->getPosts($params, true)->f(0)) . '</li>';
833                }
834                echo
835                    '</ul>';
836
837                echo
838                '<h5>' . __('Permissions:') . '</h5>' .
839                    '<ul>';
840                if ($v['super']) {
841                    echo '<li class="user_super">' . __('Super administrator') . '<br />' .
842                    '<span class="form-note">' . __('All rights on all blogs.') . '</span></li>';
843                } else {
844                    foreach ($v['p'] as $p => $V) {
845                        if (isset($perm_types[$p])) {
846                            echo '<li ' . ($p == 'admin' ? 'class="user_admin"' : '') . '>' . __($perm_types[$p]);
847                        } else {
848                            echo '<li>' . sprintf(__('[%s] (unreferenced permission)'), $p);
849                        }
850
851                        if ($p == 'admin') {
852                            echo '<br /><span class="form-note">' . __('All rights on this blog.') . '</span>';
853                        }
854                        echo '</li>';
855                    }
856                }
857                echo
858                    '</ul>';
859
860                if (!$v['super'] && $core->auth->isSuperAdmin()) {
861                    echo
862                    '<form action="' . $core->adminurl->get('admin.user.actions') . '" method="post">' .
863                    '<p class="change-user-perm"><input type="submit" class="reset" value="' . __('Change permissions') . '" />' .
864                    form::hidden(['redir'], $core->adminurl->get("admin.blog.pref", ['id' => $k], '&')) .
865                    form::hidden(['action'], 'perms') .
866                    form::hidden(['users[]'], $k) .
867                    form::hidden(['blogs[]'], $blog_id) .
868                    $core->formNonce() .
869                        '</p>' .
870                        '</form>';
871                }
872                echo '</div>';
873            }
874        }
875        echo '</div>';
876        if ($current_blog_id != $core->blog->id) {
877            $core->setBlog($current_blog_id);
878        }
879    }
880
881    echo '</div>';
882}
883
884dcPage::helpBlock('core_blog_pref');
885dcPage::close();
Note: See TracBrowser for help on using the repository browser.

Sites map