This repository contains the implementation of a simple frontend application for the S4E.io platform. The application replicates a scan tools list with filtering, responsive design, and local state persistence. It is built using Next.js, Tailwind CSS, and ShadCN UI.
You can have a look at the live preview link:
data:image/s3,"s3://crabby-images/cf223/cf223aeba13cdc84fb675113e6067a31659cc0c4" alt="Screenshot 2025-01-06 at 03 38 33"
data:image/s3,"s3://crabby-images/06c8b/06c8bf79a4e1f4ad7a365282a14f7e81d832caac" alt="Screenshot 2025-01-06 at 03 43 22"
data:image/s3,"s3://crabby-images/46c63/46c63f6168aefc78b6253901a637537087bf1b46" alt="Screenshot 2025-01-06 at 03 44 12"
data:image/s3,"s3://crabby-images/8b2f7/8b2f71939f8bde82cbd0d429bf0ec04bd1ce8c8c" alt="Screenshot 2025-01-06 at 00 14 43"
data:image/s3,"s3://crabby-images/85e61/85e61ea7ac2d1ff9ce8fa200d3f055f8446a481e" alt="image"
data:image/s3,"s3://crabby-images/8e09c/8e09c608d00e29557af12f7b7e9dd5cdc9509bcb" alt="Screenshot 2025-01-06 at 03 38 14"
data:image/s3,"s3://crabby-images/881e5/881e5e875cc0f8a7b15d6371606d8ac4626c9786" alt="Screenshot 2025-01-06 at 03 43 33"
data:image/s3,"s3://crabby-images/8e788/8e78848aa0ed79b62470d2015b55fd100ba332d3" alt="Screenshot 2025-01-06 at 03 43 54"
data:image/s3,"s3://crabby-images/5a952/5a952df2a72b4ee55ebfca5d0de09e0e5bedb558" alt="Screenshot 2025-01-06 at 03 53 19"
data:image/s3,"s3://crabby-images/6fa7e/6fa7e048cd2666a0af116a8e9f7d0322b2b5d150" alt="Screenshot 2025-01-06 at 04 09 05"
data:image/s3,"s3://crabby-images/54186/541868c551b1f883173eb2f35ad0c71eba03c862" alt="image"
S4E.io is a cybersecurity platform that continuously detects and reports system vulnerabilities. This project focuses on implementing the scan tools list available at S4E.io Scan Tools.
-
Responsive Design
- Implements a sidebar navigation and table-based layout.
- Supports both light and dark themes.
-
Table Functionality
- Filters based on
scan category
andsearch
. - Persisted filters using local storage to maintain the state after refresh or browser restart.
- Paginated table for better data visualization.
- Filters based on
-
Error Handling
- Displays user-friendly messages for API errors.
-
Backend Integration
- Fetches scan tools data via API from
https://app.s4e.io/api-token
. - Uses
fetch
for data retrieval.
- Fetches scan tools data via API from
- Next.js: Framework for server-side rendering and routing.
- Tailwind CSS: Utility-first CSS framework.
- ShadCN UI: Component library for consistent design.
- Zustand: State management library for managing table filters and persistence.
- TypeScript: Typed JavaScript for improved developer experience.
app/
βββ components/ # Placeholder for reusable React components.
βββ config/ # API endpoints and configuration files.
β βββ endpoints.ts # Endpoint configuration.
βββ lib/ # Utility functions and data definitions.
β βββ data.ts # Mock or utility data.
β βββ definitions.ts # TypeScript type definitions.
βββ scanners/ # Components and logic specific to the scan tools list.
β βββ columns.tsx # Table column definitions.
β βββ dataTable.tsx # Data table implementation.
β βββ page.tsx # Main page for displaying the scan tools list.
βββ seed/ # Seeder data for development.
β βββ seedScannersData.ts
βββ store/ # Zustand state management logic.
β βββ localStorageService.ts # Utilities for managing local storage.
β βββ queryStore.ts # Zustand store for filters and table state.
βββ ui/ # UI components like navigation and sidebar.
β βββ navLinks.tsx # Links for navigation.
β βββ sidenav.tsx # Sidebar component.
βββ utils/ # General utility functions.
β βββ utils.ts
βββ globals.css # Global styles.
βββ layout.tsx # App layout component.
βββ page.tsx # Root page implementation.
- Node.js (version >= 18.x recommended)
- npm, yarn, or pnpm
-
Clone the repository:
git clone https://github.com/your-username/s4e-frontend-task.git cd s4e-frontend-task
-
Install dependencies:
npm install
or
yarn install
or
pnpm install
-
Start the development server:
npm run dev
or
yarn dev
or
pnpm dev
-
Open the application in your browser:
- Navigate to the Tools List section.
- Use the Search or Category Filter to refine results.
- Switch between Light and Dark themes using the toggle button.
- Navigate through pages using the pagination controls.
- Endpoint: List of All Scans
- Data Fetching: Uses the fetch API for retrieving scan tools data.