2 // This file is part of Moodle - http://moodle.org/
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
18 * Output rendering of Language customization admin tool
21 * @subpackage customlang
22 * @copyright 2010 David Mudrak <david@moodle.com>
23 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
26 defined('MOODLE_INTERNAL') ||
die();
29 * Rendering methods for the tool widgets
31 class tool_customlang_renderer
extends plugin_renderer_base
{
34 * Renders customlang tool menu
38 protected function render_tool_customlang_menu(tool_customlang_menu
$menu) {
40 foreach ($menu->get_items() as $item) {
41 $output .= $this->single_button($item->url
, $item->title
, $item->method
);
43 return $this->box($output, 'menu');
47 * Renders customlang translation table
49 * @param tool_customlang_translator $translator
52 protected function render_tool_customlang_translator(tool_customlang_translator
$translator) {
55 if (empty($translator->strings
)) {
56 return $this->heading(get_string('nostringsfound', 'tool_customlang'), 3);
59 $table = new html_table();
60 $table->id
= 'translator';
62 get_string('headingcomponent', 'tool_customlang'),
63 get_string('headingstringid', 'tool_customlang'),
64 get_string('headingstandard', 'tool_customlang'),
65 get_string('headinglocal', 'tool_customlang'),
68 foreach ($translator->strings
as $string) {
71 $cells[0] = new html_table_cell($string->component
);
72 $cells[0]->attributes
['class'] = 'component';
73 // string identification code
74 $cells[1] = new html_table_cell(html_writer
::tag('div', s($string->stringid
), array('class' => 'stringid')));
75 $cells[1]->attributes
['class'] = 'stringid';
76 // master translation of the string
77 $master = html_writer
::tag('div', s($string->master
), array('class' => 'preformatted'));
78 $minheight = strlen($string->master
) / 200;
79 if (preg_match('/\{\$a(->.+)?\}/', $string->master
)) {
80 $master .= html_writer
::tag('div', $this->help_icon('placeholder', 'tool_customlang',
81 get_string('placeholderwarning', 'tool_customlang')), array('class' => 'placeholderinfo'));
83 $cells[2] = new html_table_cell($master);
84 $cells[2]->attributes
['class'] = 'standard master';
85 // local customization of the string
86 $textareaattributes = array('name'=>'cust['.$string->id
.']', 'cols'=>40, 'rows'=>3);
88 $textareaattributes['style'] = 'min-height:' . (int) 4*$minheight . 'em;';
90 $textarea = html_writer
::tag('textarea', s($string->local
), $textareaattributes);
91 $cells[3] = new html_table_cell($textarea);
92 if (!is_null($string->local
) and $string->outdated
) {
93 $mark = html_writer
::empty_tag('input', array('type' => 'checkbox', 'id' => 'update_' . $string->id
,
94 'name' => 'updates[]', 'value' => $string->id
));
95 $help = $this->help_icon('markinguptodate', 'tool_customlang');
96 $mark .= html_writer
::tag('label', get_string('markuptodate', 'tool_customlang') . $help,
97 array('for' => 'update_' . $string->id
));
98 $mark = html_writer
::tag('div', $mark, array('class' => 'uptodatewrapper'));
102 $cells[3] = new html_table_cell($textarea."\n".$mark);
103 $cells[3]->attributes
['class'] = 'local';
104 $cells[3]->id
= 'id_'.$string->id
;
105 if (!is_null($string->local
)) {
106 $cells[3]->attributes
['class'] .= ' customized';
108 if ($string->outdated
) {
109 $cells[3]->attributes
['class'] .= ' outdated';
111 if ($string->modified
) {
112 $cells[3]->attributes
['class'] .= ' modified';
115 if ($string->original
!== $string->master
) {
116 $cells[0]->rowspan
= $cells[1]->rowspan
= $cells[3]->rowspan
= 2;
119 $row = new html_table_row($cells);
120 $table->data
[] = $row;
122 if ($string->original
!== $string->master
) {
124 // original of the string
125 $cells[2] = new html_table_cell(html_writer
::tag('div', s($string->original
), array('class' => 'preformatted')));
126 $cells[2]->attributes
['class'] = 'standard original';
127 $row = new html_table_row($cells);
128 $table->data
[] = $row;
132 $output .= html_writer
::start_tag('form', array('method'=>'post', 'action'=>$translator->handler
->out()));
133 $output .= html_writer
::start_tag('div');
134 $output .= html_writer
::empty_tag('input', array('type'=>'hidden', 'name'=>'translatorsubmitted', 'value'=>1));
135 $output .= html_writer
::empty_tag('input', array('type'=>'hidden', 'name'=>'sesskey', 'value'=>sesskey()));
136 $save1 = html_writer
::empty_tag('input', array('type'=>'submit', 'name'=>'savecontinue', 'value'=>get_string('savecontinue', 'tool_customlang')));
137 $save2 = html_writer
::empty_tag('input', array('type'=>'submit', 'name'=>'savecheckin', 'value'=>get_string('savecheckin', 'tool_customlang')));
138 $output .= html_writer
::tag('fieldset', $save1.$save2, array('class'=>'buttonsbar'));
139 $output .= html_writer
::table($table);
140 $output .= html_writer
::tag('fieldset', $save1.$save2, array('class'=>'buttonsbar'));
141 $output .= html_writer
::end_tag('div');
142 $output .= html_writer
::end_tag('form');