{"id":25629178,"url":"https://github.com/DigitalProductschool/dps-react-challenge","last_synced_at":"2026-06-10T09:30:22.844Z","repository":{"id":245809037,"uuid":"819295389","full_name":"DigitalProductschool/dps-react-challenge","owner":"DigitalProductschool","description":"DPS Coding challenge based on React and Typescript","archived":false,"fork":false,"pushed_at":"2024-07-12T08:59:23.000Z","size":167,"stargazers_count":1,"open_issues_count":0,"forks_count":13,"subscribers_count":3,"default_branch":"master","last_synced_at":"2024-07-12T10:22:19.552Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"CSS","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/DigitalProductschool.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2024-06-24T08:17:24.000Z","updated_at":"2024-07-12T08:59:26.000Z","dependencies_parsed_at":"2024-06-24T09:41:25.189Z","dependency_job_id":"4f1b5482-debe-4d99-9aa2-ea647592014a","html_url":"https://github.com/DigitalProductschool/dps-react-challenge","commit_stats":null,"previous_names":["digitalproductschool/dps-react-challenge"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DigitalProductschool%2Fdps-react-challenge","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DigitalProductschool%2Fdps-react-challenge/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DigitalProductschool%2Fdps-react-challenge/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DigitalProductschool%2Fdps-react-challenge/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/DigitalProductschool","download_url":"https://codeload.github.com/DigitalProductschool/dps-react-challenge/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":240222477,"owners_count":19767460,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2025-02-22T19:17:05.112Z","updated_at":"2026-06-10T09:30:22.609Z","avatar_url":"https://github.com/DigitalProductschool.png","language":"CSS","funding_links":[],"categories":["CSS"],"sub_categories":[],"readme":"# DPS Frontend Coding Challenge\n\n## Overview\n\nThis repository contains a very basic web application based on Typescript and React. Main application file is `App.tsx`. Node and npm are required.\n\n## Environment Setup\n\nEnsure you have Node.js (v14.x or later) and npm (v6.x or later) installed.  \nTo set up and run the application, execute the following commands:\n\n```\nnpm install\nnpm run dev\n```\n\nThe application will then be accessible at http://localhost:3000.\n\n## Project Context\n\nYou will be enhancing a new CRM (Customer Relationship Management) software aimed at managing customer data efficiently. Your task is to develop a feature that displays a searchable list of customers.\n\nRefer to the attached mockup image to guide your UI development 👇\n\n![Mockup](images/mockup.png)\n\n## Challenge Tasks\n\n-   **Fork this project:** Start by forking this repository\n-   **UI Implementation:** Implement the user interface according to the provided design mockup.\n-   **Data Integration:** Utilize the endpoint https://dummyjson.com/users to fetch user data. If no filter is applied all data is displayed.\n-   **Client-side Filtering:** Implement the following filters:\n    -   **Name Filter:** An input field that dynamically filters by `firstName` or `lastName` as you type.\n    -   **City Filter:** A dropdown that lists all cities present in the data. Users can select a city to filter the list accordingly.\n    -   **Highlight Feature:** A checkbox that when checked, highlights the oldest users within each city (use data field `city`)\n    -   **Optional:** Implement a 1-second debounce on the Name Filter input. This means the application should delay the filter action until 1 second has passed without any further input from the user. This optimization helps reduce the number of processing calls, enhancing performance.\n-   **Submission:** After completing the challenge, email us the URL of your GitHub repository.\n-   **Further information:**\n    -   If there is anything unclear regarding requirements, contact us by replying to our email.\n    -   Use small commits, we want to see your progress towards the solution.\n    -   Code clean and follow the best practices.\n\n\\\nHappy coding!\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FDigitalProductschool%2Fdps-react-challenge","html_url":"https://awesome.ecosyste.ms/projects/github.com%2FDigitalProductschool%2Fdps-react-challenge","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FDigitalProductschool%2Fdps-react-challenge/lists"}