1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620 |
- (function webpackUniversalModuleDefinition(root, factory) {
- if(typeof exports === 'object' && typeof module === 'object')
- module.exports = factory(require("react-dom"), require("react"));
- else if(typeof define === 'function' && define.amd)
- define(["react-dom", "react"], factory);
- else if(typeof exports === 'object')
- exports["ReactDraggable"] = factory(require("react-dom"), require("react"));
- else
- root["ReactDraggable"] = factory(root["ReactDOM"], root["React"]);
- })(this, function(__WEBPACK_EXTERNAL_MODULE_4__, __WEBPACK_EXTERNAL_MODULE_6__) {
- return /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, {
- /******/ configurable: false,
- /******/ enumerable: true,
- /******/ get: getter
- /******/ });
- /******/ }
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "";
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 12);
- /******/ })
- /************************************************************************/
- /******/ ([
- /* 0 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.findInArray = findInArray;
- exports.isFunction = isFunction;
- exports.isNum = isNum;
- exports.int = int;
- exports.dontSetMe = dontSetMe;
- // @credits https://gist.github.com/rogozhnikoff/a43cfed27c41e4e68cdc
- function findInArray(array /*: Array<any> | TouchList*/, callback /*: Function*/) /*: any*/ {
- for (var i = 0, length = array.length; i < length; i++) {
- if (callback.apply(callback, [array[i], i, array])) return array[i];
- }
- }
- function isFunction(func /*: any*/) /*: boolean*/ {
- return typeof func === 'function' || Object.prototype.toString.call(func) === '[object Function]';
- }
- function isNum(num /*: any*/) /*: boolean*/ {
- return typeof num === 'number' && !isNaN(num);
- }
- function int(a /*: string*/) /*: number*/ {
- return parseInt(a, 10);
- }
- function dontSetMe(props /*: Object*/, propName /*: string*/, componentName /*: string*/) {
- if (props[propName]) {
- return new Error('Invalid prop ' + propName + ' passed to ' + componentName + ' - do not set this, set it on the child.');
- }
- }
- /***/ }),
- /* 1 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * Copyright (c) 2013-present, Facebook, Inc.
- * All rights reserved.
- *
- * This source code is licensed under the BSD-style license found in the
- * LICENSE file in the root directory of this source tree. An additional grant
- * of patent rights can be found in the PATENTS file in the same directory.
- *
- *
- */
- function makeEmptyFunction(arg) {
- return function () {
- return arg;
- };
- }
- /**
- * This function accepts and discards inputs; it has no side effects. This is
- * primarily useful idiomatically for overridable function endpoints which
- * always need to be callable, since JS lacks a null-call idiom ala Cocoa.
- */
- var emptyFunction = function emptyFunction() {};
- emptyFunction.thatReturns = makeEmptyFunction;
- emptyFunction.thatReturnsFalse = makeEmptyFunction(false);
- emptyFunction.thatReturnsTrue = makeEmptyFunction(true);
- emptyFunction.thatReturnsNull = makeEmptyFunction(null);
- emptyFunction.thatReturnsThis = function () {
- return this;
- };
- emptyFunction.thatReturnsArgument = function (arg) {
- return arg;
- };
- module.exports = emptyFunction;
- /***/ }),
- /* 2 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * Copyright (c) 2013-present, Facebook, Inc.
- * All rights reserved.
- *
- * This source code is licensed under the BSD-style license found in the
- * LICENSE file in the root directory of this source tree. An additional grant
- * of patent rights can be found in the PATENTS file in the same directory.
- *
- */
- /**
- * Use invariant() to assert state which your program assumes to be true.
- *
- * Provide sprintf-style format (only %s is supported) and arguments
- * to provide information about what broke and what you were
- * expecting.
- *
- * The invariant message will be stripped in production, but the invariant
- * will remain to ensure logic does not differ in production.
- */
- var validateFormat = function validateFormat(format) {};
- if (Object({"DRAGGABLE_DEBUG":undefined}).NODE_ENV !== 'production') {
- validateFormat = function validateFormat(format) {
- if (format === undefined) {
- throw new Error('invariant requires an error message argument');
- }
- };
- }
- function invariant(condition, format, a, b, c, d, e, f) {
- validateFormat(format);
- if (!condition) {
- var error;
- if (format === undefined) {
- error = new Error('Minified exception occurred; use the non-minified dev environment ' + 'for the full error message and additional helpful warnings.');
- } else {
- var args = [a, b, c, d, e, f];
- var argIndex = 0;
- error = new Error(format.replace(/%s/g, function () {
- return args[argIndex++];
- }));
- error.name = 'Invariant Violation';
- }
- error.framesToPop = 1; // we don't care about invariant's own frame
- throw error;
- }
- }
- module.exports = invariant;
- /***/ }),
- /* 3 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * Copyright 2013-present, Facebook, Inc.
- * All rights reserved.
- *
- * This source code is licensed under the BSD-style license found in the
- * LICENSE file in the root directory of this source tree. An additional grant
- * of patent rights can be found in the PATENTS file in the same directory.
- */
- var ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';
- module.exports = ReactPropTypesSecret;
- /***/ }),
- /* 4 */
- /***/ (function(module, exports) {
- module.exports = __WEBPACK_EXTERNAL_MODULE_4__;
- /***/ }),
- /* 5 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
- exports.matchesSelector = matchesSelector;
- exports.matchesSelectorAndParentsTo = matchesSelectorAndParentsTo;
- exports.addEvent = addEvent;
- exports.removeEvent = removeEvent;
- exports.outerHeight = outerHeight;
- exports.outerWidth = outerWidth;
- exports.innerHeight = innerHeight;
- exports.innerWidth = innerWidth;
- exports.offsetXYFromParent = offsetXYFromParent;
- exports.createCSSTransform = createCSSTransform;
- exports.createSVGTransform = createSVGTransform;
- exports.getTouch = getTouch;
- exports.getTouchIdentifier = getTouchIdentifier;
- exports.addUserSelectStyles = addUserSelectStyles;
- exports.removeUserSelectStyles = removeUserSelectStyles;
- exports.styleHacks = styleHacks;
- exports.addClassName = addClassName;
- exports.removeClassName = removeClassName;
- var _shims = __webpack_require__(0);
- var _getPrefix = __webpack_require__(18);
- var _getPrefix2 = _interopRequireDefault(_getPrefix);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
- /*:: import type {ControlPosition, MouseTouchEvent} from './types';*/
- var matchesSelectorFunc = '';
- function matchesSelector(el /*: Node*/, selector /*: string*/) /*: boolean*/ {
- if (!matchesSelectorFunc) {
- matchesSelectorFunc = (0, _shims.findInArray)(['matches', 'webkitMatchesSelector', 'mozMatchesSelector', 'msMatchesSelector', 'oMatchesSelector'], function (method) {
- // $FlowIgnore: Doesn't think elements are indexable
- return (0, _shims.isFunction)(el[method]);
- });
- }
- // $FlowIgnore: Doesn't think elements are indexable
- return el[matchesSelectorFunc].call(el, selector);
- }
- // Works up the tree to the draggable itself attempting to match selector.
- function matchesSelectorAndParentsTo(el /*: Node*/, selector /*: string*/, baseNode /*: Node*/) /*: boolean*/ {
- var node = el;
- do {
- if (matchesSelector(node, selector)) return true;
- if (node === baseNode) return false;
- node = node.parentNode;
- } while (node);
- return false;
- }
- function addEvent(el /*: ?Node*/, event /*: string*/, handler /*: Function*/) /*: void*/ {
- if (!el) {
- return;
- }
- if (el.attachEvent) {
- el.attachEvent('on' + event, handler);
- } else if (el.addEventListener) {
- el.addEventListener(event, handler, true);
- } else {
- // $FlowIgnore: Doesn't think elements are indexable
- el['on' + event] = handler;
- }
- }
- function removeEvent(el /*: ?Node*/, event /*: string*/, handler /*: Function*/) /*: void*/ {
- if (!el) {
- return;
- }
- if (el.detachEvent) {
- el.detachEvent('on' + event, handler);
- } else if (el.removeEventListener) {
- el.removeEventListener(event, handler, true);
- } else {
- // $FlowIgnore: Doesn't think elements are indexable
- el['on' + event] = null;
- }
- }
- function outerHeight(node /*: HTMLElement*/) /*: number*/ {
- // This is deliberately excluding margin for our calculations, since we are using
- // offsetTop which is including margin. See getBoundPosition
- var height = node.clientHeight;
- var computedStyle = node.ownerDocument.defaultView.getComputedStyle(node);
- height += (0, _shims.int)(computedStyle.borderTopWidth);
- height += (0, _shims.int)(computedStyle.borderBottomWidth);
- return height;
- }
- function outerWidth(node /*: HTMLElement*/) /*: number*/ {
- // This is deliberately excluding margin for our calculations, since we are using
- // offsetLeft which is including margin. See getBoundPosition
- var width = node.clientWidth;
- var computedStyle = node.ownerDocument.defaultView.getComputedStyle(node);
- width += (0, _shims.int)(computedStyle.borderLeftWidth);
- width += (0, _shims.int)(computedStyle.borderRightWidth);
- return width;
- }
- function innerHeight(node /*: HTMLElement*/) /*: number*/ {
- var height = node.clientHeight;
- var computedStyle = node.ownerDocument.defaultView.getComputedStyle(node);
- height -= (0, _shims.int)(computedStyle.paddingTop);
- height -= (0, _shims.int)(computedStyle.paddingBottom);
- return height;
- }
- function innerWidth(node /*: HTMLElement*/) /*: number*/ {
- var width = node.clientWidth;
- var computedStyle = node.ownerDocument.defaultView.getComputedStyle(node);
- width -= (0, _shims.int)(computedStyle.paddingLeft);
- width -= (0, _shims.int)(computedStyle.paddingRight);
- return width;
- }
- // Get from offsetParent
- function offsetXYFromParent(evt /*: {clientX: number, clientY: number}*/, offsetParent /*: HTMLElement*/) /*: ControlPosition*/ {
- var isBody = offsetParent === offsetParent.ownerDocument.body;
- var offsetParentRect = isBody ? { left: 0, top: 0 } : offsetParent.getBoundingClientRect();
- var x = evt.clientX + offsetParent.scrollLeft - offsetParentRect.left;
- var y = evt.clientY + offsetParent.scrollTop - offsetParentRect.top;
- return { x: x, y: y };
- }
- function createCSSTransform(_ref) /*: Object*/ {
- var x = _ref.x,
- y = _ref.y;
- // Replace unitless items with px
- return _defineProperty({}, (0, _getPrefix.browserPrefixToKey)('transform', _getPrefix2.default), 'translate(' + x + 'px,' + y + 'px)');
- }
- function createSVGTransform(_ref3) /*: string*/ {
- var x = _ref3.x,
- y = _ref3.y;
- return 'translate(' + x + ',' + y + ')';
- }
- function getTouch(e /*: MouseTouchEvent*/, identifier /*: number*/) /*: ?{clientX: number, clientY: number}*/ {
- return e.targetTouches && (0, _shims.findInArray)(e.targetTouches, function (t) {
- return identifier === t.identifier;
- }) || e.changedTouches && (0, _shims.findInArray)(e.changedTouches, function (t) {
- return identifier === t.identifier;
- });
- }
- function getTouchIdentifier(e /*: MouseTouchEvent*/) /*: ?number*/ {
- if (e.targetTouches && e.targetTouches[0]) return e.targetTouches[0].identifier;
- if (e.changedTouches && e.changedTouches[0]) return e.changedTouches[0].identifier;
- }
- // User-select Hacks:
- //
- // Useful for preventing blue highlights all over everything when dragging.
- // Note we're passing `document` b/c we could be iframed
- function addUserSelectStyles(doc /*: Document*/) {
- var styleEl = doc.getElementById('react-draggable-style-el');
- if (!styleEl) {
- styleEl = doc.createElement('style');
- styleEl.type = 'text/css';
- styleEl.id = 'react-draggable-style-el';
- styleEl.innerHTML = '.react-draggable-transparent-selection *::-moz-selection {background: transparent;}\n';
- styleEl.innerHTML += '.react-draggable-transparent-selection *::selection {background: transparent;}\n';
- doc.getElementsByTagName('head')[0].appendChild(styleEl);
- }
- if (doc.body) addClassName(doc.body, 'react-draggable-transparent-selection');
- }
- function removeUserSelectStyles(doc /*: Document*/) {
- if (doc.body) removeClassName(doc.body, 'react-draggable-transparent-selection');
- window.getSelection().removeAllRanges(); // remove selection caused by scroll
- }
- function styleHacks() /*: Object*/ {
- var childStyle /*: Object*/ = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
- // Workaround IE pointer events; see #51
- // https://github.com/mzabriskie/react-draggable/issues/51#issuecomment-103488278
- return _extends({
- touchAction: 'none'
- }, childStyle);
- }
- function addClassName(el /*: HTMLElement*/, className /*: string*/) {
- if (el.classList) {
- el.classList.add(className);
- } else {
- if (!el.className.match(new RegExp('(?:^|\\s)' + className + '(?!\\S)'))) {
- el.className += ' ' + className;
- }
- }
- }
- function removeClassName(el /*: HTMLElement*/, className /*: string*/) {
- if (el.classList) {
- el.classList.remove(className);
- } else {
- el.className = el.className.replace(new RegExp('(?:^|\\s)' + className + '(?!\\S)', 'g'), '');
- }
- }
- /***/ }),
- /* 6 */
- /***/ (function(module, exports) {
- module.exports = __WEBPACK_EXTERNAL_MODULE_6__;
- /***/ }),
- /* 7 */
- /***/ (function(module, exports, __webpack_require__) {
- /**
- * Copyright 2013-present, Facebook, Inc.
- * All rights reserved.
- *
- * This source code is licensed under the BSD-style license found in the
- * LICENSE file in the root directory of this source tree. An additional grant
- * of patent rights can be found in the PATENTS file in the same directory.
- */
- if (Object({"DRAGGABLE_DEBUG":undefined}).NODE_ENV !== 'production') {
- var REACT_ELEMENT_TYPE = (typeof Symbol === 'function' &&
- Symbol.for &&
- Symbol.for('react.element')) ||
- 0xeac7;
- var isValidElement = function(object) {
- return typeof object === 'object' &&
- object !== null &&
- object.$$typeof === REACT_ELEMENT_TYPE;
- };
- // By explicitly using `prop-types` you are opting into new development behavior.
- // http://fb.me/prop-types-in-prod
- var throwOnDirectAccess = true;
- module.exports = __webpack_require__(14)(isValidElement, throwOnDirectAccess);
- } else {
- // By explicitly using `prop-types` you are opting into new production behavior.
- // http://fb.me/prop-types-in-prod
- module.exports = __webpack_require__(16)();
- }
- /***/ }),
- /* 8 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * Copyright 2014-2015, Facebook, Inc.
- * All rights reserved.
- *
- * This source code is licensed under the BSD-style license found in the
- * LICENSE file in the root directory of this source tree. An additional grant
- * of patent rights can be found in the PATENTS file in the same directory.
- *
- */
- var emptyFunction = __webpack_require__(1);
- /**
- * Similar to invariant but only logs a warning if the condition is not met.
- * This can be used to log issues in development environments in critical
- * paths. Removing the logging code for production environments will keep the
- * same logic and follow the same code paths.
- */
- var warning = emptyFunction;
- if (Object({"DRAGGABLE_DEBUG":undefined}).NODE_ENV !== 'production') {
- var printWarning = function printWarning(format) {
- for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
- args[_key - 1] = arguments[_key];
- }
- var argIndex = 0;
- var message = 'Warning: ' + format.replace(/%s/g, function () {
- return args[argIndex++];
- });
- if (typeof console !== 'undefined') {
- console.error(message);
- }
- try {
- // --- Welcome to debugging React ---
- // This error was thrown as a convenience so that you can use this stack
- // to find the callsite that caused this warning to fire.
- throw new Error(message);
- } catch (x) {}
- };
- warning = function warning(condition, format) {
- if (format === undefined) {
- throw new Error('`warning(condition, format, ...args)` requires a warning ' + 'message argument');
- }
- if (format.indexOf('Failed Composite propType: ') === 0) {
- return; // Ignore CompositeComponent proptype check.
- }
- if (!condition) {
- for (var _len2 = arguments.length, args = Array(_len2 > 2 ? _len2 - 2 : 0), _key2 = 2; _key2 < _len2; _key2++) {
- args[_key2 - 2] = arguments[_key2];
- }
- printWarning.apply(undefined, [format].concat(args));
- }
- };
- }
- module.exports = warning;
- /***/ }),
- /* 9 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.getBoundPosition = getBoundPosition;
- exports.snapToGrid = snapToGrid;
- exports.canDragX = canDragX;
- exports.canDragY = canDragY;
- exports.getControlPosition = getControlPosition;
- exports.createCoreData = createCoreData;
- exports.createDraggableData = createDraggableData;
- var _shims = __webpack_require__(0);
- var _reactDom = __webpack_require__(4);
- var _reactDom2 = _interopRequireDefault(_reactDom);
- var _domFns = __webpack_require__(5);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- /*:: import type Draggable from '../Draggable';*/
- /*:: import type {Bounds, ControlPosition, DraggableData, MouseTouchEvent} from './types';*/
- /*:: import type DraggableCore from '../DraggableCore';*/
- function getBoundPosition(draggable /*: Draggable*/, x /*: number*/, y /*: number*/) /*: [number, number]*/ {
- // If no bounds, short-circuit and move on
- if (!draggable.props.bounds) return [x, y];
- // Clone new bounds
- var bounds = draggable.props.bounds;
- bounds = typeof bounds === 'string' ? bounds : cloneBounds(bounds);
- var node = findDOMNode(draggable);
- if (typeof bounds === 'string') {
- var ownerDocument = node.ownerDocument;
- var ownerWindow = ownerDocument.defaultView;
- var boundNode = void 0;
- if (bounds === 'parent') {
- boundNode = node.parentNode;
- } else {
- boundNode = ownerDocument.querySelector(bounds);
- }
- if (!(boundNode instanceof HTMLElement)) {
- throw new Error('Bounds selector "' + bounds + '" could not find an element.');
- }
- var nodeStyle = ownerWindow.getComputedStyle(node);
- var boundNodeStyle = ownerWindow.getComputedStyle(boundNode);
- // Compute bounds. This is a pain with padding and offsets but this gets it exactly right.
- bounds = {
- left: -node.offsetLeft + (0, _shims.int)(boundNodeStyle.paddingLeft) + (0, _shims.int)(nodeStyle.marginLeft),
- top: -node.offsetTop + (0, _shims.int)(boundNodeStyle.paddingTop) + (0, _shims.int)(nodeStyle.marginTop),
- right: (0, _domFns.innerWidth)(boundNode) - (0, _domFns.outerWidth)(node) - node.offsetLeft + (0, _shims.int)(boundNodeStyle.paddingRight) - (0, _shims.int)(nodeStyle.marginRight),
- bottom: (0, _domFns.innerHeight)(boundNode) - (0, _domFns.outerHeight)(node) - node.offsetTop + (0, _shims.int)(boundNodeStyle.paddingBottom) - (0, _shims.int)(nodeStyle.marginBottom)
- };
- }
- // Keep x and y below right and bottom limits...
- if ((0, _shims.isNum)(bounds.right)) x = Math.min(x, bounds.right);
- if ((0, _shims.isNum)(bounds.bottom)) y = Math.min(y, bounds.bottom);
- // But above left and top limits.
- if ((0, _shims.isNum)(bounds.left)) x = Math.max(x, bounds.left);
- if ((0, _shims.isNum)(bounds.top)) y = Math.max(y, bounds.top);
- return [x, y];
- }
- function snapToGrid(grid /*: [number, number]*/, pendingX /*: number*/, pendingY /*: number*/) /*: [number, number]*/ {
- var x = Math.round(pendingX / grid[0]) * grid[0];
- var y = Math.round(pendingY / grid[1]) * grid[1];
- return [x, y];
- }
- function canDragX(draggable /*: Draggable*/) /*: boolean*/ {
- return draggable.props.axis === 'both' || draggable.props.axis === 'x';
- }
- function canDragY(draggable /*: Draggable*/) /*: boolean*/ {
- return draggable.props.axis === 'both' || draggable.props.axis === 'y';
- }
- // Get {x, y} positions from event.
- function getControlPosition(e /*: MouseTouchEvent*/, touchIdentifier /*: ?number*/, draggableCore /*: DraggableCore*/) /*: ?ControlPosition*/ {
- var touchObj = typeof touchIdentifier === 'number' ? (0, _domFns.getTouch)(e, touchIdentifier) : null;
- if (typeof touchIdentifier === 'number' && !touchObj) return null; // not the right touch
- var node = findDOMNode(draggableCore);
- // User can provide an offsetParent if desired.
- var offsetParent = draggableCore.props.offsetParent || node.offsetParent || node.ownerDocument.body;
- return (0, _domFns.offsetXYFromParent)(touchObj || e, offsetParent);
- }
- // Create an data object exposed by <DraggableCore>'s events
- function createCoreData(draggable /*: DraggableCore*/, x /*: number*/, y /*: number*/) /*: DraggableData*/ {
- var state = draggable.state;
- var isStart = !(0, _shims.isNum)(state.lastX);
- var node = findDOMNode(draggable);
- if (isStart) {
- // If this is our first move, use the x and y as last coords.
- return {
- node: node,
- deltaX: 0, deltaY: 0,
- lastX: x, lastY: y,
- x: x, y: y
- };
- } else {
- // Otherwise calculate proper values.
- return {
- node: node,
- deltaX: x - state.lastX, deltaY: y - state.lastY,
- lastX: state.lastX, lastY: state.lastY,
- x: x, y: y
- };
- }
- }
- // Create an data exposed by <Draggable>'s events
- function createDraggableData(draggable /*: Draggable*/, coreData /*: DraggableData*/) /*: DraggableData*/ {
- return {
- node: coreData.node,
- x: draggable.state.x + coreData.deltaX,
- y: draggable.state.y + coreData.deltaY,
- deltaX: coreData.deltaX,
- deltaY: coreData.deltaY,
- lastX: draggable.state.x,
- lastY: draggable.state.y
- };
- }
- // A lot faster than stringify/parse
- function cloneBounds(bounds /*: Bounds*/) /*: Bounds*/ {
- return {
- left: bounds.left,
- top: bounds.top,
- right: bounds.right,
- bottom: bounds.bottom
- };
- }
- function findDOMNode(draggable /*: Draggable | DraggableCore*/) /*: HTMLElement*/ {
- var node = _reactDom2.default.findDOMNode(draggable);
- if (!node) {
- throw new Error('<DraggableCore>: Unmounted during event!');
- }
- // $FlowIgnore we can't assert on HTMLElement due to tests... FIXME
- return node;
- }
- /***/ }),
- /* 10 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /* WEBPACK VAR INJECTION */(function(process) {
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }();
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
- var _react = __webpack_require__(6);
- var _react2 = _interopRequireDefault(_react);
- var _propTypes = __webpack_require__(7);
- var _propTypes2 = _interopRequireDefault(_propTypes);
- var _reactDom = __webpack_require__(4);
- var _reactDom2 = _interopRequireDefault(_reactDom);
- var _domFns = __webpack_require__(5);
- var _positionFns = __webpack_require__(9);
- var _shims = __webpack_require__(0);
- var _log = __webpack_require__(11);
- var _log2 = _interopRequireDefault(_log);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
- function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
- /*:: import type {EventHandler, MouseTouchEvent} from './utils/types';*/
- // Simple abstraction for dragging events names.
- /*:: import type {Element as ReactElement} from 'react';*/
- var eventsFor = {
- touch: {
- start: 'touchstart',
- move: 'touchmove',
- stop: 'touchend'
- },
- mouse: {
- start: 'mousedown',
- move: 'mousemove',
- stop: 'mouseup'
- }
- };
- // Default to mouse events.
- var dragEventFor = eventsFor.mouse;
- /*:: type DraggableCoreState = {
- dragging: boolean,
- lastX: number,
- lastY: number,
- touchIdentifier: ?number
- };*/
- /*:: export type DraggableBounds = {
- left: number,
- right: number,
- top: number,
- bottom: number,
- };*/
- /*:: export type DraggableData = {
- node: HTMLElement,
- x: number, y: number,
- deltaX: number, deltaY: number,
- lastX: number, lastY: number,
- };*/
- /*:: export type DraggableEventHandler = (e: MouseEvent, data: DraggableData) => void;*/
- /*:: export type ControlPosition = {x: number, y: number};*/
- //
- // Define <DraggableCore>.
- //
- // <DraggableCore> is for advanced usage of <Draggable>. It maintains minimal internal state so it can
- // work well with libraries that require more control over the element.
- //
- /*:: export type DraggableCoreProps = {
- allowAnyClick: boolean,
- cancel: string,
- children: ReactElement<any>,
- disabled: boolean,
- enableUserSelectHack: boolean,
- offsetParent: HTMLElement,
- grid: [number, number],
- handle: string,
- onStart: DraggableEventHandler,
- onDrag: DraggableEventHandler,
- onStop: DraggableEventHandler,
- onMouseDown: (e: MouseEvent) => void,
- };*/
- var DraggableCore = function (_React$Component) {
- _inherits(DraggableCore, _React$Component);
- function DraggableCore() {
- var _ref;
- var _temp, _this, _ret;
- _classCallCheck(this, DraggableCore);
- for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
- args[_key] = arguments[_key];
- }
- return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = DraggableCore.__proto__ || Object.getPrototypeOf(DraggableCore)).call.apply(_ref, [this].concat(args))), _this), _this.state = {
- dragging: false,
- // Used while dragging to determine deltas.
- lastX: NaN, lastY: NaN,
- touchIdentifier: null
- }, _this.handleDragStart = function (e) {
- // Make it possible to attach event handlers on top of this one.
- _this.props.onMouseDown(e);
- // Only accept left-clicks.
- if (!_this.props.allowAnyClick && typeof e.button === 'number' && e.button !== 0) return false;
- // Get nodes. Be sure to grab relative document (could be iframed)
- var thisNode = _reactDom2.default.findDOMNode(_this);
- if (!thisNode || !thisNode.ownerDocument || !thisNode.ownerDocument.body) {
- throw new Error('<DraggableCore> not mounted on DragStart!');
- }
- var ownerDocument = thisNode.ownerDocument;
- // Short circuit if handle or cancel prop was provided and selector doesn't match.
- if (_this.props.disabled || !(e.target instanceof ownerDocument.defaultView.Node) || _this.props.handle && !(0, _domFns.matchesSelectorAndParentsTo)(e.target, _this.props.handle, thisNode) || _this.props.cancel && (0, _domFns.matchesSelectorAndParentsTo)(e.target, _this.props.cancel, thisNode)) {
- return;
- }
- // Set touch identifier in component state if this is a touch event. This allows us to
- // distinguish between individual touches on multitouch screens by identifying which
- // touchpoint was set to this element.
- var touchIdentifier = (0, _domFns.getTouchIdentifier)(e);
- _this.setState({ touchIdentifier: touchIdentifier });
- // Get the current drag point from the event. This is used as the offset.
- var position = (0, _positionFns.getControlPosition)(e, touchIdentifier, _this);
- if (position == null) return; // not possible but satisfies flow
- var x = position.x,
- y = position.y;
- // Create an event object with all the data parents need to make a decision here.
- var coreEvent = (0, _positionFns.createCoreData)(_this, x, y);
- (0, _log2.default)('DraggableCore: handleDragStart: %j', coreEvent);
- // Call event handler. If it returns explicit false, cancel.
- (0, _log2.default)('calling', _this.props.onStart);
- var shouldUpdate = _this.props.onStart(e, coreEvent);
- if (shouldUpdate === false) return;
- // Add a style to the body to disable user-select. This prevents text from
- // being selected all over the page.
- if (_this.props.enableUserSelectHack) (0, _domFns.addUserSelectStyles)(ownerDocument);
- // Initiate dragging. Set the current x and y as offsets
- // so we know how much we've moved during the drag. This allows us
- // to drag elements around even if they have been moved, without issue.
- _this.setState({
- dragging: true,
- lastX: x,
- lastY: y
- });
- // Add events to the document directly so we catch when the user's mouse/touch moves outside of
- // this element. We use different events depending on whether or not we have detected that this
- // is a touch-capable device.
- (0, _domFns.addEvent)(ownerDocument, dragEventFor.move, _this.handleDrag);
- (0, _domFns.addEvent)(ownerDocument, dragEventFor.stop, _this.handleDragStop);
- }, _this.handleDrag = function (e) {
- // Prevent scrolling on mobile devices, like ipad/iphone.
- if (e.type === 'touchmove') e.preventDefault();
- // Get the current drag point from the event. This is used as the offset.
- var position = (0, _positionFns.getControlPosition)(e, _this.state.touchIdentifier, _this);
- if (position == null) return;
- var x = position.x,
- y = position.y;
- // Snap to grid if prop has been provided
- if (Array.isArray(_this.props.grid)) {
- var _deltaX = x - _this.state.lastX,
- _deltaY = y - _this.state.lastY;
- var _snapToGrid = (0, _positionFns.snapToGrid)(_this.props.grid, _deltaX, _deltaY);
- var _snapToGrid2 = _slicedToArray(_snapToGrid, 2);
- _deltaX = _snapToGrid2[0];
- _deltaY = _snapToGrid2[1];
- if (!_deltaX && !_deltaY) return; // skip useless drag
- x = _this.state.lastX + _deltaX, y = _this.state.lastY + _deltaY;
- }
- var coreEvent = (0, _positionFns.createCoreData)(_this, x, y);
- (0, _log2.default)('DraggableCore: handleDrag: %j', coreEvent);
- // Call event handler. If it returns explicit false, trigger end.
- var shouldUpdate = _this.props.onDrag(e, coreEvent);
- if (shouldUpdate === false) {
- try {
- // $FlowIgnore
- _this.handleDragStop(new MouseEvent('mouseup'));
- } catch (err) {
- // Old browsers
- var event = ((document.createEvent('MouseEvents') /*: any*/) /*: MouseTouchEvent*/);
- // I see why this insanity was deprecated
- // $FlowIgnore
- event.initMouseEvent('mouseup', true, true, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
- _this.handleDragStop(event);
- }
- return;
- }
- _this.setState({
- lastX: x,
- lastY: y
- });
- }, _this.handleDragStop = function (e) {
- if (!_this.state.dragging) return;
- var position = (0, _positionFns.getControlPosition)(e, _this.state.touchIdentifier, _this);
- if (position == null) return;
- var x = position.x,
- y = position.y;
- var coreEvent = (0, _positionFns.createCoreData)(_this, x, y);
- var thisNode = _reactDom2.default.findDOMNode(_this);
- if (thisNode) {
- // Remove user-select hack
- if (_this.props.enableUserSelectHack) (0, _domFns.removeUserSelectStyles)(thisNode.ownerDocument);
- }
- (0, _log2.default)('DraggableCore: handleDragStop: %j', coreEvent);
- // Reset the el.
- _this.setState({
- dragging: false,
- lastX: NaN,
- lastY: NaN
- });
- // Call event handler
- _this.props.onStop(e, coreEvent);
- if (thisNode) {
- // Remove event handlers
- (0, _log2.default)('DraggableCore: Removing handlers');
- (0, _domFns.removeEvent)(thisNode.ownerDocument, dragEventFor.move, _this.handleDrag);
- (0, _domFns.removeEvent)(thisNode.ownerDocument, dragEventFor.stop, _this.handleDragStop);
- }
- }, _this.onMouseDown = function (e) {
- dragEventFor = eventsFor.mouse; // on touchscreen laptops we could switch back to mouse
- return _this.handleDragStart(e);
- }, _this.onMouseUp = function (e) {
- dragEventFor = eventsFor.mouse;
- return _this.handleDragStop(e);
- }, _this.onTouchStart = function (e) {
- // We're on a touch device now, so change the event handlers
- dragEventFor = eventsFor.touch;
- return _this.handleDragStart(e);
- }, _this.onTouchEnd = function (e) {
- // We're on a touch device now, so change the event handlers
- dragEventFor = eventsFor.touch;
- return _this.handleDragStop(e);
- }, _temp), _possibleConstructorReturn(_this, _ret);
- }
- _createClass(DraggableCore, [{
- key: 'componentWillUnmount',
- value: function componentWillUnmount() {
- // Remove any leftover event handlers. Remove both touch and mouse handlers in case
- // some browser quirk caused a touch event to fire during a mouse move, or vice versa.
- var thisNode = _reactDom2.default.findDOMNode(this);
- if (thisNode) {
- var ownerDocument = thisNode.ownerDocument;
- (0, _domFns.removeEvent)(ownerDocument, eventsFor.mouse.move, this.handleDrag);
- (0, _domFns.removeEvent)(ownerDocument, eventsFor.touch.move, this.handleDrag);
- (0, _domFns.removeEvent)(ownerDocument, eventsFor.mouse.stop, this.handleDragStop);
- (0, _domFns.removeEvent)(ownerDocument, eventsFor.touch.stop, this.handleDragStop);
- if (this.props.enableUserSelectHack) (0, _domFns.removeUserSelectStyles)(ownerDocument);
- }
- }
- // Same as onMouseDown (start drag), but now consider this a touch device.
- }, {
- key: 'render',
- value: function render() {
- // Reuse the child provided
- // This makes it flexible to use whatever element is wanted (div, ul, etc)
- return _react2.default.cloneElement(_react2.default.Children.only(this.props.children), {
- style: (0, _domFns.styleHacks)(this.props.children.props.style),
- // Note: mouseMove handler is attached to document so it will still function
- // when the user drags quickly and leaves the bounds of the element.
- onMouseDown: this.onMouseDown,
- onTouchStart: this.onTouchStart,
- onMouseUp: this.onMouseUp,
- onTouchEnd: this.onTouchEnd
- });
- }
- }]);
- return DraggableCore;
- }(_react2.default.Component);
- DraggableCore.displayName = 'DraggableCore';
- DraggableCore.propTypes = {
- /**
- * `allowAnyClick` allows dragging using any mouse button.
- * By default, we only accept the left button.
- *
- * Defaults to `false`.
- */
- allowAnyClick: _propTypes2.default.bool,
- /**
- * `disabled`, if true, stops the <Draggable> from dragging. All handlers,
- * with the exception of `onMouseDown`, will not fire.
- */
- disabled: _propTypes2.default.bool,
- /**
- * By default, we add 'user-select:none' attributes to the document body
- * to prevent ugly text selection during drag. If this is causing problems
- * for your app, set this to `false`.
- */
- enableUserSelectHack: _propTypes2.default.bool,
- /**
- * `offsetParent`, if set, uses the passed DOM node to compute drag offsets
- * instead of using the parent node.
- */
- offsetParent: function offsetParent(props, propName) {
- if (process.browser && props[propName] && props[propName].nodeType !== 1) {
- throw new Error('Draggable\'s offsetParent must be a DOM Node.');
- }
- },
- /**
- * `grid` specifies the x and y that dragging should snap to.
- */
- grid: _propTypes2.default.arrayOf(_propTypes2.default.number),
- /**
- * `handle` specifies a selector to be used as the handle that initiates drag.
- *
- * Example:
- *
- * ```jsx
- * let App = React.createClass({
- * render: function () {
- * return (
- * <Draggable handle=".handle">
- * <div>
- * <div className="handle">Click me to drag</div>
- * <div>This is some other content</div>
- * </div>
- * </Draggable>
- * );
- * }
- * });
- * ```
- */
- handle: _propTypes2.default.string,
- /**
- * `cancel` specifies a selector to be used to prevent drag initialization.
- *
- * Example:
- *
- * ```jsx
- * let App = React.createClass({
- * render: function () {
- * return(
- * <Draggable cancel=".cancel">
- * <div>
- * <div className="cancel">You can't drag from here</div>
- * <div>Dragging here works fine</div>
- * </div>
- * </Draggable>
- * );
- * }
- * });
- * ```
- */
- cancel: _propTypes2.default.string,
- /**
- * Called when dragging starts.
- * If this function returns the boolean false, dragging will be canceled.
- */
- onStart: _propTypes2.default.func,
- /**
- * Called while dragging.
- * If this function returns the boolean false, dragging will be canceled.
- */
- onDrag: _propTypes2.default.func,
- /**
- * Called when dragging stops.
- * If this function returns the boolean false, the drag will remain active.
- */
- onStop: _propTypes2.default.func,
- /**
- * A workaround option which can be passed if onMouseDown needs to be accessed,
- * since it'll always be blocked (as there is internal use of onMouseDown)
- */
- onMouseDown: _propTypes2.default.func,
- /**
- * These properties should be defined on the child, not here.
- */
- className: _shims.dontSetMe,
- style: _shims.dontSetMe,
- transform: _shims.dontSetMe
- };
- DraggableCore.defaultProps = {
- allowAnyClick: false, // by default only accept left click
- cancel: null,
- disabled: false,
- enableUserSelectHack: true,
- offsetParent: null,
- handle: null,
- grid: null,
- transform: null,
- onStart: function onStart() {},
- onDrag: function onDrag() {},
- onStop: function onStop() {},
- onMouseDown: function onMouseDown() {}
- };
- exports.default = DraggableCore;
- /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(19)))
- /***/ }),
- /* 11 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = log;
- /*eslint no-console:0*/
- function log() {
- var _console;
- if (undefined) (_console = console).log.apply(_console, arguments);
- }
- /***/ }),
- /* 12 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var Draggable = __webpack_require__(13).default;
- // Previous versions of this lib exported <Draggable> as the root export. As to not break
- // them, or TypeScript, we export *both* as the root and as 'default'.
- // See https://github.com/mzabriskie/react-draggable/pull/254
- // and https://github.com/mzabriskie/react-draggable/issues/266
- module.exports = Draggable;
- module.exports.default = Draggable;
- module.exports.DraggableCore = __webpack_require__(10).default;
- /***/ }),
- /* 13 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
- var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }();
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
- var _react = __webpack_require__(6);
- var _react2 = _interopRequireDefault(_react);
- var _propTypes = __webpack_require__(7);
- var _propTypes2 = _interopRequireDefault(_propTypes);
- var _reactDom = __webpack_require__(4);
- var _reactDom2 = _interopRequireDefault(_reactDom);
- var _classnames = __webpack_require__(17);
- var _classnames2 = _interopRequireDefault(_classnames);
- var _domFns = __webpack_require__(5);
- var _positionFns = __webpack_require__(9);
- var _shims = __webpack_require__(0);
- var _DraggableCore = __webpack_require__(10);
- var _DraggableCore2 = _interopRequireDefault(_DraggableCore);
- var _log = __webpack_require__(11);
- var _log2 = _interopRequireDefault(_log);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
- function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
- /*:: import type {ControlPosition, DraggableBounds, DraggableCoreProps} from './DraggableCore';*/
- /*:: import type {DraggableEventHandler} from './utils/types';*/
- /*:: import type {Element as ReactElement} from 'react';*/
- /*:: type DraggableState = {
- dragging: boolean,
- dragged: boolean,
- x: number, y: number,
- slackX: number, slackY: number,
- isElementSVG: boolean
- };*/
- //
- // Define <Draggable>
- //
- /*:: export type DraggableProps = {
- ...$Exact<DraggableCoreProps>,
- axis: 'both' | 'x' | 'y' | 'none',
- bounds: DraggableBounds | string | false,
- defaultClassName: string,
- defaultClassNameDragging: string,
- defaultClassNameDragged: string,
- defaultPosition: ControlPosition,
- position: ControlPosition,
- };*/
- var Draggable = function (_React$Component) {
- _inherits(Draggable, _React$Component);
- function Draggable(props /*: DraggableProps*/) {
- _classCallCheck(this, Draggable);
- var _this = _possibleConstructorReturn(this, (Draggable.__proto__ || Object.getPrototypeOf(Draggable)).call(this, props));
- _this.onDragStart = function (e, coreData) {
- (0, _log2.default)('Draggable: onDragStart: %j', coreData);
- // Short-circuit if user's callback killed it.
- var shouldStart = _this.props.onStart(e, (0, _positionFns.createDraggableData)(_this, coreData));
- // Kills start event on core as well, so move handlers are never bound.
- if (shouldStart === false) return false;
- _this.setState({ dragging: true, dragged: true });
- };
- _this.onDrag = function (e, coreData) {
- if (!_this.state.dragging) return false;
- (0, _log2.default)('Draggable: onDrag: %j', coreData);
- var uiData = (0, _positionFns.createDraggableData)(_this, coreData);
- var newState /*: $Shape<DraggableState>*/ = {
- x: uiData.x,
- y: uiData.y
- };
- // Keep within bounds.
- if (_this.props.bounds) {
- // Save original x and y.
- var _x = newState.x,
- _y = newState.y;
- // Add slack to the values used to calculate bound position. This will ensure that if
- // we start removing slack, the element won't react to it right away until it's been
- // completely removed.
- newState.x += _this.state.slackX;
- newState.y += _this.state.slackY;
- // Get bound position. This will ceil/floor the x and y within the boundaries.
- // $FlowBug
- // Recalculate slack by noting how much was shaved by the boundPosition handler.
- var _getBoundPosition = (0, _positionFns.getBoundPosition)(_this, newState.x, newState.y);
- var _getBoundPosition2 = _slicedToArray(_getBoundPosition, 2);
- newState.x = _getBoundPosition2[0];
- newState.y = _getBoundPosition2[1];
- newState.slackX = _this.state.slackX + (_x - newState.x);
- newState.slackY = _this.state.slackY + (_y - newState.y);
- // Update the event we fire to reflect what really happened after bounds took effect.
- uiData.x = newState.x;
- uiData.y = newState.y;
- uiData.deltaX = newState.x - _this.state.x;
- uiData.deltaY = newState.y - _this.state.y;
- }
- // Short-circuit if user's callback killed it.
- var shouldUpdate = _this.props.onDrag(e, uiData);
- if (shouldUpdate === false) return false;
- _this.setState(newState);
- };
- _this.onDragStop = function (e, coreData) {
- if (!_this.state.dragging) return false;
- // Short-circuit if user's callback killed it.
- var shouldStop = _this.props.onStop(e, (0, _positionFns.createDraggableData)(_this, coreData));
- if (shouldStop === false) return false;
- (0, _log2.default)('Draggable: onDragStop: %j', coreData);
- var newState /*: $Shape<DraggableState>*/ = {
- dragging: false,
- slackX: 0,
- slackY: 0
- };
- // If this is a controlled component, the result of this operation will be to
- // revert back to the old position. We expect a handler on `onDragStop`, at the least.
- var controlled = Boolean(_this.props.position);
- if (controlled) {
- var _this$props$position = _this.props.position,
- _x2 = _this$props$position.x,
- _y2 = _this$props$position.y;
- newState.x = _x2;
- newState.y = _y2;
- }
- _this.setState(newState);
- };
- _this.state = {
- // Whether or not we are currently dragging.
- dragging: false,
- // Whether or not we have been dragged before.
- dragged: false,
- // Current transform x and y.
- x: props.position ? props.position.x : props.defaultPosition.x,
- y: props.position ? props.position.y : props.defaultPosition.y,
- // Used for compensating for out-of-bounds drags
- slackX: 0, slackY: 0,
- // Can only determine if SVG after mounting
- isElementSVG: false
- };
- return _this;
- }
- _createClass(Draggable, [{
- key: 'componentWillMount',
- value: function componentWillMount() {
- if (this.props.position && !(this.props.onDrag || this.props.onStop)) {
- // eslint-disable-next-line
- console.warn('A `position` was applied to this <Draggable>, without drag handlers. This will make this ' + 'component effectively undraggable. Please attach `onDrag` or `onStop` handlers so you can adjust the ' + '`position` of this element.');
- }
- }
- }, {
- key: 'componentDidMount',
- value: function componentDidMount() {
- // Check to see if the element passed is an instanceof SVGElement
- if (typeof window.SVGElement !== 'undefined' && _reactDom2.default.findDOMNode(this) instanceof window.SVGElement) {
- this.setState({ isElementSVG: true });
- }
- }
- }, {
- key: 'componentWillReceiveProps',
- value: function componentWillReceiveProps(nextProps /*: Object*/) {
- // Set x/y if position has changed
- if (nextProps.position && (!this.props.position || nextProps.position.x !== this.props.position.x || nextProps.position.y !== this.props.position.y)) {
- this.setState({ x: nextProps.position.x, y: nextProps.position.y });
- }
- }
- }, {
- key: 'componentWillUnmount',
- value: function componentWillUnmount() {
- this.setState({ dragging: false }); // prevents invariant if unmounted while dragging
- }
- }, {
- key: 'render',
- value: function render() /*: ReactElement<any>*/ {
- var _classNames;
- var style = {},
- svgTransform = null;
- // If this is controlled, we don't want to move it - unless it's dragging.
- var controlled = Boolean(this.props.position);
- var draggable = !controlled || this.state.dragging;
- var position = this.props.position || this.props.defaultPosition;
- var transformOpts = {
- // Set left if horizontal drag is enabled
- x: (0, _positionFns.canDragX)(this) && draggable ? this.state.x : position.x,
- // Set top if vertical drag is enabled
- y: (0, _positionFns.canDragY)(this) && draggable ? this.state.y : position.y
- };
- // If this element was SVG, we use the `transform` attribute.
- if (this.state.isElementSVG) {
- svgTransform = (0, _domFns.createSVGTransform)(transformOpts);
- } else {
- // Add a CSS transform to move the element around. This allows us to move the element around
- // without worrying about whether or not it is relatively or absolutely positioned.
- // If the item you are dragging already has a transform set, wrap it in a <span> so <Draggable>
- // has a clean slate.
- style = (0, _domFns.createCSSTransform)(transformOpts);
- }
- var _props = this.props,
- defaultClassName = _props.defaultClassName,
- defaultClassNameDragging = _props.defaultClassNameDragging,
- defaultClassNameDragged = _props.defaultClassNameDragged;
- // Mark with class while dragging
- var className = (0, _classnames2.default)(this.props.children.props.className || '', defaultClassName, (_classNames = {}, _defineProperty(_classNames, defaultClassNameDragging, this.state.dragging), _defineProperty(_classNames, defaultClassNameDragged, this.state.dragged), _classNames));
- // Reuse the child provided
- // This makes it flexible to use whatever element is wanted (div, ul, etc)
- return _react2.default.createElement(
- _DraggableCore2.default,
- _extends({}, this.props, { onStart: this.onDragStart, onDrag: this.onDrag, onStop: this.onDragStop }),
- _react2.default.cloneElement(_react2.default.Children.only(this.props.children), {
- className: className,
- style: _extends({}, this.props.children.props.style, style),
- transform: svgTransform
- })
- );
- }
- }]);
- return Draggable;
- }(_react2.default.Component);
- Draggable.displayName = 'Draggable';
- Draggable.propTypes = _extends({}, _DraggableCore2.default.propTypes, {
- /**
- * `axis` determines which axis the draggable can move.
- *
- * Note that all callbacks will still return data as normal. This only
- * controls flushing to the DOM.
- *
- * 'both' allows movement horizontally and vertically.
- * 'x' limits movement to horizontal axis.
- * 'y' limits movement to vertical axis.
- * 'none' limits all movement.
- *
- * Defaults to 'both'.
- */
- axis: _propTypes2.default.oneOf(['both', 'x', 'y', 'none']),
- /**
- * `bounds` determines the range of movement available to the element.
- * Available values are:
- *
- * 'parent' restricts movement within the Draggable's parent node.
- *
- * Alternatively, pass an object with the following properties, all of which are optional:
- *
- * {left: LEFT_BOUND, right: RIGHT_BOUND, bottom: BOTTOM_BOUND, top: TOP_BOUND}
- *
- * All values are in px.
- *
- * Example:
- *
- * ```jsx
- * let App = React.createClass({
- * render: function () {
- * return (
- * <Draggable bounds={{right: 300, bottom: 300}}>
- * <div>Content</div>
- * </Draggable>
- * );
- * }
- * });
- * ```
- */
- bounds: _propTypes2.default.oneOfType([_propTypes2.default.shape({
- left: _propTypes2.default.number,
- right: _propTypes2.default.number,
- top: _propTypes2.default.number,
- bottom: _propTypes2.default.number
- }), _propTypes2.default.string, _propTypes2.default.oneOf([false])]),
- defaultClassName: _propTypes2.default.string,
- defaultClassNameDragging: _propTypes2.default.string,
- defaultClassNameDragged: _propTypes2.default.string,
- /**
- * `defaultPosition` specifies the x and y that the dragged item should start at
- *
- * Example:
- *
- * ```jsx
- * let App = React.createClass({
- * render: function () {
- * return (
- * <Draggable defaultPosition={{x: 25, y: 25}}>
- * <div>I start with transformX: 25px and transformY: 25px;</div>
- * </Draggable>
- * );
- * }
- * });
- * ```
- */
- defaultPosition: _propTypes2.default.shape({
- x: _propTypes2.default.number,
- y: _propTypes2.default.number
- }),
- /**
- * `position`, if present, defines the current position of the element.
- *
- * This is similar to how form elements in React work - if no `position` is supplied, the component
- * is uncontrolled.
- *
- * Example:
- *
- * ```jsx
- * let App = React.createClass({
- * render: function () {
- * return (
- * <Draggable position={{x: 25, y: 25}}>
- * <div>I start with transformX: 25px and transformY: 25px;</div>
- * </Draggable>
- * );
- * }
- * });
- * ```
- */
- position: _propTypes2.default.shape({
- x: _propTypes2.default.number,
- y: _propTypes2.default.number
- }),
- /**
- * These properties should be defined on the child, not here.
- */
- className: _shims.dontSetMe,
- style: _shims.dontSetMe,
- transform: _shims.dontSetMe
- });
- Draggable.defaultProps = _extends({}, _DraggableCore2.default.defaultProps, {
- axis: 'both',
- bounds: false,
- defaultClassName: 'react-draggable',
- defaultClassNameDragging: 'react-draggable-dragging',
- defaultClassNameDragged: 'react-draggable-dragged',
- defaultPosition: { x: 0, y: 0 },
- position: null
- });
- exports.default = Draggable;
- /***/ }),
- /* 14 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * Copyright 2013-present, Facebook, Inc.
- * All rights reserved.
- *
- * This source code is licensed under the BSD-style license found in the
- * LICENSE file in the root directory of this source tree. An additional grant
- * of patent rights can be found in the PATENTS file in the same directory.
- */
- var emptyFunction = __webpack_require__(1);
- var invariant = __webpack_require__(2);
- var warning = __webpack_require__(8);
- var ReactPropTypesSecret = __webpack_require__(3);
- var checkPropTypes = __webpack_require__(15);
- module.exports = function(isValidElement, throwOnDirectAccess) {
- /* global Symbol */
- var ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator;
- var FAUX_ITERATOR_SYMBOL = '@@iterator'; // Before Symbol spec.
- /**
- * Returns the iterator method function contained on the iterable object.
- *
- * Be sure to invoke the function with the iterable as context:
- *
- * var iteratorFn = getIteratorFn(myIterable);
- * if (iteratorFn) {
- * var iterator = iteratorFn.call(myIterable);
- * ...
- * }
- *
- * @param {?object} maybeIterable
- * @return {?function}
- */
- function getIteratorFn(maybeIterable) {
- var iteratorFn = maybeIterable && (ITERATOR_SYMBOL && maybeIterable[ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL]);
- if (typeof iteratorFn === 'function') {
- return iteratorFn;
- }
- }
- /**
- * Collection of methods that allow declaration and validation of props that are
- * supplied to React components. Example usage:
- *
- * var Props = require('ReactPropTypes');
- * var MyArticle = React.createClass({
- * propTypes: {
- * // An optional string prop named "description".
- * description: Props.string,
- *
- * // A required enum prop named "category".
- * category: Props.oneOf(['News','Photos']).isRequired,
- *
- * // A prop named "dialog" that requires an instance of Dialog.
- * dialog: Props.instanceOf(Dialog).isRequired
- * },
- * render: function() { ... }
- * });
- *
- * A more formal specification of how these methods are used:
- *
- * type := array|bool|func|object|number|string|oneOf([...])|instanceOf(...)
- * decl := ReactPropTypes.{type}(.isRequired)?
- *
- * Each and every declaration produces a function with the same signature. This
- * allows the creation of custom validation functions. For example:
- *
- * var MyLink = React.createClass({
- * propTypes: {
- * // An optional string or URI prop named "href".
- * href: function(props, propName, componentName) {
- * var propValue = props[propName];
- * if (propValue != null && typeof propValue !== 'string' &&
- * !(propValue instanceof URI)) {
- * return new Error(
- * 'Expected a string or an URI for ' + propName + ' in ' +
- * componentName
- * );
- * }
- * }
- * },
- * render: function() {...}
- * });
- *
- * @internal
- */
- var ANONYMOUS = '<<anonymous>>';
- // Important!
- // Keep this list in sync with production version in `./factoryWithThrowingShims.js`.
- var ReactPropTypes = {
- array: createPrimitiveTypeChecker('array'),
- bool: createPrimitiveTypeChecker('boolean'),
- func: createPrimitiveTypeChecker('function'),
- number: createPrimitiveTypeChecker('number'),
- object: createPrimitiveTypeChecker('object'),
- string: createPrimitiveTypeChecker('string'),
- symbol: createPrimitiveTypeChecker('symbol'),
- any: createAnyTypeChecker(),
- arrayOf: createArrayOfTypeChecker,
- element: createElementTypeChecker(),
- instanceOf: createInstanceTypeChecker,
- node: createNodeChecker(),
- objectOf: createObjectOfTypeChecker,
- oneOf: createEnumTypeChecker,
- oneOfType: createUnionTypeChecker,
- shape: createShapeTypeChecker
- };
- /**
- * inlined Object.is polyfill to avoid requiring consumers ship their own
- * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is
- */
- /*eslint-disable no-self-compare*/
- function is(x, y) {
- // SameValue algorithm
- if (x === y) {
- // Steps 1-5, 7-10
- // Steps 6.b-6.e: +0 != -0
- return x !== 0 || 1 / x === 1 / y;
- } else {
- // Step 6.a: NaN == NaN
- return x !== x && y !== y;
- }
- }
- /*eslint-enable no-self-compare*/
- /**
- * We use an Error-like object for backward compatibility as people may call
- * PropTypes directly and inspect their output. However, we don't use real
- * Errors anymore. We don't inspect their stack anyway, and creating them
- * is prohibitively expensive if they are created too often, such as what
- * happens in oneOfType() for any type before the one that matched.
- */
- function PropTypeError(message) {
- this.message = message;
- this.stack = '';
- }
- // Make `instanceof Error` still work for returned errors.
- PropTypeError.prototype = Error.prototype;
- function createChainableTypeChecker(validate) {
- if (Object({"DRAGGABLE_DEBUG":undefined}).NODE_ENV !== 'production') {
- var manualPropTypeCallCache = {};
- var manualPropTypeWarningCount = 0;
- }
- function checkType(isRequired, props, propName, componentName, location, propFullName, secret) {
- componentName = componentName || ANONYMOUS;
- propFullName = propFullName || propName;
- if (secret !== ReactPropTypesSecret) {
- if (throwOnDirectAccess) {
- // New behavior only for users of `prop-types` package
- invariant(
- false,
- 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +
- 'Use `PropTypes.checkPropTypes()` to call them. ' +
- 'Read more at http://fb.me/use-check-prop-types'
- );
- } else if (Object({"DRAGGABLE_DEBUG":undefined}).NODE_ENV !== 'production' && typeof console !== 'undefined') {
- // Old behavior for people using React.PropTypes
- var cacheKey = componentName + ':' + propName;
- if (
- !manualPropTypeCallCache[cacheKey] &&
- // Avoid spamming the console because they are often not actionable except for lib authors
- manualPropTypeWarningCount < 3
- ) {
- warning(
- false,
- 'You are manually calling a React.PropTypes validation ' +
- 'function for the `%s` prop on `%s`. This is deprecated ' +
- 'and will throw in the standalone `prop-types` package. ' +
- 'You may be seeing this warning due to a third-party PropTypes ' +
- 'library. See https://fb.me/react-warning-dont-call-proptypes ' + 'for details.',
- propFullName,
- componentName
- );
- manualPropTypeCallCache[cacheKey] = true;
- manualPropTypeWarningCount++;
- }
- }
- }
- if (props[propName] == null) {
- if (isRequired) {
- if (props[propName] === null) {
- return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required ' + ('in `' + componentName + '`, but its value is `null`.'));
- }
- return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required in ' + ('`' + componentName + '`, but its value is `undefined`.'));
- }
- return null;
- } else {
- return validate(props, propName, componentName, location, propFullName);
- }
- }
- var chainedCheckType = checkType.bind(null, false);
- chainedCheckType.isRequired = checkType.bind(null, true);
- return chainedCheckType;
- }
- function createPrimitiveTypeChecker(expectedType) {
- function validate(props, propName, componentName, location, propFullName, secret) {
- var propValue = props[propName];
- var propType = getPropType(propValue);
- if (propType !== expectedType) {
- // `propValue` being instance of, say, date/regexp, pass the 'object'
- // check, but we can offer a more precise error message here rather than
- // 'of type `object`'.
- var preciseType = getPreciseType(propValue);
- return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + preciseType + '` supplied to `' + componentName + '`, expected ') + ('`' + expectedType + '`.'));
- }
- return null;
- }
- return createChainableTypeChecker(validate);
- }
- function createAnyTypeChecker() {
- return createChainableTypeChecker(emptyFunction.thatReturnsNull);
- }
- function createArrayOfTypeChecker(typeChecker) {
- function validate(props, propName, componentName, location, propFullName) {
- if (typeof typeChecker !== 'function') {
- return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside arrayOf.');
- }
- var propValue = props[propName];
- if (!Array.isArray(propValue)) {
- var propType = getPropType(propValue);
- return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an array.'));
- }
- for (var i = 0; i < propValue.length; i++) {
- var error = typeChecker(propValue, i, componentName, location, propFullName + '[' + i + ']', ReactPropTypesSecret);
- if (error instanceof Error) {
- return error;
- }
- }
- return null;
- }
- return createChainableTypeChecker(validate);
- }
- function createElementTypeChecker() {
- function validate(props, propName, componentName, location, propFullName) {
- var propValue = props[propName];
- if (!isValidElement(propValue)) {
- var propType = getPropType(propValue);
- return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement.'));
- }
- return null;
- }
- return createChainableTypeChecker(validate);
- }
- function createInstanceTypeChecker(expectedClass) {
- function validate(props, propName, componentName, location, propFullName) {
- if (!(props[propName] instanceof expectedClass)) {
- var expectedClassName = expectedClass.name || ANONYMOUS;
- var actualClassName = getClassName(props[propName]);
- return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + actualClassName + '` supplied to `' + componentName + '`, expected ') + ('instance of `' + expectedClassName + '`.'));
- }
- return null;
- }
- return createChainableTypeChecker(validate);
- }
- function createEnumTypeChecker(expectedValues) {
- if (!Array.isArray(expectedValues)) {
- Object({"DRAGGABLE_DEBUG":undefined}).NODE_ENV !== 'production' ? warning(false, 'Invalid argument supplied to oneOf, expected an instance of array.') : void 0;
- return emptyFunction.thatReturnsNull;
- }
- function validate(props, propName, componentName, location, propFullName) {
- var propValue = props[propName];
- for (var i = 0; i < expectedValues.length; i++) {
- if (is(propValue, expectedValues[i])) {
- return null;
- }
- }
- var valuesString = JSON.stringify(expectedValues);
- return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of value `' + propValue + '` ' + ('supplied to `' + componentName + '`, expected one of ' + valuesString + '.'));
- }
- return createChainableTypeChecker(validate);
- }
- function createObjectOfTypeChecker(typeChecker) {
- function validate(props, propName, componentName, location, propFullName) {
- if (typeof typeChecker !== 'function') {
- return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside objectOf.');
- }
- var propValue = props[propName];
- var propType = getPropType(propValue);
- if (propType !== 'object') {
- return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an object.'));
- }
- for (var key in propValue) {
- if (propValue.hasOwnProperty(key)) {
- var error = typeChecker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);
- if (error instanceof Error) {
- return error;
- }
- }
- }
- return null;
- }
- return createChainableTypeChecker(validate);
- }
- function createUnionTypeChecker(arrayOfTypeCheckers) {
- if (!Array.isArray(arrayOfTypeCheckers)) {
- Object({"DRAGGABLE_DEBUG":undefined}).NODE_ENV !== 'production' ? warning(false, 'Invalid argument supplied to oneOfType, expected an instance of array.') : void 0;
- return emptyFunction.thatReturnsNull;
- }
- for (var i = 0; i < arrayOfTypeCheckers.length; i++) {
- var checker = arrayOfTypeCheckers[i];
- if (typeof checker !== 'function') {
- warning(
- false,
- 'Invalid argument supplid to oneOfType. Expected an array of check functions, but ' +
- 'received %s at index %s.',
- getPostfixForTypeWarning(checker),
- i
- );
- return emptyFunction.thatReturnsNull;
- }
- }
- function validate(props, propName, componentName, location, propFullName) {
- for (var i = 0; i < arrayOfTypeCheckers.length; i++) {
- var checker = arrayOfTypeCheckers[i];
- if (checker(props, propName, componentName, location, propFullName, ReactPropTypesSecret) == null) {
- return null;
- }
- }
- return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`.'));
- }
- return createChainableTypeChecker(validate);
- }
- function createNodeChecker() {
- function validate(props, propName, componentName, location, propFullName) {
- if (!isNode(props[propName])) {
- return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`, expected a ReactNode.'));
- }
- return null;
- }
- return createChainableTypeChecker(validate);
- }
- function createShapeTypeChecker(shapeTypes) {
- function validate(props, propName, componentName, location, propFullName) {
- var propValue = props[propName];
- var propType = getPropType(propValue);
- if (propType !== 'object') {
- return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.'));
- }
- for (var key in shapeTypes) {
- var checker = shapeTypes[key];
- if (!checker) {
- continue;
- }
- var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);
- if (error) {
- return error;
- }
- }
- return null;
- }
- return createChainableTypeChecker(validate);
- }
- function isNode(propValue) {
- switch (typeof propValue) {
- case 'number':
- case 'string':
- case 'undefined':
- return true;
- case 'boolean':
- return !propValue;
- case 'object':
- if (Array.isArray(propValue)) {
- return propValue.every(isNode);
- }
- if (propValue === null || isValidElement(propValue)) {
- return true;
- }
- var iteratorFn = getIteratorFn(propValue);
- if (iteratorFn) {
- var iterator = iteratorFn.call(propValue);
- var step;
- if (iteratorFn !== propValue.entries) {
- while (!(step = iterator.next()).done) {
- if (!isNode(step.value)) {
- return false;
- }
- }
- } else {
- // Iterator will provide entry [k,v] tuples rather than values.
- while (!(step = iterator.next()).done) {
- var entry = step.value;
- if (entry) {
- if (!isNode(entry[1])) {
- return false;
- }
- }
- }
- }
- } else {
- return false;
- }
- return true;
- default:
- return false;
- }
- }
- function isSymbol(propType, propValue) {
- // Native Symbol.
- if (propType === 'symbol') {
- return true;
- }
- // 19.4.3.5 Symbol.prototype[@@toStringTag] === 'Symbol'
- if (propValue['@@toStringTag'] === 'Symbol') {
- return true;
- }
- // Fallback for non-spec compliant Symbols which are polyfilled.
- if (typeof Symbol === 'function' && propValue instanceof Symbol) {
- return true;
- }
- return false;
- }
- // Equivalent of `typeof` but with special handling for array and regexp.
- function getPropType(propValue) {
- var propType = typeof propValue;
- if (Array.isArray(propValue)) {
- return 'array';
- }
- if (propValue instanceof RegExp) {
- // Old webkits (at least until Android 4.0) return 'function' rather than
- // 'object' for typeof a RegExp. We'll normalize this here so that /bla/
- // passes PropTypes.object.
- return 'object';
- }
- if (isSymbol(propType, propValue)) {
- return 'symbol';
- }
- return propType;
- }
- // This handles more types than `getPropType`. Only used for error messages.
- // See `createPrimitiveTypeChecker`.
- function getPreciseType(propValue) {
- if (typeof propValue === 'undefined' || propValue === null) {
- return '' + propValue;
- }
- var propType = getPropType(propValue);
- if (propType === 'object') {
- if (propValue instanceof Date) {
- return 'date';
- } else if (propValue instanceof RegExp) {
- return 'regexp';
- }
- }
- return propType;
- }
- // Returns a string that is postfixed to a warning about an invalid type.
- // For example, "undefined" or "of type array"
- function getPostfixForTypeWarning(value) {
- var type = getPreciseType(value);
- switch (type) {
- case 'array':
- case 'object':
- return 'an ' + type;
- case 'boolean':
- case 'date':
- case 'regexp':
- return 'a ' + type;
- default:
- return type;
- }
- }
- // Returns class name of the object, if any.
- function getClassName(propValue) {
- if (!propValue.constructor || !propValue.constructor.name) {
- return ANONYMOUS;
- }
- return propValue.constructor.name;
- }
- ReactPropTypes.checkPropTypes = checkPropTypes;
- ReactPropTypes.PropTypes = ReactPropTypes;
- return ReactPropTypes;
- };
- /***/ }),
- /* 15 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * Copyright 2013-present, Facebook, Inc.
- * All rights reserved.
- *
- * This source code is licensed under the BSD-style license found in the
- * LICENSE file in the root directory of this source tree. An additional grant
- * of patent rights can be found in the PATENTS file in the same directory.
- */
- if (Object({"DRAGGABLE_DEBUG":undefined}).NODE_ENV !== 'production') {
- var invariant = __webpack_require__(2);
- var warning = __webpack_require__(8);
- var ReactPropTypesSecret = __webpack_require__(3);
- var loggedTypeFailures = {};
- }
- /**
- * Assert that the values match with the type specs.
- * Error messages are memorized and will only be shown once.
- *
- * @param {object} typeSpecs Map of name to a ReactPropType
- * @param {object} values Runtime values that need to be type-checked
- * @param {string} location e.g. "prop", "context", "child context"
- * @param {string} componentName Name of the component for error messages.
- * @param {?Function} getStack Returns the component stack.
- * @private
- */
- function checkPropTypes(typeSpecs, values, location, componentName, getStack) {
- if (Object({"DRAGGABLE_DEBUG":undefined}).NODE_ENV !== 'production') {
- for (var typeSpecName in typeSpecs) {
- if (typeSpecs.hasOwnProperty(typeSpecName)) {
- var error;
- // Prop type validation may throw. In case they do, we don't want to
- // fail the render phase where it didn't fail before. So we log it.
- // After these have been cleaned up, we'll let them throw.
- try {
- // This is intentionally an invariant that gets caught. It's the same
- // behavior as without this statement except with a better message.
- invariant(typeof typeSpecs[typeSpecName] === 'function', '%s: %s type `%s` is invalid; it must be a function, usually from ' + 'React.PropTypes.', componentName || 'React class', location, typeSpecName);
- error = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, ReactPropTypesSecret);
- } catch (ex) {
- error = ex;
- }
- warning(!error || error instanceof Error, '%s: type specification of %s `%s` is invalid; the type checker ' + 'function must return `null` or an `Error` but returned a %s. ' + 'You may have forgotten to pass an argument to the type checker ' + 'creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and ' + 'shape all require an argument).', componentName || 'React class', location, typeSpecName, typeof error);
- if (error instanceof Error && !(error.message in loggedTypeFailures)) {
- // Only monitor this failure once because there tends to be a lot of the
- // same error.
- loggedTypeFailures[error.message] = true;
- var stack = getStack ? getStack() : '';
- warning(false, 'Failed %s type: %s%s', location, error.message, stack != null ? stack : '');
- }
- }
- }
- }
- }
- module.exports = checkPropTypes;
- /***/ }),
- /* 16 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * Copyright 2013-present, Facebook, Inc.
- * All rights reserved.
- *
- * This source code is licensed under the BSD-style license found in the
- * LICENSE file in the root directory of this source tree. An additional grant
- * of patent rights can be found in the PATENTS file in the same directory.
- */
- var emptyFunction = __webpack_require__(1);
- var invariant = __webpack_require__(2);
- var ReactPropTypesSecret = __webpack_require__(3);
- module.exports = function() {
- function shim(props, propName, componentName, location, propFullName, secret) {
- if (secret === ReactPropTypesSecret) {
- // It is still safe when called from React.
- return;
- }
- invariant(
- false,
- 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +
- 'Use PropTypes.checkPropTypes() to call them. ' +
- 'Read more at http://fb.me/use-check-prop-types'
- );
- };
- shim.isRequired = shim;
- function getShim() {
- return shim;
- };
- // Important!
- // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.
- var ReactPropTypes = {
- array: shim,
- bool: shim,
- func: shim,
- number: shim,
- object: shim,
- string: shim,
- symbol: shim,
- any: shim,
- arrayOf: getShim,
- element: shim,
- instanceOf: getShim,
- node: shim,
- objectOf: getShim,
- oneOf: getShim,
- oneOfType: getShim,
- shape: getShim
- };
- ReactPropTypes.checkPropTypes = emptyFunction;
- ReactPropTypes.PropTypes = ReactPropTypes;
- return ReactPropTypes;
- };
- /***/ }),
- /* 17 */
- /***/ (function(module, exports, __webpack_require__) {
- var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*!
- Copyright (c) 2016 Jed Watson.
- Licensed under the MIT License (MIT), see
- http://jedwatson.github.io/classnames
- */
- /* global define */
- (function () {
- 'use strict';
- var hasOwn = {}.hasOwnProperty;
- function classNames () {
- var classes = [];
- for (var i = 0; i < arguments.length; i++) {
- var arg = arguments[i];
- if (!arg) continue;
- var argType = typeof arg;
- if (argType === 'string' || argType === 'number') {
- classes.push(arg);
- } else if (Array.isArray(arg)) {
- classes.push(classNames.apply(null, arg));
- } else if (argType === 'object') {
- for (var key in arg) {
- if (hasOwn.call(arg, key) && arg[key]) {
- classes.push(key);
- }
- }
- }
- }
- return classes.join(' ');
- }
- if (typeof module !== 'undefined' && module.exports) {
- module.exports = classNames;
- } else if (true) {
- // register as 'classnames', consistent with npm package name
- !(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_RESULT__ = function () {
- return classNames;
- }.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__),
- __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
- } else {
- window.classNames = classNames;
- }
- }());
- /***/ }),
- /* 18 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.getPrefix = getPrefix;
- exports.browserPrefixToKey = browserPrefixToKey;
- exports.browserPrefixToStyle = browserPrefixToStyle;
- var prefixes = ['Moz', 'Webkit', 'O', 'ms'];
- function getPrefix() /*: string*/ {
- var prop /*: string*/ = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'transform';
- // Checking specifically for 'window.document' is for pseudo-browser server-side
- // environments that define 'window' as the global context.
- // E.g. React-rails (see https://github.com/reactjs/react-rails/pull/84)
- if (typeof window === 'undefined' || typeof window.document === 'undefined') return '';
- var style = window.document.documentElement.style;
- if (prop in style) return '';
- for (var i = 0; i < prefixes.length; i++) {
- if (browserPrefixToKey(prop, prefixes[i]) in style) return prefixes[i];
- }
- return '';
- }
- function browserPrefixToKey(prop /*: string*/, prefix /*: string*/) /*: string*/ {
- return prefix ? '' + prefix + kebabToTitleCase(prop) : prop;
- }
- function browserPrefixToStyle(prop /*: string*/, prefix /*: string*/) /*: string*/ {
- return prefix ? '-' + prefix.toLowerCase() + '-' + prop : prop;
- }
- function kebabToTitleCase(str /*: string*/) /*: string*/ {
- var out = '';
- var shouldCapitalize = true;
- for (var i = 0; i < str.length; i++) {
- if (shouldCapitalize) {
- out += str[i].toUpperCase();
- shouldCapitalize = false;
- } else if (str[i] === '-') {
- shouldCapitalize = true;
- } else {
- out += str[i];
- }
- }
- return out;
- }
- // Default export is the prefix itself, like 'Moz', 'Webkit', etc
- // Note that you may have to re-test for certain things; for instance, Chrome 50
- // can handle unprefixed `transform`, but not unprefixed `user-select`
- exports.default = getPrefix();
- /***/ }),
- /* 19 */
- /***/ (function(module, exports) {
- // shim for using process in browser
- var process = module.exports = {};
- // cached from whatever global is present so that test runners that stub it
- // don't break things. But we need to wrap it in a try catch in case it is
- // wrapped in strict mode code which doesn't define any globals. It's inside a
- // function because try/catches deoptimize in certain engines.
- var cachedSetTimeout;
- var cachedClearTimeout;
- function defaultSetTimout() {
- throw new Error('setTimeout has not been defined');
- }
- function defaultClearTimeout () {
- throw new Error('clearTimeout has not been defined');
- }
- (function () {
- try {
- if (typeof setTimeout === 'function') {
- cachedSetTimeout = setTimeout;
- } else {
- cachedSetTimeout = defaultSetTimout;
- }
- } catch (e) {
- cachedSetTimeout = defaultSetTimout;
- }
- try {
- if (typeof clearTimeout === 'function') {
- cachedClearTimeout = clearTimeout;
- } else {
- cachedClearTimeout = defaultClearTimeout;
- }
- } catch (e) {
- cachedClearTimeout = defaultClearTimeout;
- }
- } ())
- function runTimeout(fun) {
- if (cachedSetTimeout === setTimeout) {
- //normal enviroments in sane situations
- return setTimeout(fun, 0);
- }
- // if setTimeout wasn't available but was latter defined
- if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {
- cachedSetTimeout = setTimeout;
- return setTimeout(fun, 0);
- }
- try {
- // when when somebody has screwed with setTimeout but no I.E. maddness
- return cachedSetTimeout(fun, 0);
- } catch(e){
- try {
- // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally
- return cachedSetTimeout.call(null, fun, 0);
- } catch(e){
- // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error
- return cachedSetTimeout.call(this, fun, 0);
- }
- }
- }
- function runClearTimeout(marker) {
- if (cachedClearTimeout === clearTimeout) {
- //normal enviroments in sane situations
- return clearTimeout(marker);
- }
- // if clearTimeout wasn't available but was latter defined
- if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {
- cachedClearTimeout = clearTimeout;
- return clearTimeout(marker);
- }
- try {
- // when when somebody has screwed with setTimeout but no I.E. maddness
- return cachedClearTimeout(marker);
- } catch (e){
- try {
- // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally
- return cachedClearTimeout.call(null, marker);
- } catch (e){
- // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.
- // Some versions of I.E. have different rules for clearTimeout vs setTimeout
- return cachedClearTimeout.call(this, marker);
- }
- }
- }
- var queue = [];
- var draining = false;
- var currentQueue;
- var queueIndex = -1;
- function cleanUpNextTick() {
- if (!draining || !currentQueue) {
- return;
- }
- draining = false;
- if (currentQueue.length) {
- queue = currentQueue.concat(queue);
- } else {
- queueIndex = -1;
- }
- if (queue.length) {
- drainQueue();
- }
- }
- function drainQueue() {
- if (draining) {
- return;
- }
- var timeout = runTimeout(cleanUpNextTick);
- draining = true;
- var len = queue.length;
- while(len) {
- currentQueue = queue;
- queue = [];
- while (++queueIndex < len) {
- if (currentQueue) {
- currentQueue[queueIndex].run();
- }
- }
- queueIndex = -1;
- len = queue.length;
- }
- currentQueue = null;
- draining = false;
- runClearTimeout(timeout);
- }
- process.nextTick = function (fun) {
- var args = new Array(arguments.length - 1);
- if (arguments.length > 1) {
- for (var i = 1; i < arguments.length; i++) {
- args[i - 1] = arguments[i];
- }
- }
- queue.push(new Item(fun, args));
- if (queue.length === 1 && !draining) {
- runTimeout(drainQueue);
- }
- };
- // v8 likes predictible objects
- function Item(fun, array) {
- this.fun = fun;
- this.array = array;
- }
- Item.prototype.run = function () {
- this.fun.apply(null, this.array);
- };
- process.title = 'browser';
- process.browser = true;
- process.env = {};
- process.argv = [];
- process.version = ''; // empty string to avoid regexp issues
- process.versions = {};
- function noop() {}
- process.on = noop;
- process.addListener = noop;
- process.once = noop;
- process.off = noop;
- process.removeListener = noop;
- process.removeAllListeners = noop;
- process.emit = noop;
- process.prependListener = noop;
- process.prependOnceListener = noop;
- process.listeners = function (name) { return [] }
- process.binding = function (name) {
- throw new Error('process.binding is not supported');
- };
- process.cwd = function () { return '/' };
- process.chdir = function (dir) {
- throw new Error('process.chdir is not supported');
- };
- process.umask = function() { return 0; };
- /***/ })
- /******/ ]);
- });
- //# sourceMappingURL=react-draggable.js.map
|