Swamped TV Dashboard is a Next.js-powered analytics platform tailored for setup box data analysis. Harnessing the power of Elasticsearch, it offers insights into channel performance, top channels, slow channels, device monitoring, and configuration. Built with a modular Redux store and intuitive UI components.
This dashboard is designed to analyze and visualize data retrieved from an Elasticsearch database. It offers insights into various aspects of setup box data, such as channel performance, top channels, slow channels, device monitoring, and configuration details.
- Next.js - A React framework for server-rendered applications.
- UI Library - @mui/joy for building user interfaces.
- State Management - Redux and Redux-Saga for managing application state.
- Charts - Chart.js and Highcharts for data visualization.
- @elastic/elasticsearch - JavaScript client for Elasticsearch.
To run this dashboard locally, follow these steps:
Node.js Runtime: 18.x or newer;
- Install dependencies:
npm install
- Configure Elasticsearch:
- Ensure you have Elasticsearch up and running, and configure the data.
- For simple setup, you can check elasticdb folder
- For secure setup, you can check elastic_secure folder
- Add dummy data to elastic search db:
- For initial data in the elastic db you can setup using es_data_provider
- Setup .env:
- Create .env file, and put env variables like in example.env file
- For secure elastic connection put env variables like in example.secure.env file
- Start the development server:
- install dependencies
npm install
-
run development server
npm run dev
This command will start the Next.js development server, and you can access the dashboard in your browser at http://localhost:3000.
- Deploying using docker and nginx:
-
Make sure to put proper elastic search url at NEXT_ELASTIC_URL. Avoid
http://localhost:9200
orhttp://120.0.0.1:9200
. If your elastic search is running locally on the machine, you should use hosted domain or ip at the place oflocalhost
. -
In secure elastic connection, NEXT_ELASTIC_URL with start with
https://
. -
Run docker compose
docker-compose up -d
This command will serve the Next.js app, and you can access the dashboard in your browser at http://localhost.
Here's the folder structure for the project:
- app/: Next.js navigation related folder representing different sections of the
dashboard
and server sideapi
related to elastic search and auth. For more detail see here. - data/: This directory contains the API repository and any data-related files.
- domain/: Here we put business logics. In the domain folder we have Redux Store and module specific folder.
swamped-dashboard/
│
├── app/
│ ├── (dashboard)
│ │ ├── actions/
│ │ │ └── report-generation/
│ │ │ ├── page.tsx
│ │ │ └── styles.module.scss
│ │ │
│ │ ├── analysis/
│ │ ├── configuration/
│ │ ├── map/
│ │ └── layout.tsx
│ │
│ ├── api
│ │ ├── auth/
│ │ │ ├── login/
│ │ │ └── ..
│ │ │
│ │ ├── elastic/
│ │ │ ├── bouquets/
│ │ │ ├── ..
│ │ │ └── api.constants.ts
│ │ │
│ │ └── api.constants.ts
│ │
│ ├── auth/
│ ├── favicon.ico
│ ├── layout.tsx
│ ├── page.tsx
│ └── ...
│
├── data/
│ ├── api/
│ │ ├── api.constants.ts
│ │ └── ..
│ │
│ ├── elastic/
│ │ ├── bouquets
│ │ │ └── bouquets.ts
│ │ └── ..
│ │
├── domain/
│ ├── charts
│ │ └── helper.ts
│ │
│ ├── ..
│ └── store/
│ ├── deviceMonitor/
│ │ ├── reducer.ts
│ │ ├── saga.ts
│ │ └── selector.ts
│ │
│ ├── ..
│ ├── store.constants.ts
│ └── store.ts
│
├── resources/
│ ├── styles/
│ └── ...
│
├── tools/
│ ├── global.css
│ └── ...
|
├── types/
│ ├── analysis/
│ └── ...
|
├── ui/
│ ├── sections/
│ │ ├── actions/
│ │ │ └── ReportGeneration/
│ │ │ ├── ReportGeneration.module.scss
│ │ │ └── ReportGeneration.tsx
│ │ │
│ │ └── ...
│ │
│ ├── common/
│ ├── components/
│ ├── widgets/
│ ├── global.css
│ └── ...
│
├── .gitignore
├── package.json
├── README.md
└── ...
The Elastic Search API is built using the following technology:
- @elastic/elasticsearch: The official JavaScript client for Elasticsearch, used to query and interact with the Elasticsearch database.
The Elastic Search API provides various endpoints for data retrieval and aggregation:
- events/: Handles aggregation, hits, filters queries for event data.
- cities/: Contains logic for getting cities list.
- pincodes/: Contains logic for getting pincodes from event related index.
- bouquets/: Contains logic for getting bouquets from event related index.
- channels/: Contains logic for getting channels from event related index.
These endpoints are responsible for retrieving and processing data from the Elasticsearch database to populate the Next.js dashboard with relevant information.
These apis is called from data/api/elastic
folder, which is client side code. Which is connect in Redux store's saga related files.
For example: Check this file
for saga connection to api related to cities.
The project uses Redux, a predictable state container for webapp, to manage state. You can learn more about Redux in the official Redux documentation.
The Redux store in the project is built using the following technologies:
- Redux: A predictable state container webapp.
- Redux-Saga: A library for managing side effects in Redux applications. For example calling api on effect of action.
Each module within the store/
directory represents a specific part of your application's state management. These states are in use inside ui/
and in app/
folder. Here's a brief description of one of the module:
- deviceMonitor/: Contains the state management logic and files related to Device Monitor section in dashboard. Including the following files:
reducer.ts
: Defines the Redux reducer for Module 2.saga.ts
: Manages asynchronous actions and side effects for Moduleselector.ts
: Provides selectors to access specific parts of state.
For other modules you can check into folder domain/store/
The dashboard consists of several pages, each dedicated to a specific information of the setup box data analysis. This is made according to nextJs navigation more detail here. Here's an overview of the available dashboard pages:
- Channel Performance: Displays performance metrics for various channels based on bouquet and bouquet channels selected.
- Top Channels: Provides insights into the top-performing channels based on different filters.
- Slow Channels: Provides insights into the slow-performing channels based on different filters.
- Device Monitor: Offers real-time monitoring of device status and statistics.
- Configuration: Allows users to view and manage setup box configurations.
The user interface (UI) of the dashboard is organized into different sections, each responsible for presenting specific data and functionalities. These sections include:
- Channel Performance Section: Visualizes channel performance data.
- Top Channels Section: Presents information about top-performing channels.
- Slow Channels Section: Highlights channels with performance problems.
- Device Monitor Section: Displays real-time device monitoring data.
- Configuration Section: Provides a user interface for managing setup box configurations.