From 766f9bee34a48b874508745e9c5de2b7d5d7da3e Mon Sep 17 00:00:00 2001 From: Voyage Date: Thu, 10 Oct 2024 13:18:38 +0500 Subject: [PATCH] Update sorting-view.js --- src/view/sorting-view.js | 30 ++++++++++++++++++++++-------- 1 file changed, 22 insertions(+), 8 deletions(-) diff --git a/src/view/sorting-view.js b/src/view/sorting-view.js index 7d93a1b..507b123 100644 --- a/src/view/sorting-view.js +++ b/src/view/sorting-view.js @@ -1,5 +1,4 @@ -import { SORTING_COLUMNS } from '../const.js'; -import RadiosListView from './radios-list-view.js'; +import AbstractView from '../framework/view/abstract-view.js'; function createSortingItemTemplate(column) { const { type, label, active, defaultSelected } = column; @@ -10,18 +9,33 @@ function createSortingItemTemplate(column) { `; } -function createSortingTemplate() { +function createSortingTemplate(items) { return `
- ${SORTING_COLUMNS.map(createSortingItemTemplate).join('')} + ${items.map(createSortingItemTemplate).join('')}
`; } -export default class SortingView extends RadiosListView { - constructor() { - super({ items: SORTING_COLUMNS }); +export default class SortingView extends AbstractView { + #items = []; + #onSortChange = null; + + constructor({ + items, + onSortChange + }) { + super(); + + this.#items = items; + this.#onSortChange = onSortChange; + this.element.addEventListener('change', this.#sortingChangeHandler); } get template() { - return createSortingTemplate(); + return createSortingTemplate(this.#items); } + + #sortingChangeHandler = (evt) => { + evt.preventDefault(); + this.#onSortChange(evt.target.value); + }; }