Commit c74c14bf authored by Oleg Korshul's avatar Oleg Korshul

input spaces & backspace&delete in composite input

parent ffe1a082
...@@ -53,7 +53,8 @@ var AscBrowser = { ...@@ -53,7 +53,8 @@ var AscBrowser = {
isSafari : false, isSafari : false,
isArm : false, isArm : false,
isMozilla : false, isMozilla : false,
isRetina : false isRetina : false,
isLinuxOS : false
}; };
// user agent lower case // user agent lower case
......
...@@ -272,7 +272,8 @@ ...@@ -272,7 +272,8 @@
} }
} }
if (!this.KeyDownFlag && c_oCompositionState.end == this.compositionState && !this.TextInputAfterComposition && this.HtmlArea.value != "") var _value = this.HtmlArea.value;
if (!this.KeyDownFlag && c_oCompositionState.end == this.compositionState && !this.TextInputAfterComposition && _value != "")
{ {
this.Api.Begin_CompositeInput(); this.Api.Begin_CompositeInput();
this.checkCompositionData(this.HtmlArea.value); this.checkCompositionData(this.HtmlArea.value);
...@@ -281,8 +282,32 @@ ...@@ -281,8 +282,32 @@
} }
this.TextInputAfterComposition = false; this.TextInputAfterComposition = false;
if (c_oCompositionState.end == this.compositionState) if (c_oCompositionState.end == this.compositionState)
{
if (AscCommon.AscBrowser.isChrome && AscCommon.AscBrowser.isLinuxOS)
{
// space!!!
var _code = (_value.length == 1) ? _value.charCodeAt(0) : 0;
if (_code == 12288 || _code == 32)
{
var _e = {
altKey : false,
ctrlKey : false,
shiftKey : false,
target : null,
charCode : 0,
which : 0,
keyCode : 12288,
code : "space"
};
this.Api.onKeyDown(_e);
this.Api.onKeyUp(_e);
}
}
this.clear(); this.clear();
}
}, },
onTextInput : function(e) onTextInput : function(e)
...@@ -348,7 +373,15 @@ ...@@ -348,7 +373,15 @@
onKeyDown : function(e) onKeyDown : function(e)
{ {
if (c_oCompositionState.end != this.compositionState) if (c_oCompositionState.end != this.compositionState)
{
if (this.IsUseFirstTextInputAfterComposition && e.keyCode == 8 || e.keyCode == 46) // del, backspace
{
this.onCompositionEnd(e, this.HtmlArea.value);
this.IsUseFirstTextInputAfterComposition = false;
}
return; return;
}
if (null != this.nativeFocusElement) if (null != this.nativeFocusElement)
{ {
...@@ -379,6 +412,17 @@ ...@@ -379,6 +412,17 @@
{ {
this.KeyDownFlag = false; this.KeyDownFlag = false;
if (c_oCompositionState.end != this.compositionState)
{
if (this.IsUseFirstTextInputAfterComposition && e.keyCode == 8 || e.keyCode == 46) // del, backspace
{
this.onCompositionEnd(e, this.HtmlArea.value);
this.IsUseFirstTextInputAfterComposition = false;
}
return;
}
if (c_oCompositionState.end == this.compositionState) if (c_oCompositionState.end == this.compositionState)
return this.Api.onKeyUp(e); return this.Api.onKeyUp(e);
...@@ -434,10 +478,10 @@ ...@@ -434,10 +478,10 @@
this.Api.Begin_CompositeInput(); this.Api.Begin_CompositeInput();
}, },
onCompositionUpdate : function(e, isLockTarget) onCompositionUpdate : function(e, isLockTarget, _data)
{ {
var _old = this.compositionValue.splice(0); var _old = this.compositionValue.splice(0);
this.checkCompositionData(e.data); this.checkCompositionData((_data != null) ? _data : e.data);
var _isEqualLen = (_old.length == this.compositionValue.length); var _isEqualLen = (_old.length == this.compositionValue.length);
var _isEqual = _isEqualLen; var _isEqual = _isEqualLen;
...@@ -478,26 +522,20 @@ ...@@ -478,26 +522,20 @@
this.compositionState = c_oCompositionState.process; this.compositionState = c_oCompositionState.process;
}, },
onCompositionEnd : function(e) onCompositionEnd : function(e, _data)
{
// chrome, linux: всегда приходит пустая дата
if (!this.IsUseFirstTextInputAfterComposition)
{ {
if (e.data === undefined || (e.data == "" && (this.compositionValue.length != 0))) if (!this.IsUseFirstTextInputAfterComposition &&
AscCommon.AscBrowser.isChrome &&
AscCommon.AscBrowser.isLinuxOS &&
(e.data == null || e.data == ""))
{ {
// always data == ""
console.log("chrome_linux_end");
this.IsUseFirstTextInputAfterComposition = true; this.IsUseFirstTextInputAfterComposition = true;
return; return;
} }
else
{
this.onCompositionUpdate(e, false);
}
}
else
{
this.onCompositionUpdate(e, false);
}
this.onCompositionUpdate(e, false, _data);
this.Api.Set_CursorPosInCompositeText(1000); // max this.Api.Set_CursorPosInCompositeText(1000); // max
this.clear(); this.clear();
...@@ -510,7 +548,7 @@ ...@@ -510,7 +548,7 @@
checkCompositionData : function(data) checkCompositionData : function(data)
{ {
this.compositionValue = []; this.compositionValue = [];
var _length = data.length; var _length = (data != null) ? data.length : 0;
for (var i = 0; i < _length; i++) for (var i = 0; i < _length; i++)
{ {
var _code = data.charCodeAt(i); var _code = data.charCodeAt(i);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment