Merge pull request #2075 from ONLYOFFICE/feature/letter-exceptions

Feature/letter exceptions
This commit is contained in:
Julia Radzhabova 2022-11-23 20:43:00 +03:00 committed by GitHub
commit 3bb02dcb3f
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
8 changed files with 463 additions and 44 deletions

View file

@ -97,13 +97,43 @@
</div> </div>
</div> </div>
</div> </div>
<div id="id-autocorrect-dialog-settings-autocorrect" class="settings-panel"> <div id="id-autocorrect-dialog-settings-exceptions" class="settings-panel">
<div class="inner-content" style="width: 100%;"> <div class="inner-content">
<div class="padding-small"> <table cols="1" style="width: 100%;">
<div id="id-autocorrect-dialog-chk-fl-sentence"></div> <tr>
</div> <td style="padding-bottom: 12px;">
<div class="padding-small"> <div id="auto-correct-exceptions-chk-sentence" style="padding-bottom: 8px;"></div>
<div id="id-autocorrect-dialog-chk-fl-cells"></div> <div id="auto-correct-exceptions-chk-cells"></div>
</div> </td>
</tr>
<tr>
<td>
<label><%= scope.textForLangFL %></label>
</td>
</tr>
<tr>
<td style="padding-bottom: 12px;">
<div id="auto-correct-exceptions-lang" style="display: inline-block; margin-right: 15px;vertical-align: middle;"></div>
</td>
</tr>
<tr>
<td>
<label><%= scope.textFLDont %></label>
<div id="auto-correct-exceptions-find" style="height:22px;width: 100%;margin-bottom: 4px;"></div>
</td>
</tr>
<tr>
<td style="padding-bottom: 8px;">
<div id="auto-correct-exceptions-list" class="" style="width:100%; height: 139px;"></div>
</td>
</tr>
<tr>
<td style="padding-bottom: 18px;">
<button type="button" class="btn btn-text-default auto" id="auto-correct-btn-exceptions-reset" style="min-width: 86px;"><%= scope.textResetAll %></button>
<button type="button" class="btn btn-text-default auto" id="auto-correct-btn-exceptions-delete" style="min-width: 86px;float: right;"><%= scope.textDelete %></button>
<button type="button" class="btn btn-text-default auto" id="auto-correct-btn-exceptions-edit" style="min-width: 86px;float: right;margin-right:5px;"><%= scope.textAdd %></button>
</td>
</tr>
</table>
</div> </div>
</div> </div>

View file

@ -47,6 +47,8 @@ define([ 'text!common/main/lib/template/AutoCorrectDialog.template',
], function (contentTemplate) { 'use strict'; ], function (contentTemplate) { 'use strict';
var _mathStore = new Common.UI.DataViewStore(); var _mathStore = new Common.UI.DataViewStore();
var _functionsStore = new Common.UI.DataViewStore(); var _functionsStore = new Common.UI.DataViewStore();
var _exciptionsStore = new Common.UI.DataViewStore();
var _exciptionsLangs = [0x0409, 0x0419];
Common.Views.AutoCorrectDialog = Common.Views.AdvancedSettingsWindow.extend(_.extend({ Common.Views.AutoCorrectDialog = Common.Views.AdvancedSettingsWindow.extend(_.extend({
options: { options: {
@ -57,7 +59,8 @@ define([ 'text!common/main/lib/template/AutoCorrectDialog.template',
}, },
initialize : function(options) { initialize : function(options) {
var filter = Common.localStorage.getKeysFilter(); var filter = Common.localStorage.getKeysFilter(),
me = this;
this.appPrefix = (filter && filter.length) ? filter.split(',')[0] : ''; this.appPrefix = (filter && filter.length) ? filter.split(',')[0] : '';
var items = [ var items = [
@ -66,7 +69,7 @@ define([ 'text!common/main/lib/template/AutoCorrectDialog.template',
]; ];
if (this.appPrefix=='de-' || this.appPrefix=='pe-') { if (this.appPrefix=='de-' || this.appPrefix=='pe-') {
items.push({panelId: 'id-autocorrect-dialog-settings-de-autoformat', panelCaption: this.textAutoFormat}); items.push({panelId: 'id-autocorrect-dialog-settings-de-autoformat', panelCaption: this.textAutoFormat});
items.push({panelId: 'id-autocorrect-dialog-settings-autocorrect', panelCaption: this.textAutoCorrect}); items.push({panelId: 'id-autocorrect-dialog-settings-exceptions', panelCaption: this.textAutoCorrect});
} else if (this.appPrefix=='sse-') } else if (this.appPrefix=='sse-')
items.push({panelId: 'id-autocorrect-dialog-settings-sse-autoformat', panelCaption: this.textAutoFormat}); items.push({panelId: 'id-autocorrect-dialog-settings-sse-autoformat', panelCaption: this.textAutoFormat});
@ -105,6 +108,19 @@ define([ 'text!common/main/lib/template/AutoCorrectDialog.template',
this.arrAddRec = value ? JSON.parse(value) : []; this.arrAddRec = value ? JSON.parse(value) : [];
value = Common.Utils.InternalSettings.get(path + "-rem"); value = Common.Utils.InternalSettings.get(path + "-rem");
this.arrRemRec = value ? JSON.parse(value) : []; this.arrRemRec = value ? JSON.parse(value) : [];
this.arrAddExceptions = {};
this.arrRemExceptions = {};
_exciptionsLangs.forEach(function(lang) {
path = me.appPrefix + "settings-letter-exception";
value = Common.Utils.InternalSettings.get(path + "-add-" + lang);
me.arrAddExceptions[lang] = value ? JSON.parse(value) : [];
value = Common.Utils.InternalSettings.get(path + "-rem-" + lang);
me.arrRemExceptions[lang] = value ? JSON.parse(value) : [];
});
Common.Views.AdvancedSettingsWindow.prototype.initialize.call(this, this.options); Common.Views.AdvancedSettingsWindow.prototype.initialize.call(this, this.options);
}, },
@ -335,27 +351,121 @@ define([ 'text!common/main/lib/template/AutoCorrectDialog.template',
Common.Utils.InternalSettings.set(me.appPrefix + "settings-autoformat-double-space", checked); Common.Utils.InternalSettings.set(me.appPrefix + "settings-autoformat-double-space", checked);
me.api.asc_SetAutoCorrectDoubleSpaceWithPeriod(checked); me.api.asc_SetAutoCorrectDoubleSpaceWithPeriod(checked);
}); });
// AutoCorrect // AutoCorrect
this.chFLSentence = new Common.UI.CheckBox({ var exciptionsActiveLang = Common.Utils.InternalSettings.get('settings-letter-exception-lang');
el: $window.find('#id-autocorrect-dialog-chk-fl-sentence'), this.exceptionsLangCmb = new Common.UI.ComboBox({
el : $window.find('#auto-correct-exceptions-lang'),
style : 'width: 145px;',
menuStyle : 'min-width:100%;',
editable : false,
takeFocusOnClose : true,
menuCls : 'menu-aligned',
cls : 'input-group-nr',
dataHintDirection: 'bottom',
data : _exciptionsLangs.map(function(lang){
var langName = Common.util.LanguageInfo.getLocalLanguageName(lang);
return {
displayValue: langName[1],
shortName: langName[0],
value: lang
};
})
}).on('selected', function(combo, record) {
if(exciptionsActiveLang != record.value) {
exciptionsActiveLang = record.value;
Common.Utils.InternalSettings.set('settings-letter-exception-lang', exciptionsActiveLang);
me.onInitExceptionsList(true);
me.onChangeInputException(me.exceptionsFindInput, me.exceptionsFindInput.getValue());
}
});
if(!exciptionsActiveLang) {
var curLangObj = this.exceptionsLangCmb.store.findWhere({value: this.api.asc_getDefaultLanguage()});
if (!curLangObj) {
var nameLang = Common.util.LanguageInfo.getLocalLanguageName(this.api.asc_getDefaultLanguage())[0].split(/[\-\_]/)[0];
curLangObj = this.exceptionsLangCmb.store.find(function(lang){
return lang.get('shortName').indexOf(nameLang)==0;
});
}
if(curLangObj) exciptionsActiveLang = curLangObj.get('value');
}
this.exceptionsLangCmb.setValue(exciptionsActiveLang ? exciptionsActiveLang : _exciptionsLangs[0]);
this.onInitExceptionsList(true);
this.exceptionsList = new Common.UI.ListView({
el: $window.find('#auto-correct-exceptions-list'),
store: new Common.UI.DataViewStore(_exciptionsStore.slice(0, 6)),
simpleAddMode: false,
template: _.template(['<div class="listview inner" style=""></div>'].join('')),
itemTemplate: _.template([
'<div id="<%= id %>" class="list-item" style="width: 340px;text-overflow: ellipsis;overflow: hidden;<% if (defaultDisabled) { %> font-style:italic; opacity: 0.5;<% } %>"><%= value + "."%></div>'
].join('')),
scrollAlwaysVisible: true,
tabindex: 1
});
this.exceptionsList.on('item:select', _.bind(this.onSelectExceptionItem, this));
this.exceptionsFindInput = new Common.UI.InputField({
el : $window.find('#auto-correct-exceptions-find'),
allowBlank : true,
validateOnChange : true,
maxLength : 255,
validation : function () { return true; }
}).on ('changing', _.bind(this.onChangeInputException, this));
this.exceptionsFindInput.cmpEl.find('input').on('keydown', function(event){
if (event.key == 'ArrowDown') {
var _selectedItem = me.exceptionsList.getSelectedRec() || me.exceptionsList.store.at(0);
if (_selectedItem) {
me.exceptionsList.selectRecord(_selectedItem);
me.exceptionsList.scrollToRecord(_selectedItem);
}
_.delay(function(){
me.exceptionsList.focus();
},10);
}
});
this.btnResetExceptions = new Common.UI.Button({
el: $window.find('#auto-correct-btn-exceptions-reset')
});
this.btnResetExceptions.on('click', _.bind(this.onResetExceptionsToDefault, this));
this.btnAddExceptions = new Common.UI.Button({
el: $window.find('#auto-correct-btn-exceptions-edit')
});
this.btnAddExceptions.on('click', _.bind(this.onAddException, this, false));
this.btnDeleteExceptions = new Common.UI.Button({
el: $window.find('#auto-correct-btn-exceptions-delete')
});
this.btnDeleteExceptions.on('click', _.bind(this.onDeleteException, this, false));
this.chkSentenceExceptions = new Common.UI.CheckBox({
el: $window.find('#auto-correct-exceptions-chk-sentence'),
labelText: this.textFLSentence, labelText: this.textFLSentence,
value: Common.Utils.InternalSettings.get(this.appPrefix + "settings-autoformat-fl-sentence") value: Common.Utils.InternalSettings.get(this.appPrefix + "settings-letter-exception-sentence")
}).on('change', function(field, newValue, oldValue, eOpts){ }).on('change', function(field, newValue, oldValue, eOpts){
var checked = (field.getValue()==='checked'); var checked = (field.getValue()==='checked');
Common.localStorage.setBool(me.appPrefix + "settings-autoformat-fl-sentence", checked); Common.localStorage.setBool(me.appPrefix + "settings-letter-exception-sentence", checked);
Common.Utils.InternalSettings.set(me.appPrefix + "settings-autoformat-fl-sentence", checked); Common.Utils.InternalSettings.set(me.appPrefix + "settings-letter-exception-sentence", checked);
me.api.asc_SetAutoCorrectFirstLetterOfSentences && me.api.asc_SetAutoCorrectFirstLetterOfSentences(checked); me.api.asc_SetAutoCorrectFirstLetterOfSentences && me.api.asc_SetAutoCorrectFirstLetterOfSentences(checked);
}); });
this.chFLCells = new Common.UI.CheckBox({ this.chkSentenceCells = new Common.UI.CheckBox({
el: $window.find('#id-autocorrect-dialog-chk-fl-cells'), el: $window.find('#auto-correct-exceptions-chk-cells'),
labelText: this.textFLCells, labelText: this.textFLCells,
value: Common.Utils.InternalSettings.get(this.appPrefix + "settings-autoformat-fl-cells") value: Common.Utils.InternalSettings.get(this.appPrefix + "settings-letter-exception-cells")
}).on('change', function(field, newValue, oldValue, eOpts){ }).on('change', function(field, newValue, oldValue, eOpts){
var checked = (field.getValue()==='checked'); var checked = (field.getValue()==='checked');
Common.localStorage.setBool(me.appPrefix + "settings-autoformat-fl-cells", checked); Common.localStorage.setBool(me.appPrefix + "settings-letter-exception-cells", checked);
Common.Utils.InternalSettings.set(me.appPrefix + "settings-autoformat-fl-cells", checked); Common.Utils.InternalSettings.set(me.appPrefix + "settings-letter-exception-cells", checked);
me.api.asc_SetAutoCorrectFirstLetterOfCells && me.api.asc_SetAutoCorrectFirstLetterOfCells(checked); me.api.asc_SetAutoCorrectFirstLetterOfSentences && me.api.asc_SetAutoCorrectFirstLetterOfSentences(checked);
}); });
this.btnsCategory[3].on('click', _.bind(this.onAutocorrectCategoryClick, this, false)); this.btnsCategory[3].on('click', _.bind(this.onAutocorrectCategoryClick, this, false));
@ -392,6 +502,7 @@ define([ 'text!common/main/lib/template/AutoCorrectDialog.template',
afterRender: function() { afterRender: function() {
this.updateControls(); this.updateControls();
this.updateRecControls(); this.updateRecControls();
this.updateExceptionsControls();
if (this.storageName) { if (this.storageName) {
var value = Common.localStorage.getItem(this.storageName); var value = Common.localStorage.getItem(this.storageName);
this.setActiveCategory((value!==null) ? parseInt(value) : 0); this.setActiveCategory((value!==null) ? parseInt(value) : 0);
@ -402,10 +513,9 @@ define([ 'text!common/main/lib/template/AutoCorrectDialog.template',
var arr = [ var arr = [
this.chReplaceType, this.inputReplace, this.inputBy, this.mathList, this.btnReset, this.btnEdit, this.btnDelete, // 0 tab this.chReplaceType, this.inputReplace, this.inputBy, this.mathList, this.btnReset, this.btnEdit, this.btnDelete, // 0 tab
this.inputRecFind, this.mathRecList, this.btnResetRec, this.btnAddRec, this.btnDeleteRec, // 1 tab this.inputRecFind, this.mathRecList, this.btnResetRec, this.btnAddRec, this.btnDeleteRec, // 1 tab
this.chHyperlink // 2 tab
]; ];
arr = arr.concat(this.chNewRows ? [this.chNewRows] : [this.chQuotes, this.chHyphens, this.chBulleted, this.chNumbered]); arr = arr.concat(this.chNewRows ? [this.chHyperlink, this.chNewRows] : [this.chQuotes, this.chHyphens, this.chHyperlink, this.chDoubleSpaces, this.chBulleted, this.chNumbered]);
arr = arr.concat(this.chFLSentence ? [this.chFLSentence, this.chFLCells] : []); arr = arr.concat(this.chkSentenceExceptions ? [this.chkSentenceExceptions, this.chkSentenceCells, this.exceptionsLangCmb, this.exceptionsFindInput, this.exceptionsList, this.btnResetExceptions, this.btnAddExceptions, this.btnDeleteExceptions] : []);
return arr; return arr;
}, },
@ -481,28 +591,43 @@ define([ 'text!common/main/lib/template/AutoCorrectDialog.template',
onAutocorrectCategoryClick: function(delay) { onAutocorrectCategoryClick: function(delay) {
var me = this; var me = this;
_.delay(function(){ _.delay(function(){
me.chFLSentence.focus(); $('input', me.exceptionsFindInput.cmpEl).select().focus();
},delay ? 50 : 0); },delay ? 50 : 0);
if (me.exceptionsList.store.length < _exciptionsStore.length) {
_.delay(function(){
me.exceptionsList.setStore(_exciptionsStore);
me.exceptionsList.onResetItems();
},delay ? 100 : 10);
}
}, },
onDelete: function() { onDelete: function() {
var rec = this.mathList.getSelectedRec(); var rec = this.mathList.getSelectedRec();
var path = '';
var val;
if (rec) { if (rec) {
if (rec.get('defaultValue')) { if (rec.get('defaultValue')) {
var path = this.appPrefix + "settings-math-correct-rem"; path = this.appPrefix + "settings-math-correct-rem";
var disabled = !rec.get('defaultDisabled'); var disabled = !rec.get('defaultDisabled');
rec.set('defaultDisabled', disabled); rec.set('defaultDisabled', disabled);
if (disabled) if (disabled)
this.arrRem.push(rec.get('replaced')); this.arrRem.push(rec.get('replaced'));
else else
this.arrRem.splice(this.arrRem.indexOf(rec.get('replaced')), 1); this.arrRem.splice(this.arrRem.indexOf(rec.get('replaced')), 1);
var val = JSON.stringify(this.arrRem); val = JSON.stringify(this.arrRem);
Common.Utils.InternalSettings.set(path, val); Common.Utils.InternalSettings.set(path, val);
Common.localStorage.setItem(path, val); Common.localStorage.setItem(path, val);
this.btnDelete.setCaption(disabled ? this.textRestore : this.textDelete); this.btnDelete.setCaption(disabled ? this.textRestore : this.textDelete);
disabled ? this.api.asc_deleteFromAutoCorrectMathSymbols(rec.get('replaced')) : this.api.asc_AddOrEditFromAutoCorrectMathSymbols(rec.get('replaced'), rec.get('defaultValue')); disabled ? this.api.asc_deleteFromAutoCorrectMathSymbols(rec.get('replaced')) : this.api.asc_AddOrEditFromAutoCorrectMathSymbols(rec.get('replaced'), rec.get('defaultValue'));
} else { } else {
_mathStore.remove(rec); _mathStore.remove(rec);
this.arrAdd.splice(this.arrAdd.indexOf(rec.get('replaced')), 1);
path = this.appPrefix + "settings-math-correct-add";
val = JSON.stringify(this.arrAdd);
Common.Utils.InternalSettings.set(path, val);
Common.localStorage.setItem(path, val);
this.mathList.scroller && this.mathList.scroller.update({}); this.mathList.scroller && this.mathList.scroller.update({});
this.api.asc_deleteFromAutoCorrectMathSymbols(rec.get('replaced')); this.api.asc_deleteFromAutoCorrectMathSymbols(rec.get('replaced'));
} }
@ -746,22 +871,30 @@ define([ 'text!common/main/lib/template/AutoCorrectDialog.template',
onDeleteRec: function() { onDeleteRec: function() {
var rec = this.mathRecList.getSelectedRec(); var rec = this.mathRecList.getSelectedRec();
var path;
var val;
if (rec) { if (rec) {
if (rec.get('defaultValue')) { if (rec.get('defaultValue')) {
var path = this.appPrefix + "settings-rec-functions-rem"; path = this.appPrefix + "settings-rec-functions-rem";
var disabled = !rec.get('defaultDisabled'); var disabled = !rec.get('defaultDisabled');
rec.set('defaultDisabled', disabled); rec.set('defaultDisabled', disabled);
if (disabled) if (disabled)
this.arrRemRec.push(rec.get('value')); this.arrRemRec.push(rec.get('value'));
else else
this.arrRemRec.splice(this.arrRemRec.indexOf(rec.get('value')), 1); this.arrRemRec.splice(this.arrRemRec.indexOf(rec.get('value')), 1);
var val = JSON.stringify(this.arrRemRec); val = JSON.stringify(this.arrRemRec);
Common.Utils.InternalSettings.set(path, val); Common.Utils.InternalSettings.set(path, val);
Common.localStorage.setItem(path, val); Common.localStorage.setItem(path, val);
this.btnDeleteRec.setCaption(disabled ? this.textRestore : this.textDelete); this.btnDeleteRec.setCaption(disabled ? this.textRestore : this.textDelete);
disabled ? this.api.asc_deleteFromAutoCorrectMathFunctions(rec.get('value')) : this.api.asc_AddFromAutoCorrectMathFunctions(rec.get('value')); disabled ? this.api.asc_deleteFromAutoCorrectMathFunctions(rec.get('value')) : this.api.asc_AddFromAutoCorrectMathFunctions(rec.get('value'));
} else { } else {
_functionsStore.remove(rec); _functionsStore.remove(rec);
this.arrAddRec.splice(this.arrAddRec.indexOf(rec.get('value')), 1);
path = this.appPrefix + "settings-rec-functions-add";
val = JSON.stringify(this.arrAddRec);
Common.Utils.InternalSettings.set(path, val);
Common.localStorage.setItem(path, val);
this.mathRecList.scroller && this.mathRecList.scroller.update({}); this.mathRecList.scroller && this.mathRecList.scroller.update({});
this.api.asc_deleteFromAutoCorrectMathFunctions(rec.get('value')); this.api.asc_deleteFromAutoCorrectMathFunctions(rec.get('value'));
} }
@ -822,6 +955,204 @@ define([ 'text!common/main/lib/template/AutoCorrectDialog.template',
this.btnAddRec.setDisabled(!!rec || !value); this.btnAddRec.setDisabled(!!rec || !value);
}, },
onInitExceptionsList: function(overrideNotEmptyStore) {
if (_exciptionsStore.length>0 && !overrideNotEmptyStore) return;
_exciptionsStore.comparator = function(item1, item2) {
var n1 = item1.get('value').toLowerCase(),
n2 = item2.get('value').toLowerCase();
if (n1==n2) return 0;
return (n1<n2) ? -1 : 1;
};
var activeLang = this.exceptionsLangCmb.getValue(),
arrAdd = this.arrAddExceptions[activeLang] ? this.arrAddExceptions[activeLang] : [],
arrRem = this.arrRemExceptions[activeLang] ? this.arrRemExceptions[activeLang] : [];
var arr = (this.api) ? this.api.asc_GetAutoCorrectSettings().get_FirstLetterExceptionManager()
.get_DefaultExceptions(activeLang) : [],
data = [];
_.each(arr, function(item, index){
data.push({
value: item,
defaultValue: true,
defaultDisabled: arrRem.indexOf(item)>-1
});
});
var dataAdd = [];
_.each(arrAdd, function(item, index){
if (_.findIndex(data, {value: item})<0) {
dataAdd.push({
value: item,
defaultValue: false,
defaultDisabled: false
});
}
});
_exciptionsStore.reset(data.concat(dataAdd));
this.updateExceptionsControls();
},
onResetExceptionsToDefault: function() {
var apiFlManager = this.api.asc_GetAutoCorrectSettings().get_FirstLetterExceptionManager();
var activeLang = this.exceptionsLangCmb.getValue();
Common.UI.warning({
maxwidth: 500,
msg: this.textWarnResetFL,
buttons: ['yes', 'no'],
primary: 'yes',
callback: _.bind(function(btn, dontshow){
if (btn == 'yes') {
apiFlManager.put_Exceptions(apiFlManager.get_DefaultExceptions(activeLang), activeLang);
this.onResetExceptionsList();
}
}, this)
});
},
onResetExceptionsList: function() {
var path = this.appPrefix + "settings-letter-exception";
var activeLang = this.exceptionsLangCmb.getValue();
var val = JSON.stringify([]);
Common.Utils.InternalSettings.set(path + "-add-" + activeLang, val);
Common.localStorage.setItem(path + "-add-" + activeLang, val);
Common.Utils.InternalSettings.set(path + "-rem-" + activeLang, val);
Common.localStorage.setItem(path + "-rem-" + activeLang, val);
this.arrAddExceptions[activeLang] = [];
this.arrRemExceptions[activeLang] = [];
_exciptionsStore.remove(_exciptionsStore.where({defaultValue: false}));
_exciptionsStore.each(function(item, index){
item.set('defaultDisabled', false);
});
this.exceptionsList.deselectAll();
if (this.exceptionsList.scroller) {
this.exceptionsList.scroller.update();
this.exceptionsList.scroller.scrollTop(0);
}
this.updateExceptionsControls();
},
onDeleteException: function() {
var rec = this.exceptionsList.getSelectedRec();
var apiFlManager = this.api.asc_GetAutoCorrectSettings().get_FirstLetterExceptionManager();
var activeLang = this.exceptionsLangCmb.getValue();
if (rec) {
var val;
var path = '';
if (rec.get('defaultValue')) {
var disabled = !rec.get('defaultDisabled');
path = this.appPrefix + "settings-letter-exception-rem-" + activeLang;
rec.set('defaultDisabled', disabled);
if (disabled)
this.arrRemExceptions[activeLang].push(rec.get('value'));
else
this.arrRemExceptions[activeLang].splice(this.arrRemExceptions[activeLang].indexOf(rec.get('value')), 1);
val = JSON.stringify(this.arrRemExceptions[activeLang]);
Common.Utils.InternalSettings.set(path, val);
Common.localStorage.setItem(path, val);
this.btnDeleteExceptions.setCaption(disabled ? this.textRestore : this.textDelete);
disabled ? apiFlManager.remove_Exception(rec.get('value'), activeLang) : apiFlManager.add_Exception(rec.get('value'), activeLang);
} else {
_exciptionsStore.remove(rec);
this.arrAddExceptions[activeLang].splice(this.arrAddExceptions[activeLang].indexOf(rec.get('value')), 1);
path = this.appPrefix + "settings-letter-exception-add-" + activeLang;
val = JSON.stringify(this.arrAddExceptions[activeLang]);
Common.Utils.InternalSettings.set(path, val);
Common.localStorage.setItem(path, val);
this.exceptionsList.scroller && this.exceptionsList.scroller.update({});
apiFlManager.remove_Exception(rec.get('value'), activeLang);
}
this.updateExceptionsControls();
}
},
onAddException: function() {
var rec = this.exceptionsList.getSelectedRec(),
activeLang = this.exceptionsLangCmb.getValue(),
me = this,
value = this.exceptionsFindInput.getValue().trim(),
applySettings = function(record) {
var path = me.appPrefix + "settings-letter-exception-add-" + activeLang;
var val = JSON.stringify(me.arrAddExceptions[activeLang]);
Common.Utils.InternalSettings.set(path, val);
Common.localStorage.setItem(path, val);
me.api.asc_GetAutoCorrectSettings().get_FirstLetterExceptionManager().add_Exception(record.get('value') ,activeLang);
me.exceptionsList.selectRecord(record);
me.exceptionsList.scrollToRecord(record);
};
if (!rec) {
rec = _exciptionsStore.findWhere({value: value})
}
if (!rec) {
if(value[value.length-1] === '.')
value = value.slice(0, -1);
if (/^[^\%/\\&\?\,\.\s\d\'\;:!-+!@#\$\^*)(]{1,20}$/.test(value)) {
rec = _exciptionsStore.add({
value: value,
defaultValue: false,
defaultDisabled: false
});
this.arrAddExceptions[activeLang].push(rec.get('value'));
applySettings(rec);
} else
Common.UI.warning({
maxwidth: 500,
msg: this.textWarnAddFL
});
} else {
me.exceptionsList.selectRecord(rec);
me.exceptionsList.scrollToRecord(rec);
}
},
onSelectExceptionItem: function(lisvView, itemView, record) {
if (record) {
this.exceptionsFindInput.setValue(record.get('value'));
}
this.updateExceptionsControls(record);
},
onChangeInputException: function (input, value) {
var _selectedItem;
value = value.trim();
if (value.length) {
if(value[value.length-1] === '.')
value = value.slice(0, -1);
var store = this.exceptionsList.store;
_selectedItem = store.find(function(item) {
if ( item.get('value').indexOf(value) == 0) {
return true;
}
});
if (_selectedItem) {
this.exceptionsList.scrollToRecord(_selectedItem, true);
if (_selectedItem.get('value') == value)
this.exceptionsList.selectRecord(_selectedItem, true);
else
_selectedItem = null;
}
}
(!_selectedItem) && this.exceptionsList.deselectAll();
this.updateExceptionsControls(_selectedItem);
},
updateExceptionsControls: function(rec) {
if (!this.exceptionsList) return;
rec = rec || this.exceptionsList.getSelectedRec();
var value = this.exceptionsFindInput.getValue();
this.btnDeleteExceptions.setCaption(rec && rec.get('defaultDisabled') ? this.textRestore : this.textDelete);
this.btnDeleteExceptions.setDisabled(!rec);
this.btnAddExceptions.setDisabled(!!rec || !value);
},
textTitle: 'AutoCorrect', textTitle: 'AutoCorrect',
textMathCorrect: 'Math AutoCorrect', textMathCorrect: 'Math AutoCorrect',
textReplace: 'Replace', textReplace: 'Replace',
@ -850,8 +1181,12 @@ define([ 'text!common/main/lib/template/AutoCorrectDialog.template',
textNewRowCol: 'Include new rows and columns in table', textNewRowCol: 'Include new rows and columns in table',
textAutoCorrect: 'AutoCorrect', textAutoCorrect: 'AutoCorrect',
textFLSentence: 'Capitalize first letter of sentences', textFLSentence: 'Capitalize first letter of sentences',
textWarnResetFL: 'Any exceptions you added will be removed and the removed ones will be restored. Do you want to continue?',
textWarnAddFL: 'Exceptions must contain only the letters, uppercase or lowercase.',
textForLangFL: 'Exceptions for the language:',
textHyperlink: 'Internet and network paths with hyperlinks', textHyperlink: 'Internet and network paths with hyperlinks',
textFLCells: 'Capitalize first letter of table cells', textFLCells: 'Capitalize first letter of table cells',
textFLDont: 'Don`t capitalize after',
textDoubleSpaces: 'Add period with double-space' textDoubleSpaces: 'Add period with double-space'
}, Common.Views.AutoCorrectDialog || {})) }, Common.Views.AutoCorrectDialog || {}))

View file

@ -2848,18 +2848,37 @@ define([
Common.Utils.InternalSettings.set("de-settings-autoformat-hyphens", value); Common.Utils.InternalSettings.set("de-settings-autoformat-hyphens", value);
me.api.asc_SetAutoCorrectHyphensWithDash(value); me.api.asc_SetAutoCorrectHyphensWithDash(value);
value = Common.localStorage.getBool("de-settings-autoformat-fl-sentence", true); value = Common.localStorage.getItem("de-settings-letter-exception-sentence");
Common.Utils.InternalSettings.set("de-settings-autoformat-fl-sentence", value); value = value !== null ? parseInt(value) != 0 : Common.localStorage.getBool("de-settings-autoformat-fl-sentence", true);
Common.Utils.InternalSettings.set("de-settings-letter-exception-sentence", value);
me.api.asc_SetAutoCorrectFirstLetterOfSentences(value); me.api.asc_SetAutoCorrectFirstLetterOfSentences(value);
value = Common.localStorage.getItem("de-settings-letter-exception-cells");
value = value !== null ? parseInt(value) != 0 : Common.localStorage.getBool("de-settings-autoformat-fl-cells", true);
Common.Utils.InternalSettings.set("de-settings-letter-exception-cells", value);
me.api.asc_SetAutoCorrectFirstLetterOfCells(value);
[0x0409, 0x0419].forEach(function(lang) {
var apiFlManager = me.api.asc_GetAutoCorrectSettings().get_FirstLetterExceptionManager();
value = Common.localStorage.getItem("de-settings-letter-exception-add-" + lang);
Common.Utils.InternalSettings.set("de-settings-letter-exception-add-" + lang, value);
arrAdd = value ? JSON.parse(value) : [];
value = Common.localStorage.getItem("de-settings-letter-exception-rem-" + lang);
Common.Utils.InternalSettings.set("de-settings-letter-exception-rem-" + lang, value);
arrRem = value ? JSON.parse(value) : [];
var arrRes = _.union(apiFlManager.get_Exceptions(lang), arrAdd);
arrRes = _.difference(arrRes, arrRem);
arrRes.sort();
apiFlManager.put_Exceptions(arrRes, lang);
});
value = Common.localStorage.getBool("de-settings-autoformat-hyperlink", true); value = Common.localStorage.getBool("de-settings-autoformat-hyperlink", true);
Common.Utils.InternalSettings.set("de-settings-autoformat-hyperlink", value); Common.Utils.InternalSettings.set("de-settings-autoformat-hyperlink", value);
me.api.asc_SetAutoCorrectHyperlinks(value); me.api.asc_SetAutoCorrectHyperlinks(value);
value = Common.localStorage.getBool("de-settings-autoformat-fl-cells", true);
Common.Utils.InternalSettings.set("de-settings-autoformat-fl-cells", value);
me.api.asc_SetAutoCorrectFirstLetterOfCells(value);
value = Common.localStorage.getBool("de-settings-autoformat-double-space", Common.Utils.isMac); // add period with double-space in MacOs by default value = Common.localStorage.getBool("de-settings-autoformat-double-space", Common.Utils.isMac); // add period with double-space in MacOs by default
Common.Utils.InternalSettings.set("de-settings-autoformat-double-space", value); Common.Utils.InternalSettings.set("de-settings-autoformat-double-space", value);
me.api.asc_SetAutoCorrectDoubleSpaceWithPeriod(value); me.api.asc_SetAutoCorrectDoubleSpaceWithPeriod(value);

View file

@ -391,6 +391,10 @@
"Common.Views.AutoCorrectDialog.textDoubleSpaces": "Add period with double-space", "Common.Views.AutoCorrectDialog.textDoubleSpaces": "Add period with double-space",
"Common.Views.AutoCorrectDialog.textFLCells": "Capitalize first letter of table cells", "Common.Views.AutoCorrectDialog.textFLCells": "Capitalize first letter of table cells",
"Common.Views.AutoCorrectDialog.textFLSentence": "Capitalize first letter of sentences", "Common.Views.AutoCorrectDialog.textFLSentence": "Capitalize first letter of sentences",
"Common.Views.AutoCorrectDialog.textForLangFL": "Exceptions for the language:",
"Common.Views.AutoCorrectDialog.textWarnResetFL": "Any exceptions you added will be removed and the removed ones will be restored. Do you want to continue?",
"Common.Views.AutoCorrectDialog.textWarnAddFL": "Exceptions must contain only the letters, uppercase or lowercase.",
"Common.Views.AutoCorrectDialog.textFLDont": "Don`t capitalize after",
"Common.Views.AutoCorrectDialog.textHyperlink": "Internet and network paths with hyperlinks", "Common.Views.AutoCorrectDialog.textHyperlink": "Internet and network paths with hyperlinks",
"Common.Views.AutoCorrectDialog.textHyphens": "Hyphens (--) with dash (—)", "Common.Views.AutoCorrectDialog.textHyphens": "Hyphens (--) with dash (—)",
"Common.Views.AutoCorrectDialog.textMathCorrect": "Math AutoCorrect", "Common.Views.AutoCorrectDialog.textMathCorrect": "Math AutoCorrect",

View file

@ -391,6 +391,10 @@
"Common.Views.AutoCorrectDialog.textDoubleSpaces": "Добавлять точку двойным пробелом", "Common.Views.AutoCorrectDialog.textDoubleSpaces": "Добавлять точку двойным пробелом",
"Common.Views.AutoCorrectDialog.textFLCells": "Делать первые буквы ячеек таблиц прописными", "Common.Views.AutoCorrectDialog.textFLCells": "Делать первые буквы ячеек таблиц прописными",
"Common.Views.AutoCorrectDialog.textFLSentence": "Делать первые буквы предложений прописными", "Common.Views.AutoCorrectDialog.textFLSentence": "Делать первые буквы предложений прописными",
"Common.Views.AutoCorrectDialog.textForLangFL": "Исключения для языка:",
"Common.Views.AutoCorrectDialog.textFLDont": "Не писать прописными буквами после",
"Common.Views.AutoCorrectDialog.textWarnResetFL": "Все добавленные вами исключения будут удалены, а удаленные восстановлены. Вы хотите продолжить?",
"Common.Views.AutoCorrectDialog.textWarnAddFL": "Исключения должны содержать только прописные или строчные буквы.",
"Common.Views.AutoCorrectDialog.textHyperlink": "Адреса в Интернете и сетевые пути гиперссылками", "Common.Views.AutoCorrectDialog.textHyperlink": "Адреса в Интернете и сетевые пути гиперссылками",
"Common.Views.AutoCorrectDialog.textHyphens": "Дефисы (--) на тире (—)", "Common.Views.AutoCorrectDialog.textHyphens": "Дефисы (--) на тире (—)",
"Common.Views.AutoCorrectDialog.textMathCorrect": "Автозамена математическими символами", "Common.Views.AutoCorrectDialog.textMathCorrect": "Автозамена математическими символами",

View file

@ -2406,18 +2406,37 @@ define([
Common.Utils.InternalSettings.set("pe-settings-autoformat-hyphens", value); Common.Utils.InternalSettings.set("pe-settings-autoformat-hyphens", value);
me.api.asc_SetAutoCorrectHyphensWithDash(value); me.api.asc_SetAutoCorrectHyphensWithDash(value);
value = Common.localStorage.getBool("pe-settings-autoformat-fl-sentence", true); value = Common.localStorage.getItem("pe-settings-letter-exception-sentence");
Common.Utils.InternalSettings.set("pe-settings-autoformat-fl-sentence", value); value = value !== null ? parseInt(value) != 0 : Common.localStorage.getBool("pe-settings-autoformat-fl-sentence", true);
Common.Utils.InternalSettings.set("pe-settings-letter-exception-sentence", value);
me.api.asc_SetAutoCorrectFirstLetterOfSentences(value); me.api.asc_SetAutoCorrectFirstLetterOfSentences(value);
value = Common.localStorage.getItem("pe-settings-letter-exceptionl-cells", true);
value = value !== null ? parseInt(value) != 0 : Common.localStorage.getBool("pe-settings-autoformat-fl-cells", true);
Common.Utils.InternalSettings.set("pe-settings-letter-exception-cells", value);
me.api.asc_SetAutoCorrectFirstLetterOfCells && me.api.asc_SetAutoCorrectFirstLetterOfCells(value);
[0x0409, 0x0419].forEach(function(lang) {
var apiFlManager = me.api.asc_GetAutoCorrectSettings().get_FirstLetterExceptionManager();
value = Common.localStorage.getItem("pe-settings-letter-exception-add-" + lang);
Common.Utils.InternalSettings.set("pe-settings-letter-exception-add-" + lang, value);
arrAdd = value ? JSON.parse(value) : [];
value = Common.localStorage.getItem("pe-settings-letter-exception-rem-" + lang);
Common.Utils.InternalSettings.set("pe-settings-letter-exception-rem-" + lang, value);
arrRem = value ? JSON.parse(value) : [];
var arrRes = _.union(apiFlManager.get_Exceptions(lang), arrAdd);
arrRes = _.difference(arrRes, arrRem);
arrRes.sort();
apiFlManager.put_Exceptions(arrRes, lang);
});
value = Common.localStorage.getBool("pe-settings-autoformat-hyperlink", true); value = Common.localStorage.getBool("pe-settings-autoformat-hyperlink", true);
Common.Utils.InternalSettings.set("pe-settings-autoformat-hyperlink", value); Common.Utils.InternalSettings.set("pe-settings-autoformat-hyperlink", value);
me.api.asc_SetAutoCorrectHyperlinks(value); me.api.asc_SetAutoCorrectHyperlinks(value);
value = Common.localStorage.getBool("pe-settings-autoformat-fl-cells", true);
Common.Utils.InternalSettings.set("pe-settings-autoformat-fl-cells", value);
me.api.asc_SetAutoCorrectFirstLetterOfCells && me.api.asc_SetAutoCorrectFirstLetterOfCells(value);
value = Common.localStorage.getBool("pe-settings-autoformat-double-space", Common.Utils.isMac); // add period with double-space in MacOs by default value = Common.localStorage.getBool("pe-settings-autoformat-double-space", Common.Utils.isMac); // add period with double-space in MacOs by default
Common.Utils.InternalSettings.set("pe-settings-autoformat-double-space", value); Common.Utils.InternalSettings.set("pe-settings-autoformat-double-space", value);
me.api.asc_SetAutoCorrectDoubleSpaceWithPeriod(value); me.api.asc_SetAutoCorrectDoubleSpaceWithPeriod(value);

View file

@ -483,6 +483,10 @@
"Common.Views.AutoCorrectDialog.textDoubleSpaces": "Add period with double-space", "Common.Views.AutoCorrectDialog.textDoubleSpaces": "Add period with double-space",
"Common.Views.AutoCorrectDialog.textFLCells": "Capitalize first letter of table cells", "Common.Views.AutoCorrectDialog.textFLCells": "Capitalize first letter of table cells",
"Common.Views.AutoCorrectDialog.textFLSentence": "Capitalize first letter of sentences", "Common.Views.AutoCorrectDialog.textFLSentence": "Capitalize first letter of sentences",
"Common.Views.AutoCorrectDialog.textForLangFL": "Exceptions for the language:",
"Common.Views.AutoCorrectDialog.textWarnResetFL": "Any exceptions you added will be removed and the removed ones will be restored. Do you want to continue?",
"Common.Views.AutoCorrectDialog.textWarnAddFL": "Exceptions must contain only the letters, uppercase or lowercase.",
"Common.Views.AutoCorrectDialog.textFLDont": "Don`t capitalize after",
"Common.Views.AutoCorrectDialog.textHyperlink": "Internet and network paths with hyperlinks", "Common.Views.AutoCorrectDialog.textHyperlink": "Internet and network paths with hyperlinks",
"Common.Views.AutoCorrectDialog.textHyphens": "Hyphens (--) with dash (—)", "Common.Views.AutoCorrectDialog.textHyphens": "Hyphens (--) with dash (—)",
"Common.Views.AutoCorrectDialog.textMathCorrect": "Math AutoCorrect", "Common.Views.AutoCorrectDialog.textMathCorrect": "Math AutoCorrect",

View file

@ -483,6 +483,10 @@
"Common.Views.AutoCorrectDialog.textDoubleSpaces": "Добавлять точку двойным пробелом", "Common.Views.AutoCorrectDialog.textDoubleSpaces": "Добавлять точку двойным пробелом",
"Common.Views.AutoCorrectDialog.textFLCells": "Делать первые буквы ячеек таблиц прописными", "Common.Views.AutoCorrectDialog.textFLCells": "Делать первые буквы ячеек таблиц прописными",
"Common.Views.AutoCorrectDialog.textFLSentence": "Делать первые буквы предложений прописными", "Common.Views.AutoCorrectDialog.textFLSentence": "Делать первые буквы предложений прописными",
"Common.Views.AutoCorrectDialog.textForLangFL": "Исключения для языка:",
"Common.Views.AutoCorrectDialog.textFLDont": "Не писать прописными буквами после",
"Common.Views.AutoCorrectDialog.textWarnResetFL": "Все добавленные вами исключения будут удалены, а удаленные восстановлены. Вы хотите продолжить?",
"Common.Views.AutoCorrectDialog.textWarnAddFL": "Исключения должны содержать только прописные или строчные буквы.",
"Common.Views.AutoCorrectDialog.textHyperlink": "Адреса в Интернете и сетевые пути гиперссылками", "Common.Views.AutoCorrectDialog.textHyperlink": "Адреса в Интернете и сетевые пути гиперссылками",
"Common.Views.AutoCorrectDialog.textHyphens": "Дефисы (--) на тире (—)", "Common.Views.AutoCorrectDialog.textHyphens": "Дефисы (--) на тире (—)",
"Common.Views.AutoCorrectDialog.textMathCorrect": "Автозамена математическими символами", "Common.Views.AutoCorrectDialog.textMathCorrect": "Автозамена математическими символами",