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.

Differences Between: [Versions 311 and 402]

   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  /**
  18   * Contains the class for fetching the important dates in mod_data for a given module instance and a user.
  19   *
  20   * @package   mod_data
  21   * @copyright 2021 Shamim Rezaie <shamim@moodle.com>
  22   * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  23   */
  24  
  25  declare(strict_types=1);
  26  
  27  namespace mod_data;
  28  
  29  use core\activity_dates;
  30  
  31  /**
  32   * Class for fetching the important dates in mod_data for a given module instance and a user.
  33   *
  34   * @copyright 2021 Shamim Rezaie <shamim@moodle.com>
  35   * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  36   */
  37  class dates extends activity_dates {
  38  
  39      /**
  40       * Returns a list of important dates in mod_data
  41       *
  42       * @return array
  43       */
  44      protected function get_dates(): array {
  45          $timeopen = $this->cm->customdata['timeavailablefrom'] ?? null;
  46          $timeclose = $this->cm->customdata['timeavailableto'] ?? null;
  47          $now = time();
  48          $dates = [];
  49  
  50          if ($timeopen) {
  51              $openlabelid = $timeopen > $now ? 'activitydate:opens' : 'activitydate:opened';
  52              $dates[] = [
  53                  'dataid' => 'timeavailablefrom',
  54                  'label' => get_string($openlabelid, 'course'),
  55                  'timestamp' => (int) $timeopen,
  56              ];
  57          }
  58  
  59          if ($timeclose) {
  60              $closelabelid = $timeclose > $now ? 'activitydate:closes' : 'activitydate:closed';
  61              $dates[] = [
  62                  'dataid' => 'timeavailableto',
  63                  'label' => get_string($closelabelid, 'course'),
  64                  'timestamp' => (int) $timeclose,
  65              ];
  66          }
  67  
  68          return $dates;
  69      }
  70  }