Merge pull request #1200 from ONLYOFFICE/feature/sse-text-qualifier

Feature/sse text qualifier
This commit is contained in:
Julia Radzhabova 2021-09-24 10:29:06 +03:00 committed by GitHub
commit 5f34dcab62
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 40 additions and 8 deletions

View file

@ -291,10 +291,12 @@ define([
}
var decimal = this.separatorOptions ? this.separatorOptions.decimal : undefined,
thousands = this.separatorOptions ? this.separatorOptions.thousands : undefined;
thousands = this.separatorOptions ? this.separatorOptions.thousands : undefined,
qualifier = this.separatorOptions ? this.separatorOptions.qualifier : '"';
var options = new Asc.asc_CTextOptions(encoding, delimiter, delimiterChar);
decimal && options.asc_setNumberDecimalSeparator(decimal);
thousands && options.asc_setNumberGroupSeparator(thousands);
qualifier && options.asc_setTextQualifier(qualifier);
this.handler.call(this, state, {
textOptions: options,
range: this.txtDestRange ? this.txtDestRange.getValue() : '',
@ -433,6 +435,7 @@ define([
if (this.separatorOptions) {
options.asc_setNumberDecimalSeparator(this.separatorOptions.decimal);
options.asc_setNumberGroupSeparator(this.separatorOptions.thousands);
options.asc_setTextQualifier(this.separatorOptions.qualifier);
}
this.api.asc_TextImport(options, _.bind(this.previewCallback, this), this.type == Common.Utils.importTextType.Paste);
break;
@ -441,6 +444,7 @@ define([
if (this.separatorOptions) {
options.asc_setNumberDecimalSeparator(this.separatorOptions.decimal);
options.asc_setNumberGroupSeparator(this.separatorOptions.thousands);
options.asc_setTextQualifier(this.separatorOptions.qualifier);
}
this.api.asc_decodeBuffer(this.preview, options, _.bind(this.previewCallback, this));
break;
@ -536,17 +540,20 @@ define([
var me = this,
decimal = this.api.asc_getDecimalSeparator(),
thousands = this.api.asc_getGroupSeparator();
thousands = this.api.asc_getGroupSeparator(),
qualifier = this.settings ? this.settings.asc_getTextQualifier() : '"';
(new SSE.Views.AdvancedSeparatorDialog({
props: {
decimal: decimal,
thousands: thousands
thousands: thousands,
qualifier: qualifier
},
handler: function(result, value) {
if (result == 'ok') {
me.separatorOptions = {
decimal: (value.decimal.length > 0) ? value.decimal : decimal,
thousands: (value.thousands.length > 0) ? value.thousands : thousands
thousands: (value.thousands.length > 0) ? value.thousands : thousands,
qualifier: value.qualifier
};
}
}

View file

@ -66,6 +66,12 @@ define([
'<div style="margin-bottom: 10px;">',
'<div id="id-adv-separator-thousands" class=""></div><label class="input-row" style="margin-left: 10px; padding-top: 4px;">' + this.strThousandsSeparator + '</label>',
'</div>',
'<div class="input-row" style="margin-bottom: 8px;">',
'<label>' + this.textQualifier + '</label>',
'</div>',
'<div style="margin-bottom: 12px;">',
'<div id="id-adv-separator-qualifier" class="input-group-nr"></div>',
'</div>',
'</div>'
].join('');
@ -92,14 +98,27 @@ define([
validateOnBlur: false
});
this.cmbQualifier = new Common.UI.ComboBox({
el: $('#id-adv-separator-qualifier'),
style: 'width: 100px;',
menuStyle: 'min-width: 100px;',
cls: 'input-group-nr',
data: [
{value: '"', displayValue: '"'},
{value: '\'', displayValue: '\''},
{value: null, displayValue: this.txtNone}],
editable: false,
takeFocusOnClose: true
});
var $window = this.getChild();
$window.find('.btn').on('click', _.bind(this.onBtnClick, this));
$window.find('.dlg-btn').on('click', _.bind(this.onBtnClick, this));
this.afterRender();
},
getFocusedComponents: function() {
return [this.inputDecimalSeparator, this.inputThousandsSeparator];
return [this.inputDecimalSeparator, this.inputThousandsSeparator, this.cmbQualifier];
},
getDefaultFocusableComponent: function () {
@ -114,6 +133,7 @@ define([
if (props) {
this.inputDecimalSeparator.setValue(props.decimal || '');
this.inputThousandsSeparator.setValue(props.thousands || '');
this.cmbQualifier.setValue(props.qualifier || null);
}
},
@ -128,7 +148,8 @@ define([
_handleInput: function(state) {
if (this.options.handler) {
this.options.handler.call(this, state, {decimal: this.inputDecimalSeparator.getValue(), thousands: this.inputThousandsSeparator.getValue()});
this.options.handler.call(this, state, {decimal: this.inputDecimalSeparator.getValue(), thousands: this.inputThousandsSeparator.getValue(),
qualifier: this.cmbQualifier.getValue()});
}
this.close();
@ -137,7 +158,9 @@ define([
textTitle: 'Advanced Settings',
textLabel: 'Settings used to recognize numeric data',
strDecimalSeparator: 'Decimal separator',
strThousandsSeparator: 'Thousands separator'
strThousandsSeparator: 'Thousands separator',
txtNone: '(none)',
textQualifier: 'Text qualifier'
}, SSE.Views.AdvancedSeparatorDialog || {}));
});

View file

@ -1432,6 +1432,8 @@
"SSE.Views.AdvancedSeparatorDialog.strThousandsSeparator": "Thousands separator",
"SSE.Views.AdvancedSeparatorDialog.textLabel": "Settings used to recognize numeric data",
"SSE.Views.AdvancedSeparatorDialog.textTitle": "Advanced Settings",
"SSE.Views.AdvancedSeparatorDialog.txtNone": "(none)",
"SSE.Views.AdvancedSeparatorDialog.textQualifier": "Text qualifier",
"SSE.Views.AutoFilterDialog.btnCustomFilter": "Custom Filter",
"SSE.Views.AutoFilterDialog.textAddSelection": "Add current selection to filter",
"SSE.Views.AutoFilterDialog.textEmptyItem": "{Blanks}",