. /** * Class definition for mod_attendance_take_page_params * * @package mod_attendance * @copyright 2016 Dan Marsden http://danmarsden.com * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ defined('MOODLE_INTERNAL') || die(); /** * contains functions/constants used by take attendance page. * * @copyright 2016 Dan Marsden http://danmarsden.com * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class mod_attendance_take_page_params { /** Sorted list. */ const SORTED_LIST = 1; /** Sorted grid. */ const SORTED_GRID = 2; /** Default view */ const DEFAULT_VIEW_MODE = self::SORTED_LIST; /** @var int */ public $sessionid; /** @var int */ public $grouptype; /** @var int */ public $group; /** @var int */ public $sort; /** @var int */ public $copyfrom; /** @var int view mode of taking attendance page*/ public $viewmode; /** @var int */ public $gridcols; /** * Initialize params. */ public function init() { if (!isset($this->group)) { $this->group = 0; } if (!isset($this->sort)) { $this->sort = ATT_SORT_DEFAULT; } $this->init_view_mode(); $this->init_gridcols(); } /** * Initialise view mode params. */ private function init_view_mode() { if (isset($this->viewmode)) { set_user_preference("attendance_take_view_mode", $this->viewmode); } else { $this->viewmode = get_user_preferences("attendance_take_view_mode", self::DEFAULT_VIEW_MODE); } } /** * Initilise grid columns. */ private function init_gridcols() { if (isset($this->gridcols)) { set_user_preference("attendance_gridcolumns", $this->gridcols); } else { $this->gridcols = get_user_preferences("attendance_gridcolumns", 5); } } /** * Get main page params. * @return array */ public function get_significant_params() { $params = array(); $params['sessionid'] = $this->sessionid; $params['grouptype'] = $this->grouptype; if ($this->group) { $params['group'] = $this->group; } if ($this->sort != ATT_SORT_DEFAULT) { $params['sort'] = $this->sort; } if (isset($this->copyfrom)) { $params['copyfrom'] = $this->copyfrom; } return $params; } }