Light Tag
The Light Tag is a pick-by-light system from NIMMSTA. Each of the Light Tags store their location information on device and can be triggered using the location information. We call the process of defining the location information "Attach". If you reset the location, we call it "Detach".
The following documentation helps you to illuminate, attach a location, and reset a Light Tag location.
Prerequisites
Before starting to use Light Tag methods, you need to have a connection manager, you can use NimmstaConnectionManager to connect to a device.
Glossary
- Light Tag: A Light Tag device is a physical device that can be attached to a location and illuminated.
- Location: A location is a given name by end user to locate a Light Tag device later.
- Attach: The process of setting the location on a Light Tag.
- Detach: The process of resetting a Light Tags location to the default one.
- Illumination: A method to illuminate a Light Tag device.
- LedMode: A mode in which a Light Tag device can be illuminated.
- address: it is Light Tag device Mac Address.
Light Tag Device Basics
Before you start adding your application-specific code, you should know a few basic concepts around the devices:
- Every Light Tag has a unique Mac Address and can Store a "Location". We call the process of defining the Location "Attach".
- The Location is a simple string that can be up to 20 characters long.
- The SDK provides functions to define which Light Tags should be illuminated and with which color and intensity.
- As long as no new information is coming, the SDK will always search for those Light Tags and illuminate them. Also when losing the connection, it will retry doing this.
Check if Light Tag is supported
You can check with a simple property if Light Tag is supported. Please be aware it is only available after onReady:
NIMMSTA.onReady(() => {
    console.log('Light Tag supported', NIMMSTA.isLightTagSupported) // true if supported, false if not and undefined if js lib / app needs update / not ready, yet
});
Supported Configuration
Light Tag LED Mode Color (LTColor)
We have 13 predefined colors, of those the first 6 are very good distinguishable. In addition, we we have an automatic color which is recommended for most cases. The automatic color will choose a color that is not used by other Light Tags currently used by other users connected to the Cloud. If all colors are used or no cloud connection is available, it will pick a random color.
To get your desired color you can use the following predefined colors enum:
export enum LTColor {
  // Very good distinguishable colors
  RED,
  GREEN,
  BLUE,
  YELLOW,
  PURPLE,
  TURQUOISE,
  // less distinguishable colors
  WHITE,
  ORANGE,
  VIOLET,
  FORESTGREEN,
  MAGENTA,
  LIME,
  PINK,
  // Color Modes
  AUTOMATIC, // Recommended for most cases
  RANDOM,
  OFF,
}
Light Tag LED Mode Intensity (LTIntensity)
this value should be something between 0 and 300. All values above 100 mean more than 100% which will decrease battery life.
Light Tag LED Blinking Pattern (LTBlinkingPattern)
this value should be one of the following values:
Attach Location
To attach a location to a LightTag device you can use the following method: It will store the information on the device, so other devices can illuminate it by location. For the successful case, the Light Tag device will blink green.
var deviceAddress = document.getElementById("deviceAddress").value;
var location = document.getElementById("location").value;
connectionManager.attachLocation(deviceAddress, location).then(() => {
    console.log("Location attached");
}).catch((error) => {
    console.error(JSON.stringify(error));
});
Reset Location
To delete location information from a LightTag device you can use the following method:
var deviceAddress = document.getElementById("deviceAddress").value;
connectionManager.detachLocation(deviceAddress).then(() => {
    console.log("Location reset");
}).catch((error) => {
    console.error(JSON.stringify(error));
});
Illumination
To illuminate a light tag, you need to provide the locations of Light Tags being illuminated and also the desired LED Mode. The SDK in the background will make sure to illuminate the Light Tag as long it is in range and also reilluminate it if it goes out of range and comes back in range. There can be a maximum of 5 Light Tags illuminated at the same time. The Light Tags will be illuminated until a new request is received. To turn it off, send a request with an empty deviceList.
function setDesiredLightTagDevices(
      desiredDevices: [lightTag: string],
      ledMode: LEDMode
): Promise<void> {}
desiredDevices is an array of LightTag device locations. Maximum: 5 Locations.
ledMode is a JSON object with the following properties:
- color: LTColor
- pattern: LTBlinkingPattern (DOUBLE, TRIPLE, BLINK, PULSE, OFF)
- intensity: LTIntensity (from 0 to 300, 100 is 100%. It is not recommened to use values above 100)
Illuminate Light Tag
var device = document.getElementById("deviceName").value;
var ledMode = {
    color: LTColor.RED,
    pattern: LTBlinkingPattern.BLINK,
    intensity: parseInt($('#intensity').val()) * 100,
};
connectionManager.setDesiredLightTagDevices([device], ledMode).then(() => {
    console.log("Lighttag started");
}).catch((error) => {
    console.error(JSON.stringify(error));
});
Prepare Light Tag Illumination
Sometimes, it is necessary to prepare the Light Tag illumination before the actual illumination. This improves performance. The same method can be used if you want to use different LED Modes for different Light Tags. Please use App Version 7.3.0 or later.
connectionManager.setDesiredLightTagDevices({
    "location1": {
        color: LTColor.RED,
        pattern: LTBlinkingPattern.BLINK,
        intensity: 100,
    },
    "location2": {
        color: LTColor.GREEN,
        pattern: LTBlinkingPattern.BLINK,
        intensity: 100,
    },
    "location3": {
        color: LTColor.OFF, // prepares the light tag.
        pattern: LTBlinkingPattern.BLINK,
        intensity: 100,
    }
});
connectionManager.setDesiredLightTagDevices({
    "location1": LTColor.RED,
    "location2": LTColor.GREEN,
    "location3": LTColor.OFF, // prepares the light tag.
});
Stop of Light Tag Illumination
to stop illuminating devices you can use the following method:
connectionManager.setDesiredLightTagDevices([]).then(() => {
    console.log("Lighttag reset");
}).catch((error) => {
    console.error(JSON.stringify(error));
})
Search for nearby Light Tags (From App 7.3+)
To search for nearby Light Tags you can use the following method:
Listen to Light Tag Found
const subscription = connectionManager.lightTagFoundEvent.subscribe((lightTag) => {
    console.log("Light Tag Found: " + lightTag);
});
// once not needed anymore, unsubscribe. You still have to call stop manually!
subscription.cancel();