From b0f383ef44faf59d97b83d54bfd6424d6f6e651d Mon Sep 17 00:00:00 2001 From: ifdjhxh Date: Sat, 7 Dec 2024 20:08:09 +0300 Subject: [PATCH] Filter components --- main/_front/src/html/components.html | 6 +-- main/_front/src/js/components.js | 57 +++++++++++++----------- main/controllers/ComponentsController.js | 16 ++++--- 3 files changed, 46 insertions(+), 33 deletions(-) diff --git a/main/_front/src/html/components.html b/main/_front/src/html/components.html index 9a53f1e..0eab0fc 100644 --- a/main/_front/src/html/components.html +++ b/main/_front/src/html/components.html @@ -12,7 +12,7 @@ - +
@@ -67,7 +67,7 @@

Комплектующие

-
+
diff --git a/main/_front/src/js/components.js b/main/_front/src/js/components.js index 2b51705..18bc0b2 100644 --- a/main/_front/src/js/components.js +++ b/main/_front/src/js/components.js @@ -1,35 +1,16 @@ const choiceLists = document.querySelectorAll(".choice"); -choiceLists.forEach((choiceList) => { - const choiceItems = choiceList.querySelectorAll(".choice__elem"); - choiceItems.forEach((choice) => { - if (choice.classList.contains("active")) { - choiceList.dataset.value = choice.dataset.value; - // console.log(choice.dataset.value); - } - choice.addEventListener("click", (e) => { - choiceItems.forEach((choice) => { - if (choice === e.target) { - choiceList.dataset.value = choice.dataset.value; - choice.classList.add("active"); - console.log(choice.dataset.value); - }else { - choice.classList.remove("active"); - } - }); - }); - }); -}) +const choice_components = document.querySelector("#choice_components"); -const cards_place = document.querySelector("#cards_place"); let isAdmin = false; -const addCards = () => { - fetch("http://localhost:4444/components") +const addCards = (type) => { + fetch(`http://localhost:4444/components${type ? "?type=" + type : ""}`) .then(res => res.json()) .then(data => { console.log(data); + cards_place.replaceChildren(); data.forEach((item) => { cards_place.insertAdjacentHTML("beforeend", `
@@ -43,7 +24,6 @@ const addCards = () => {
`) }) - console.log("here") const card__buttons = document.querySelectorAll(".card__button"); card__buttons.forEach((card_button) => { card_button.addEventListener("click",(e) => { @@ -55,6 +35,33 @@ const addCards = () => { }) }) } + +choiceLists.forEach((choiceList) => { + const choiceItems = choiceList.querySelectorAll(".choice__elem"); + choiceItems.forEach((choice) => { + if (choice.classList.contains("active")) { + choiceList.dataset.value = choice.dataset.value; + // console.log(choice.dataset.value); + } + choice.addEventListener("click", (e) => { + choiceItems.forEach((choice) => { + if (choice === e.target) { + choiceList.dataset.value = choice.dataset.value; + choice.classList.add("active"); + console.log(choice.dataset.value); + console.log("here"); + if (choiceList.id === "choice_components") { + addCards(choice.dataset.value) + } + }else { + choice.classList.remove("active"); + } + }); + }); + }); +}) + + const btn_add = document.querySelector("#add"); document.addEventListener("DOMContentLoaded", function() { @@ -71,6 +78,6 @@ document.addEventListener("DOMContentLoaded", function() { isAdmin = true; btn_add.parentElement.classList.remove('hide'); } - addCards(); + addCards("cpu"); }) }) \ No newline at end of file diff --git a/main/controllers/ComponentsController.js b/main/controllers/ComponentsController.js index 335501f..fdfd619 100644 --- a/main/controllers/ComponentsController.js +++ b/main/controllers/ComponentsController.js @@ -1,5 +1,5 @@ import ComponentsModel from "../models/Components.js"; - + export const addComponent = async (req, res) => { try { const components = await ComponentsModel.find({name: req.body.name}); @@ -27,10 +27,16 @@ export const addComponent = async (req, res) => { }) } } - + export const getAll = async (req, res) => { try { - const components = await ComponentsModel.find().exec(); + console.log(req.query); + let components; + if (req.query.type){ + components = await ComponentsModel.find({type: req.query.type}).exec(); + }else { + components = await ComponentsModel.find().exec(); + } res.json(components); }catch (err){ console.warn(err); @@ -39,11 +45,11 @@ export const getAll = async (req, res) => { }) } } - + export const getOne = async (req, res) => { try { const componentId = String(req.params.id); - + ComponentsModel.findOne({ _id: componentId }).then(