DocumentServer/OfficeWeb/apps/common/mobile/lib/component/slider/Vertical.js
nikolay ivanov a8be6b9e72 init repo
2014-07-05 18:22:49 +00:00

168 lines
6.2 KiB
JavaScript

/*
* (c) Copyright Ascensio System SIA 2010-2014
*
* 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
*
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
* EU, LV-1021.
*
* 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
*
*/
Ext.define("Common.component.slider.Vertical", {
extend: "Ext.slider.Slider",
xtype: "verticalslider",
config: {
baseCls: "x-slider-vertical",
thumbConfig: {
draggable: {
direction: "vertical"
}
}
},
refreshOffsetValueRatio: function () {
var valueRange = this.getMaxValue() - this.getMinValue(),
trackHeight = this.elementHeight - this.thumbHeight;
this.offsetValueRatio = trackHeight / valueRange;
},
refreshElementHeight: function () {
this.elementHeight = this.element.dom.offsetHeight;
var thumb = this.getThumb(0);
if (thumb) {
this.thumbHeight = thumb.getElementWidth();
}
},
refresh: function () {
this.refreshElementHeight();
this.refreshValue();
},
onThumbDragStart: function (thumb, e) {
if (e.absDeltaY <= e.absDeltaX) {
return false;
} else {
e.stopPropagation();
}
if (this.getAllowThumbsOverlapping()) {
this.setActiveThumb(thumb);
}
this.dragStartValue = this.getValue()[this.getThumbIndex(thumb)];
this.fireEvent("dragstart", this, thumb, this.dragStartValue, e);
},
onThumbDrag: function (thumb, e, offsetX, offsetY) {
var index = this.getThumbIndex(thumb),
offsetValueRatio = this.offsetValueRatio,
constrainedValue = this.constrainValue(offsetY / offsetValueRatio);
e.stopPropagation();
this.setIndexValue(index, constrainedValue);
this.fireEvent("drag", this, thumb, this.getValue(), e);
return false;
},
setIndexValue: function (index, value, animation) {
var thumb = this.getThumb(index),
values = this.getValue(),
offsetValueRatio = this.offsetValueRatio,
draggable = thumb.getDraggable();
draggable.setOffset(null, value * offsetValueRatio, animation);
values[index] = this.constrainValue(draggable.getOffset().y / offsetValueRatio);
},
updateValue: function (newValue, oldValue) {
var thumbs = this.getThumbs(),
ln = newValue.length,
i;
this.setThumbsCount(ln);
for (i = 0; i < ln; i++) {
thumbs[i].getDraggable().setExtraConstraint(null).setOffset(0, newValue[i] * this.offsetValueRatio);
}
for (i = 0; i < ln; i++) {
this.refreshThumbConstraints(thumbs[i]);
}
},
refreshThumbConstraints: function (thumb) {
var allowThumbsOverlapping = this.getAllowThumbsOverlapping(),
offsetY = thumb.getDraggable().getOffset().y,
thumbs = this.getThumbs(),
index = this.getThumbIndex(thumb),
previousThumb = thumbs[index - 1],
nextThumb = thumbs[index + 1],
thumbHeight = this.thumbHeight;
if (previousThumb) {
previousThumb.getDraggable().addExtraConstraint({
max: {
y: offsetY - ((allowThumbsOverlapping) ? 0 : thumbHeight)
}
});
}
if (nextThumb) {
nextThumb.getDraggable().addExtraConstraint({
min: {
y: offsetY + ((allowThumbsOverlapping) ? 0 : thumbHeight)
}
});
}
},
onTap: function (e) {
if (this.isDisabled()) {
return;
}
var targetElement = Ext.get(e.target);
if (!targetElement || targetElement.hasCls("x-thumb")) {
return;
}
var touchPointY = e.touch.point.y,
element = this.element,
elementY = element.getY(),
offset = touchPointY - elementY - (this.thumbHeight / 2),
value = this.constrainValue(offset / this.offsetValueRatio),
values = this.getValue(),
minDistance = Infinity,
ln = values.length,
i,
absDistance,
testValue,
closestIndex,
oldValue,
thumb;
if (ln === 1) {
closestIndex = 0;
} else {
for (i = 0; i < ln; i++) {
testValue = values[i];
absDistance = Math.abs(testValue - value);
if (absDistance < minDistance) {
minDistance = absDistance;
closestIndex = i;
}
}
}
oldValue = values[closestIndex];
thumb = this.getThumb(closestIndex);
this.setIndexValue(closestIndex, value, this.getAnimation());
this.refreshThumbConstraints(thumb);
if (oldValue !== value) {
this.fireEvent("change", this, thumb, value, oldValue);
}
}
},
function () {
Ext.deprecateProperty(this, "animationDuration", null, "Ext.slider.Slider.animationDuration has been removed");
});