Fix Bug 19846: search by function name
This commit is contained in:
parent
48934472b5
commit
b528c26570
|
@ -63,23 +63,26 @@ define([
|
||||||
contentTemplate : '',
|
contentTemplate : '',
|
||||||
title : t.txtTitle,
|
title : t.txtTitle,
|
||||||
items : [],
|
items : [],
|
||||||
buttons: ['ok', 'cancel']
|
buttons: null
|
||||||
}, options);
|
}, options);
|
||||||
|
|
||||||
this.template = options.template || [
|
this.template = options.template || [
|
||||||
'<div class="box" style="height:' + (_options.height - 85) + 'px;">',
|
'<div class="box" style="height:' + (_options.height - 85) + 'px;">',
|
||||||
'<div class="content-panel" >',
|
'<div class="content-panel" >',
|
||||||
|
'<div id="formula-dlg-search" style="height:22px; margin-bottom:10px;"></div>',
|
||||||
'<label class="header">' + t.textGroupDescription + '</label>',
|
'<label class="header">' + t.textGroupDescription + '</label>',
|
||||||
'<div id="formula-dlg-combo-group" class="input-group-nr" style="margin-top: 10px"/>',
|
'<div id="formula-dlg-combo-group" class="input-group-nr" style=""/>',
|
||||||
'<label class="header" style="margin-top:10px">' + t.textListDescription + '</label>',
|
'<label class="header" style="margin-top: 10px">' + t.textListDescription + '</label>',
|
||||||
'<div id="formula-dlg-combo-functions" class="combo-functions"/>',
|
'<div id="formula-dlg-combo-functions" class="combo-functions"/>',
|
||||||
'<label id="formula-dlg-args" style="margin-top: 7px">' + '</label>',
|
'<label id="formula-dlg-args" style="margin-top: 7px">' + '</label>',
|
||||||
'<label id="formula-dlg-desc" style="margin-top: 4px; display: block;">' + '</label>',
|
'<label id="formula-dlg-desc" style="margin-top: 4px; display: block;">' + '</label>',
|
||||||
|
|
||||||
'</div>',
|
'</div>',
|
||||||
'</div>',
|
'</div>',
|
||||||
'<div class="separator horizontal"/>'
|
'<div class="separator horizontal"/>',
|
||||||
|
'<div class="footer center">',
|
||||||
|
'<button id="formula-dlg-btn-ok" class="btn normal dlg-btn primary" result="ok" style="width: 86px;">' + this.okButtonText + '</button>',
|
||||||
|
'<button class="btn normal dlg-btn" result="cancel" style="width: 86px;">' + this.cancelButtonText + '</button>',
|
||||||
|
'</div>'
|
||||||
].join('');
|
].join('');
|
||||||
|
|
||||||
this.api = options.api;
|
this.api = options.api;
|
||||||
|
@ -95,6 +98,27 @@ define([
|
||||||
|
|
||||||
this.$window.find('.dlg-btn').on('click', _.bind(this.onBtnClick, this));
|
this.$window.find('.dlg-btn').on('click', _.bind(this.onBtnClick, this));
|
||||||
|
|
||||||
|
var me = this;
|
||||||
|
this.inputSearch = new Common.UI.InputField({
|
||||||
|
el : $('#formula-dlg-search', this.$window),
|
||||||
|
allowBlank : true,
|
||||||
|
placeHolder : this.txtSearch,
|
||||||
|
validateOnChange : true,
|
||||||
|
validation : function () { return true; }
|
||||||
|
}).on ('changing', function (input, value) {
|
||||||
|
if (value.length) {
|
||||||
|
value = value.replace(/([.?*+^$[\]\\(){}|-])/g, "\\$1");
|
||||||
|
me.filter = new RegExp(value, 'ig');
|
||||||
|
} else {
|
||||||
|
me.filter = undefined;
|
||||||
|
}
|
||||||
|
me.filterFormulas();
|
||||||
|
});
|
||||||
|
|
||||||
|
this.btnOk = new Common.UI.Button({
|
||||||
|
el: $('#formula-dlg-btn-ok')
|
||||||
|
});
|
||||||
|
|
||||||
this.syntaxLabel = $('#formula-dlg-args');
|
this.syntaxLabel = $('#formula-dlg-args');
|
||||||
this.descLabel = $('#formula-dlg-desc');
|
this.descLabel = $('#formula-dlg-desc');
|
||||||
this.fillFormulasGroups();
|
this.fillFormulasGroups();
|
||||||
|
@ -120,47 +144,35 @@ define([
|
||||||
|
|
||||||
Common.UI.Window.prototype.show.call(this);
|
Common.UI.Window.prototype.show.call(this);
|
||||||
|
|
||||||
this.mask = $('.modals-mask');
|
|
||||||
this.mask.on('mousedown',_.bind(this.onUpdateFocus, this));
|
|
||||||
this.$window.on('mousedown',_.bind(this.onUpdateFocus, this));
|
|
||||||
|
|
||||||
group && this.cmbFuncGroup.setValue(group);
|
group && this.cmbFuncGroup.setValue(group);
|
||||||
(group || this.cmbFuncGroup.getValue()=='Last10') && this.fillFunctions(this.cmbFuncGroup.getValue());
|
(group || this.cmbFuncGroup.getValue()=='Last10') && this.fillFunctions(this.cmbFuncGroup.getValue());
|
||||||
|
|
||||||
if (this.cmbListFunctions) {
|
if (this.cmbListFunctions) {
|
||||||
|
this.inputSearch.setValue('');
|
||||||
_.delay(function (me) {
|
_.delay(function (me) {
|
||||||
me.cmbListFunctions.$el.find('.listview').focus();
|
me.inputSearch.$el.find('input').focus();
|
||||||
}, 100, this);
|
}, 100, this);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
hide: function () {
|
hide: function () {
|
||||||
//NOTE: scroll to top
|
var val = this.cmbFuncGroup.getValue();
|
||||||
//if (this.cmbListFunctions && this.functions && this.functions.length) {
|
(val=='Recommended') && (val = 'Last10');
|
||||||
// $(this.cmbListFunctions.scroller.el).scrollTop(-this.cmbListFunctions.scroller.getScrollTop());
|
if (this.cmbFuncGroup.store.at(0).get('value')=='Recommended') {
|
||||||
//}
|
this.cmbFuncGroup.store.shift();
|
||||||
|
this.cmbFuncGroup.onResetItems();
|
||||||
this.mask.off('mousedown',_.bind(this.onUpdateFocus, this));
|
}
|
||||||
this.$window.off('mousedown',_.bind(this.onUpdateFocus, this));
|
this.cmbFuncGroup.setValue(val);
|
||||||
|
this.recommended = this.filter = undefined;
|
||||||
|
|
||||||
Common.UI.Window.prototype.hide.call(this);
|
Common.UI.Window.prototype.hide.call(this);
|
||||||
},
|
},
|
||||||
|
|
||||||
onBtnClick: function (event) {
|
onBtnClick: function (event) {
|
||||||
if ('ok' === event.currentTarget.attributes['result'].value) {
|
this._handleInput(event.currentTarget.attributes['result'].value);
|
||||||
if (this.handler) {
|
|
||||||
this.handler.call(this, this.applyFunction);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
this.hide();
|
|
||||||
},
|
},
|
||||||
onDblClickFunction: function () {
|
onDblClickFunction: function () {
|
||||||
if (this.handler) {
|
this._handleInput('ok');
|
||||||
this.handler.call(this, this.applyFunction);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.hide();
|
|
||||||
},
|
},
|
||||||
onSelectGroup: function (combo, record) {
|
onSelectGroup: function (combo, record) {
|
||||||
if (!_.isUndefined(record) && !_.isUndefined(record.value)) {
|
if (!_.isUndefined(record) && !_.isUndefined(record.value)) {
|
||||||
|
@ -172,14 +184,20 @@ define([
|
||||||
onSelectFunction: function (listView, itemView, record) {
|
onSelectFunction: function (listView, itemView, record) {
|
||||||
var funcId, functions, func;
|
var funcId, functions, func;
|
||||||
|
|
||||||
if (this.formulasGroups) {
|
if (this.formulasGroups && record) {
|
||||||
this.applyFunction = {name: record.get('value'), origin: record.get('origin')};
|
this.applyFunction = {name: record.get('value'), origin: record.get('origin')};
|
||||||
this.syntaxLabel.text(this.applyFunction.name + record.get('args'));
|
this.syntaxLabel.text(this.applyFunction.name + record.get('args'));
|
||||||
this.descLabel.text(record.get('desc'));
|
this.descLabel.text(record.get('desc'));
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
onPrimary: function(list, record, event) {
|
onPrimary: function(list, record, event) {
|
||||||
if (this.handler) {
|
this._handleInput('ok');
|
||||||
|
},
|
||||||
|
|
||||||
|
_handleInput: function(state) {
|
||||||
|
if (this.handler && state == 'ok') {
|
||||||
|
if (this.btnOk.isDisabled())
|
||||||
|
return;
|
||||||
this.handler.call(this, this.applyFunction);
|
this.handler.call(this, this.applyFunction);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -187,9 +205,11 @@ define([
|
||||||
},
|
},
|
||||||
|
|
||||||
onUpdateFocus: function () {
|
onUpdateFocus: function () {
|
||||||
_.delay(function(me) {
|
if (this.cmbListFunctions) {
|
||||||
me.cmbListFunctions.$el.find('.listview').focus();
|
_.delay(function (me) {
|
||||||
}, 100, this);
|
me.cmbListFunctions.$el.find('.listview').focus();
|
||||||
|
}, 100, this);
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
//
|
//
|
||||||
|
@ -228,6 +248,9 @@ define([
|
||||||
this.cmbFuncGroup.setValue('Last10');
|
this.cmbFuncGroup.setValue('Last10');
|
||||||
this.fillFunctions('Last10');
|
this.fillFunctions('Last10');
|
||||||
|
|
||||||
|
this.allFunctions = new Common.UI.DataViewStore();
|
||||||
|
var group = this.formulasGroups.findWhere({name : 'All'});
|
||||||
|
group && this.allFunctions.reset(group.get('functions'));
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
fillFunctions: function (name) {
|
fillFunctions: function (name) {
|
||||||
|
@ -246,48 +269,69 @@ define([
|
||||||
this.cmbListFunctions.on('item:dblclick', _.bind(this.onDblClickFunction, this));
|
this.cmbListFunctions.on('item:dblclick', _.bind(this.onDblClickFunction, this));
|
||||||
this.cmbListFunctions.on('entervalue', _.bind(this.onPrimary, this));
|
this.cmbListFunctions.on('entervalue', _.bind(this.onPrimary, this));
|
||||||
this.cmbListFunctions.onKeyDown = _.bind(this.onKeyDown, this.cmbListFunctions);
|
this.cmbListFunctions.onKeyDown = _.bind(this.onKeyDown, this.cmbListFunctions);
|
||||||
this.cmbListFunctions.$el.find('.listview').focus();
|
|
||||||
this.cmbListFunctions.scrollToRecord = _.bind(this.onScrollToRecordCustom, this.cmbListFunctions);
|
this.cmbListFunctions.scrollToRecord = _.bind(this.onScrollToRecordCustom, this.cmbListFunctions);
|
||||||
|
this.onUpdateFocus();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.functions) {
|
if (this.functions) {
|
||||||
this.functions.reset();
|
this.functions.reset();
|
||||||
|
|
||||||
var i = 0,
|
var functions = null;
|
||||||
length = 0,
|
if (name=='Recommended') {
|
||||||
functions = null,
|
functions = this.recommended;
|
||||||
group = this.formulasGroups.findWhere({name : name});
|
} else {
|
||||||
|
var group = this.formulasGroups.findWhere({name : name});
|
||||||
if (group) {
|
group && (functions = group.get('functions'));
|
||||||
functions = group.get('functions');
|
|
||||||
if (functions && functions.length) {
|
|
||||||
length = functions.length;
|
|
||||||
for (i = 0; i < length; ++i) {
|
|
||||||
this.functions.push(new Common.UI.DataViewModel({
|
|
||||||
id : functions[i].get('index'),
|
|
||||||
selected : i < 1,
|
|
||||||
allowSelected : true,
|
|
||||||
value : functions[i].get('name'),
|
|
||||||
args : functions[i].get('args'),
|
|
||||||
desc : functions[i].get('desc'),
|
|
||||||
origin : functions[i].get('origin')
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
|
|
||||||
this.applyFunction = {name: functions[0].get('name'), origin: functions[0].get('origin')};
|
|
||||||
|
|
||||||
this.syntaxLabel.text(this.applyFunction.name + functions[0].get('args'));
|
|
||||||
this.descLabel.text(functions[0].get('desc'));
|
|
||||||
this.cmbListFunctions.scroller.update({
|
|
||||||
minScrollbarLength : 40,
|
|
||||||
alwaysVisibleY : true
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
var length = functions ? functions.length : 0;
|
||||||
|
for (var i = 0; i < length; ++i) {
|
||||||
|
this.functions.push(new Common.UI.DataViewModel({
|
||||||
|
id : functions[i].get('index'),
|
||||||
|
selected : i < 1,
|
||||||
|
allowSelected : true,
|
||||||
|
value : functions[i].get('name'),
|
||||||
|
args : functions[i].get('args'),
|
||||||
|
desc : functions[i].get('desc'),
|
||||||
|
origin : functions[i].get('origin')
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
|
||||||
|
this.applyFunction = length ? {name: functions[0].get('name'), origin: functions[0].get('origin')} : undefined;
|
||||||
|
|
||||||
|
this.syntaxLabel.text(length ? this.applyFunction.name + functions[0].get('args') : '');
|
||||||
|
this.descLabel.text(length ? functions[0].get('desc') : '');
|
||||||
|
this.cmbListFunctions.scroller.update({
|
||||||
|
minScrollbarLength : 40,
|
||||||
|
alwaysVisibleY : true
|
||||||
|
});
|
||||||
|
this.btnOk.setDisabled(!length);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
filterFormulas: function() {
|
||||||
|
if (!this.filter) {
|
||||||
|
this.cmbFuncGroup.setValue('Last10');
|
||||||
|
this.fillFunctions('Last10');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var me = this,
|
||||||
|
arr = this.allFunctions.filter(function(item) {
|
||||||
|
return !!item.get('name').match(me.filter);
|
||||||
|
});
|
||||||
|
if (arr.length>0 && this.cmbFuncGroup.store.at(0).get('value')!='Recommended') {
|
||||||
|
this.cmbFuncGroup.store.unshift({value: 'Recommended', displayValue: this.txtRecommended});
|
||||||
|
this.cmbFuncGroup.onResetItems();
|
||||||
|
} else if (arr.length==0 && this.cmbFuncGroup.store.at(0).get('value')=='Recommended') {
|
||||||
|
this.cmbFuncGroup.store.shift();
|
||||||
|
this.cmbFuncGroup.onResetItems();
|
||||||
|
}
|
||||||
|
this.cmbFuncGroup.setValue('Recommended');
|
||||||
|
this.recommended = arr;
|
||||||
|
this.fillFunctions('Recommended');
|
||||||
|
},
|
||||||
|
|
||||||
onKeyDown: function (e, event) {
|
onKeyDown: function (e, event) {
|
||||||
var i = 0, record = null,
|
var i = 0, record = null,
|
||||||
me = this,
|
me = this,
|
||||||
|
@ -374,7 +418,9 @@ define([
|
||||||
textGroupDescription: 'Select Function Group',
|
textGroupDescription: 'Select Function Group',
|
||||||
textListDescription: 'Select Function',
|
textListDescription: 'Select Function',
|
||||||
sDescription: 'Description',
|
sDescription: 'Description',
|
||||||
txtTitle: 'Insert Function'
|
txtTitle: 'Insert Function',
|
||||||
|
txtSearch: 'Search',
|
||||||
|
txtRecommended: 'Recommended'
|
||||||
|
|
||||||
}, SSE.Views.FormulaDialog || {}));
|
}, SSE.Views.FormulaDialog || {}));
|
||||||
});
|
});
|
|
@ -1737,6 +1737,8 @@
|
||||||
"SSE.Views.FormulaDialog.textGroupDescription": "Select Function Group",
|
"SSE.Views.FormulaDialog.textGroupDescription": "Select Function Group",
|
||||||
"SSE.Views.FormulaDialog.textListDescription": "Select Function",
|
"SSE.Views.FormulaDialog.textListDescription": "Select Function",
|
||||||
"SSE.Views.FormulaDialog.txtTitle": "Insert Function",
|
"SSE.Views.FormulaDialog.txtTitle": "Insert Function",
|
||||||
|
"SSE.Views.FormulaDialog.txtSearch": "Search",
|
||||||
|
"SSE.Views.FormulaDialog.txtRecommended": "Recommended",
|
||||||
"SSE.Views.FormulaTab.textAutomatic": "Automatic",
|
"SSE.Views.FormulaTab.textAutomatic": "Automatic",
|
||||||
"SSE.Views.FormulaTab.textCalculateCurrentSheet": "Calculate current sheet",
|
"SSE.Views.FormulaTab.textCalculateCurrentSheet": "Calculate current sheet",
|
||||||
"SSE.Views.FormulaTab.textCalculateWorkbook": "Calculate workbook",
|
"SSE.Views.FormulaTab.textCalculateWorkbook": "Calculate workbook",
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
.combo-functions {
|
.combo-functions {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: 184px;
|
height: 161px;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue