Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.2.x will end 22 April 2024 (12 months).
  • Bug fixes for security issues in 4.2.x will end 7 October 2024 (18 months).
  • PHP version: minimum PHP 8.0.0 Note: minimum PHP version has increased since Moodle 4.1. PHP 8.1.x is supported too.
   1  <?php
   2  // This file is part of Moodle - http://moodle.org/
   3  //
   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.
   8  //
   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.
  13  //
  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/>.
  16  
  17  namespace mod_feedback\form;
  18  
  19  use core_form\dynamic_form;
  20  use moodle_url;
  21  use context;
  22  use context_module;
  23  use context_system;
  24  
  25  /**
  26   * Prints the create new template form
  27   *
  28   * @copyright 2021 Peter Dias
  29   * @license http://www.gnu.org/copyleft/gpl.html GNU Public License
  30   * @package mod_feedback
  31   */
  32  class create_template_form extends dynamic_form {
  33      /**
  34       * Define the form
  35       */
  36      public function definition() {
  37          $mform =& $this->_form;
  38  
  39          $mform->addElement('hidden', 'id');
  40          $mform->setType('id', PARAM_INT);
  41  
  42          $mform->addElement('text',
  43              'templatename',
  44              get_string('name', 'feedback'),
  45              ['maxlength' => '200', 'size' => '50']);
  46          $mform->setType('templatename', PARAM_TEXT);
  47  
  48          if (has_capability('mod/feedback:createpublictemplate', context_system::instance())) {
  49              $mform->addElement('checkbox',
  50                  'ispublic', '',
  51                  get_string('public', 'feedback'));
  52          }
  53      }
  54  
  55      /**
  56       * Returns context where this form is used
  57       *
  58       * @return context
  59       */
  60      protected function get_context_for_dynamic_submission(): context {
  61          $id = $this->optional_param('id', null, PARAM_INT);
  62          list($course, $cm) = get_course_and_cm_from_cmid($id, 'feedback');
  63          return context_module::instance($cm->id);
  64      }
  65  
  66      /**
  67       * Checks if current user has access to this form, otherwise throws exception
  68       *
  69       * @throws \moodle_exception User does not have capability to access the form
  70       */
  71      protected function check_access_for_dynamic_submission(): void {
  72          $context = $this->get_context_for_dynamic_submission();
  73          if (!has_capability('mod/feedback:edititems', $context) ||
  74              !(has_capability('mod/feedback:createprivatetemplate', $context) ||
  75              has_capability('mod/feedback:createpublictemplate', $context))) {
  76              throw new \moodle_exception('nocapabilitytousethisservice');
  77          }
  78      }
  79  
  80      /**
  81       * Process the form submission, used if form was submitted via AJAX
  82       *
  83       * @return array Returns whether a new template was created.
  84       */
  85      public function process_dynamic_submission(): array {
  86          global $PAGE;
  87          $formdata = $this->get_data();
  88          $ispublic = !empty($formdata->ispublic) ? 1 : 0;
  89          $result = feedback_save_as_template($PAGE->activityrecord, $formdata->templatename, $ispublic);
  90          return [
  91              'result' => $result,
  92          ];
  93      }
  94  
  95      /**
  96       * Load in existing data as form defaults
  97       */
  98      public function set_data_for_dynamic_submission(): void {
  99          $this->set_data((object)[
 100              'id' => $this->optional_param('id', null, PARAM_INT),
 101          ]);
 102      }
 103  
 104      /**
 105       * Returns url to set in $PAGE->set_url() when form is being rendered or submitted via AJAX
 106       *
 107       * @return moodle_url
 108       */
 109      protected function get_page_url_for_dynamic_submission(): moodle_url {
 110          $params = [
 111              'id' => $this->optional_param('id', null, PARAM_INT),
 112          ];
 113          return new moodle_url('/mod/feedback/edit.php', $params);
 114      }
 115  }