[SSE] Show menu for total row in formated table
This commit is contained in:
parent
031a75e0b9
commit
0e371cfb9b
|
@ -237,6 +237,7 @@ define([
|
||||||
view.pmiNumFormat.menu.on('item:click', _.bind(me.onNumberFormatSelect, me));
|
view.pmiNumFormat.menu.on('item:click', _.bind(me.onNumberFormatSelect, me));
|
||||||
view.pmiNumFormat.menu.on('show:after', _.bind(me.onNumberFormatOpenAfter, me));
|
view.pmiNumFormat.menu.on('show:after', _.bind(me.onNumberFormatOpenAfter, me));
|
||||||
view.pmiAdvancedNumFormat.on('click', _.bind(me.onCustomNumberFormat, me));
|
view.pmiAdvancedNumFormat.on('click', _.bind(me.onCustomNumberFormat, me));
|
||||||
|
view.tableTotalMenu.on('item:click', _.bind(me.onTotalMenuClick, me));
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
view.menuViewCopy.on('click', _.bind(me.onCopyPaste, me));
|
view.menuViewCopy.on('click', _.bind(me.onCopyPaste, me));
|
||||||
|
@ -321,6 +322,7 @@ define([
|
||||||
this.api.asc_registerCallback('asc_onFormulaInfo', _.bind(this.onFormulaInfo, this));
|
this.api.asc_registerCallback('asc_onFormulaInfo', _.bind(this.onFormulaInfo, this));
|
||||||
this.api.asc_registerCallback('asc_ChangeCropState', _.bind(this.onChangeCropState, this));
|
this.api.asc_registerCallback('asc_ChangeCropState', _.bind(this.onChangeCropState, this));
|
||||||
this.api.asc_registerCallback('asc_onInputMessage', _.bind(this.onInputMessage, this));
|
this.api.asc_registerCallback('asc_onInputMessage', _.bind(this.onInputMessage, this));
|
||||||
|
this.api.asc_registerCallback('asc_onTableTotalMenu', _.bind(this.onTableTotalMenu, this));
|
||||||
}
|
}
|
||||||
return this;
|
return this;
|
||||||
},
|
},
|
||||||
|
@ -2120,6 +2122,63 @@ define([
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
onTableTotalMenu: function(current) {
|
||||||
|
if (current !== undefined) {
|
||||||
|
var me = this,
|
||||||
|
documentHolderView = me.documentHolder,
|
||||||
|
menu = documentHolderView.tableTotalMenu,
|
||||||
|
menuContainer = documentHolderView.cmpEl.find(Common.Utils.String.format('#menu-container-{0}', menu.id));
|
||||||
|
|
||||||
|
if (menu.isVisible()) {
|
||||||
|
menu.hide();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Common.UI.Menu.Manager.hideAll();
|
||||||
|
|
||||||
|
if (!menu.rendered) {
|
||||||
|
// Prepare menu container
|
||||||
|
if (menuContainer.length < 1) {
|
||||||
|
menuContainer = $(Common.Utils.String.format('<div id="menu-container-{0}" style="position: absolute; z-index: 10000;"><div class="dropdown-toggle" data-toggle="dropdown"></div></div>', menu.id));
|
||||||
|
documentHolderView.cmpEl.append(menuContainer);
|
||||||
|
}
|
||||||
|
|
||||||
|
menu.render(menuContainer);
|
||||||
|
menu.cmpEl.attr({tabindex: "-1"});
|
||||||
|
}
|
||||||
|
|
||||||
|
menu.clearAll();
|
||||||
|
var func = _.find(menu.items, function(item) { return item.value == current; });
|
||||||
|
if (func)
|
||||||
|
func.setChecked(true, true);
|
||||||
|
|
||||||
|
var coord = me.api.asc_getActiveCellCoord(),
|
||||||
|
offset = {left:0,top:0},
|
||||||
|
showPoint = [coord.asc_getX() + offset.left, (coord.asc_getY() < 0 ? 0 : coord.asc_getY()) + coord.asc_getHeight() + offset.top];
|
||||||
|
menuContainer.css({left: showPoint[0], top : showPoint[1]});
|
||||||
|
|
||||||
|
me._preventClick = true;
|
||||||
|
menuContainer.attr('data-value', 'prevent-canvas-click');
|
||||||
|
menu.show();
|
||||||
|
|
||||||
|
menu.alignPosition();
|
||||||
|
_.delay(function() {
|
||||||
|
menu.cmpEl.focus();
|
||||||
|
}, 10);
|
||||||
|
} else {
|
||||||
|
this.documentHolder.tableTotalMenu.hide();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
onTotalMenuClick: function(menu, item) {
|
||||||
|
if (item.value==Asc.ETotalsRowFunction.totalrowfunctionCustom) {
|
||||||
|
this.onInsFunction(item);
|
||||||
|
} else {
|
||||||
|
this.api.asc_insertInCell(item.value, Asc.c_oAscPopUpSelectorType.TotalRowFunc);
|
||||||
|
}
|
||||||
|
Common.NotificationCenter.trigger('edit:complete', this.documentHolder);
|
||||||
|
},
|
||||||
|
|
||||||
onFormulaCompleteMenu: function(funcarr) {
|
onFormulaCompleteMenu: function(funcarr) {
|
||||||
if (!this.documentHolder.funcMenu || Common.Utils.ModalWindow.isVisible() || this.rangeSelectionMode) return;
|
if (!this.documentHolder.funcMenu || Common.Utils.ModalWindow.isVisible() || this.rangeSelectionMode) return;
|
||||||
|
|
||||||
|
|
|
@ -979,6 +979,23 @@ define([
|
||||||
mnu.cmpEl.removeAttr('oo_editor_input').attr('oo_editor_keyboard', true);
|
mnu.cmpEl.removeAttr('oo_editor_input').attr('oo_editor_keyboard', true);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
this.tableTotalMenu = new Common.UI.Menu({
|
||||||
|
maxHeight: 160,
|
||||||
|
cyclic: false,
|
||||||
|
cls: 'lang-menu',
|
||||||
|
items: [
|
||||||
|
{caption: this.textNone, value: Asc.ETotalsRowFunction.totalrowfunctionNone, checkable: true},
|
||||||
|
{caption: this.textAverage, value: Asc.ETotalsRowFunction.totalrowfunctionAverage, checkable: true },
|
||||||
|
{caption: this.textCount, value: Asc.ETotalsRowFunction.totalrowfunctionCount, checkable: true },
|
||||||
|
{caption: this.textMax, value: Asc.ETotalsRowFunction.totalrowfunctionMax, checkable: true },
|
||||||
|
{caption: this.textMin, value: Asc.ETotalsRowFunction.totalrowfunctionMin, checkable: true },
|
||||||
|
{caption: this.textSum, value: Asc.ETotalsRowFunction.totalrowfunctionSum, checkable: true },
|
||||||
|
{caption: this.textStdDev, value: Asc.ETotalsRowFunction.totalrowfunctionStdDev, checkable: true },
|
||||||
|
{caption: this.textVar, value: Asc.ETotalsRowFunction.totalrowfunctionVar, checkable: true },
|
||||||
|
{caption: this.textMore, value: Asc.ETotalsRowFunction.totalrowfunctionCustom, checkable: true }
|
||||||
|
]
|
||||||
|
});
|
||||||
|
|
||||||
me.fireEvent('createdelayedelements', [me]);
|
me.fireEvent('createdelayedelements', [me]);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -1111,7 +1128,15 @@ define([
|
||||||
textCropFit: 'Fit',
|
textCropFit: 'Fit',
|
||||||
textListSettings: 'List Settings',
|
textListSettings: 'List Settings',
|
||||||
textFromStorage: 'From Storage',
|
textFromStorage: 'From Storage',
|
||||||
advancedSlicerText: 'Slicer Advanced Settings'
|
advancedSlicerText: 'Slicer Advanced Settings',
|
||||||
|
textAverage: 'Average',
|
||||||
|
textMax: 'Max',
|
||||||
|
textMin: 'Min',
|
||||||
|
textCount: 'Count',
|
||||||
|
textSum: 'Sum',
|
||||||
|
textStdDev: 'StdDev',
|
||||||
|
textVar: 'Var',
|
||||||
|
textMore: 'More functions'
|
||||||
|
|
||||||
}, SSE.Views.DocumentHolder || {}));
|
}, SSE.Views.DocumentHolder || {}));
|
||||||
});
|
});
|
Loading…
Reference in a new issue