3.0 source code
This commit is contained in:
@@ -1,168 +1,168 @@
|
||||
/*
|
||||
* (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");
|
||||
/*
|
||||
* (c) Copyright Ascensio System SIA 2010-2015
|
||||
*
|
||||
* 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");
|
||||
});
|
||||
Reference in New Issue
Block a user