2016-04-01 13:17:09 +00:00
|
|
|
/*
|
|
|
|
*
|
2019-01-17 13:05:03 +00:00
|
|
|
* (c) Copyright Ascensio System SIA 2010-2019
|
2016-04-01 13:17:09 +00:00
|
|
|
*
|
|
|
|
* This program is a free software product. You can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
|
|
|
* version 3 as published by the Free Software Foundation. In accordance with
|
|
|
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
|
|
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
|
|
|
* of any third-party rights.
|
|
|
|
*
|
|
|
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
|
|
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
|
|
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
|
|
|
*
|
2019-01-17 13:00:34 +00:00
|
|
|
* You can contact Ascensio System SIA at 20A-12 Ernesta Birznieka-Upisha
|
|
|
|
* street, Riga, Latvia, EU, LV-1050.
|
2016-04-01 13:17:09 +00:00
|
|
|
*
|
|
|
|
* The interactive user interfaces in modified source and object code versions
|
|
|
|
* of the Program must display Appropriate Legal Notices, as required under
|
|
|
|
* Section 5 of the GNU AGPL version 3.
|
|
|
|
*
|
|
|
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
|
|
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
|
|
|
* grant you any rights under trademark law for use of our trademarks.
|
|
|
|
*
|
|
|
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
|
|
|
* well as technical writing content are licensed under the terms of the
|
|
|
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
|
|
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
|
|
|
*
|
|
|
|
*/
|
2016-03-11 00:48:53 +00:00
|
|
|
/**
|
|
|
|
* ComboBorderSize.js
|
|
|
|
*
|
|
|
|
* Created by Julia Radzhabova on 2/10/14
|
2018-03-01 12:16:38 +00:00
|
|
|
* Copyright (c) 2018 Ascensio System SIA. All rights reserved.
|
2016-03-11 00:48:53 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Using template
|
|
|
|
*
|
|
|
|
* <div class="input-group input-group-nr combobox combo-border-size" id="id-combobox">
|
|
|
|
* <div class="form-control"></div>
|
|
|
|
* <div style="display: table-cell;"></div>
|
|
|
|
* <button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown"><span class="caret"></span></button>
|
|
|
|
* <ul class="dropdown-menu"></ul>
|
|
|
|
* </div>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
if (Common === undefined)
|
|
|
|
var Common = {};
|
|
|
|
|
|
|
|
define([
|
|
|
|
'common/main/lib/component/ComboBox'
|
|
|
|
], function () {
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
Common.UI.BordersModel = Backbone.Model.extend({
|
|
|
|
defaults: function() {
|
|
|
|
return {
|
|
|
|
value: null,
|
|
|
|
displayValue: null,
|
|
|
|
pxValue: null,
|
|
|
|
id: Common.UI.getId(),
|
|
|
|
offsety: undefined
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
Common.UI.BordersStore = Backbone.Collection.extend({
|
|
|
|
model: Common.UI.BordersModel
|
|
|
|
});
|
|
|
|
|
|
|
|
Common.UI.ComboBorderSize = Common.UI.ComboBox.extend(_.extend({
|
|
|
|
template: _.template([
|
|
|
|
'<div class="input-group combobox combo-border-size input-group-nr <%= cls %>" id="<%= id %>" style="<%= style %>">',
|
2018-08-15 13:39:16 +00:00
|
|
|
'<div class="form-control" style="padding-top:2px; <%= style %>"></div>',
|
2016-03-11 00:48:53 +00:00
|
|
|
'<div style="display: table-cell;"></div>',
|
|
|
|
'<button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown"><span class="caret img-commonctrl"></span></button>',
|
|
|
|
'<ul class="dropdown-menu <%= menuCls %>" style="<%= menuStyle %>" role="menu">',
|
|
|
|
'<% _.each(items, function(item) { %>',
|
|
|
|
'<li id="<%= item.id %>" data-value="<%= item.value %>"><a tabindex="-1" type="menuitem">',
|
|
|
|
'<span><%= item.displayValue %></span>',
|
|
|
|
'<% if (item.offsety!==undefined) { %>',
|
|
|
|
'<img src="" align="right" style="background-position: 0 -<%= item.offsety %>px;">',
|
|
|
|
'<% } %>',
|
|
|
|
'</a></li>',
|
|
|
|
'<% }); %>',
|
|
|
|
'</ul>',
|
|
|
|
'</div>'
|
|
|
|
].join('')),
|
|
|
|
|
|
|
|
initialize : function(options) {
|
2016-09-14 13:34:08 +00:00
|
|
|
var txtPt = Common.Utils.Metric.getMetricName(Common.Utils.Metric.c_MetricUnits.pt),
|
|
|
|
data = [
|
2016-04-06 13:38:54 +00:00
|
|
|
{displayValue: '0.5 ' + txtPt, value: 0.5, pxValue: 0.5, offsety: 0},
|
|
|
|
{displayValue: '1 ' + txtPt, value: 1, pxValue: 1, offsety: 20},
|
|
|
|
{displayValue: '1.5 ' + txtPt, value: 1.5, pxValue: 2, offsety: 40},
|
|
|
|
{displayValue: '2.25 ' + txtPt, value: 2.25,pxValue: 3, offsety: 60},
|
|
|
|
{displayValue: '3 ' + txtPt, value: 3, pxValue: 4, offsety: 80},
|
|
|
|
{displayValue: '4.5 ' + txtPt, value: 4.5, pxValue: 5, offsety: 100},
|
|
|
|
{displayValue: '6 ' + txtPt, value: 6, pxValue: 6, offsety: 120}
|
2016-09-14 13:34:08 +00:00
|
|
|
];
|
2016-09-23 08:23:23 +00:00
|
|
|
if (options.allowNoBorders !== false)
|
2016-09-14 13:34:08 +00:00
|
|
|
data.unshift({displayValue: this.txtNoBorders, value: 0, pxValue: 0 });
|
|
|
|
|
|
|
|
Common.UI.ComboBox.prototype.initialize.call(this, _.extend({
|
|
|
|
editable: false,
|
|
|
|
store: new Common.UI.BordersStore(),
|
|
|
|
data: data,
|
2019-06-25 13:22:50 +00:00
|
|
|
menuStyle: 'min-width: 160px;'
|
2016-03-11 00:48:53 +00:00
|
|
|
}, options));
|
|
|
|
},
|
|
|
|
|
|
|
|
render : function(parentEl) {
|
|
|
|
Common.UI.ComboBox.prototype.render.call(this, parentEl);
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
itemClicked: function (e) {
|
|
|
|
var el = $(e.currentTarget).parent();
|
|
|
|
|
|
|
|
this._selectedItem = this.store.findWhere({
|
|
|
|
id: el.attr('id')
|
|
|
|
});
|
|
|
|
if (this._selectedItem) {
|
|
|
|
$('.selected', $(this.el)).removeClass('selected');
|
|
|
|
el.addClass('selected');
|
|
|
|
this.updateFormControl(this._selectedItem);
|
|
|
|
|
|
|
|
this.trigger('selected', this, _.extend({}, this._selectedItem.toJSON()), e);
|
|
|
|
e.preventDefault();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
updateFormControl: function(record) {
|
|
|
|
var formcontrol = $(this.el).find('.form-control');
|
|
|
|
|
|
|
|
if (record.get('value')>0) {
|
|
|
|
formcontrol[0].innerHTML = '';
|
|
|
|
formcontrol.removeClass('text').addClass('image');
|
2020-04-03 17:21:00 +00:00
|
|
|
formcontrol.css('background-position', '10px -' + record.get('offsety') + 'px');
|
2016-03-11 00:48:53 +00:00
|
|
|
} else {
|
|
|
|
formcontrol[0].innerHTML = this.txtNoBorders;
|
|
|
|
formcontrol.removeClass('image').addClass('text');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
setValue: function(value) {
|
|
|
|
this._selectedItem = (value===null || value===undefined) ? undefined : _.find(this.store.models, function(item) {
|
|
|
|
if ( value<item.attributes.value+0.01 && value>item.attributes.value-0.01) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
$('.selected', $(this.el)).removeClass('selected');
|
|
|
|
|
|
|
|
if (this._selectedItem) {
|
|
|
|
this.updateFormControl(this._selectedItem);
|
|
|
|
$('#' + this._selectedItem.get('id'), $(this.el)).addClass('selected');
|
|
|
|
} else {
|
|
|
|
var formcontrol = $(this.el).find('.form-control');
|
|
|
|
formcontrol[0].innerHTML = '';
|
|
|
|
formcontrol.removeClass('image').addClass('text');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
txtNoBorders: 'No Borders'
|
|
|
|
}, Common.UI.ComboBorderSize || {}));
|
|
|
|
|
|
|
|
Common.UI.ComboBorderSizeEditable = Common.UI.ComboBox.extend(_.extend({
|
|
|
|
template: _.template([
|
|
|
|
'<span class="input-group combobox combo-border-size input-group-nr <%= cls %>" id="<%= id %>" style="<%= style %>">',
|
|
|
|
'<input type="text" class="form-control text">',
|
|
|
|
'<button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown"><span class="caret img-commonctrl"></span></button>',
|
|
|
|
'<ul class="dropdown-menu <%= menuCls %>" style="<%= menuStyle %>" role="menu">',
|
|
|
|
'<% _.each(items, function(item) { %>',
|
|
|
|
'<li id="<%= item.id %>" data-value="<%= item.value %>"><a tabindex="-1" type="menuitem">',
|
|
|
|
'<span><%= item.displayValue %></span>',
|
|
|
|
'<% if (item.offsety!==undefined) { %>',
|
|
|
|
'<img src="" align="right" style="background-position: 0 -<%= item.offsety %>px;">',
|
|
|
|
'<% } %>',
|
|
|
|
'</a></li>',
|
|
|
|
'<% }); %>',
|
|
|
|
'</ul>',
|
|
|
|
'</span>'
|
|
|
|
].join('')),
|
|
|
|
|
|
|
|
initialize : function(options) {
|
|
|
|
this.txtNoBorders = options.txtNoBorders || this.txtNoBorders;
|
2016-09-23 08:23:23 +00:00
|
|
|
var txtPt = Common.Utils.Metric.getMetricName(Common.Utils.Metric.c_MetricUnits.pt),
|
|
|
|
data = [
|
2016-04-06 13:38:54 +00:00
|
|
|
{displayValue: '0.5 ' + txtPt, value: 0.5, pxValue: 0.5, offsety: 0},
|
|
|
|
{displayValue: '1 ' + txtPt, value: 1, pxValue: 1, offsety: 20},
|
|
|
|
{displayValue: '1.5 ' + txtPt, value: 1.5, pxValue: 2, offsety: 40},
|
|
|
|
{displayValue: '2.25 ' + txtPt, value: 2.25,pxValue: 3, offsety: 60},
|
|
|
|
{displayValue: '3 ' + txtPt, value: 3, pxValue: 4, offsety: 80},
|
|
|
|
{displayValue: '4.5 ' + txtPt, value: 4.5, pxValue: 5, offsety: 100},
|
|
|
|
{displayValue: '6 ' + txtPt, value: 6, pxValue: 6, offsety: 120}
|
2016-09-23 08:23:23 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
if (options.allowNoBorders !== false)
|
|
|
|
data.unshift({displayValue: this.txtNoBorders, value: 0, pxValue: 0 });
|
|
|
|
|
|
|
|
Common.UI.ComboBox.prototype.initialize.call(this, _.extend({
|
|
|
|
editable: true,
|
|
|
|
store: new Common.UI.BordersStore(),
|
|
|
|
data: data,
|
2019-06-25 13:22:50 +00:00
|
|
|
menuStyle: 'min-width: 160px;'
|
2016-03-11 00:48:53 +00:00
|
|
|
}, options));
|
|
|
|
},
|
|
|
|
|
|
|
|
render : function(parentEl) {
|
|
|
|
Common.UI.ComboBox.prototype.render.call(this, parentEl);
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
txtNoBorders: 'No Borders'
|
|
|
|
}, Common.UI.ComboBorderSizeEditable || {}));
|
2016-06-29 12:47:08 +00:00
|
|
|
|
|
|
|
Common.UI.ComboBorderType = Common.UI.ComboBorderSize.extend(_.extend({
|
|
|
|
template: _.template([
|
|
|
|
'<div class="input-group combobox combo-border-size input-group-nr <%= cls %>" id="<%= id %>" style="<%= style %>">',
|
|
|
|
'<div class="form-control" style="<%= style %>"></div>',
|
|
|
|
'<div style="display: table-cell;"></div>',
|
|
|
|
'<button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown"><span class="caret img-commonctrl"></span></button>',
|
|
|
|
'<ul class="dropdown-menu <%= menuCls %>" style="<%= menuStyle %>" role="menu">',
|
|
|
|
'<% _.each(items, function(item) { %>',
|
2020-04-03 17:21:00 +00:00
|
|
|
'<li id="<%= item.id %>" data-value="<%= item.value %>"><a tabindex="-1" type="menuitem" style="padding: 2px 0 2px 10px;">',
|
2016-06-29 12:47:08 +00:00
|
|
|
'<span style="margin-top: 0;"></span>',
|
|
|
|
'<% if (item.offsety!==undefined) { %>',
|
|
|
|
'<img src="" align="left" style="background-position: 0 -<%= item.offsety %>px;">',
|
|
|
|
'<% } %>',
|
|
|
|
'</a></li>',
|
|
|
|
'<% }); %>',
|
|
|
|
'</ul>',
|
|
|
|
'</div>'
|
|
|
|
].join('')),
|
|
|
|
|
|
|
|
initialize : function(options) {
|
|
|
|
Common.UI.ComboBorderSize.prototype.initialize.call(this, _.extend({
|
|
|
|
store: new Common.UI.BordersStore(),
|
|
|
|
data: [
|
|
|
|
{value: Asc.c_oDashType.solid, offsety: 140},
|
|
|
|
{value: Asc.c_oDashType.sysDot, offsety: 160},
|
|
|
|
{value: Asc.c_oDashType.sysDash, offsety: 180},
|
|
|
|
{value: Asc.c_oDashType.dash, offsety: 200},
|
|
|
|
{value: Asc.c_oDashType.dashDot, offsety: 220},
|
|
|
|
{value: Asc.c_oDashType.lgDash, offsety: 240},
|
|
|
|
{value: Asc.c_oDashType.lgDashDot, offsety: 260},
|
|
|
|
{value: Asc.c_oDashType.lgDashDotDot, offsety: 280}
|
|
|
|
]
|
|
|
|
}, options));
|
|
|
|
},
|
|
|
|
|
|
|
|
render : function(parentEl) {
|
|
|
|
Common.UI.ComboBorderSize.prototype.render.call(this, parentEl);
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
updateFormControl: function(record) {
|
|
|
|
var formcontrol = $(this.el).find('.form-control');
|
|
|
|
formcontrol[0].innerHTML = '';
|
|
|
|
formcontrol.removeClass('text').addClass('image');
|
2020-04-03 17:21:00 +00:00
|
|
|
formcontrol.css('background-position', '10px -' + record.get('offsety') + 'px');
|
2016-06-29 12:47:08 +00:00
|
|
|
}
|
|
|
|
}, Common.UI.ComboBorderType || {}));
|
2019-11-22 14:38:04 +00:00
|
|
|
|
|
|
|
Common.UI.ComboBoxColor = Common.UI.ComboBox.extend(_.extend({
|
|
|
|
template: _.template([
|
2020-04-16 15:42:54 +00:00
|
|
|
'<div class="input-group combobox combo-color input-group-nr <%= cls %>" id="<%= id %>" style="<%= style %>">',
|
2019-11-22 14:38:04 +00:00
|
|
|
'<div class="form-control" style="padding:2px 14px 2px 3px; <%= style %> display: block;">',
|
|
|
|
'<div style="display: inline-block;overflow: hidden;width: 100%;height: 100%;"></div>',
|
|
|
|
'</div>',
|
|
|
|
'<button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown"><span class="caret img-commonctrl"></span></button>',
|
|
|
|
'<ul class="dropdown-menu <%= menuCls %>" style="<%= menuStyle %>" role="menu">',
|
|
|
|
'<% _.each(items, function(item) { %>',
|
|
|
|
'<% if (item.value==-1) { %>',
|
|
|
|
'<li id="<%= item.id %>" data-value="<%= item.value %>"><a tabindex="-1" type="menuitem"><%= scope.getDisplayValue(item) %></a></li>',
|
|
|
|
'<% } else { %>',
|
|
|
|
'<li id="<%= item.id %>" data-value="<%= item.value %>">',
|
|
|
|
'<a tabindex="-1" type="menuitem" style="padding: 5px;"><div style="height: 15px;background-color: #<%= item.value %>"></div></a>',
|
|
|
|
'</li>',
|
|
|
|
'<% } %>',
|
|
|
|
'<% }); %>',
|
|
|
|
'</ul>',
|
|
|
|
'</div>'
|
|
|
|
].join('')),
|
|
|
|
|
|
|
|
itemClicked: function (e) {
|
|
|
|
var el = $(e.currentTarget).parent();
|
|
|
|
|
|
|
|
this._selectedItem = this.store.findWhere({
|
|
|
|
id: el.attr('id')
|
|
|
|
});
|
|
|
|
if (this._selectedItem) {
|
|
|
|
$('.selected', $(this.el)).removeClass('selected');
|
|
|
|
el.addClass('selected');
|
|
|
|
this.updateFormControl(this._selectedItem);
|
|
|
|
|
|
|
|
this.trigger('selected', this, _.extend({}, this._selectedItem.toJSON()), e);
|
|
|
|
e.preventDefault();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
updateFormControl: function(record) {
|
|
|
|
var formcontrol = $(this.el).find('.form-control > div');
|
|
|
|
|
2020-04-16 15:42:54 +00:00
|
|
|
formcontrol[0].innerHTML = record.get('displayValue');
|
2019-11-22 14:38:04 +00:00
|
|
|
if (record.get('value')!=-1) {
|
|
|
|
formcontrol.css({'background': '#' + record.get('value'), 'margin-top': '0'});
|
2020-04-16 15:42:54 +00:00
|
|
|
record.get('displayColor') && formcontrol.css({'color': '#' + record.get('displayColor'), 'text-align': 'center'});
|
2019-11-22 14:38:04 +00:00
|
|
|
} else {
|
|
|
|
formcontrol.css({'background': '', 'margin-top': '1px'});
|
2020-04-16 15:42:54 +00:00
|
|
|
formcontrol.css({'color': '', 'text-align': ''});
|
2019-11-22 14:38:04 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
setValue: function(value) {
|
|
|
|
var obj;
|
|
|
|
this._selectedItem = this.store.findWhere((obj={}, obj[this.valueField]=value, obj));
|
|
|
|
|
|
|
|
$('.selected', $(this.el)).removeClass('selected');
|
|
|
|
|
|
|
|
if (this._selectedItem) {
|
|
|
|
this.updateFormControl(this._selectedItem);
|
|
|
|
$('#' + this._selectedItem.get('id'), $(this.el)).addClass('selected');
|
|
|
|
} else {
|
|
|
|
var formcontrol = $(this.el).find('.form-control > div');
|
|
|
|
formcontrol[0].innerHTML = '';
|
|
|
|
formcontrol.css('background', '');
|
|
|
|
}
|
2019-11-26 07:37:44 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
onResetItems: function() {
|
|
|
|
if (this.itemsTemplate) {
|
|
|
|
$(this.el).find('ul').html( $(this.itemsTemplate({
|
|
|
|
items: this.store.toJSON(),
|
|
|
|
scope: this
|
|
|
|
})));
|
|
|
|
} else {
|
|
|
|
$(this.el).find('ul').html(_.template([
|
|
|
|
'<% _.each(items, function(item) { %>',
|
|
|
|
'<% if (item.value==-1) { %>',
|
|
|
|
'<li id="<%= item.id %>" data-value="<%= item.value %>"><a tabindex="-1" type="menuitem"><%= scope.getDisplayValue(item) %></a></li>',
|
|
|
|
'<% } else { %>',
|
|
|
|
'<li id="<%= item.id %>" data-value="<%= item.value %>">',
|
|
|
|
'<a tabindex="-1" type="menuitem" style="padding: 5px;"><div style="height: 15px;background-color: #<%= item.value %>"></div></a>',
|
|
|
|
'</li>',
|
|
|
|
'<% } %>',
|
|
|
|
'<% }); %>'
|
|
|
|
].join(''))({
|
|
|
|
items: this.store.toJSON(),
|
|
|
|
scope: this
|
|
|
|
}));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!_.isUndefined(this.scroller)) {
|
|
|
|
this.scroller.destroy();
|
|
|
|
delete this.scroller;
|
|
|
|
}
|
|
|
|
this.scroller = new Common.UI.Scroller(_.extend({
|
|
|
|
el: $('.dropdown-menu', this.cmpEl),
|
|
|
|
minScrollbarLength : 40,
|
|
|
|
includePadding : true,
|
|
|
|
wheelSpeed: 10,
|
|
|
|
alwaysVisibleY: this.scrollAlwaysVisible
|
|
|
|
}, this.options.scroller));
|
2019-11-22 14:38:04 +00:00
|
|
|
}
|
2019-11-26 07:37:44 +00:00
|
|
|
|
2019-11-22 14:38:04 +00:00
|
|
|
}, Common.UI.ComboBoxColor || {}));
|
|
|
|
|
2016-03-11 00:48:53 +00:00
|
|
|
});
|