Skip to content

rhochmayr/lp-dash

Repository files navigation

Lilypad Dashboard

Lilypad Dasboad (lp-dash) aims to help users to view Lilypad node status. At the moment the site allows to monitor the PoW transactions against multiple nodes.

Currently the dashboard is in development and will be updated with new features and improvements.

Table of Contents

Features

  • Multiple nodes / wallets support
  • Auto-refresh
  • Persistent state using local storage
  • PoW transaction details
  • Node labeling
  • Node metrics (CPU, Memory, GPU, uptime, etc.)
  • Node leaderboard details (rank, energy, points)
  • Bulk addition of nodes

Components

This repository contains a modern dashboard application built with React, TypeScript, and Vite. It leverages various UI components and hooks to provide a seamless user experience.

  • React: A JavaScript library for building user interfaces.
  • TypeScript: A strongly typed programming language that builds on JavaScript.
  • Vite: A fast build tool and development server.
  • Tailwind CSS: A utility-first CSS framework.
  • Radix UI: A set of accessible, unstyled UI components.
  • Custom Hooks: Includes custom hooks like use-toast for toast notifications.

Screenshots

Dashboard

Installation

To get started with lp-dash, clone the repository and install the dependencies:

git clone https://github.com/rhochmayr/lp-dash.git
cd lp-dash
npm install

Usage

To start the development server, run:

npm run dev

This will start the Vite development server and you can view the application at http://localhost:5173.

Adding Multiple Nodes

The Lilypad Node Checker now supports adding multiple nodes at once. You can input or upload multiple node addresses simultaneously. This can be done using a comma-separated list of wallet addresses or a multiline list of wallet addresses.

Instructions

  1. Open the Add Nodes form.
  2. Enter the Ethereum wallet addresses in the input field. You can either:
    • Enter a comma-separated list of wallet addresses.
    • Enter a multiline list of wallet addresses.
  3. Click the "Add Nodes" button.
  4. The form will validate each address individually and add valid addresses.
  5. Invalid addresses will be reported without stopping the addition of other valid addresses.

Scripts

  • dev: Starts the development server.
  • build: Builds the project for production.
  • lint: Runs ESLint to check for linting errors.
  • preview: Previews the production build.

Project Structure

.
├── public/             # Static files
├── src/                # Source files
│   ├── components/     # Reusable components
│   │   ├── controls/   # Form controls
│   │   ├── header/     # Header component
│   │   ├── node/       # Node components
│   │   ├── ui/         # UI components
│   │   ├── wallet/     # Wallet components
│   ├── constants/      # Constants
│   ├── hooks/          # Custom hooks
│   ├── lib/            # Utility functions
│   │   ├── api/        # API functions
│   ├── types/          # Type definitions
├── index.html    
├── README.md
├── ...

Contributing

Contributions are welcome! Please open an issue or submit a pull request for any changes.

License

This project is open source and available under the MIT License.

Releases

No releases published

Packages

No packages published