定制 deniaz/terrific-twig 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

deniaz/terrific-twig

最新稳定版本:v1.0.0

Composer 安装命令:

composer require deniaz/terrific-twig

包简介

Extension to embrace the Terrific frontend methodology in Twig. Currently it adds a custom component tag to Twig which mimics Nitro's handlebars helper.

README 文档

README

Build Status Latest Stable Version Total Downloads License

Extension to embrace the Terrific frontend methodology in Twig.

Currently it adds a custom component tag to Twig which mimics Nitro's handlebars helper.

Installation

Using composer:

$ composer require namics/terrific-twig

Requirements

The following versions of PHP are currently supported.

  • PHP 5.4 (Deprecated. Builds are failing since the tests are relying on ::class.)
  • PHP 5.5
  • PHP 5.6
  • PHP 7
  • HHVM

Setup

Step 1: Implement TemplateInformationProvider

class TemplateInformationProvider implements TemplateInformationProviderInterface
{
    public function getPaths()
    {
      return []; // List of path where Terrific Components can be found, e.g. (/var/www/example.com/frontend/components)
    }
    
    public function getFileExtension()
    {
      $fileExtension = 'html.twig';
      return $fileExtension;
    }
}

Step 2: Implement ContextProviderInterface

class ContextProvider implements ContextProviderInterface
{
    public function compile(Twig_Compiler $compiler, Twig_Node $component, Twig_Node $dataVariant, $only) {
        // ...
    }
}

Step 3: Add TerrificLoader

$loader = ...;
$chain = new Twig_Loader_Chain([$loader, new TerrificLoader(new TemplateInformationProvider)]);
$twig = new Twig_Environment($chain);

Step 4: Add TerrificExtension

$twig = new Twig_Environment($chain);
$twig->addExtension(new TerrificExtension(new ContextProvider));

Step 5: Profit!

Usage

{# Includes the component, component's default data is merged with the context #}
{% component 'Example' %}

{# Includes the component, the default data is injected as a child context #}
{% component 'Example' only %}

{# Includes the component, but a variantion of the component data is merged with the context #}
{% component 'Example' 'example-variant' %}

{# Includes the component, but a variantion of the component data is injected as a child context #}
{% component 'Example' 'example-variant' only %}

{# Includes the component, data object is merged with the context #}
{% component 'Example' { title: 'Inject an Object' } %}

{# Includes the component, data object is injected as a child context #}
{% component 'Example' { title: 'Inject an Object' } only %}

Documentation

Extension

The extension provides terrific extensions to Twig. Currently the extension provides the ComponentTokenParser.

Token Parser

The token parser contains the parsing step for the component tag. It tokenizes the stream to different nodes (component, data) and an attribute (only).

The functionality is based on the fantastic Twig_TokenParser_Include.

Node

The Node compiles the tokenized tag to PHP. To see some of the output, check the ComponentTest.

Loader

The TerrificLoader extends the Twig_Loader_Filesystem as it actually loads templates from the filesystem. An implementation of TemplateLocatorInterface provides the paths where the loader should search for templates.

Template Information Provider

An implementation of TemplateInformationProviderInterface should return a list of paths where templates live. These should be in the form of ['frontend/components/atoms', 'frontend/components/molecules', 'frontend/components/organisms']. The component directory will be provided by the TerrificLoader (Example/example.[ext]).

Context Provider

This is the tricky part. An implementation of ContextProviderInterface decides which data will be made available to Twig templates. TODO: More on that.

ConfigReader

Reads nitro's config.json and parses essential information such as the component paths and file extension.

Credits

This project is partially sponsored by Namics.

统计信息

  • 总下载量: 59
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 1
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 3
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-03-02