-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathtext-input.html
142 lines (122 loc) · 5.62 KB
/
text-input.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
<script type="text/x-red" data-template-name="ui_text-input">
<div class="form-row">
<label for="node-input-group"><i class="fa fa-table"></i> Group</label>
<input type="text" id="node-input-group">
</div>
<div class="form-row">
<label><i class="fa fa-object-group"></i> Size</label>
<input type="hidden" id="node-input-width">
<input type="hidden" id="node-input-height">
<button class="editor-button" id="node-input-size"></button>
</div>
<div class="form-row">
<label for="node-input-mode"><i class="fa fa-keyboard-o"></i> Mode</label>
<select style="width:128px" id="node-input-mode">
<option value="text">text input</option>
<option value="email">email address</option>
<option value="password">password</option>
<option value="number">number</option>
<option value="tel">telephone input</option>
<option value="color">color picker</option>
<option value="time">time picker</option>
<option value="week">week picker</option>
<option value="month">month picker</option>
</select>
</div>
<div class="form-row">
<label for="node-input-action"><i class="fa fa-tag"></i> Action</label>
<input type="text" id="node-input-action" placeholder="" style="width: 70%;">
<span style="display: block; padding-left: 106px; color: gray; font-size: x-small;">Available actions: Set, Get, Disable, Enable, Hide, Show</span>
<input type="hidden" id="node-input-actionType">
</div>
<div class="form-row">
<label for="node-input-write"><i class="fa fa-pencil"></i> Value</label>
<input type="text" id="node-input-write" style="width:70%;" />
<input type="hidden" id="node-input-writeType">
</div>
<div class="form-row">
<label for="node-input-label"><i class="fa fa-i-cursor"></i> Label</label>
<input type="text" id="node-input-label">
</div>
<div class="form-row">
<label for="node-input-tooltip"><i class="fa fa-info-circle"></i> Tooltip</label>
<input type="text" id="node-input-tooltip" placeholder="optional tooltip">
</div>
<div class="form-row">
<label for="node-input-change"><i class="fa fa-bolt"></i> On change</label>
<input type="checkbox" id="node-input-change" style="display:inline-block; width:auto; margin: 0;">
<span style="padding: 0 5px"> output after </span>
<input type="text" style="width:58px" id="node-input-delay">
<span>(ms)</span>
</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" checked id="node-input-passthru" style="display:inline-block; width:auto; vertical-align:top;">
</div>
<div class="form-row">
<label for="node-input-topic"><i class="fa fa-tags"></i> Topic</label>
<input type="text" id="node-input-topic" placeholder="" style="width: 70%;">
</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>
<div class="form-tips">Setting <b>Delay</b> to 0 waits for Enter or Tab key, to send input.</span></div>
</script>
<script type="text/javascript">
RED.nodes.registerType('ui_text-input', {
category: 'ui',
color: 'rgb(176, 223, 227)',
defaults: {
action: { value: "set", required: true, validate: RED.validators.typedInput("actionType") },
actionType: { value: "str" },
write: { value: "payload", required: false, validate: RED.validators.typedInput("writeType") },
writeType: { value: "msg" },
name: { value: '' },
label: { value: '' },
tooltip: { value: '' },
group: { type: 'ui_group', required: true },
order: { value: 0 },
width: {
value: 0, validate: function (v) {
var width = v || 0;
var currentGroup = $('#node-input-group').val() || this.group;
var groupNode = RED.nodes.node(currentGroup);
var valid = !groupNode || +width <= +groupNode.width;
$("#node-input-size").toggleClass("input-error", !valid);
return valid;
}
},
height: { value: 0 },
passthru: { value: true },
mode: { value: 'text', required: true },
change: { value: true },
delay: { value: 300, validate: RED.validators.number() },
topic: { value: '' }
},
inputs: 1,
outputs: 1,
icon: "text.png",
paletteLabel: "input",
label: function () {
return this.name || "ui input";
},
oneditprepare: function () {
$("#node-input-size").elementSizer({
width: "#node-input-width",
height: "#node-input-height",
group: "#node-input-group"
});
$("#node-input-action").typedInput({
default: 'str',
typeField: $("#node-input-actionType"),
types: ['str', 'msg', 'flow', 'global', 'env']
});
$("#node-input-write").typedInput({
default: 'str',
typeField: $("#node-input-writeType"),
types: ['str', 'msg', 'flow', 'global', 'env']
});
}
});
</script>