Skip to content

Decentralized application (DApp) focused on end-user sensors networks.

License

Notifications You must be signed in to change notification settings

zirreal/sensors.robonomics.network

 
 

Repository files navigation

sensors.social

📌 Overview

sensors.social is a decentralized application that visualizes data from sensors sending their measurements to the blockchain (Polkadot network, Robonomics parachain). The platform supports two modes of operation:

  • Peer-to-peer connectivity for direct access to sensor data.
  • Federative concept for accumulating sensor data and displaying measurement history.

For more details on connectivity and how to deploy your own map interface (or even a connectivity server), visit Robonomics Academy.

🚀 Deployment

1️⃣ Clone the Repository

Simply clone the repository and navigate to the project directory:

 git clone https://github.com/airalab/sensors.social.git
 cd sensors.social

If you plan to contribute or customize the project extensively, consider forking it first.

2️⃣ Install Dependencies

Ensure Node.js and Yarn are installed:

 node -v  # Should be >= 16
 yarn -v  # Should be installed

Then install the required dependencies:

 yarn install

3️⃣ Start the Server Locally for Development

 yarn dev

🔧 Setup Your Own Map (For Experienced Users)

1️⃣ Deploy Your Own Instance of the Map

2️⃣ Enable GitHub Actions

To activate GitHub Actions in your repository:

  • Navigate to the Actions tab in your GitHub repository.
  • If prompted, enable workflows by clicking Enable GitHub Actions.
  • Ensure that workflows are correctly set up in .github/workflows/.

3️⃣ Configure Deployment

Option 1: Deploy Without a Custom Domain

  • Open .github/workflows/main.yaml and remove the line:
    cname: sensors.social
  • Add the following permissions block right below runs-on: ubuntu-latest:
    permissions:
      contents: write
  • In vite.config.js, add the following line to the defineConfig object, just above the plugins section:
    base: "/<repository_name>/",
    Replace <repository_name> with the name of your fork.

Option 2: Deploy With a Custom Domain

  • Open .github/workflows/main.yaml and replace:
    cname: sensors.social
    with your custom domain:
    cname: your-custom-domain.com
  • Add the following permissions block right below runs-on: ubuntu-latest:
    permissions:
      contents: write

4️⃣ Finalizing Deployment

After modifying the necessary files, deploy your instance of the map by following these steps:

  1. Commit and push the changes to your forked repository:
    git add .
    git commit -m "Configured deployment settings"
    git push origin main
  2. Wait until the GitHub Actions workflow successfully completes.
  3. Navigate to the Pages section in your repository Settings.
  4. Enable GitHub Pages by selecting Deploy from a branch as the source.
  5. Choose the gh-pages branch and the root folder.
  6. Save the settings—GitHub Pages will deploy your instance of the map.

You can now access your deployed map using the provided GitHub Pages URL.

💬 Localization & Translations

You can add a new language to the map by modifying the translation files located in src/translate/.

📝 Adding a New Language

1️⃣ Create a new translation file in src/translate/, e.g., es.js.

2️⃣ Update index.js in the same folder:

  • Import your newly created translation file:
import es from "./es";

export default { en, ru, es };
  • Add the new language to the language list:
  export const languages = [
    { code: "en", title: "English" },
    { code: "ru", title: "Русский" },
    { code: "es", title: "Español" },
  ];

📏 Translating Measurements

Measurement values are located in src/measurements/.
To support multiple languages, update the relevant files in this folder.

Files to Update

Measurement Type File Name
Carbon Monoxide co.js
Background Radiation gs.js
Humidity humidity.js
Ammonia (NH₃) nh3.js
Nitrogen Dioxide (NO₂) no2.js
Noise Levels noise.js, noiseavg.js, noisemax.js
PM10 Particulate Matter pm10.js
PM2.5 Particulate Matter pm25.js
Pressure pressure.js
Temperature temperature.js

Example Translation Update (humidity.js)

To add support for Spanish (es), update the name, nameshort, and zones properties:

     name: {  
       en: "Humidity",  
       ru: "Влажность",  
       es: "Humedad"  
     },  
     nameshort: {  
       en: "Humidity",  
       ru: "Влажность",  
       es: "Humedad"  
     },  

     zones: [  
       {  
         value: 30,  
         color: "#ff4d00",  
         label: {  
           en: "Very dry",  
           ru: "Очень сухо",  
           es: "Muy seco"  
         }  
       }  
     ]  

❓ Support

For questions or suggestions, create an issue in the repository.


About

Decentralized application (DApp) focused on end-user sensors networks.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Vue 57.1%
  • JavaScript 35.3%
  • CSS 7.2%
  • HTML 0.4%