From 25a27b492cde2a55353af43d62e0a3f3833b284c Mon Sep 17 00:00:00 2001 From: Marie Birner Date: Mon, 10 Apr 2023 22:42:00 +0200 Subject: [PATCH] [WIP] filter btns session storage --- frontend/main.ts | 117 +++++++++++++++++++++++++++++--------- templates/index.html.tera | 53 +++++++++-------- 2 files changed, 116 insertions(+), 54 deletions(-) diff --git a/frontend/main.ts b/frontend/main.ts index a6a8f5f..c7c48cd 100644 --- a/frontend/main.ts +++ b/frontend/main.ts @@ -8,41 +8,105 @@ document.addEventListener('DOMContentLoaded', function() { }); function initToggle() { - const toggle = document.querySelector('#filterdays-js'); + // get filter btns & set object sessionStorage + const btns = >document.querySelectorAll('.filter-trips-js'); + let filterObject = new Map(); - if(toggle) { - toggle.addEventListener('click', () => { - toggle.ariaPressed = (toggle.ariaPressed === 'true') ? 'false' : 'true'; - toggle.setAttribute('aria-pressed', toggle.ariaPressed); - - const daysNoTrips = document.querySelectorAll('div[data-trips="0"]'); - Array.prototype.forEach.call(daysNoTrips, (day: HTMLElement) => { - day.classList.toggle('hidden'); + if(btns) { + Array.prototype.forEach.call(btns, (btn: HTMLButtonElement) => { + filterObject.set(btn.dataset.action, btn.ariaPressed); + + btn.addEventListener('click', () => { + let filter = sessionStorage.getItem('tripsFilter'); + if(filter) { + let filterMap = new Map(JSON.parse(filter)); + for (let entry of filterMap.entries()) { + if(entry[0] === btn.dataset.action) { + filterMap.set(entry[0],'true'); + } else { + filterMap.set(entry[0],'false'); + } + } + sessionStorage.setItem('tripsFilter', JSON.stringify( Array.from(filterMap.entries()))); + } + resetFilteredElements(); + console.log(btn.ariaPressed); + if(btn.ariaPressed === 'false'){ + Array.prototype.forEach.call(btns, (b: HTMLButtonElement) => { + b.setAttribute('aria-pressed', 'false'); + }); + triggerFilterAction(btn.dataset.action); + } }); - }); + }); } - const coxToggle = document.querySelector('#filtertrips-js'); + let filter = sessionStorage.getItem('tripsFilter'); + if(filter) { + let filterMap = new Map(JSON.parse(filter)); + for (let entry of filterMap.entries()) { + if(entry[1] === 'true') { + triggerFilterAction(entry[0]); + } + } + } else { + sessionStorage.setItem('tripsFilter', JSON.stringify( Array.from(filterObject.entries()))); + } +} - if(coxToggle) { - coxToggle.addEventListener('click', () => { - coxToggle.ariaPressed = (coxToggle.ariaPressed === 'true') ? 'false' : 'true'; - coxToggle.setAttribute('aria-pressed', coxToggle.ariaPressed); - - const noCoxNeeded = document.querySelectorAll('div[data-coxneeded="false"]'); - Array.prototype.forEach.call(noCoxNeeded, (notNeeded: HTMLElement) => { - notNeeded.classList.toggle('hidden'); - }); +function resetFilteredElements() { + const hiddenElements = document.querySelectorAll('.reset-js.hidden'); + if(hiddenElements) { + Array.prototype.forEach.call(hiddenElements, (hiddenElement: HTMLButtonElement) => { + hiddenElement.classList.remove('hidden'); }); } +} - const monthToggle = document.querySelector('#filtermonth-js'); +function triggerFilterAction(activeFilter: any) { + const activeBtn = document.querySelector('button[data-action="' + activeFilter + '"]'); + if(activeBtn) { + activeBtn.setAttribute('aria-pressed', 'true'); + + filterAction(activeFilter); + } +} + +function filterAction(activeFilter: string) { + switch(activeFilter) { + case 'filter-days': { + filterDays(); + break; + } + case 'filter-coxs': { + filterCoxs(); + break; + } + case 'filter-months': { + filterMonths(activeFilter) + break; + } + } +} + +function filterDays() { + const daysNoTrips = document.querySelectorAll('div[data-trips="0"]'); + Array.prototype.forEach.call(daysNoTrips, (day: HTMLElement) => { + day.classList.toggle('hidden'); + }); +} + +function filterCoxs() { + const noCoxNeeded = document.querySelectorAll('div[data-coxneeded="false"]'); + Array.prototype.forEach.call(noCoxNeeded, (notNeeded: HTMLElement) => { + notNeeded.classList.toggle('hidden'); + }); +} + +function filterMonths(action: string) { const months = ['01', '02', '03', '04', '05', '06', '07', '08', '09', '10', '11', '12']; - + const monthToggle = document.querySelector('button[data-action="' + action + '"]'); if(monthToggle) { - monthToggle.addEventListener('click', () => { - monthToggle.ariaPressed = (monthToggle.ariaPressed === 'true') ? 'false' : 'true'; - monthToggle.setAttribute('aria-pressed', monthToggle.ariaPressed); const currentMonth = monthToggle.dataset.month; if(currentMonth) { @@ -58,9 +122,8 @@ function initToggle() { }); }); } - }); + } } -} function initSearch() { const input = document.querySelector('#filter-js'); diff --git a/templates/index.html.tera b/templates/index.html.tera index b8cda64..5069411 100644 --- a/templates/index.html.tera +++ b/templates/index.html.tera @@ -12,15 +12,15 @@ {% if loggedin_user.is_cox %}
- - - @@ -37,7 +37,7 @@ {% endif %} {% endfor %} {% endif %} -
+

{{ day.day| date(format="%d.%m.%Y") }} {{ day.day | date(format="%A", locale="de_AT") }} @@ -146,7 +146,7 @@ {% if day.trips | length > 0 %}
{% for trip in day.trips %} -
+
{{ trip.planned_starting_time }} Uhr