Skip to content

Instantly share code, notes, and snippets.

View language-switcher.twig
{# v3 #}
{# http://craftsnippets.com/articles/universal-language-switcher-for-craft-cms #}
{# logic #}
{% set currentElement = craft.app.urlManager.matchedElement %}
{% set sites = craft.app.sites.getGroupById(currentSite.groupId).getSites() %}
{% set switcherLinks = [] %}
{% for site in sites|filter(x => x.baseUrl is not empty) %}
{% set title = craft.app.i18n.getLocaleById(site.language).displayName %}
{% set url = site.getBaseUrl() %}
@piotrpog
piotrpog / quick_edit_craft4.twig
Last active December 10, 2023 00:45
Quick edit link component for Craft CMS 4. More info on http://craftsnippets.com/articles/quick-edit
View quick_edit_craft4.twig
{# v5 #}
{% if currentUser and currentUser.can('accessCp') and not craft.app.request.isLivePreview %}
{% if _globals.get('currentElement') %}
{% set element = _globals.get('currentElement') %}
{% else %}
{% set element = craft.app.urlManager.matchedElement %}
{% endif %}
{% if element and element.canSave(currentUser) and element.getCpEditUrl() is not null %}
{% set editLink = element.getCpEditUrl() %}
{% set editText = 'edit'|t %}
View test
Garnish.on(Craft.BaseElementIndex, 'updateElements', (ev) => {
// ev.target = the element index
});
View Alpine JS modal component
{# v6 #}
{# USAGE:
{% embed '_components/modal' with {
modalHandle: 'exampleHandle'
} %}
{% block modalContent %}
SOMETHING INSIDE
{% endblock %}
{% endembed %}
#}
@piotrpog
piotrpog / product.twig
Last active June 15, 2022 19:01
Commerce product page with sprig. Old version, doesnt work with Craft 4.
View product.twig
{% extends 'shop/_layouts/main' %}
{% block main %}
{{ sprig('product_content', {productId: product.id}) }}
{{ sprig.script }}
{% endblock %}
@piotrpog
piotrpog / pretty_url_macro.twig
Created August 28, 2020 06:49
Pretty URL Twig Macro
View pretty_url_macro.twig
{% macro prettyUrl(url) %}
{{url
|trim('https://', 'left')
|trim('http://', 'left')
|trim('www.', 'left')
|trim('/', 'right')
}}
{% endmacro %}
View CSS for more readable Neo plugin blocks (Craft CMS)
[data-neo-b].blocktype{
font-size: 1.1rem;
background-color: #03A9F4;
color: white;
padding-left: 3rem !important;
padding-right: 3rem !important;
}
.ni_block{
border: 2px solid rgb(3 169 244 / 50%) !important;
View email_layout.twig
{# based on Postmark Transactional Email Templates
https://postmarkapp.com/transactional-email-templates #}
{# If you change button color, remember to pass it to macro AND define "buttonColor" before "extends" tag. #}
{# macro title #}
{% macro title(titleText) %}
{% if titleText is defined %}
<h1 style="margin-top: 0; color: #333333; font-size: 22px; font-weight: bold; text-align: center;" align="left">{{titleText}}</h1>
{% endif %}
@piotrpog
piotrpog / gist:5c34d9de9b167dc2edca52ea2db7efdb
Created August 3, 2020 06:47
Craft CMS Verbb Navigation - URL stucture based on menu structure
View gist:5c34d9de9b167dc2edca52ea2db7efdb
{{ craft.navigation.nodes().ancestorOf( craft.navigation.nodes('test').all()|filter(x => x.element.id == id)|first.id ).ancestorDist(1).one().element.uri ?? null }}/{{slug}}
@piotrpog
piotrpog / link_list_macro.twig
Created June 29, 2020 08:04
Twig macro generating links from array of entries
View link_list_macro.twig