209 lines
6.6 KiB
Diff
209 lines
6.6 KiB
Diff
--- jquery-ui-original.js 2014-05-09 15:37:46.890181010 +0200
|
|
+++ h5p-jquery-ui.js 2014-06-10 11:15:26.992887996 +0200
|
|
@@ -1,3 +1,6 @@
|
|
+var oldJQuery = jQuery;
|
|
+jQuery = H5P.jQuery;
|
|
+
|
|
/*! jQuery UI - v1.10.2 - 2013-03-14
|
|
* http://jqueryui.com
|
|
* Includes: jquery.ui.core.js, jquery.ui.widget.js, jquery.ui.mouse.js, jquery.ui.draggable.js, jquery.ui.droppable.js, jquery.ui.resizable.js, jquery.ui.selectable.js, jquery.ui.sortable.js, jquery.ui.effect.js, jquery.ui.accordion.js, jquery.ui.autocomplete.js, jquery.ui.button.js, jquery.ui.datepicker.js, jquery.ui.dialog.js, jquery.ui.effect-blind.js, jquery.ui.effect-bounce.js, jquery.ui.effect-clip.js, jquery.ui.effect-drop.js, jquery.ui.effect-explode.js, jquery.ui.effect-fade.js, jquery.ui.effect-fold.js, jquery.ui.effect-highlight.js, jquery.ui.effect-pulsate.js, jquery.ui.effect-scale.js, jquery.ui.effect-shake.js, jquery.ui.effect-slide.js, jquery.ui.effect-transfer.js, jquery.ui.menu.js, jquery.ui.position.js, jquery.ui.progressbar.js, jquery.ui.slider.js, jquery.ui.spinner.js, jquery.ui.tabs.js, jquery.ui.tooltip.js
|
|
@@ -920,7 +920,7 @@
|
|
.bind("mousemove."+this.widgetName, this._mouseMoveDelegate)
|
|
.bind("mouseup."+this.widgetName, this._mouseUpDelegate);
|
|
|
|
- event.preventDefault();
|
|
+ if (this.widgetName === 'slider') {
|
|
+ // Prevent tragging of slider handle(anchor) in Firefox
|
|
+ event.preventDefault();
|
|
+ }
|
|
|
|
mouseHandled = true;
|
|
return true;
|
|
@@ -1029,6 +1032,7 @@
|
|
if (this.options.disabled){
|
|
this.element.addClass("ui-draggable-disabled");
|
|
}
|
|
+ this.element[0].style.msTouchAction = this.element[0].style.touchAction = 'none';
|
|
|
|
this._mouseInit();
|
|
|
|
@@ -14985,3 +14989,177 @@
|
|
});
|
|
|
|
}( jQuery ) );
|
|
+
|
|
+/*!
|
|
+ * jQuery UI Touch Punch 0.2.2
|
|
+ *
|
|
+ * Copyright 2011, Dave Furfero
|
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|
+ *
|
|
+ * Depends:
|
|
+ * jquery.ui.widget.js
|
|
+ * jquery.ui.mouse.js
|
|
+ */
|
|
+(function ($) {
|
|
+
|
|
+ // Detect touch support
|
|
+ $.support.touch = 'ontouchend' in document;
|
|
+
|
|
+ // Ignore browsers without touch support
|
|
+ if (!$.support.touch) {
|
|
+ return;
|
|
+ }
|
|
+
|
|
+ var mouseProto = $.ui.mouse.prototype,
|
|
+ _mouseInit = mouseProto._mouseInit,
|
|
+ touchHandled;
|
|
+
|
|
+ /**
|
|
+ * Simulate a mouse event based on a corresponding touch event
|
|
+ * @param {Object} event A touch event
|
|
+ * @param {String} simulatedType The corresponding mouse event
|
|
+ */
|
|
+ function simulateMouseEvent (event, simulatedType) {
|
|
+
|
|
+ // Ignore multi-touch events
|
|
+ if (event.originalEvent.touches.length > 1) {
|
|
+ return;
|
|
+ }
|
|
+
|
|
+ event.preventDefault();
|
|
+
|
|
+ var touch = event.originalEvent.changedTouches[0],
|
|
+ simulatedEvent = document.createEvent('MouseEvents');
|
|
+
|
|
+ // Initialize the simulated mouse event using the touch event's coordinates
|
|
+ simulatedEvent.initMouseEvent(
|
|
+ simulatedType, // type
|
|
+ true, // bubbles
|
|
+ true, // cancelable
|
|
+ window, // view
|
|
+ 1, // detail
|
|
+ touch.screenX, // screenX
|
|
+ touch.screenY, // screenY
|
|
+ touch.clientX, // clientX
|
|
+ touch.clientY, // clientY
|
|
+ false, // ctrlKey
|
|
+ false, // altKey
|
|
+ false, // shiftKey
|
|
+ false, // metaKey
|
|
+ 0, // button
|
|
+ null // relatedTarget
|
|
+ );
|
|
+
|
|
+ // Dispatch the simulated event to the target element
|
|
+ event.target.dispatchEvent(simulatedEvent);
|
|
+ }
|
|
+
|
|
+ /**
|
|
+ * Handle the jQuery UI widget's touchstart events
|
|
+ * @param {Object} event The widget element's touchstart event
|
|
+ */
|
|
+ mouseProto._touchStart = function (event) {
|
|
+
|
|
+ var self = this;
|
|
+
|
|
+ // Ignore the event if another widget is already being handled
|
|
+ if (touchHandled || !self._mouseCapture(event.originalEvent.changedTouches[0])) {
|
|
+ return;
|
|
+ }
|
|
+
|
|
+ // Set the flag to prevent other widgets from inheriting the touch event
|
|
+ touchHandled = true;
|
|
+
|
|
+ // Track movement to determine if interaction was a click
|
|
+ self._touchMoved = false;
|
|
+
|
|
+ // Simulate the mouseover event
|
|
+ simulateMouseEvent(event, 'mouseover');
|
|
+
|
|
+ // Simulate the mousemove event
|
|
+ simulateMouseEvent(event, 'mousemove');
|
|
+
|
|
+ // Simulate the mousedown event
|
|
+ simulateMouseEvent(event, 'mousedown');
|
|
+ };
|
|
+
|
|
+ /**
|
|
+ * Handle the jQuery UI widget's touchmove events
|
|
+ * @param {Object} event The document's touchmove event
|
|
+ */
|
|
+ mouseProto._touchMove = function (event) {
|
|
+
|
|
+ // Ignore event if not handled
|
|
+ if (!touchHandled) {
|
|
+ return;
|
|
+ }
|
|
+
|
|
+ // Interaction was not a click
|
|
+ this._touchMoved = true;
|
|
+
|
|
+ // Simulate the mousemove event
|
|
+ simulateMouseEvent(event, 'mousemove');
|
|
+
|
|
+ event.stopPropagation();
|
|
+ };
|
|
+
|
|
+ /**
|
|
+ * Handle the jQuery UI widget's touchend events
|
|
+ * @param {Object} event The document's touchend event
|
|
+ */
|
|
+ mouseProto._touchEnd = function (event) {
|
|
+
|
|
+ // Ignore event if not handled
|
|
+ if (!touchHandled) {
|
|
+ return;
|
|
+ }
|
|
+
|
|
+ // Simulate the mouseup event
|
|
+ simulateMouseEvent(event, 'mouseup');
|
|
+
|
|
+ // Simulate the mouseout event
|
|
+ simulateMouseEvent(event, 'mouseout');
|
|
+
|
|
+ // If the touch interaction did not move, it should trigger a click
|
|
+ if (!this._touchMoved) {
|
|
+
|
|
+ // Simulate the click event
|
|
+ simulateMouseEvent(event, 'click');
|
|
+ }
|
|
+
|
|
+ // Unset the flag to allow other widgets to inherit the touch event
|
|
+ touchHandled = false;
|
|
+ };
|
|
+
|
|
+ /**
|
|
+ * A duck punch of the $.ui.mouse _mouseInit method to support touch events.
|
|
+ * This method extends the widget with bound touch event handlers that
|
|
+ * translate touch events to mouse events and pass them to the widget's
|
|
+ * original mouse event handling methods.
|
|
+ */
|
|
+ mouseProto._mouseInit = function () {
|
|
+
|
|
+ var self = this;
|
|
+
|
|
+ // Delegate the touch handlers to the widget's element
|
|
+ self.element
|
|
+ .bind('touchstart', $.proxy(self, '_touchStart'))
|
|
+ .bind('touchmove', $.proxy(self, '_touchMove'))
|
|
+ .bind('touchend', $.proxy(self, '_touchEnd'));
|
|
+
|
|
+ // Call the original $.ui.mouse init method
|
|
+ _mouseInit.call(self);
|
|
+ };
|
|
+
|
|
+})(jQuery);
|
|
+
|
|
+(function ($) {
|
|
+ // This is a hack to make stuff like ckeditor work inside modal dialogs. Since ckeditor dialogs are placed on body and not in the ui.dialog's DOM. See http://bugs.jqueryui.com/ticket/9087
|
|
+ $.widget("ui.dialog", $.ui.dialog, {
|
|
+ _allowInteraction: function (event) {
|
|
+ return true;
|
|
+ }
|
|
+ });
|
|
+ $.ui.dialog.prototype._focusTabbable = function () {};
|
|
+})(jQuery);
|
|
+
|
|
+jQuery = oldJQuery;
|