. /** * Target class. * * @package tool_usertours * @copyright 2016 Andrew Nicols * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ namespace tool_usertours; defined('MOODLE_INTERNAL') || die(); /** * Target class. * * @copyright 2016 Andrew Nicols * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class target { /** * @var TARGET_SELECTOR The target is a CSS selector. */ const TARGET_SELECTOR = 0; /** * @var TARGET_BLOCK The target is a block. */ const TARGET_BLOCK = 1; /** * @var TARGET_UNATTACHED The target is unattached to any specific node. */ const TARGET_UNATTACHED = 2; /** * @var array $mapping The list of target type to target name. */ protected static $mapping = [ self::TARGET_BLOCK => 'block', self::TARGET_SELECTOR => 'selector', self::TARGET_UNATTACHED => 'unattached', ]; /** * Return the name of the class for this target type. * * @param int $type The type of target. * @return string The class name. */ public static function get_classname($type) { $targettype = self::$mapping[self::get_target_constant($type)]; return "\\tool_usertours\\local\\target\\{$targettype}"; } /** * Return the instance of the class for this target. * * @param step $step The step. * @return target The target instance. */ public static function get_target_type(step $step) { if (!isset(self::$mapping[$step->get_targettype()])) { throw new \moodle_exception('Unknown Target type'); } $targettype = self::$mapping[$step->get_targettype()]; return "\\tool_usertours\\local\\target\\{$targettype}"; } /** * Return the constant used to describe this target. * * @param string $type The type of the target. * @return int The constant for this target. */ public static function get_target_constant($type) { return array_search($type, self::$mapping); } /** * Return the constant used to describe this class. * * @param string $classname The fully-qualified class name of the target * @return int The constant for this target. */ public static function get_target_constant_for_class($classname) { $rc = new \ReflectionClass($classname); return self::get_target_constant($rc->getShortName()); } /** * Return the instance of the class for this target. * * @param step $step The step. * @return target The target instance. */ public static function get_target_instance(step $step) { $targetclass = self::get_target_type($step); return new $targetclass($step); } /** * Return the complete lits of target types. * * @return array */ public static function get_target_types() { return self::$mapping; } }