Added methods render and refactoring class

This commit is contained in:
Макс Овсяников 2022-09-21 22:30:52 +03:00
parent 0035cb2f75
commit 4bb46a37f8
2 changed files with 126 additions and 109 deletions

View File

@ -8,13 +8,15 @@ export class DropDown {
constructor(options = {}) { constructor(options = {}) {
this.#init(options); this.#init(options);
this.#initSelected(); // this.#initAmount();
this.#initAmount(); this.#render();
this.#initItems(); // this.#initEvent();
this.#initEvent();
} }
#open() { #open() {
this.#list = this.#element.querySelector('.list');
this.#caret = this.#element.querySelector('.caret');
this.#list.classList.toggle('open'); this.#list.classList.toggle('open');
this.#caret.classList.toggle('caret_rotate'); this.#caret.classList.toggle('caret_rotate');
} }
@ -32,27 +34,25 @@ export class DropDown {
#initSelected() { #initSelected() {
const { styles } = this.#options; const { styles } = this.#options;
if (this.#options.selected) { console.log(this.#options.placeholder);
this.#createSelected(this.#options.selected);
} else { // if (this.#options.selected) {
this.#createSelected('Select...'); // this.#createSelected(this.#options.selected);
} // } else {
// this.#createSelected('Select...');
// }
if (!this.#options.selected && this.#options.placeholder) { if (!this.#options.selected && this.#options.placeholder) {
this.#createSelected(this.#options.placeholder); this.#createSelected(this.#options.placeholder);
} }
if ((styles && this.#options.placeholder) || (styles && this.#options.selected)) { // if ((styles && this.#options.placeholder) || (styles && this.#options.selected)) {
this.#createSelected(this.#options.placeholder); // this.#createSelected(this.#options.placeholder);
this.#customStyles(styles); // this.#customStyles(styles);
} else { // } else {
this.#createSelected('Select...'); // this.#createSelected('Select...');
this.#customStyles(styles); // this.#customStyles(styles);
} // }
this.#element.addEventListener('click', () => {
this.#open();
});
} }
#initAmount() { #initAmount() {
@ -70,24 +70,49 @@ export class DropDown {
this.#element.innerHTML += `<ul class="list">${templete}</ul>`; this.#element.innerHTML += `<ul class="list">${templete}</ul>`;
} }
#initItems() { //ToDo: fix problem lisiner!
const { items, styles } = this.#options; #render() {
const { items } = this.#options;
if (!Array.isArray(items)) { const templete = items.map((item) => {
return; return `
<li class="list__item" >${item}</li>
`;
});
this.#element.innerHTML = '';
this.#initSelected();
this.#element.insertAdjacentHTML('beforeend', `<ul class="list">${templete.join('')}</ul>`);
this.#element.addEventListener('click', () => {
console.log('aaasa');
this.#open();
this.#selecteItem();
});
} }
if (!styles) { // #render() {
const templete = items.map((item) => `<li class="list__item" >${item}</li>`).join(''); // const { items } = this.#options;
this.#element.innerHTML += `<ul class="list">${templete}</ul>`;
}
if (styles) { // const templete = items.map((item) => {
const templete = items.map((item) => `<li class="list__item" >${item}</li>`).join(''); // return `
this.#element.innerHTML += `<ul class="list" style="${styles}" >${templete}</ul>`; // <li class="list__item" >${item}</li>
this.#customStyles(styles); // `;
} // });
// this.#element.innerHTML = '';
// this.#initSelected();
// this.#element.insertAdjacentHTML('beforeend', `<ul class="list">${templete.join('')}</ul>`);
// this.#element.addEventListener('click', openSelect);
// function openSelect() {
// console.log('aaasa');
// this.#element.removeEventListener('click', openSelect);
// }
// }
#selecteItem() {
const options = this.#element.querySelectorAll('.list__item'); const options = this.#element.querySelectorAll('.list__item');
const selected = this.#element.querySelector('.selected'); const selected = this.#element.querySelector('.selected');
@ -101,39 +126,26 @@ export class DropDown {
option.classList.add('active'); option.classList.add('active');
}); });
}); });
//ToDo: finish this function(catigories)
items.forEach((item) => {
if (typeof item === 'object') {
for (const key in item) {
const element = item[key];
// console.log(element);
if (typeof element === 'string') {
console.log(element);
}
}
}
});
} }
#initEvent() { // #initEvent() {
const { event } = this.#options; // const { event } = this.#options;
this.#list = this.#element.querySelector('.list'); // this.#list = this.#element.querySelector('.list');
this.#caret = this.#element.querySelector('.caret'); // this.#caret = this.#element.querySelector('.caret');
if (event === 'mouseenter') { // if (event === 'mouseenter') {
this.#element.addEventListener(event, () => { // this.#element.addEventListener(event, () => {
this.#list.classList.add('open'); // this.#list.classList.add('open');
this.#caret.classList.add('caret_rotate'); // this.#caret.classList.add('caret_rotate');
}); // });
this.#element.addEventListener('mouseleave', () => { // this.#element.addEventListener('mouseleave', () => {
this.#list.classList.remove('open'); // this.#list.classList.remove('open');
this.#caret.classList.remove('caret_rotate'); // this.#caret.classList.remove('caret_rotate');
}); // });
} // }
} // }
#customStyles(styles) { #customStyles(styles) {
if (!styles) { if (!styles) {
@ -176,32 +188,35 @@ export class DropDown {
} }
#createSelected(content, styles) { #createSelected(content, styles) {
if (content) {
console.log('ds');
this.#element.innerHTML = ` this.#element.innerHTML = `
<div class="cg-select"> <div class="cg-select">
<span class="selected">${content}</span> <span class="selected">${content}</span>
<div class="caret"></div> <div class="caret"></div>
</div> </div>
`; `;
if (styles) {
this.#customStyles(styles);
this.#element.innerHTML = `
<div class="cg-select" style = "${styles}">
<span class="selected" style = "${styles}">${content}</span>
<div class="caret" style = "${styles}"></div>
</div>
`;
}
} }
// addItem(item) { // if (styles) {
// const { items } = this.#options; // this.#customStyles(styles);
// console.log('Добавление елемента', item); // this.#element.innerHTML = `
// <div class="cg-select" style = "${styles}">
// items.push(item); // <span class="selected" style = "${styles}">${content}</span>
// <div class="caret" style = "${styles}"></div>
// console.log(items); // </div>
// `;
// } // }
}
addItem(item) {
const { items } = this.#options;
items.push(item);
console.log(items);
this.#render();
}
} }

View File

@ -2,36 +2,38 @@ import { DropDown } from './cg-dropdown';
const dropdown = new DropDown({ const dropdown = new DropDown({
selector: '.cg-dropdown', selector: '.cg-dropdown',
placeholder: 'Выберите авто',
items: ['BMW', 'Opel', 'Mersedes', 'MAN', 'max'], items: ['BMW', 'Opel', 'Mersedes', 'MAN', 'max'],
}); });
const dropdown2 = new DropDown({ dropdown.addItem('Zaz');
selector: '.cg-dropdown2', dropdown.addItem('Kamaz');
placeholder: 'Выберите авто',
items: ['BMW', 'Opel', 'Mersedes', 'MAN', 'Kamaz'], // const dropdown2 = new DropDown({
event: 'mouseenter', // selector: '.cg-dropdown2',
styles: { // placeholder: 'Выберите авто',
head: { // items: ['BMW', 'Opel', 'Mersedes', 'MAN', 'Kamaz'],
background: 'red', // event: 'mouseenter',
color: 'black', // styles: {
width: '400px', // head: {
}, // background: 'red',
placeholder: { // color: 'black',
color: 'grey', // width: '400px',
}, // },
caret: { // placeholder: {
'border-top': '6px solid black', // color: 'grey',
}, // },
list: { // caret: {
background: 'red', // 'border-top': '6px solid black',
color: 'black', // },
width: '412px', // list: {
}, // background: 'red',
}, // color: 'black',
}); // width: '412px',
// },
// },
// });
// dropdown.addItem('Zaz');
// const dropdown3 = new DropDown({ // const dropdown3 = new DropDown({
// selector: '.cg-dropdown3', // selector: '.cg-dropdown3',
// selected: '', // selected: '',