Fix Bug 41744

This commit is contained in:
Julia Radzhabova 2019-06-04 15:27:54 +03:00
parent 21e097427e
commit 2dca033d91

View file

@ -95,6 +95,9 @@ define([
this.recent = _.isNumber(options.recent) ? options.recent : 5; this.recent = _.isNumber(options.recent) ? options.recent : 5;
var filter = Common.localStorage.getKeysFilter();
this.appPrefix = (filter && filter.length) ? filter.split(',')[0] : '';
// Common.NotificationCenter.on('fonts:change', _.bind(this.onApiChangeFont, this)); // Common.NotificationCenter.on('fonts:change', _.bind(this.onApiChangeFont, this));
Common.NotificationCenter.on('fonts:load', _.bind(this.fillFonts, this)); Common.NotificationCenter.on('fonts:load', _.bind(this.fillFonts, this));
}, },
@ -320,6 +323,13 @@ define([
if (me.recent > 0) { if (me.recent > 0) {
me.store.on('add', me.onInsertItem, me); me.store.on('add', me.onInsertItem, me);
me.store.on('remove', me.onRemoveItem, me); me.store.on('remove', me.onRemoveItem, me);
Common.Utils.InternalSettings.set(me.appPrefix + "-settings-recent-fonts", Common.localStorage.getItem(me.appPrefix + "-settings-recent-fonts"));
var arr = Common.Utils.InternalSettings.get(me.appPrefix + "-settings-recent-fonts");
arr = arr ? arr.split(';') : [];
arr.reverse().forEach(function(item) {
item && me.addItemToRecent(me.store.findWhere({name: item}), true);
});
} }
}); });
}, },
@ -360,11 +370,11 @@ define([
}, },
itemClicked: function (e) { itemClicked: function (e) {
Common.UI.ComboBox.prototype.itemClicked.apply(this, arguments);
var el = $(e.target).closest('li'); var el = $(e.target).closest('li');
var record = this.store.findWhere({id: el.attr('id')}); var record = this.store.findWhere({id: el.attr('id')});
this.addItemToRecent(record); this.addItemToRecent(record);
Common.UI.ComboBox.prototype.itemClicked.apply(this, arguments);
}, },
onInsertItem: function(item) { onInsertItem: function(item) {
@ -419,19 +429,29 @@ define([
Common.UI.ComboBox.prototype.onAfterHideMenu.apply(this, arguments); Common.UI.ComboBox.prototype.onAfterHideMenu.apply(this, arguments);
}, },
addItemToRecent: function(record) { addItemToRecent: function(record, silent) {
if (this.recent<1) return; if (this.recent<1) return;
if (record.get('type') != FONT_TYPE_RECENT && var font = this.store.findWhere({name: record.get('name'),type:FONT_TYPE_RECENT});
!this.store.findWhere({name: record.get('name'),type:FONT_TYPE_RECENT})) { font && this.store.remove(font);
var fonts = this.store.where({type:FONT_TYPE_RECENT});
if (!(fonts.length < this.recent)) {
this.store.remove(fonts[this.recent - 1]);
}
var new_record = record.clone(); var fonts = this.store.where({type:FONT_TYPE_RECENT});
new_record.set({'type': FONT_TYPE_RECENT, 'id': Common.UI.getId(), cloneid: record.id}); if (!(fonts.length < this.recent)) {
this.store.add(new_record, {at:0}); this.store.remove(fonts[this.recent - 1]);
}
var new_record = record.clone();
new_record.set({'type': FONT_TYPE_RECENT, 'id': Common.UI.getId(), cloneid: record.id});
this.store.add(new_record, {at:0});
if (!silent) {
var arr = [];
this.store.where({type:FONT_TYPE_RECENT}).forEach(function(item){
arr.push(item.get('name'));
});
arr = arr.join(';');
Common.localStorage.setItem(this.appPrefix + "-settings-recent-fonts", arr);
Common.Utils.InternalSettings.set(this.appPrefix + "-settings-recent-fonts", arr);
} }
}, },