如何从 Apostrophe CMS 中的宏定义区域小部件
How to define area widgets from a macro in Apostrophe CMS
我想在一个地方为我的所有列和布局定义小部件。
此代码将在 views/macros/columnWidgets.html
{% macro columnWidgets(data, option) %}
{{ apos.area(data.widget, '{{option}}', {
blockLevelControls: true,
widgets: {
'apostrophe-rich-text': {
toolbar: [ 'Styles', 'Bold', 'Italic', 'Blockquote', 'Link', 'Anchor', 'Unlink', 'BulletedList' ],
styles: [
{ name: 'Paragraph', element: 'p' },
{ name: 'Quote / Section Descriptor', element: 'h3' },
{ name: 'Main Heading', element: 'h1',attributes: { 'class': 'main-heading'} }
]
},
'apostrophe-html': {
toolbar: [ 'Styles', 'Bold', 'Italic', 'Link', 'Unlink', 'Anchor', 'Table', 'BulletedList', 'Blockquote', 'Strike', 'Subscript', 'Superscript','Image','slideshow' ],
styles: [
{ name: 'Marker: Yellow', element: 'span', styles: { 'background-color': 'Yellow' } }
]
},
'apostrophe-images': {
minSize: [ 700, 350 ],
aspectRatio: [ 2, 1 ],
size: 'full'
}
}
}) }}
{% endmacro %}
然后在我的 4Column Layout Widget 中,我会按照这些行包含一些内容。
{% import 'macros/columnWidgets.html' as columnwidgets %}
{{ apps.columnWidgets(数据,'column1') }}
当然,我们在自己的项目中一直这样做。
// in app.js
modules: {
'apostrophe-templates': {
viewsFolderFallback: __dirname + '/views'
}, ...
}
{# In views/macros/areas.html %}
{% macro content(context, name) %}
{{ apos.area(context, name, {
widgets: {
'apostrophe-rich-text': {
toolbar: [ 'Styles', 'Bold', 'Italic', 'Link', 'Anchor', 'Unlink', 'BulletedList' ]
},
'apostrophe-images': {},
'apostrophe-files': {},
'apostrophe-video': {}
}
}) }}
{% endmacro %}
{# In any other template in any module #}
{% import "macros/areas.html" as areas %}
{{ areas.content(data.page, 'body') }}
viewsFolderFallback
的使用非常方便
共享顶级文件夹成为从任何模块导入、包含、扩展等模板文件的后备位置。
我想在一个地方为我的所有列和布局定义小部件。
此代码将在 views/macros/columnWidgets.html
{% macro columnWidgets(data, option) %}
{{ apos.area(data.widget, '{{option}}', {
blockLevelControls: true,
widgets: {
'apostrophe-rich-text': {
toolbar: [ 'Styles', 'Bold', 'Italic', 'Blockquote', 'Link', 'Anchor', 'Unlink', 'BulletedList' ],
styles: [
{ name: 'Paragraph', element: 'p' },
{ name: 'Quote / Section Descriptor', element: 'h3' },
{ name: 'Main Heading', element: 'h1',attributes: { 'class': 'main-heading'} }
]
},
'apostrophe-html': {
toolbar: [ 'Styles', 'Bold', 'Italic', 'Link', 'Unlink', 'Anchor', 'Table', 'BulletedList', 'Blockquote', 'Strike', 'Subscript', 'Superscript','Image','slideshow' ],
styles: [
{ name: 'Marker: Yellow', element: 'span', styles: { 'background-color': 'Yellow' } }
]
},
'apostrophe-images': {
minSize: [ 700, 350 ],
aspectRatio: [ 2, 1 ],
size: 'full'
}
}
}) }}
{% endmacro %}
然后在我的 4Column Layout Widget 中,我会按照这些行包含一些内容。
{% import 'macros/columnWidgets.html' as columnwidgets %}
{{ apps.columnWidgets(数据,'column1') }}
当然,我们在自己的项目中一直这样做。
// in app.js
modules: {
'apostrophe-templates': {
viewsFolderFallback: __dirname + '/views'
}, ...
}
{# In views/macros/areas.html %}
{% macro content(context, name) %}
{{ apos.area(context, name, {
widgets: {
'apostrophe-rich-text': {
toolbar: [ 'Styles', 'Bold', 'Italic', 'Link', 'Anchor', 'Unlink', 'BulletedList' ]
},
'apostrophe-images': {},
'apostrophe-files': {},
'apostrophe-video': {}
}
}) }}
{% endmacro %}
{# In any other template in any module #}
{% import "macros/areas.html" as areas %}
{{ areas.content(data.page, 'body') }}
viewsFolderFallback
的使用非常方便
共享顶级文件夹成为从任何模块导入、包含、扩展等模板文件的后备位置。