2013-02-20 12:21:57 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
// This file is part of the customcert module for Moodle - http://moodle.org/
|
|
|
|
//
|
|
|
|
// Moodle is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// Moodle is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2013-05-17 03:05:42 +00:00
|
|
|
require_once($CFG->dirroot . '/mod/customcert/includes/tcpdf_colors.php');
|
|
|
|
|
2013-02-20 12:21:57 +00:00
|
|
|
/**
|
|
|
|
* The base class for the customcert elements.
|
|
|
|
*
|
2013-04-26 07:30:33 +00:00
|
|
|
* @package mod_customcert
|
2013-02-20 12:21:57 +00:00
|
|
|
* @copyright Mark Nelson <markn@moodle.com>
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
|
|
*/
|
|
|
|
|
2013-04-10 09:17:19 +00:00
|
|
|
defined('MOODLE_INTERNAL') || die('Direct access to this script is forbidden.');
|
2013-02-20 12:21:57 +00:00
|
|
|
|
|
|
|
class customcert_element_base {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The data for the element we are adding.
|
|
|
|
*/
|
|
|
|
public $element;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor.
|
|
|
|
*
|
|
|
|
* @param stdClass $element the element data
|
|
|
|
*/
|
|
|
|
function __construct($element) {
|
|
|
|
$this->element = new stdClass();
|
|
|
|
$this->element = $element;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function is responsible for adding the element for the first time
|
|
|
|
* to the database when no data has yet been specified, default values set.
|
2013-04-29 10:10:06 +00:00
|
|
|
* Can be overridden if more functionality is needed.
|
2013-02-20 12:21:57 +00:00
|
|
|
*
|
|
|
|
* @param string $element the name of the element
|
|
|
|
* @param int $pageid the page id we are saving it to
|
|
|
|
*/
|
|
|
|
public static function add_element($element, $pageid) {
|
|
|
|
global $DB;
|
|
|
|
|
2013-04-24 09:24:57 +00:00
|
|
|
// Set the time as a variable.
|
|
|
|
$time = time();
|
|
|
|
|
2013-02-20 12:21:57 +00:00
|
|
|
$data = new stdClass();
|
|
|
|
$data->pageid = $pageid;
|
|
|
|
$data->element = $element;
|
2013-05-17 03:08:29 +00:00
|
|
|
$data->font = 'times';
|
2013-02-20 12:21:57 +00:00
|
|
|
$data->size = '12';
|
2013-04-11 11:12:44 +00:00
|
|
|
$data->colour = '#000000';
|
2013-02-20 12:21:57 +00:00
|
|
|
$data->posx = '250';
|
|
|
|
$data->posy = '250';
|
2013-04-12 08:24:58 +00:00
|
|
|
$data->sequence = customcert_element_base::get_element_sequence($pageid);
|
2013-04-24 09:24:57 +00:00
|
|
|
$data->timecreated = $time;
|
|
|
|
$data->timemodified = $time;
|
2013-02-20 12:21:57 +00:00
|
|
|
|
|
|
|
$DB->insert_record('customcert_elements', $data);
|
|
|
|
}
|
|
|
|
|
2013-04-12 08:24:58 +00:00
|
|
|
/**
|
|
|
|
* Returns the sequence on a specified customcert page for a
|
|
|
|
* newly created element.
|
|
|
|
*
|
|
|
|
* @param int $pageid the id of the page we are adding this element to
|
|
|
|
* @return int the element number
|
|
|
|
*/
|
|
|
|
public static function get_element_sequence($pageid) {
|
|
|
|
global $DB;
|
|
|
|
|
|
|
|
// Set the sequence of the element we are creating.
|
|
|
|
$sequence = 1;
|
|
|
|
// Check if there already elements that exist, if so, overwrite value.
|
|
|
|
$sql = "SELECT MAX(sequence) as maxsequence
|
|
|
|
FROM {customcert_elements}
|
|
|
|
WHERE pageid = :id";
|
|
|
|
// Get the current max sequence on this page and add 1 to get the new sequence.
|
|
|
|
if ($maxseq = $DB->get_record_sql($sql, array('id' => $pageid))) {
|
|
|
|
$sequence = $maxseq->maxsequence + 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $sequence;
|
|
|
|
}
|
|
|
|
|
2013-02-20 12:21:57 +00:00
|
|
|
/**
|
|
|
|
* This function renders the form elements when adding a customcert element.
|
2013-02-26 09:22:52 +00:00
|
|
|
* Can be overridden if more functionality is needed.
|
2013-02-20 12:21:57 +00:00
|
|
|
*
|
|
|
|
* @param stdClass $mform the edit_form instance.
|
|
|
|
*/
|
|
|
|
public function render_form_elements($mform) {
|
|
|
|
// The identifier.
|
|
|
|
$id = $this->element->id;
|
|
|
|
|
2013-02-22 09:25:14 +00:00
|
|
|
// Commonly used string.
|
|
|
|
$strrequired = get_string('required');
|
|
|
|
|
2013-02-24 15:41:33 +00:00
|
|
|
// The common elements.
|
2013-02-22 09:25:14 +00:00
|
|
|
$mform->addElement('select', 'font_' . $id, get_string('font', 'customcert'), customcert_get_fonts());
|
|
|
|
$mform->addElement('select', 'size_' . $id, get_string('fontsize', 'customcert'), customcert_get_font_sizes());
|
2013-02-24 15:41:33 +00:00
|
|
|
$mform->addElement('customcert_colourpicker', 'colour_' . $id, get_string('fontcolour', 'customcert'));
|
2013-02-22 09:25:14 +00:00
|
|
|
$mform->addElement('text', 'posx_' . $id, get_string('posx', 'customcert'), array('size' => 10));
|
|
|
|
$mform->addElement('text', 'posy_' . $id, get_string('posy', 'customcert'), array('size' => 10));
|
|
|
|
|
|
|
|
// Set the types of these elements.
|
|
|
|
$mform->setType('font_' . $id, PARAM_TEXT);
|
|
|
|
$mform->setType('size_' . $id, PARAM_INT);
|
2013-02-24 15:41:33 +00:00
|
|
|
$mform->setType('colour_' . $id, PARAM_RAW); // Need to validate that this is a valid colour.
|
2013-02-22 09:25:14 +00:00
|
|
|
$mform->setType('posx_' . $id, PARAM_INT);
|
|
|
|
$mform->setType('posy_' . $id, PARAM_INT);
|
|
|
|
|
|
|
|
// Set the values of these elements.
|
|
|
|
$mform->setDefault('font_' . $id, $this->element->font);
|
|
|
|
$mform->setDefault('size_' . $id, $this->element->size);
|
|
|
|
$mform->setDefault('colour_' . $id, $this->element->colour);
|
|
|
|
$mform->setDefault('posx_' . $id, $this->element->posx);
|
|
|
|
$mform->setDefault('posy_' . $id, $this->element->posy);
|
2013-02-20 12:21:57 +00:00
|
|
|
|
2013-02-22 09:25:14 +00:00
|
|
|
// Add help buttons.
|
|
|
|
$mform->addHelpButton('font_' . $id, 'font', 'customcert');
|
|
|
|
$mform->addHelpButton('size_' . $id, 'fontsize', 'customcert');
|
|
|
|
$mform->addHelpButton('colour_' . $id, 'fontcolour', 'customcert');
|
|
|
|
$mform->addHelpButton('posx_' . $id, 'posx', 'customcert');
|
|
|
|
$mform->addHelpButton('posy_' . $id, 'posy', 'customcert');
|
2013-05-03 10:51:41 +00:00
|
|
|
}
|
2013-02-20 12:21:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Performs validation on the element values.
|
|
|
|
* Can be overridden if more functionality is needed.
|
|
|
|
*
|
|
|
|
* @param array $data the submitted data
|
2013-03-14 01:16:37 +00:00
|
|
|
* @param array $files the submitted files
|
2013-02-20 12:21:57 +00:00
|
|
|
* @return array the validation errors
|
|
|
|
*/
|
|
|
|
public function validate_form_elements($data, $files) {
|
|
|
|
$errors = array();
|
|
|
|
|
|
|
|
// The identifier.
|
|
|
|
$id = $this->element->id;
|
|
|
|
|
2013-02-24 15:41:33 +00:00
|
|
|
// Validate the colour.
|
2013-02-20 12:21:57 +00:00
|
|
|
$colour = 'colour_' . $id;
|
2013-02-24 15:41:33 +00:00
|
|
|
$colourdata = $data[$colour];
|
|
|
|
if (!$this->validate_colour($colourdata)) {
|
|
|
|
$errors[$colour] = get_string('invalidcolour', 'customcert');
|
2013-02-20 12:21:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Get position X.
|
|
|
|
$posx = 'posx_' . $id;
|
2013-04-24 10:07:56 +00:00
|
|
|
// Check if posx is not set, or not numeric or less than 0.
|
|
|
|
if ((!isset($data[$posx])) || (!is_numeric($data[$posx])) || ($data[$posx] <= 0)) {
|
2013-02-24 15:41:33 +00:00
|
|
|
$errors[$posx] = get_string('invalidposition', 'customcert', 'X');
|
2013-02-20 12:21:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Get position Y.
|
|
|
|
$posy = 'posy_' . $id;
|
2013-04-24 10:07:56 +00:00
|
|
|
// Check if posy is not set, or not numeric or less than 0.
|
|
|
|
if ((!isset($data[$posy])) || (!is_numeric($data[$posy])) || ($data[$posy] <= 0)) {
|
2013-02-24 15:41:33 +00:00
|
|
|
$errors[$posy] = get_string('invalidposition', 'customcert', 'Y');
|
2013-02-20 12:21:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return $errors;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handles saving the form elements created by this element.
|
2013-04-29 10:10:06 +00:00
|
|
|
* Can be overridden if more functionality is needed.
|
2013-02-20 12:21:57 +00:00
|
|
|
*
|
|
|
|
* @param stdClass $data the form data.
|
|
|
|
*/
|
|
|
|
public function save_form_elements($data) {
|
|
|
|
global $DB;
|
|
|
|
|
|
|
|
// The identifier.
|
|
|
|
$id = $this->element->id;
|
|
|
|
|
|
|
|
// Get the name of the fields we want from the form.
|
2013-02-22 08:15:32 +00:00
|
|
|
$datainfo = $this->save_unique_data($data);
|
2013-02-20 12:21:57 +00:00
|
|
|
$font = 'font_' . $id;
|
|
|
|
$size = 'size_' . $id;
|
|
|
|
$colour = 'colour_' . $id;
|
|
|
|
$posx = 'posx_' . $id;
|
|
|
|
$posy = 'posy_' . $id;
|
|
|
|
|
|
|
|
// Get the data from the form.
|
|
|
|
$element = new stdClass();
|
|
|
|
$element->id = $id;
|
2013-02-22 08:15:32 +00:00
|
|
|
$element->data = $datainfo;
|
2013-02-20 12:21:57 +00:00
|
|
|
$element->font = (!empty($data->$font)) ? $data->$font : null;
|
|
|
|
$element->size = (!empty($data->$size)) ? $data->$size : null;
|
2013-02-24 15:41:33 +00:00
|
|
|
$element->colour = (!empty($data->$colour)) ? $data->$colour : null;
|
2013-02-20 12:21:57 +00:00
|
|
|
$element->posx = (!empty($data->$posx)) ? $data->$posx : null;
|
|
|
|
$element->posy = (!empty($data->$posy)) ? $data->$posy : null;
|
2013-04-24 09:24:57 +00:00
|
|
|
$element->timemodified = time();
|
2013-02-20 12:21:57 +00:00
|
|
|
|
|
|
|
// Ok, now update record in the database.
|
|
|
|
$DB->update_record('customcert_elements', $element);
|
|
|
|
}
|
|
|
|
|
2013-02-22 08:15:32 +00:00
|
|
|
/**
|
|
|
|
* This will handle how form data will be saved into the data column in the
|
|
|
|
* customcert column.
|
2013-04-29 10:10:06 +00:00
|
|
|
* Can be overridden if more functionality is needed.
|
2013-02-22 08:15:32 +00:00
|
|
|
*
|
|
|
|
* @param stdClass $data the form data.
|
2013-05-28 08:33:46 +00:00
|
|
|
* @return string the unique data to save
|
2013-02-22 08:15:32 +00:00
|
|
|
*/
|
|
|
|
public function save_unique_data($data) {
|
2013-05-28 08:33:46 +00:00
|
|
|
return '';
|
2013-02-22 08:15:32 +00:00
|
|
|
}
|
|
|
|
|
2013-05-03 10:51:41 +00:00
|
|
|
/**
|
|
|
|
* This will handle how individual elements save their data
|
|
|
|
* to a template to be loaded later.
|
|
|
|
* Can be overridden if more functionality is needed.
|
|
|
|
*
|
2013-05-28 08:33:46 +00:00
|
|
|
* @param stdClass $data the form data
|
|
|
|
* @return bool returns true if the data was saved to the template, false otherwise
|
2013-05-03 10:51:41 +00:00
|
|
|
*/
|
|
|
|
public function save_data_to_template($data) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This will handle how individual elements load their data
|
|
|
|
* from a template to an existing customcert.
|
|
|
|
* Can be overridden if more functionality is needed.
|
|
|
|
*
|
2013-05-28 08:33:46 +00:00
|
|
|
* @param stdClass $data the form data
|
|
|
|
* @return bool returns true if the data was loaded from the template, false otherwise
|
2013-05-03 10:51:41 +00:00
|
|
|
*/
|
|
|
|
public function load_data_from_template($data) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2013-02-20 12:21:57 +00:00
|
|
|
/**
|
2013-04-10 09:53:56 +00:00
|
|
|
* Handles rendering the element on the pdf.
|
2013-04-29 10:10:06 +00:00
|
|
|
* Must be overridden.
|
2013-02-20 12:21:57 +00:00
|
|
|
*
|
2013-04-11 10:21:54 +00:00
|
|
|
* @param stdClass $pdf the pdf object
|
|
|
|
* @param int $userid
|
2013-02-20 12:21:57 +00:00
|
|
|
*/
|
2013-04-11 10:21:54 +00:00
|
|
|
public function render($pdf, $userid) {
|
2013-04-29 10:10:06 +00:00
|
|
|
// Must be overridden.
|
2013-02-20 12:21:57 +00:00
|
|
|
}
|
|
|
|
|
2013-04-11 10:42:23 +00:00
|
|
|
/**
|
|
|
|
* Common behaviour for rendering specified content on the pdf.
|
|
|
|
*
|
|
|
|
* @param stdClass $pdf the pdf object
|
|
|
|
* @param stdClass $content the content to render
|
|
|
|
*/
|
|
|
|
public function render_content($pdf, $content) {
|
2013-05-17 04:15:01 +00:00
|
|
|
$this->set_font($pdf);
|
2013-04-11 10:42:23 +00:00
|
|
|
$fontcolour = TCPDF_COLORS::convertHTMLColorToDec($this->element->colour, $fontcolour);
|
|
|
|
$pdf->SetTextColor($fontcolour['R'], $fontcolour['G'], $fontcolour['B']);
|
|
|
|
$pdf->writeHTMLCell(0, 0, $this->element->posx, $this->element->posy, $content);
|
|
|
|
}
|
|
|
|
|
2013-02-20 12:21:57 +00:00
|
|
|
/**
|
|
|
|
* Handles deleting any data this element may have introduced.
|
2013-04-29 10:10:06 +00:00
|
|
|
* Can be overridden if more functionality is needed.
|
2013-02-20 12:21:57 +00:00
|
|
|
*
|
|
|
|
* @return bool success return true if deletion success, false otherwise
|
|
|
|
*/
|
|
|
|
public function delete_element() {
|
|
|
|
global $DB;
|
|
|
|
|
|
|
|
return $DB->delete_records('customcert_elements', array('id' => $this->element->id));
|
|
|
|
}
|
2013-02-24 15:41:33 +00:00
|
|
|
|
2013-05-17 04:15:01 +00:00
|
|
|
/**
|
|
|
|
* Sets the font for the element.
|
|
|
|
*
|
|
|
|
* @param stdClass $pdf the pdf object
|
|
|
|
*/
|
|
|
|
public function set_font($pdf) {
|
|
|
|
// Variable for the font.
|
|
|
|
$font = $this->element->font;
|
|
|
|
// Get the last two characters of the font name.
|
|
|
|
$fontlength = strlen($font);
|
|
|
|
$lastchar = $font[$fontlength - 1];
|
|
|
|
$secondlastchar = $font[$fontlength - 2];
|
|
|
|
// The attributes of the font.
|
|
|
|
$attr = '';
|
|
|
|
// Check if the last character is 'i'.
|
|
|
|
if ($lastchar == 'i') {
|
|
|
|
// Remove the 'i' from the font name.
|
|
|
|
$font = substr($font, 0, -1);
|
|
|
|
// Check if the second last char is b.
|
|
|
|
if ($secondlastchar == 'b') {
|
|
|
|
// Remove the 'b' from the font name.
|
|
|
|
$font = substr($font, 0, -1);
|
|
|
|
$attr .= 'B';
|
|
|
|
}
|
|
|
|
$attr .= 'I';
|
|
|
|
} else if ($lastchar == 'b') {
|
|
|
|
// Remove the 'b' from the font name.
|
|
|
|
$font = substr($font, 0, -1);
|
|
|
|
$attr .= 'B';
|
|
|
|
}
|
|
|
|
// Check if this font is going to be bold.
|
|
|
|
$pdf->setFont($font, $attr, $this->element->size);
|
|
|
|
}
|
|
|
|
|
2013-02-24 15:41:33 +00:00
|
|
|
/**
|
|
|
|
* Validates the colour selected.
|
|
|
|
*
|
2013-05-28 08:33:46 +00:00
|
|
|
* @param string $colour
|
|
|
|
* @return bool returns true if the colour is valid, false otherwise
|
2013-02-24 15:41:33 +00:00
|
|
|
*/
|
|
|
|
protected function validate_colour($colour) {
|
|
|
|
/**
|
|
|
|
* List of valid HTML colour names
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
$colournames = array(
|
|
|
|
'aliceblue', 'antiquewhite', 'aqua', 'aquamarine', 'azure',
|
|
|
|
'beige', 'bisque', 'black', 'blanchedalmond', 'blue',
|
|
|
|
'blueviolet', 'brown', 'burlywood', 'cadetblue', 'chartreuse',
|
|
|
|
'chocolate', 'coral', 'cornflowerblue', 'cornsilk', 'crimson',
|
|
|
|
'cyan', 'darkblue', 'darkcyan', 'darkgoldenrod', 'darkgray',
|
|
|
|
'darkgrey', 'darkgreen', 'darkkhaki', 'darkmagenta',
|
|
|
|
'darkolivegreen', 'darkorange', 'darkorchid', 'darkred',
|
|
|
|
'darksalmon', 'darkseagreen', 'darkslateblue', 'darkslategray',
|
|
|
|
'darkslategrey', 'darkturquoise', 'darkviolet', 'deeppink',
|
|
|
|
'deepskyblue', 'dimgray', 'dimgrey', 'dodgerblue', 'firebrick',
|
|
|
|
'floralwhite', 'forestgreen', 'fuchsia', 'gainsboro',
|
|
|
|
'ghostwhite', 'gold', 'goldenrod', 'gray', 'grey', 'green',
|
|
|
|
'greenyellow', 'honeydew', 'hotpink', 'indianred', 'indigo',
|
|
|
|
'ivory', 'khaki', 'lavender', 'lavenderblush', 'lawngreen',
|
|
|
|
'lemonchiffon', 'lightblue', 'lightcoral', 'lightcyan',
|
|
|
|
'lightgoldenrodyellow', 'lightgray', 'lightgrey', 'lightgreen',
|
|
|
|
'lightpink', 'lightsalmon', 'lightseagreen', 'lightskyblue',
|
|
|
|
'lightslategray', 'lightslategrey', 'lightsteelblue', 'lightyellow',
|
|
|
|
'lime', 'limegreen', 'linen', 'magenta', 'maroon',
|
|
|
|
'mediumaquamarine', 'mediumblue', 'mediumorchid', 'mediumpurple',
|
|
|
|
'mediumseagreen', 'mediumslateblue', 'mediumspringgreen',
|
|
|
|
'mediumturquoise', 'mediumvioletred', 'midnightblue', 'mintcream',
|
|
|
|
'mistyrose', 'moccasin', 'navajowhite', 'navy', 'oldlace', 'olive',
|
|
|
|
'olivedrab', 'orange', 'orangered', 'orchid', 'palegoldenrod',
|
|
|
|
'palegreen', 'paleturquoise', 'palevioletred', 'papayawhip',
|
|
|
|
'peachpuff', 'peru', 'pink', 'plum', 'powderblue', 'purple', 'red',
|
|
|
|
'rosybrown', 'royalblue', 'saddlebrown', 'salmon', 'sandybrown',
|
|
|
|
'seagreen', 'seashell', 'sienna', 'silver', 'skyblue', 'slateblue',
|
|
|
|
'slategray', 'slategrey', 'snow', 'springgreen', 'steelblue', 'tan',
|
|
|
|
'teal', 'thistle', 'tomato', 'turquoise', 'violet', 'wheat', 'white',
|
|
|
|
'whitesmoke', 'yellow', 'yellowgreen'
|
|
|
|
);
|
|
|
|
|
|
|
|
if (preg_match('/^#?([[:xdigit:]]{3}){1,2}$/', $colour)) {
|
|
|
|
return true;
|
|
|
|
} else if (in_array(strtolower($colour), $colournames)) {
|
|
|
|
return true;
|
|
|
|
}
|
2013-04-11 11:25:55 +00:00
|
|
|
|
|
|
|
return false;
|
2013-02-24 15:41:33 +00:00
|
|
|
}
|
|
|
|
}
|