. defined('MOODLE_INTERNAL') OR die('not allowed'); require_once($CFG->dirroot.'/mod/apply/item/apply_item_class.php'); // class apply_item_tableend extends apply_item_base { protected $type = "tableend"; private $commonparams; private $item_form; private $item; public function init() { } public function build_editform($item, $apply, $cm) { global $DB, $CFG; require_once('tableend_form.php'); //get the lastposition number of the apply_items $position = $item->position; $lastposition = $DB->count_records('apply_item', array('apply_id'=>$apply->id)); if ($position == -1) { $i_formselect_last = $lastposition + 1; $i_formselect_value = $lastposition + 1; $item->position = $lastposition + 1; } else { $i_formselect_last = $lastposition; $i_formselect_value = $item->position; } //the elements for position dropdownlist $positionlist = array_slice(range(0, $i_formselect_last), 1, $i_formselect_last, true); if (!property_exists($item, 'label')) $item->label = ''; if ($item->label=='') $item->label = 'table_end'; //all items for dependitem $applyitems = apply_get_depend_candidates_for_item($apply, $item); $commonparams = array('cmid'=>$cm->id, 'id'=>isset($item->id) ? $item->id : null, 'typ'=>$item->typ, 'items'=>$applyitems, 'apply_id'=>$apply->id); //build the form $customdata = array('item' => $item, 'common' => $commonparams, 'positionlist' => $positionlist, 'position' => $position); $this->item_form = new apply_tableend_form('edit_item.php', $customdata); } //this function only can used after the call of build_editform() public function show_editform() { $this->item_form->display(); } public function is_cancelled() { return $this->item_form->is_cancelled(); } public function get_data() { if ($this->item = $this->item_form->get_data()) { return true; } return false; } public function save_item() { global $DB; if (!$item = $this->item_form->get_data()) { return false; } if (isset($item->clone_item) AND $item->clone_item) { $item->id = ''; //to clone this item $item->position++; } $item->presentation = ''; $item->hasvalue = $this->get_hasvalue(); if (!$item->id) { $item->id = $DB->insert_record('apply_item', $item); } else { $DB->update_record('apply_item', $item); } return $DB->get_record('apply_item', array('id'=>$item->id)); } public function get_analysed($item, $groupid = false, $courseid = false) { return null; } public function get_printval($item, $value) { if (!isset($value->value)) { return ''; } return $value->value; } public function print_analysed($item, $itemnr = '', $groupid = false, $courseid = false) { return $itemnr; } public function excelprint_item(&$worksheet, $row_offset, $xls_formats, $item, $groupid, $courseid = false) { return $row_offset; } /** * print the item at the edit-page of apply * * @global object * @param object $item * @return void */ public function print_item_preview($item) { global $OUTPUT, $DB; global $Table_in; $align = right_to_left() ? 'right' : 'left'; echo '
'; echo '('.$item->label.') '; echo format_text($item->name, true, false, false).' ['.$item->position.']'; // //Warnning!! No table is nested. This close is ignored. if (!$Table_in) echo '  ['.get_string('no_table','apply').']'; if ($item->dependitem) { if ($dependitem = $DB->get_record('apply_item', array('id'=>$item->dependitem))) { echo ' '; echo '('.$dependitem->label.'->'.$item->dependvalue.')'; echo ''; } } echo '
'; echo '
'; // apply_close_table_tag(); //echo '
'; } /** * print the item at the complete-page of apply * * @global object * @param object $item * @param string $value * @param bool $highlightrequire * @return void */ public function print_item_submit($item, $value = '', $highlightrequire = false) { apply_close_table_tag(); } /** * print the item at the complete-page of apply * * @global object * @param object $item * @param string $value * @return void */ public function print_item_show_value($item, $value = '') { apply_close_table_tag(); } public function check_value($value, $item) { return true; } public function create_value($data) { $data = s($data); return $data; } //compares the dbvalue with the dependvalue //dbvalue is the value put in by the user //dependvalue is the value that is compared public function compare_value($item, $dbvalue, $dependvalue) { if ($dbvalue == $dependvalue) { return true; } return false; } public function get_presentation($data) { } public function get_hasvalue() { return 0; } public function can_switch_require() { return false; } public function value_type() { return PARAM_RAW; } public function clean_input_value($value) { return s($value); } }