Filtros de Produto

Como adicionar e gerenciar o componente Filtros de produto na sua loja.

O Filtros de Produto é o componente que atende as necessidades de filtrar os produtos de um dado conjunto, definido por uma Tag. Na grande maioria dos casos esse componente é implementado na página de listagem de produtos. Nesse artigo você confere como adicionar esse componente na sua loja, e como adaptar os parâmetros para seu negócio.

📘

Demonstração do componente

Visualize como é o componente acessando o Filtros de Produto Demo. Recomendamos utilizar a versão mais atualizada do componente: (v15).

Tipos de filtro

Por padrão, na Vnda, à medida que vamos selecionando os filtros, as opções vão se mantendo mesmo que no momento não tenhamos produtos em determinada tag/atributo.

Temos a opção de ir "afunilando" os filtros conforme as opções vão sendo selecionadas. Para isso em admin/config/gerais/configuracoes-adicionais inserir o seguinte comando search_use_api: true.

Para desativar, no mesmo local inserir search_use_api: false.

Mostrar apenas os produtos disponíveis

Por padrão na plataforma sempre ao fazer a chamada de produtos, o {% load_products %} serão trazidos também os produtos indisponíveis.

Para excluir os produtos indisponíveis do front do site em /admin/config/gerais/extrasmarque a opção Listar somente produtos disponíveis?.

Implementação

Os filtros de produtos, como todos os outros componentes, já vem implementados nos templates da VNDA. Caso você precise fazer esta implementação manualmente, ou alterar o seu funcionamento, deve-se, primeiro, dar atenção a importação dos arquivos Javascript e CSS do componente. Junto a isso, você deve adicionar o objeto {{ aggregations }}. Usando o template 1 como exemplo, a chamada dos arquivos é feita da seguinte forma:

<script>
  window.filterSettings = {
    script: "{{ 'products-filter.v15.js' | component_path }}",
    styles: "{{ 'products-filter.v15.css' | component_path }}",
    aggregations: {{ aggregations | to_json }},
    patterns: {{ patterns_list | to_json }},
    has_sort: {{ has_sort }},
    prices_range: [
      {% if ranges %}
        {% for range in ranges %}
          {% assign values = range | strip | split: '-' %}
          [{{ values[0] | times: 1.00 }}, {{ values[1] | times: 1.00 }}],
        {% endfor %}
      {% endif %}
    ]
  }
</script>

🚧

Objeto {{ aggregations }}

Para que o filtro de produtos comporte-se de forma dinâmica, utilizamos o objeto {{ aggregations }}. Os atributos types e properties desse objeto serão utilizados no código JavaScript de declaração do componente.

Entre todos os componentes, os filtros são os que possuem maior diversidade de formas, de acordo com as escolhas selecionadas nos seus parâmetros. O parâmetro mode é responsável por grande parte desta variação, pois controla a forma de exibição do filtro, podendo variar entre horizontal, vertical, popup ou aba lateral.

Para cada uma dessas opções do parâmetro mode, os templates contam com um conjunto especifico de configurações no seu arquivo SCSS (assets\sass\content\tag\_filters.scss). Ao escolher uma das opções para usar, aconselha-se buscar em qual dos templates ela já foi implementada e utilizar o seu arquivo _filters.scss como ponto de partida do processo de personalização.

Caso opte-se por usar a aba lateral (drawer) no parâmetro mode, deve-se incluir um botão para controlar a exibição do componente, semelhante ao exemplo abaixo.

<button aria-label="Abrir filtro" class="button-default -outlined" id="open-filter-mobile">
  <svg class="icon">
  	<use xlink:href="#icon-filter"/>
  </svg>
  FILTROS
</button>
const mobileButton = document.querySelector('#open-filter-mobile')

if (mobileButton) mobileButton.addEventListener('click', () => {
	FilterComponent.show()
})

Além do mode, há uma serie de outros parametros que podem ser configurados de acordo com as necessidades da loja. Essas configurações se concentram na função setFilters do arquivo filters.js (assets\javascripts\pages\tag\filters.js).

    setFilters: function() {
      const { root } = FilterComponent;
      const tags = FilterComponent.setTagTypes()
      const properties = FilterComponent.setPropeties()
      const priceSettings = FilterComponent.setPricesRanges()
      const mode = (window.innerWidth <= 1024) ? 'drawer' : 'vertical'
  
      const componentFilters = new Vnda.Component.ProductsFilter({
        mode,
        hasSort: true,
        filterOnClick: false,
        resetMode: 'all',
        tags,
        properties,
        price: priceSettings.price,
        priceProps: priceSettings.priceProps
      });
  
      // Renderiza o componente
      componentFilters.render(root);
      FilterComponent.instance = componentFilters
      root.dispatchEvent(new Event('vnda:filter-component-loaded'))
    },

Todas as outras funções necessarias para o funcionamento do componente de filtros também se encontram no arquivo filters.js (assets\javascripts\pages\tag\filters.js). Sem aprofundar muito em cada uma delas, deve-se ter atenção a função setPropeties, que trata dos atributos dos produtos contidos na variável aggregations.

Parâmetros do componente

Os parâmetros define as características dos Filtros de Produto. Veja na tabela abaixo os parâmetros e o que eles determinam no componente. Note que os parâmetros que possuem valores padrões estão sinalizados na coluna Default, e as opções de entrada que o parâmetro pode receber estão apresentados na coluna Tipos/Opções de entrada.

ParâmetroDescriçãoTipos/Opções de entradaDefaultObrigatório
modeDefine como o componente é exibido.drawer,
balloon (descontinuado na v15),
horizontal ou
vertical
drawerNão
filtersStartOpenDefine se as opções de filtro iniciarão abertas ou fechadas. Aplica-se somente ao mode drawer e verticaltrue ou falsefalseNão
sideDrawerDefine a posição do componente, quando o componente estiver no mode drawer.right ou leftrightNão
hasInputSearchHabilita o campo de busca.true ou falsefalseNão
hasSortHabilita a ordenação dos resultados.true ou falsefalseNão
filterOnClickDefine o carregamento automático do filtro. Se habilitado, ao clicar em alguma opção do filtro, o resultado carrega automaticamente.true ou falsefalseNão
resetModeDefine como limpar os resultados do filtro. É possível ter um botão que limpe todos os resultados (all), um botão para cada opção do filtro (each) ou não ter botão para limpar os resultados (none).all,
each ou
none
noneNão
tagsDefine o filtro de categorias (tags).
Veja como declarar esse parâmetro em parâmetro tags
--Não
propertiesDefine o filtro de propriedades. É possível adicionar vários tipos de filtros de propriedades utilizando essa parâmetro.--Não
sortDefine a forma de ordenação do filtro.
Para utilizar essa parâmetro, o parâmetro HasSort deve estar ativado.
Veja como declarar esse parâmetro em parâmetro sort.
grid ou list-Não
priceCarrega os valores de limite inferior e superior para o filtro de preço.--Não
pricePropsDefine as opções de valores para o filtro de preço.

Veja como declarar esse parâmetro em parâmetro priceProps
--Não
patternsArray de URLs que define valores das estampas para filtros de propriedade.
Veja como declarar esse parâmetro em parâmetro patterns
--Não

Parâmetro tags:

tags = aggregations.types.categoria && [{
      title: "Categoria",
      type: "categoria",
      style: "list",
      options: aggregations.types.categoria
    }];

Parâmetro sort:

sort: {
  style: "grid", // estilo de como as opções são mostradas ( 'grid' ou 'list')
    columns: 3, // quantidade de colunas, no caso de style 'grid'. Descontinuado na versão 15 
  };
}

Parâmetro priceProps:

priceProps: {
  mode: 'options',
  options: [
    [0, 99.99],
    [100, 199.99],
    [200, 299.99]
  ]
}

Parâmetro patterns:

patterns: [
  { 
    "value": "Xadrez | estampa-xadrez", 
    "pattern": "http://via.placeholder.com/30x30"
  }
],

Eventos

A partir da versão 15, os filtros disparam eventos toda vez que: o filtro for carregado, uma opção de filtro for aberta, uma opção de filtro for fechada ou quando o filtro for fechado (caso o mode seja drawer). O trecho abaixo indica os eventos:

// Evento disparado sempre que uma opção de filtro for aberta 
window.addEventListener('vnda:filter-component-item-open', (event) => {
 console.log(event)
})

// Evento disparado sempre que uma opção de filtro for aberta 
window.addEventListener('vnda:filter-component-item-close', (event) => {
 console.log(event)
})

// Evento disparado quando o filtro for carregado
window.addEventListener('vnda:filter-component-loaded', (event) => {
  console.log(event)
})

// Evento disparado quando o filtro for fechado. Somente para o mode drawe
window.addEventListener('vnda:filter-component-closed', (event) => {
  console.log(event)
})

Método

O método disponível para esse componente é o toggle(). Ele abre o filtro se ele estiver fechado e fecha o drawer se ele estiver aberto (para os casos de mode drawer).

Exemplo de implementação

Confira foi feita a implementação do filtro de produtos no Template1 acessando os arquivos: