UNPKG

node-red-contrib-smartnora

Version:

Google Smart Home integration via Smart Nora https://smart-nora.eu/

168 lines (166 loc) 6.71 kB
<script type="text/javascript"> RED.nodes.registerType('noraf-vacuum', { category: 'nora', color: 'rgb(235, 227, 141)', icon: 'assistant.png', defaults: { devicename: { value: 'Vacuum', required: true, }, roomhint: { value: '' }, name: { value: '' }, onOffSupported: { value: true, }, onOffMode: { value: 'cq' }, dockSupported: { value: false, }, returnDockErrorCodeIfAlreadyDocked: { value: false, }, startStopPausable: { value: true }, topic: { value: '' }, passthru: { value: false, }, nora: { type: 'noraf-config', required: true }, twofactor: { value: 'off', }, twofactorpin: { value: '' }, filter: { value: false, }, }, inputs: 1, outputs: 1, paletteLabel: 'vacuum', label: function () { return this.name || this.devicename || 'vacuum'; }, oneditprepare: function () { $('#node-input-onOffSupported').change(function () { $('#onOff-support')[$(this).is(':checked') ? 'show' : 'hide'](); }); $('#node-input-dockSupported').change(function () { $('#dock-support')[$(this).is(':checked') ? 'show' : 'hide'](); }); $('#node-input-twofactor').change(function () { if ($(this).val() === 'pin') { $('#node-twofactor-pin').show(); } else { $('#node-twofactor-pin').hide(); } }); }, oneditsave: function () { }, }); </script> <script type="text/html" data-template-name="noraf-vacuum"> <style> .trait-support { margin-left: 5px; border-left: 1px solid lightgray; padding-left: 10px; padding-top: 10px; margin-top: -15px; margin-bottom: 5px; } </style> <div class="form-row"> <label for="node-input-nora"><i class="fa fa-table"></i> Config</label> <input type="text" id="node-input-nora"> </div> <div class="form-row"> <label for="node-input-devicename"><i class="fa fa-i-cursor"></i> Vacuum Name</label> <input type="text" id="node-input-devicename"> </div> <div class="form-row"> <label style="width:auto" for="node-input-passthru"><i class="fa fa-arrow-right"></i> If <code>msg</code> arrives on input, pass through to output: </label> <input type="checkbox" id="node-input-passthru" style="display:inline-block; width:auto; vertical-align:top;"> </div> <div class="form-row"> <label style="width:auto" for="node-input-filter"><i class="fa fa-filter"></i> Ignore input messages that don't match the <code>topic</code> value: </label> <input type="checkbox" id="node-input-filter" style="display:inline-block; width:auto; vertical-align:top;"> </div> <div class="form-row"> <label style="width:auto"><i class="fa fa-play"></i> Start / Stop</label> </div> <div id="startStop-support" class="trait-support"> <div class="form-row"> <label style="width:auto" for="node-input-startStopPausable"> Pausable </label> <input type="checkbox" id="node-input-startStopPausable" style="display:inline-block; width:auto; vertical-align:top;"> </div> </div> <div class="form-row"> <label style="width:auto" for="node-input-onOffSupported"><i class="fa fa-power-off"></i> On / Off</label> <input type="checkbox" id="node-input-onOffSupported" style="display:inline-block; width:auto; vertical-align:top;"> </div> <div id="onOff-support" class="trait-support"> <div class="form-row"> <label for="node-input-onOffMode"> Mode</label> <select id="node-input-onOffMode"> <option value="cq">command & query</option> <option value="c">command only</option> <option value="q">query only</option> </select> </div> </div> <div class="form-row"> <label style="width:auto" for="node-input-dockSupported"><i class="fa fa-map-marker"></i> Dock trait support</label> <input type="checkbox" id="node-input-dockSupported" style="display:inline-block; width:auto; vertical-align:top;"> </div> <div id="dock-support" class="trait-support"> <div class="form-row"> <label style="width:auto" for="node-input-returnDockErrorCodeIfAlreadyDocked"><i class="fa fa-exclamation-triangle"></i> If dock state doesn't change via voice, warn user: </label> <input type="checkbox" id="node-input-returnDockErrorCodeIfAlreadyDocked" style="display:inline-block; width:auto; vertical-align:top;"> </div> </div> <div class="form-row"> <label for="node-input-roomhint"><i class="fa fa-i-cursor"></i> Room Hint</label> <input type="text" id="node-input-roomhint"> </div> <div class="form-row"> <label for="node-input-twofactor"><i class="fa fa-question-sign"></i> Two Factor</label> <select id="node-input-twofactor"> <option value="off">None</option> <option value="ack">Acknowledge</option> <option value="pin">Pin</option> </select> </div> <div id="node-twofactor-pin" class="form-row"> <label for="node-input-twofactorpin"><i class="fa fa-code"></i> Pin</label> <input type="text" id="node-input-twofactorpin"> </div> <div class="form-row"> <label for="node-input-topic" style="padding-left:25px; margin-right:-25px">Topic</label> <input type="text" id="node-input-topic"> </div> <div class="form-row"> <label for="node-input-name"><i class="fa fa-tag"></i> Name</label> <input type="text" id="node-input-name"> </div> </script> <script type="text/html" data-help-name="noraf-vacuum"> <p> <a href="https://github.com/andrei-tatar/node-red-contrib-smartnora/blob/master/doc/nodes/vacuum/README.md">https://github.com/andrei-tatar/node-red-contrib-smartnora/blob/master/doc/nodes/vacuum/README.md</a> </p> </script>