Skip to content

Latest commit

 

History

History
127 lines (94 loc) · 1.84 KB

README.md

File metadata and controls

127 lines (94 loc) · 1.84 KB

esp-status-light

ESP Status light

Simple multipurpose light to show different statuses on an array of LEDs. Exemplary use case: placed between two office doors, each half of the ring showing if the person within the office is free to talk or occupied.

3D printed case by marcluer is available on Thingiverse.

Setup

Any ESP board with WiFi and a WS2812 LED strip, matrix or ring should work.

This specific config was tested with:

  • Wemos D1 Mini
  • Neopixel ring (24 LEDs)
  • PlatformIO CLI

Define hardware settings in main.h, set up the number of LEDs and segments there.

pio run -t upload

API usage

You can either control the status light via segment numbers or add names to segments in persistent memory.

Set status of a semgent (zero-indexed), default statuses: free, occupied, dnd:

PUT /api/status

Body:
{
  "segment": 1,
  "status": "occupied"
}

Response: 
changed segment 1 to status occupied with brightness 100

Set status of a named segment:

PUT /api/status

Body:
{
  "name": "Bob",
  "status": "free"
}
Response: 
changed segment 3 to status occupied with brightness 100

Add name to segment:

PUT /api/segments

Body:
{
  "segment": 0,
  "name": "Alice"
}

Response:
saved Alice to segment 0

Get current status of a segment:

GET /api/segments?segment=<id>

Response:
{
  "status": "off"
}

Get current status of all segments:

GET /api/segments

Response:
[
  {
    "name": "Alice",
    "position": 0,
    "status": "dnd"
  },
  {
    "name": "Bob",
    "position": 1,
    "status": "free"
  }
]

Toggle light status (keeping segment status):

PUT /api/leds

Body:
{
  "leds": false
}

Response: 
leds set to 0

Set LED brightness from 1 to 100

PUT /api/leds

Body:
{
  "brightness": 42
}

Response: 
leds set to 42