Files
EverShelf/evershelf-kiosk
dadaloop82 9083e25f37 feat(kiosk): add camera, microphone, storage permissions
- Manifest: CAMERA, RECORD_AUDIO, READ_EXTERNAL_STORAGE, READ_MEDIA_IMAGES
- Runtime: requests all permissions on startup (requestAllPermissions)
- WebView: onPermissionRequest checks runtime grants, requests if needed
- onRequestPermissionsResult grants pending WebView permission after user allows
- Camera and mic now work inside the kiosk WebView
2026-04-16 19:07:30 +00:00
..

EverShelf Kiosk

Android kiosk app that displays the EverShelf web interface in full-screen mode while running the Smart Scale BLE Gateway as a background service.

Features

  • Full-screen WebView — displays EverShelf in immersive kiosk mode (no status bar, no navigation)
  • Built-in Scale Gateway — BLE connection to smart scales with WebSocket server on port 8765
  • Auto-reconnect — automatically reconnects to the last connected scale
  • Foreground service — gateway runs even when the screen is off
  • Camera pass-through — allows barcode scanning from within the WebView
  • Error recovery — shows retry page when the server is unreachable

Setup

  1. Install the APK on your Android tablet/phone
  2. On first launch, grant Bluetooth and Location permissions
  3. Tap the subtle ⚙️ icon in the top-right corner to configure the EverShelf server URL
  4. In EverShelf settings, set the Scale Gateway URL to ws://localhost:8765

Architecture

KioskActivity (WebView — full-screen EverShelf)
    ↕ binds to
ScaleGatewayService (foreground service)
    ├── BleScaleManager (BLE scanning + connection)
    │   └── ScaleProtocol (multi-protocol weight parser)
    └── GatewayWebSocketServer (port 8765)
            ↕ WebSocket
        WebView (EverShelf JavaScript connects to ws://localhost:8765)

Building

cd evershelf-kiosk
./gradlew assembleDebug
# APK at app/build/outputs/apk/debug/app-debug.apk

Requirements

  • Android 7.0+ (API 24)
  • Bluetooth Low Energy support
  • Network access to EverShelf server