[DE mobile] Custom Color (shape fill, border color)

This commit is contained in:
Julia Svinareva 2019-10-07 10:15:35 +03:00
parent 7b11701a7b
commit 3f97b8af79
11 changed files with 48 additions and 18 deletions

View file

@ -58,7 +58,7 @@ define([
template: _.template([ template: _.template([
'<div class="custom-colors">', '<div class="custom-colors">',
'<div style="padding: 10px 15px; display: flex; justify-content: space-between; height: 30px;">', '<div style="padding: 10px 15px; display: flex; justify-content: space-between; height: 30px;">',
'<div class="color-preview" style=""></div>', '<div class="color-hsb-preview" style=""></div>',
'<% if (android) { %>', '<% if (android) { %>',
'<a href="#" class="button button-fill button-raised" id="add-new-color" style="margin-left: 20px;line-height: 30px;width: 100%;height: 30px;"><%= scope.textAddNewColor %></a>', '<a href="#" class="button button-fill button-raised" id="add-new-color" style="margin-left: 20px;line-height: 30px;width: 100%;height: 30px;"><%= scope.textAddNewColor %></a>',
'<% } else { %>', '<% } else { %>',
@ -310,7 +310,7 @@ define([
} }
var color = this.colorHslToRgb(this.currentHsl[0], this.currentHsl[1], this.currentHsl[2]); var color = this.colorHslToRgb(this.currentHsl[0], this.currentHsl[1], this.currentHsl[2]);
this.currentColor = this.colorRgbToHex(color[0], color[1], color[2]); this.currentColor = this.colorRgbToHex(color[0], color[1], color[2]);
$('.color-preview').css({'background-color': this.currentColor}); $('.color-hsb-preview').css({'background-color': this.currentColor});
}, },

View file

@ -226,13 +226,9 @@ define([
}, },
saveDynamicColor: function(color) { saveDynamicColor: function(color) {
this.isDynamicColors = false;
var key_name = 'asc.'+Common.localStorage.getId()+'.colors.custom'; var key_name = 'asc.'+Common.localStorage.getId()+'.colors.custom';
var colors = Common.localStorage.getItem(key_name); var colors = Common.localStorage.getItem(key_name);
colors = colors ? colors.split(',') : []; colors = colors ? colors.split(',') : [];
if (colors.length > 0) {
this.isDynamicColors = true;
}
if (colors.push(color) > this.options.dynamiccolors) colors.shift(); if (colors.push(color) > this.options.dynamiccolors) colors.shift();
this.dynamicColors = colors; this.dynamicColors = colors;
Common.localStorage.setItem(key_name, colors.join().toUpperCase()); Common.localStorage.setItem(key_name, colors.join().toUpperCase());
@ -251,7 +247,7 @@ define([
templateColors += '<a data-color="empty" style="background-color: #ffffff;"></a>'; templateColors += '<a data-color="empty" style="background-color: #ffffff;"></a>';
} }
} }
$('.dynamic-colors .item-inner').html(_.template(templateColors)); $(this.el).find('.dynamic-colors .item-inner').html(_.template(templateColors));
$(this.el).find('.color-palette .dynamic-colors a').on('click', _.bind(this.onColorClick, this)); $(this.el).find('.color-palette .dynamic-colors a').on('click', _.bind(this.onColorClick, this));
}, },

View file

@ -43,7 +43,7 @@
} }
.custom-colors { .custom-colors {
.color-preview { .color-hsb-preview {
width: 75px; width: 75px;
border: 1px solid rgba(0, 0, 0, 0.3); border: 1px solid rgba(0, 0, 0, 0.3);
} }

View file

@ -48,7 +48,7 @@
} }
.custom-colors { .custom-colors {
.color-preview { .color-hsb-preview {
width: 75px; width: 75px;
border: 1px solid rgba(0, 0, 0, 0.3); border: 1px solid rgba(0, 0, 0, 0.3);
} }

View file

@ -157,7 +157,7 @@ define([
transparent: true transparent: true
}); });
this.paletteFillColor.on('customcolor', function () { this.paletteFillColor.on('customcolor', function () {
me.showCustomColor(); me.showCustomFillColor();
}); });
var template = _.template(['<div class="list-block">', var template = _.template(['<div class="list-block">',
'<ul>', '<ul>',
@ -173,7 +173,7 @@ define([
'</ul>', '</ul>',
'</div>'].join('')); '</div>'].join(''));
$('#tab-shape-fill').append(template({scope: this})); $('#tab-shape-fill').append(template({scope: this}));
$('#edit-shape-add-custom-color').single('click', _.bind(this.showCustomColor, this)); $('#edit-shape-add-custom-color').single('click', _.bind(this.showCustomFillColor, this));
Common.Utils.addScrollIfNeed('.page.shape-style', '.page.shape-style .page-content'); Common.Utils.addScrollIfNeed('.page.shape-style', '.page.shape-style .page-content');
this.fireEvent('page:show', [this, selector]); this.fireEvent('page:show', [this, selector]);
}, },
@ -200,11 +200,29 @@ define([
this.paletteBorderColor = new Common.UI.ThemeColorPalette({ this.paletteBorderColor = new Common.UI.ThemeColorPalette({
el: $('.page[data-page=edit-shape-border-color] .page-content') el: $('.page[data-page=edit-shape-border-color] .page-content')
}); });
this.paletteBorderColor.on('customcolor', function () {
me.showCustomBorderColor();
});
var template = _.template(['<div class="list-block">',
'<ul>',
'<li>',
'<a id="edit-shape-add-custom-border-color" class="item-link">',
'<div class="item-content">',
'<div class="item-inner">',
'<div class="item-title"><%= scope.textAddCustomColor %></div>',
'</div>',
'</div>',
'</a>',
'</li>',
'</ul>',
'</div>'].join(''));
$('.page[data-page=edit-shape-border-color] .page-content').append(template({scope: this}));
$('#edit-shape-add-custom-border-color').single('click', _.bind(this.showCustomBorderColor, this));
this.fireEvent('page:show', [this, selector]); this.fireEvent('page:show', [this, selector]);
}, },
showCustomColor: function() { showCustomFillColor: function() {
var me = this, var me = this,
selector = '#edit-shape-custom-color-view'; selector = '#edit-shape-custom-color-view';
me.showPage(selector, true); me.showPage(selector, true);
@ -220,6 +238,22 @@ define([
me.fireEvent('page:show', [me, selector]); me.fireEvent('page:show', [me, selector]);
}, },
showCustomBorderColor: function() {
var me = this,
selector = '#edit-shape-custom-color-view';
me.showPage(selector, true);
me.customBorderColorPicker = new Common.UI.HsbColorPicker({
el: $('.page[data-page=edit-shape-custom-color] .page-content'),
color: me.paletteBorderColor.currentColor
});
me.customBorderColorPicker.on('addcustomcolor', function (colorPicker, color) {
me.paletteBorderColor.addNewDynamicColor(colorPicker, color);
});
me.fireEvent('page:show', [me, selector]);
},
textStyle: 'Style', textStyle: 'Style',
textWrap: 'Wrap', textWrap: 'Wrap',
textReplace: 'Replace', textReplace: 'Replace',

View file

@ -6222,7 +6222,7 @@ html.pixel-ratio-3 .document-menu .list-block li:last-child li .item-inner:after
.color-palette .dynamic-colors .item-inner { .color-palette .dynamic-colors .item-inner {
overflow: visible; overflow: visible;
} }
.custom-colors .color-preview { .custom-colors .color-hsb-preview {
width: 75px; width: 75px;
border: 1px solid rgba(0, 0, 0, 0.3); border: 1px solid rgba(0, 0, 0, 0.3);
} }

View file

@ -5816,7 +5816,7 @@ html.phone .document-menu .list-block .item-link {
.color-palette.list-block:last-child li:last-child a { .color-palette.list-block:last-child li:last-child a {
border-radius: 0; border-radius: 0;
} }
.custom-colors .color-preview { .custom-colors .color-hsb-preview {
width: 75px; width: 75px;
border: 1px solid rgba(0, 0, 0, 0.3); border: 1px solid rgba(0, 0, 0, 0.3);
} }

View file

@ -6222,7 +6222,7 @@ html.pixel-ratio-3 .document-menu .list-block li:last-child li .item-inner:after
.color-palette .dynamic-colors .item-inner { .color-palette .dynamic-colors .item-inner {
overflow: visible; overflow: visible;
} }
.custom-colors .color-preview { .custom-colors .color-hsb-preview {
width: 75px; width: 75px;
border: 1px solid rgba(0, 0, 0, 0.3); border: 1px solid rgba(0, 0, 0, 0.3);
} }

View file

@ -5816,7 +5816,7 @@ html.phone .document-menu .list-block .item-link {
.color-palette.list-block:last-child li:last-child a { .color-palette.list-block:last-child li:last-child a {
border-radius: 0; border-radius: 0;
} }
.custom-colors .color-preview { .custom-colors .color-hsb-preview {
width: 75px; width: 75px;
border: 1px solid rgba(0, 0, 0, 0.3); border: 1px solid rgba(0, 0, 0, 0.3);
} }

View file

@ -6222,7 +6222,7 @@ html.pixel-ratio-3 .document-menu .list-block li:last-child li .item-inner:after
.color-palette .dynamic-colors .item-inner { .color-palette .dynamic-colors .item-inner {
overflow: visible; overflow: visible;
} }
.custom-colors .color-preview { .custom-colors .color-hsb-preview {
width: 75px; width: 75px;
border: 1px solid rgba(0, 0, 0, 0.3); border: 1px solid rgba(0, 0, 0, 0.3);
} }

View file

@ -5826,7 +5826,7 @@ html.phone .document-menu .list-block .item-link {
.color-palette.list-block:last-child li:last-child a { .color-palette.list-block:last-child li:last-child a {
border-radius: 0; border-radius: 0;
} }
.custom-colors .color-preview { .custom-colors .color-hsb-preview {
width: 75px; width: 75px;
border: 1px solid rgba(0, 0, 0, 0.3); border: 1px solid rgba(0, 0, 0, 0.3);
} }