Improved reply keyboard on mobile

This commit is contained in:
Igor Zhukov 2015-07-13 13:56:28 +03:00
parent da0ed26c0a
commit 5918400f42
6 changed files with 42 additions and 12 deletions

View File

@ -2112,7 +2112,10 @@ angular.module('myApp.controllers', ['myApp.i18n'])
else if (replyToMarkup) { else if (replyToMarkup) {
replyClear(); replyClear();
} }
$scope.$broadcast('ui_keyboard_update'); $scope.$broadcast('ui_keyboard_update', {
enabled: replyKeyboard && !replyKeyboard.pFlags.hidden &&
replyKeyboard._ == 'replyKeyboardMarkup'
});
} }
function replyKeyboardToggle ($event) { function replyKeyboardToggle ($event) {

View File

@ -440,11 +440,11 @@ angular.module('myApp.directives', ['myApp.filters'])
$scope.$emit('reply_button_press', button); $scope.$emit('reply_button_press', button);
} }
$scope.$on('ui_keyboard_update', function () { $scope.$on('ui_keyboard_update', function (e, data) {
onContentLoaded(function () { onContentLoaded(function () {
scroller.updateHeight(); scroller.updateHeight();
scroller.scrollTo(0); scroller.scrollTo(0);
$scope.$emit('ui_panel_update'); $scope.$emit('ui_panel_update', {blur: data.enabled});
}) })
}); });
onContentLoaded(function () { onContentLoaded(function () {
@ -1212,10 +1212,14 @@ angular.module('myApp.directives', ['myApp.filters'])
}); });
}); });
$scope.$on('ui_panel_update', function () { $scope.$on('ui_panel_update', function (e, data) {
onContentLoaded(function () { onContentLoaded(function () {
updateSizes(); updateSizes();
$scope.$broadcast('ui_message_send'); if (data && data.blur) {
$scope.$broadcast('ui_message_blur');
} else {
$scope.$broadcast('ui_message_send');
}
$timeout(function () { $timeout(function () {
$(scrollableWrap).trigger('scroll'); $(scrollableWrap).trigger('scroll');
@ -1539,6 +1543,9 @@ angular.module('myApp.directives', ['myApp.filters'])
focusField(); focusField();
} }
}); });
$scope.$on('ui_message_blur', function () {
composer.blur();
});
function focusField () { function focusField () {
onContentLoaded(function () { onContentLoaded(function () {

View File

@ -250,10 +250,14 @@ angular.module('myApp.directives')
}); });
}); });
$scope.$on('ui_panel_update', function () { $scope.$on('ui_panel_update', function (e, data) {
onContentLoaded(function () { onContentLoaded(function () {
updateSizes(); updateSizes();
$scope.$broadcast('ui_message_send'); if (data && data.blur) {
$scope.$broadcast('ui_message_blur');
} else {
$scope.$broadcast('ui_message_send');
}
$timeout(function () { $timeout(function () {
$(scrollableWrap).trigger('scroll'); $(scrollableWrap).trigger('scroll');

View File

@ -200,14 +200,14 @@ function getRichElementValue(node, lines, line, selNode, selOffset) {
line.push(node.alt); line.push(node.alt);
} }
} }
if (selNode === node) {
line.push('\001');
}
var curChild = node.firstChild; var curChild = node.firstChild;
while (curChild) { while (curChild) {
getRichElementValue(curChild, lines, line, selNode, selOffset); getRichElementValue(curChild, lines, line, selNode, selOffset);
curChild = curChild.nextSibling; curChild = curChild.nextSibling;
} }
if (selNode === node) {
line.push('\001');
}
if (isBlock && line.length) { if (isBlock && line.length) {
lines.push(line.join('')); lines.push(line.join(''));
line.splice(0, line.length); line.splice(0, line.length);

View File

@ -1066,6 +1066,14 @@ MessageComposer.prototype.focus = function () {
} }
} }
MessageComposer.prototype.blur = function () {
if (this.richTextareaEl) {
this.richTextareaEl[0].blur();
} else {
this.textareaEl[0].blur();
}
}
MessageComposer.prototype.renderSuggestions = function (html) { MessageComposer.prototype.renderSuggestions = function (html) {
this.autoCompleteEl.html(html.join('')); this.autoCompleteEl.html(html.join(''));
this.autoCompleteWrapEl.show(); this.autoCompleteWrapEl.show();
@ -1148,7 +1156,6 @@ MessageComposer.prototype.updatePosition = function () {
var offset = (this.richTextareaEl || this.textareaEl).offset(); var offset = (this.richTextareaEl || this.textareaEl).offset();
var height = this.scroller.updateHeight(); var height = this.scroller.updateHeight();
var width = $((this.richTextareaEl || this.textareaEl)[0].parentNode).outerWidth(); var width = $((this.richTextareaEl || this.textareaEl)[0].parentNode).outerWidth();
console.log(width);
this.autoCompleteWrapEl.css({ this.autoCompleteWrapEl.css({
top: offset.top - height, top: offset.top - height,
left: Config.Mobile ? 0 : offset.left, left: Config.Mobile ? 0 : offset.left,

View File

@ -1304,7 +1304,16 @@ a.im_panel_peer_photo .peer_initials {
&_emoji_insert_btn { &_emoji_insert_btn {
top: 0; top: 0;
right: 0px; right: 0px;
margin-top: -3px; margin-top: -1px;
}
&_command_btn {
top: 2px;
right: 35px;
}
&_keyboard_btn {
top: 2px;
right: 35px;
} }
&_emoji_panel { &_emoji_panel {