2014-08-31 18:08:00 +02:00
|
|
|
gui.widgets.LineEdit = {
|
|
|
|
new: func(parent, style, cfg)
|
|
|
|
{
|
|
|
|
var m = gui.Widget.new(gui.widgets.LineEdit);
|
|
|
|
m._cfg = Config.new(cfg);
|
|
|
|
m._focus_policy = m.StrongFocus;
|
|
|
|
m._setView( style.createWidget(parent, "line-edit", m._cfg) );
|
|
|
|
|
|
|
|
m.setLayoutMinimumSize([28, 16]);
|
|
|
|
m.setLayoutSizeHint([150, 28]);
|
|
|
|
|
|
|
|
m._text = "";
|
|
|
|
m._max_length = 32767;
|
|
|
|
m._cursor = 0;
|
|
|
|
m._selection_start = 0;
|
|
|
|
m._selection_end = 0;
|
|
|
|
|
2023-01-06 12:21:26 +01:00
|
|
|
m.context_menu = gui.Menu.new();
|
2023-01-08 15:35:46 +01:00
|
|
|
m.context_menu.createItem(text: "Copy", cb: func() { m.copy(); }, shortcut: "<Ctrl>+C");
|
|
|
|
m.context_menu.createItem(text: "Cut", cb: func() { m.cut(); }, shortcut: "<Ctrl>+X");
|
|
|
|
m.context_menu.createItem(text: "Paste", cb: func() { m.paste(); }, shortcut: "<Ctrl>+V");
|
|
|
|
m.context_menu.createItem(text: "Clear", cb: func() { m.clear(); }, shortcut: "<Ctrl>+D");
|
|
|
|
m.context_menu.createItem(text: "Select all", cb: func() { m.selectAll(); }, shortcut: "<Ctrl>+A");
|
|
|
|
m.context_menu.setCanvasItem(m);
|
2023-01-06 12:21:26 +01:00
|
|
|
|
2014-08-31 18:08:00 +02:00
|
|
|
return m;
|
|
|
|
},
|
2023-01-06 12:21:26 +01:00
|
|
|
showContextMenu: func(e) {
|
|
|
|
me.context_menu.show(e.screenX, e.screenY);
|
|
|
|
},
|
2014-09-01 19:31:25 +02:00
|
|
|
setText: func(text)
|
|
|
|
{
|
2022-06-30 12:39:41 +02:00
|
|
|
if (text == nil) {
|
|
|
|
me.clear();
|
|
|
|
return me;
|
|
|
|
}
|
|
|
|
|
2014-09-01 19:31:25 +02:00
|
|
|
me._text = utf8.substr(text, 0, me._max_length);
|
|
|
|
me._cursor = utf8.size(me._text);
|
|
|
|
me._selection_start = me._cursor;
|
|
|
|
me._selection_end = me._cursor;
|
|
|
|
|
|
|
|
if( me._view != nil )
|
|
|
|
me._view.setText(me, me._text);
|
2014-11-23 23:35:26 +01:00
|
|
|
|
|
|
|
return me;
|
2014-09-01 19:31:25 +02:00
|
|
|
},
|
2022-06-30 12:39:41 +02:00
|
|
|
clear: func
|
|
|
|
{
|
|
|
|
me._text = "";
|
|
|
|
me._cursor = 0;
|
|
|
|
me._selection_start = 0;
|
|
|
|
me._selection_end = 0;
|
|
|
|
|
|
|
|
if( me._view != nil )
|
|
|
|
me._view.setText(me, "");
|
|
|
|
},
|
2014-09-01 19:31:25 +02:00
|
|
|
text: func()
|
|
|
|
{
|
|
|
|
return me._text;
|
|
|
|
},
|
2023-01-06 12:21:26 +01:00
|
|
|
selectedText: func() {
|
|
|
|
return utf8.substr(me._text, me._selection_start, me._selection_end);
|
|
|
|
},
|
2014-08-31 18:08:00 +02:00
|
|
|
setMaxLength: func(len)
|
|
|
|
{
|
|
|
|
me._max_length = len;
|
|
|
|
|
|
|
|
if( utf8.size(me._text) <= len )
|
2014-11-23 23:35:26 +01:00
|
|
|
return me;
|
2014-08-31 18:08:00 +02:00
|
|
|
|
|
|
|
me._text = utf8.substr(me._text, 0, me._max_length);
|
|
|
|
me.moveCursor(me._cursor);
|
2014-11-23 23:35:26 +01:00
|
|
|
return me;
|
2014-08-31 18:08:00 +02:00
|
|
|
},
|
|
|
|
moveCursor: func(pos, mark = 0)
|
|
|
|
{
|
|
|
|
var len = utf8.size(me._text);
|
|
|
|
me._cursor = math.max(0, math.min(pos, len));
|
|
|
|
|
|
|
|
me._selection_start = me._cursor;
|
|
|
|
me._selection_end = me._cursor;
|
|
|
|
|
|
|
|
me._onStateChange();
|
2014-11-23 23:35:26 +01:00
|
|
|
return me;
|
2014-08-31 18:08:00 +02:00
|
|
|
},
|
|
|
|
home: func()
|
|
|
|
{
|
|
|
|
me.moveCursor(0);
|
|
|
|
},
|
|
|
|
end: func()
|
|
|
|
{
|
|
|
|
me.moveCursor(utf8.size(me._text));
|
|
|
|
},
|
|
|
|
# Insert given text after cursor (and first remove selection if set)
|
|
|
|
insert: func(text)
|
|
|
|
{
|
|
|
|
var after = utf8.substr(me._text, me._selection_end);
|
|
|
|
me._text = utf8.substr(me._text, 0, me._selection_start);
|
|
|
|
|
|
|
|
# Replace selected text, insert new text and place cursor after inserted
|
|
|
|
# text
|
|
|
|
var remaining = me._max_length - me._selection_start - utf8.size(after);
|
|
|
|
if( remaining != 0 )
|
|
|
|
me._text ~= utf8.substr(text, 0, remaining);
|
|
|
|
|
|
|
|
me._cursor = utf8.size(me._text);
|
|
|
|
me._selection_start = me._cursor;
|
|
|
|
me._selection_end = me._cursor;
|
|
|
|
|
|
|
|
me._text ~= after;
|
|
|
|
|
|
|
|
if( me._view != nil )
|
|
|
|
me._view.setText(me, me._text);
|
2014-11-23 23:35:26 +01:00
|
|
|
|
|
|
|
return me;
|
2014-08-31 18:08:00 +02:00
|
|
|
},
|
2023-01-06 12:21:26 +01:00
|
|
|
copy: func() {
|
|
|
|
clipboard.setText(me.selectedText());
|
|
|
|
},
|
|
|
|
cut: func() {
|
|
|
|
clipboard.setText(me.selectedText());
|
|
|
|
me.removeSelection();
|
|
|
|
},
|
2014-08-31 18:08:00 +02:00
|
|
|
paste: func(mode = nil)
|
|
|
|
{
|
|
|
|
me.insert(clipboard.getText(mode != nil ? mode : clipboard.CLIPBOARD));
|
|
|
|
},
|
2023-01-06 12:21:26 +01:00
|
|
|
selectAll: func() {
|
|
|
|
me._selection_start = 0;
|
|
|
|
me._selection_end = utf8.size(me._text) - 1;
|
|
|
|
},
|
2014-08-31 18:08:00 +02:00
|
|
|
# Remove selected text
|
|
|
|
removeSelection: func()
|
|
|
|
{
|
|
|
|
if( me._selection_start == me._selection_end )
|
2014-11-23 23:35:26 +01:00
|
|
|
return me;
|
2014-08-31 18:08:00 +02:00
|
|
|
|
|
|
|
me._text = utf8.substr(me._text, 0, me._selection_start)
|
|
|
|
~ utf8.substr(me._text, me._selection_end);
|
|
|
|
|
|
|
|
me._cursor = me._selection_start;
|
|
|
|
me._selection_end = me._selection_start;
|
|
|
|
|
|
|
|
if( me._view != nil )
|
|
|
|
me._view.setText(me, me._text);
|
2014-11-23 23:35:26 +01:00
|
|
|
|
|
|
|
return me;
|
2014-08-31 18:08:00 +02:00
|
|
|
},
|
|
|
|
# Remove selection or if nothing is selected the character before the cursor
|
|
|
|
backspace: func()
|
|
|
|
{
|
|
|
|
if( me._selection_start == me._selection_end )
|
|
|
|
{
|
|
|
|
if( me._selection_start == 0 )
|
|
|
|
# Before first character...
|
2014-11-23 23:35:26 +01:00
|
|
|
return me;
|
2014-08-31 18:08:00 +02:00
|
|
|
|
|
|
|
me._selection_start -= 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
me.removeSelection();
|
2014-11-23 23:35:26 +01:00
|
|
|
return me;
|
2014-08-31 18:08:00 +02:00
|
|
|
},
|
|
|
|
# Remove selection or if nothing is selected the character after the cursor
|
2023-01-06 12:21:26 +01:00
|
|
|
delete: func()
|
2014-08-31 18:08:00 +02:00
|
|
|
{
|
|
|
|
if( me._selection_start == me._selection_end )
|
|
|
|
{
|
|
|
|
if( me._selection_end == utf8.size(me._text) )
|
|
|
|
# After last character...
|
2014-11-23 23:35:26 +01:00
|
|
|
return me;
|
2014-08-31 18:08:00 +02:00
|
|
|
|
|
|
|
me._selection_end += 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
me.removeSelection();
|
2014-11-23 23:35:26 +01:00
|
|
|
return me;
|
2014-08-31 18:08:00 +02:00
|
|
|
},
|
|
|
|
# protected:
|
|
|
|
_setView: func(view)
|
|
|
|
{
|
|
|
|
call(gui.Widget._setView, [view], me);
|
|
|
|
|
|
|
|
var el = view._root;
|
2023-01-08 15:35:46 +01:00
|
|
|
el.addEventListener("keypress", func (e) {
|
|
|
|
if (!e.ctrlKey and !e.altKey and !e.metaKey) {
|
|
|
|
me.insert(e.key);
|
|
|
|
}
|
|
|
|
});
|
2014-08-31 18:08:00 +02:00
|
|
|
el.addEventListener("keydown", func (e)
|
|
|
|
{
|
|
|
|
if( me._view == nil )
|
|
|
|
return;
|
|
|
|
|
2015-06-02 18:27:19 +02:00
|
|
|
if( e.key == "Enter" )
|
|
|
|
me._trigger("editingFinished", {text: me.text()}); # TODO validator/etc.
|
|
|
|
else if( e.key == "Backspace" )
|
2014-08-31 18:08:00 +02:00
|
|
|
me.backspace();
|
|
|
|
else if( e.key == "Delete" )
|
2023-01-06 12:21:26 +01:00
|
|
|
me.delete();
|
2014-08-31 18:08:00 +02:00
|
|
|
else if( e.key == "Left" )
|
|
|
|
me.moveCursor(me._cursor - 1);
|
|
|
|
else if( e.key == "Right")
|
|
|
|
me.moveCursor(me._cursor + 1);
|
|
|
|
else if( e.key == "Home" )
|
|
|
|
me.home();
|
|
|
|
else if( e.key == "End" )
|
|
|
|
me.end();
|
|
|
|
});
|
2023-01-06 12:21:26 +01:00
|
|
|
el.addEventListener("click", func(e) {
|
|
|
|
if (e.button == 2) {
|
|
|
|
me.showContextMenu(e);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
del: func() {
|
|
|
|
me.context_menu.del();
|
2014-08-31 18:08:00 +02:00
|
|
|
}
|
|
|
|
};
|