website_blog/views/snippets/s_blog_posts.xml

150 lines
7.7 KiB
XML
Raw Permalink Normal View History

<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- Snippet -->
<template id="s_blog_posts" name="Blog Posts">
<t t-call="website.s_dynamic_snippet_template">
<t t-set="snippet_name" t-value="'s_blog_posts'"/>
<t t-set="snippet_classes" t-value="'s_dynamic_snippet_blog_posts s_blog_post_big_picture s_blog_posts_effect_marley'"/>
</t>
</template>
<!-- Load-time templates (rendered in JS on page load) -->
<!-- List layout -->
<template id="dynamic_filter_template_blog_post_list" name="List layout">
<div t-foreach="records" t-as="data" class="d-flex mt-3 s_blog_posts_post" data-number-of-elements="2">
<t t-set="record" t-value="data['_record']"/>
<a class="s_blog_posts_post_cover flex-grow-0 flex-shrink-0 align-self-baseline position-relative" t-att-href="data['call_to_action_url']" t-att-title="'Read' + data['name']">
<t t-call="website.record_cover">
<t t-set="_record" t-value="record"/>
<t t-set="_resize_height" t-value="128"/>
<t t-set="_resize_width" t-value="128"/>
<t t-set="additionnal_classes" t-value="'w-100 h-100 bg-200 position-absolute'"/>
</t>
</a>
<div class="ps-2">
<a class="" t-att-title="'Read' + data['name']" t-att-href="data['call_to_action_url']">
<div class="s_blog_posts_post_title mb-1">
<span t-if="is_sample" class="bg-primary text-uppercase px-1">Sample</span>
<span t-field="record.name"/>
</div>
</a>
<div class="s_blog_posts_post_subtitle mb-1 d-none d-sm-block" t-field="record.subtitle"/>
</div>
</div>
</template>
<!-- Big picture layout -->
<template id="dynamic_filter_template_blog_post_big_picture" name="Big picture layout">
<figure t-foreach="records" t-as="data" class="my-3 w-100 s_blog_posts_post" data-number-of-elements="3">
<t t-set="record" t-value="data['_record']"/>
<a class="s_blog_posts_post_cover position-relative d-flex flex-column shadow-sm overflow-hidden rounded text-decoration-none" t-att-href="data['call_to_action_url']">
<t t-call="website.record_cover">
<t t-set="_record" t-value="record"/>
<t t-set="_resize_height" t-value="512"/>
<t t-set="_resize_width" t-value="512"/>
<t t-set="use_filters" t-value="True"/>
<t t-set="additionnal_classes" t-value="'h-100 w-100 bg-600 position-absolute'"/>
</t>
<figcaption class="text-center w-100 h-100 px-3 d-flex flex-column flex-grow-1">
<div t-if="is_sample" class="h5 o_ribbon_right bg-primary text-uppercase">Sample</div>
<div class="s_blog_posts_post_title text-white" t-field="record.name"/>
<div class="s_blog_posts_post_subtitle text-white" t-field="record.subtitle"/>
</figcaption>
</a>
</figure>
</template>
<!-- Horizontal layout -->
<template id="dynamic_filter_template_blog_post_horizontal" name="Horizontal layout">
<figure t-foreach="records" t-as="data" class="post s_blog_posts_post w-100" data-number-of-elements="3">
<t t-set="record" t-value="data['_record']"/>
<span t-if="is_sample" class="h5 float-end bg-primary text-uppercase rounded-circle px-2 py-2">Sample</span>
<figcaption>
<h4 class="mb0">
<a t-att-href="data['call_to_action_url']" t-field="record.name"/>
</h4>
<h5 class="mt0 mb4" t-field="record.post_date" t-options='{"format": "dd/MM"}'/>
</figcaption>
<a t-att-href="data['call_to_action_url']">
<t t-call="website.record_cover">
<t t-set="_record" t-value="record"/>
<t t-set="_resize_height" t-value="512"/>
<t t-set="_resize_width" t-value="512"/>
<t t-set="additionnal_classes" t-value="'thumb'"/>
</t>
</a>
</figure>
</template>
<!-- Card layout -->
<template id="dynamic_filter_template_blog_post_card" name="Card layout">
<div t-foreach="records" t-as="data" class="s_blog_posts_post pb32 w-100" data-number-of-elements="3">
<t t-set="record" t-value="data['_record']"/>
<div class="card">
<a class="s_blog_posts_post_cover" t-att-href="data['call_to_action_url']">
<t t-call="website.record_cover">
<t t-set="_record" t-value="record"/>
<t t-set="_resize_height" t-value="256"/>
<t t-set="_resize_width" t-value="256"/>
<t t-set="additionnal_classes" t-value="'thumb'"/>
</t>
</a>
<div class="card-body">
<div t-if="is_sample" class="h5 o_ribbon_right bg-primary text-uppercase">Sample</div>
<a t-att-href="data['call_to_action_url']"><h4 class="mb-0" t-field="record.name"/></a>
</div>
<div class="card-footer d-flex justify-content-between">
<span class="text-muted mb-0" t-field="record.post_date" t-options='{"format": "MMM d, yyyy"}' />
<span class="text-muted mb-0">In <a class="fw-bold" t-field="record.blog_id.name" t-att-href="'/blog/%s' % record.blog_id.id" />
<a t-if="is_sample" class="fw-bold" href="#">Sample</a>
</span>
</div>
</div>
</div>
</template>
<!-- Options -->
<template id="s_blog_posts_options" inherit_id="website.snippet_options">
<xpath expr="." position="inside">
<t t-call="website_blog.s_dynamic_snippet_options_template">
<t t-set="snippet_name" t-value="'dynamic_snippet_blog_posts'"/>
<t t-set="snippet_selector" t-value="'.s_dynamic_snippet_blog_posts'"/>
</t>
</xpath>
<xpath expr="//div[@data-js='layout_column']" position="attributes">
<attribute name="data-exclude" add=".s_blog_posts, .s_blog_posts_big_picture" separator=","/>
</xpath>
</template>
<template id="s_dynamic_snippet_options_template" inherit_id="website.s_dynamic_snippet_options_template">
<xpath expr="//we-select[@data-name='filter_opt']" position="after">
<we-select t-if="snippet_name == 'dynamic_snippet_blog_posts'" string="Blog" data-no-preview="true" data-name="blog_opt" data-attribute-name="filterByBlogId">
<we-button data-select-data-attribute="-1">All blogs</we-button>
<!-- the blog list will be generated in js -->
</we-select>
</xpath>
<xpath expr="//we-select[@data-name='template_opt']" position="after">
<we-select t-if="snippet_name == 'dynamic_snippet_blog_posts'"
string="Hover effect" class="o_we_sublevel_1 o_we_inline"
data-no-widget-refresh="true" data-name="hover_effect_opt">
<we-button data-select-class="">None</we-button>
<we-button data-select-class="s_blog_posts_effect_marley">Marley</we-button>
<we-button data-select-class="s_blog_posts_effect_dexter">Dexter</we-button>
<we-button data-select-class="s_blog_posts_effect_chico">Silly-Chico</we-button>
</we-select>
</xpath>
</template>
<!-- Assets -->
<record id="website_blog.s_blog_posts_000_scss" model="ir.asset">
<field name="name">Blog posts 000 SCSS</field>
<field name="bundle">web.assets_frontend</field>
<field name="path">website_blog/static/src/snippets/s_blog_posts/000.scss</field>
</record>
<record id="website_blog.s_blog_posts_000_js" model="ir.asset">
<field name="name">Blog posts 000 JS</field>
<field name="bundle">web.assets_frontend</field>
<field name="path">website_blog/static/src/snippets/s_blog_posts/000.js</field>
</record>
</odoo>