BetterFrame/nodered/src/bf-trigger-kiosk-changed.html

43 lines
1.6 KiB
HTML
Raw Normal View History

<script type="text/javascript">
RED.nodes.registerType("bf-trigger-kiosk-changed", {
category: "BetterFrame Triggers",
color: "#a6d4ff",
defaults: {
name: { value: "" },
kiosk_id: { value: "" },
},
inputs: 0,
outputs: 1,
icon: "betterframe.svg",
label: function () {
return this.name || "kiosk changed";
},
paletteLabel: "Kiosk Changed Trigger",
});
</script>
<script type="text/html" data-template-name="bf-trigger-kiosk-changed">
<div class="form-row">
<label for="node-input-name"><i class="fa fa-tag"></i> Name</label>
<input type="text" id="node-input-name" placeholder="(optional)" />
</div>
<div class="form-row">
<label for="node-input-kiosk_id"><i class="fa fa-tv"></i> Kiosk ID</label>
<input type="number" id="node-input-kiosk_id" placeholder="(blank = all kiosks)" />
</div>
<div class="form-tips">
Triggers on kiosk WS connect/disconnect and heartbeats with hardware telemetry.
Listens on <code>POST /in/kiosk.changed</code> internally — no upstream
<code>http in</code> node required.
Emits <code>msg.payload = {kiosk_id, kiosk_name, event, cpu_temp_c?, fan_rpm?, fan_pwm?}</code>.
Leave Kiosk ID blank to receive events from all kiosks.
</div>
</script>
<script type="text/html" data-help-name="bf-trigger-kiosk-changed">
<p>Fires on kiosk WS connect/disconnect and heartbeats with hardware telemetry.</p>
<p>Listens on <code>POST /in/kiosk.changed</code> internally — no upstream
<code>http in</code> node needed.</p>
<p>Optional <b>Kiosk ID</b> filter limits this node to a single kiosk.</p>
</script>