diff --git a/npm-shrinkwrap.json b/npm-shrinkwrap.json index a0d7a7a..e9e1a39 100644 --- a/npm-shrinkwrap.json +++ b/npm-shrinkwrap.json @@ -3098,6 +3098,16 @@ "from": "jodid25519@>=1.0.0 <2.0.0", "resolved": "https://registry.npmjs.org/jodid25519/-/jodid25519-1.0.2.tgz" }, + "jquery": { + "version": "3.2.1", + "from": "jquery@latest", + "resolved": "https://registry.npmjs.org/jquery/-/jquery-3.2.1.tgz" + }, + "jquery-ui": { + "version": "1.12.1", + "from": "jquery-ui@latest", + "resolved": "https://registry.npmjs.org/jquery-ui/-/jquery-ui-1.12.1.tgz" + }, "js-base64": { "version": "2.1.9", "from": "js-base64@>=2.1.9 <3.0.0", diff --git a/package.json b/package.json index 502c1c1..2deaebd 100644 --- a/package.json +++ b/package.json @@ -40,6 +40,9 @@ "file-loader": "^0.10.1", "html-webpack-plugin": "^2.28.0", "http-server": "^0.9.0", + "jquery": "^3.2.1", + "jquery-ui": "^1.12.1", + "jquery-ui-bundle": "^1.12.1", "karma": "^0.13.22", "karma-babel-preprocessor": "^6.0.1", "karma-chai": "^0.1.0", diff --git a/src/Main/Toolbox/Keyboard/Panel/KeyOverlay/SlideSelector/index.jsx b/src/Main/Toolbox/Keyboard/Panel/KeyOverlay/SlideSelector/index.jsx index 5b90c66..be5d9f2 100644 --- a/src/Main/Toolbox/Keyboard/Panel/KeyOverlay/SlideSelector/index.jsx +++ b/src/Main/Toolbox/Keyboard/Panel/KeyOverlay/SlideSelector/index.jsx @@ -1,7 +1,9 @@ import React, { Component } from 'react'; import CSSModules from 'react-css-modules'; import styles from './styles.scss'; -import Draggable from 'draggable'; +import $ from 'jquery'; +import 'jquery-ui-bundle'; + import _ from 'lodash'; class SlideSelector extends Component { @@ -13,6 +15,7 @@ class SlideSelector extends Component { this.optionClass = this.optionClass.bind(this); this.optionClass = this.optionClass.bind(this); this.onDrag = this.onDrag.bind(this); + this.onDragStop = this.onDragStop.bind(this); this.state = { selected: this.props.default || 1 @@ -24,23 +27,36 @@ class SlideSelector extends Component { } initDraggable() { - var element = this.sliderBall; - var options = { - limit: this.slider, - grid: this.props.options.count, - onDrag: this.onDrag - }; - - new Draggable(element, options); + var $element = $(this.sliderBall); + + $element.draggable({ + axis: "y", + containment: "parent", + stop: this.onDragStop + }) + } + + onDragStop(event, { position: { left, top } }) { + // + // use this.slider.offsetTop to get difference in offset between + // slider options and sliderBall + // + const $sliderBall = $(event.target); + const $closest = $(this.getClosestOption(left, top + this.slider.offsetTop)) + const closestY = $closest.position().top - this.slider.offsetTop; + + $sliderBall.stop().animate({ + top: closestY + }, 500,'easeOutCirc'); } getClosestOption(x, y) { - const locations = this.getOptionLocations(); + const locations = this.getOptionLocations(); let closestIdx = 0; locations.forEach((location, idx) => { - let diff = Math.abs(location - y); - let closestOptionDiff = locations[closestIdx] - y; + const diff = Math.abs(location - y); + const closestOptionDiff = Math.abs(locations[closestIdx] - y); if(diff < closestOptionDiff){ closestIdx = idx; @@ -51,7 +67,8 @@ class SlideSelector extends Component { } getOptionLocations() { - const optionsCount = this.props.options.count; + const optionsCount = Object.keys(this.props.options).length; + // returns the y offsets of all options return _.times(optionsCount, i => this['option' + i].offsetTop); } @@ -72,7 +89,9 @@ class SlideSelector extends Component { renderOption(optionId, idx) { return ( -