From df00d1e97063a61e2addecc3f0e943a2ebbd788a Mon Sep 17 00:00:00 2001 From: Yaroslav Volkov Date: Mon, 1 Jun 2026 18:45:56 +0200 Subject: [PATCH 1/2] solution --- README.md | 6 +++--- src/scripts/main.js | 32 +++++++++++++++++++++++++++++++- 2 files changed, 34 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 294f077fb..925e6dfe8 100644 --- a/README.md +++ b/README.md @@ -1,5 +1,5 @@ 1. Replace `` with your Github username in the link - - [DEMO LINK](https://.github.io/js_task_parse_list_DOM/) + - [DEMO LINK](https://PatronXXi.github.io/js_task_parse_list_DOM/) 2. Follow [this instructions](https://mate-academy.github.io/layout_task-guideline/) - Run `npm run test` command to test your code; - Run `npm run test:only -- -n` to run fast test ignoring linter; @@ -10,14 +10,14 @@ Hey there! Can you parse data from the list and sort it based on data attributes? Your task: Sort list by salary in descending order. -Get an array of employees. Write two functions: +Get an array of employees. Write two functions: - first, which sorts the list by salary from data attributes - second, which returns an array of objects, where objects are employees. The schema for the employee: ``` { - name, + name, position, salary, age diff --git a/src/scripts/main.js b/src/scripts/main.js index a765fdb1d..2a8edfab5 100644 --- a/src/scripts/main.js +++ b/src/scripts/main.js @@ -1,3 +1,33 @@ 'use strict'; -// write code here +function salaryReplace(salaryString) { + return Number(salaryString.replace(/[$,]/g, '')); +} + +const list = document.querySelector('ul'); + +function sortList(list) { + const listArray = Array.from(list.children); + + listArray.sort((a, b) => { + const salaryA = salaryReplace(a.dataset.salary); + const salaryB = salaryReplace(b.dataset.salary); + + return salaryB - salaryA; + }); + list.append(...listArray); +} + +function getEmployees(list) { + const items = list.children; + + return Array.from(items).map((item) => ({ + name: item.textContent.trim(), + position: item.dataset.position, + salary: salaryReplace(item.dataset.salary), + age: Number(item.dataset.age), + })); +} + +sortList(list); +getEmployees(list); From 5afc75820a18e887637d0c623a91ca09ce9abe40 Mon Sep 17 00:00:00 2001 From: Yaroslav Volkov Date: Mon, 1 Jun 2026 18:46:30 +0200 Subject: [PATCH 2/2] solution 2 --- src/scripts/main.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/scripts/main.js b/src/scripts/main.js index 2a8edfab5..2f8eff292 100644 --- a/src/scripts/main.js +++ b/src/scripts/main.js @@ -1,3 +1,4 @@ +/* eslint-disable no-shadow */ 'use strict'; function salaryReplace(salaryString) {