Skip to content

Commit cb2addb

Browse files
author
Patrick Knabe
committed
Just a commit of current work
1 parent 3bc1652 commit cb2addb

File tree

6 files changed

+410
-0
lines changed

6 files changed

+410
-0
lines changed

CHANGELOG.md

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
# Changelog
2+
3+
## [v1.0.0] - 2020-09-30
4+
5+
### Added
6+
- Functional digital display for the Node-RED Dashboard
7+
- Readme, Changelog and License
8+
9+
[v1.0.0]: https://github.com/patrickknabe/node-red-contrib-ui-digital-display/releases/tag/v1.0.0

digital_display.svg

Lines changed: 248 additions & 0 deletions
Loading

display.html

Lines changed: 70 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,70 @@
1+
<script type="text/javascript">
2+
3+
RED.nodes.registerType( 'ui_digital_display', {
4+
category: 'dashboard',
5+
paletteLabel: 'digital display',
6+
inputs: 1,
7+
outputs: 0,
8+
color: '#2ed7e4',
9+
icon: 'font-awesome/fa-clock-o',
10+
align: 'right',
11+
defaults: {
12+
name: { value: '' },
13+
group: { type: 'ui_group', required: true },
14+
order: { value: 0 },
15+
width: { value: 0, validate: function( width ) {
16+
const group = RED.nodes.node( $( '#node-input-group' ).val() || this.group );
17+
const valid = !group || +width <= +group.width;
18+
19+
$( '#node-input-size' ).toggleClass( 'input-error', !valid );
20+
21+
return valid;
22+
} },
23+
height: { value: 0 }
24+
},
25+
label: function() {
26+
return this.name || 'digital display';
27+
},
28+
oneditprepare: () => {
29+
$( '#node-input-size' ).elementSizer( {
30+
width: "#node-input-width",
31+
height: "#node-input-height",
32+
group: "#node-input-group"
33+
} );
34+
}
35+
} );
36+
37+
</script>
38+
39+
<script type="text/html" data-template-name="ui_digital_display">
40+
<div class="form-row">
41+
<label for="node-input-name"><i class="fa fa-fw fa-tag"></i> Name</label>
42+
<input type="text" id="node-input-name" placeholder="Name" />
43+
</div>
44+
<br />
45+
<div class="form-row" id="template-row-group">
46+
<label><i class="fa fa-fw fa-table"></i> Group</label>
47+
<input type="text" id="node-input-group" />
48+
</div>
49+
<div class="form-row" id="template-row-size">
50+
<label><i class="fa fa-fw fa-object-group"></i> Size</label>
51+
<input type="hidden" id="node-input-width" />
52+
<input type="hidden" id="node-input-height" />
53+
<button id="node-input-size" class="editor-button"></button>
54+
</div>
55+
</script>
56+
57+
<script type="text/html" data-help-name="ui_digital_display">
58+
<p style="text-align: justify;">
59+
A digital display, with adjustable number of digits and decimal places, for the Node-RED Dashboard.
60+
</p>
61+
<br />
62+
<p style="text-align: center;">
63+
<img alt="ui_digital_display" src="" />
64+
</p>
65+
<br />
66+
<p style="text-align: justify;">
67+
The time to be displayed is transferred as timestamp (milliseconds since 01.01.1970) in
68+
<code>msg.payload</code>. The local time is displayed in the dashboard.
69+
</p>
70+
</script>

display.js

Lines changed: 45 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,45 @@
1+
module.exports = RED => {
2+
let ui;
3+
4+
RED.nodes.registerType( 'ui_digital_display', function( config ) {
5+
RED.nodes.createNode( this, config );
6+
7+
if( !ui ) {
8+
try {
9+
ui = RED.require( 'node-red-dashboard' )( RED );
10+
} catch {}
11+
}
12+
13+
if( ui && RED.nodes.getNode( config.group ) ) {
14+
this.on( 'close', ui.addWidget( {
15+
node: this,
16+
format: `
17+
<div style="border-bottom: 1px solid #000000; font-size: 16px; font-weight: bold; margin: 0 0 10px;">Hurz der Habicht</div>
18+
<div style="display: flex; height: 100%; justify-content: flex-end; margin: 0 0 10px;">
19+
<svg ng-repeat="x in [].constructor( 2 ) track by $index" style="height: 100%;" version="1.1" viewBox="0 0 660 1000" xmlns="http://www.w3.org/2000/svg">
20+
<path d="m581.06 885.86h51.994l26.941 58.193-34.923 55.952h-51.994l-25.991-56.215z" />
21+
<path d="m73.685 963.97 83.764-78.112h233.35l72.84 78.112-38.641 36.033h-317.71z" />
22+
<path d="m525.64 542.51 27.085 29.045-23.14 330.91-27.204 25.368-79.153-84.881 15.331-219.24z" />
23+
<path d="m68.05 539.75 62.822 67.368-17.266 246.91-76.188 71.046-37.419-40.127 21.076-301.4z" />
24+
<path d="m171.1 443.65h262.35l55.921 59.968-58.717 54.612h-272.94l-50.926-54.612z" />
25+
<path d="m454.96 389.16 15.725-224.88 95.964-89.488 19.36 20.761-23.784 340.13-34.168 31.863z" />
26+
<path d="m87.115 72.249 75.498 80.961-16.917 241.93-74.915 69.86-38.525-41.313 22.462-321.23z" />
27+
<path d="m164.59 7.6241e-5h332.31l33.735 36.176-84.078 78.404h-247.65l-73.113-78.404z" />
28+
</svg>
29+
</div>
30+
`,
31+
width: config.width,
32+
height: +config.height || RED.nodes.getNode( config.group ).config.width,
33+
group: config.group,
34+
order: config.order,
35+
initController: $scope => $scope.$watch( 'msg.payload', payload => {
36+
const date = new Date( +payload || 0 );
37+
38+
$( `#ui_clock_${ $scope.$id }_s` ).attr( 'transform', `rotate( ${ date.getSeconds() * 6 }, 500, 500 )` );
39+
$( `#ui_clock_${ $scope.$id }_m` ).attr( 'transform', `rotate( ${ ( date.getMinutes() + date.getSeconds() / 60 ) * 6 }, 500, 500 )` );
40+
$( `#ui_clock_${ $scope.$id }_h` ).attr( 'transform', `rotate( ${ ( date.getHours() + date.getMinutes() / 60 ) * 30 }, 500, 500 )` );
41+
} )
42+
} ) );
43+
}
44+
} );
45+
};

package-lock.json

Lines changed: 5 additions & 0 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

0 commit comments

Comments
 (0)