Skip to content

jerzyucandoimage/fractal-twig-context-subrender

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Extended Fractal Twig Adapter

An adapter that extends the Fractal Twig adapter and introduces include operator in context data.

Installation

npm install --save-dev https://github.com/jerzyucandoimage/fractal-twig-context-subrender.git

in your fractal.js

const fractal = require('@frctl/fractal').create();
const twigAdapter = require('fractal-twig-context-subrender');
const twig = twigAdapter();

in the fractal configuration file

supportIncludesInTheContextData: true

The include statement

To include all the data from another component and assign it to specific variable

context: 
  include: 'component-name--variant-name as customVariableName'   

To include object by it's source path

context: 
  someDestinationObject:
    include: 'component-name--variant-name.path.to.the.source.data.object'   

To include all object's sub-properties use the spread ... operator

context: 
  someDestinationObject:
    include: '...component-name--variant-name'   

To include all object's sub properties - spread operator with source path

context: 
  someDestinationObject:
    include: '...component-name--variant-name.some.path'   

To include multiple entries at once

context: 
  someDestinationObject:
    include: 'component-name--variant-name.some.path as someCustomVariableName, component-name--variant-name.some.path as anotherCustomVariableName'   

To include multiple entries one by one

context: 
  someDestinationObject:
    include1: 'component-name--variant-name.some.path as someCustomVariableName'
    include2: 'component-name--variant-name.some.path as anotherCustomVariableName'  

By default existing variables are not being overriden. To force overriding use ! operator at the end

context: 
  someDestinationObject:
    include: 'component-name--variant-name.some.path!'   
context: 
  someDestinationObject:
    include: '...component-name--variant-name.some.path!'   
context: 
  someDestinationObject:
    include: 'component-name--variant-name.some.path as customVariableName!'   

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Packages

No packages published