ICanBoogie/Module v2.2.4
  • Namespace
  • Class

Namespaces

  • ICanBoogie
    • Module

Classes

  • Descriptor
  • Hooks
  • ModelCollection
  • ModuleCollection
  • ModuleTemplateResolver

Interfaces

  • HasModelProperty
  • HasModuleProperty
  • HasRecordsFetcherProperty

Exceptions

  • ModuleConstructorMissing
  • ModuleIsDisabled
  • ModuleNotDefined
  1   2   3   4   5   6   7   8   9  10  11  12  13  14  15  16  17  18  19  20  21  22  23  24  25  26  27  28  29  30  31  32  33  34  35  36  37  38  39  40  41  42  43  44  45  46  47  48  49  50  51  52  53  54  55  56  57  58  59  60  61  62  63  64  65  66  67  68  69  70  71  72  73  74  75  76  77  78  79  80  81  82  83  84  85  86  87  88  89  90  91  92  93  94  95  96  97  98  99 100 101 102 103 104 105 106 107 108 109 110 111 
<?php

/*
 * This file is part of the ICanBoogie package.
 *
 * (c) Olivier Laviale <olivier.laviale@gmail.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace ICanBoogie\Module;

use ICanBoogie\Module;
use ICanBoogie\Render\TemplateResolver;
use ICanBoogie\Render\TemplateResolverTrait;

/**
 * Decorates a template resolver and adds support for module defined templates.
 *
 * Templates are inherited between modules.
 *
 * @package ICanBoogie\Module
 */
class ModuleTemplateResolver implements TemplateResolver
{
    use TemplateResolverTrait;

    /**
     * @var TemplateResolver
     */
    private $component;

    /**
     * @var ModuleCollection
     */
    private $modules;

    public function __construct(TemplateResolver $component, ModuleCollection $modules)
    {
        $this->component = $component;
        $this->modules = $modules;
    }

    /**
     * @inheritdoc
     */
    public function resolve($name, array $extensions, &$tried = [])
    {
        $template_pathname = $this->component->resolve($name, $extensions, $tried);

        if ($template_pathname)
        {
            return $template_pathname;
        }

        $modules = $this->modules;
        $module_id = dirname($name);

        if (empty($modules[$module_id]))
        {
            return null;
        }

        return $this->resolve_from_module($modules[$module_id], $name, $extensions, $tried);
    }

    /**
     * Resolves a template from a module and its parents.
     *
     * @param Module $module
     * @param string $name
     * @param array $extensions
     * @param array $tried
     *
     * @return string|null
     */
    public function resolve_from_module(Module $module, $name, array $extensions, &$tried = [])
    {
        $paths = [];

        while ($module)
        {
            $paths[] = $module->path . 'templates' . DIRECTORY_SEPARATOR;

            $module = $module->parent;
        }

        $name = basename($name);

        return $this->resolve_path($this
            ->resolve_tries($paths, $name, $extensions), $tried);
    }

    /**
     * @inheritdoc
     */
    public function add_path($path, $weight = 0)
    {
        $this->component->add_path($path, $weight);
    }

    /**
     * @inheritdoc
     */
    public function get_paths()
    {
        return $this->component->get_paths();
    }
}
ICanBoogie/Module v2.2.4 API documentation generated by ApiGen