react-carousel-ninja
Advanced tools
Comparing version
{ | ||
"name": "react-carousel-ninja", | ||
"version": "0.1.2", | ||
"version": "0.1.3", | ||
"description": "", | ||
@@ -5,0 +5,0 @@ "author": "ahomu", |
@@ -9,3 +9,3 @@ /** | ||
* homepage: https://github.com/ahomu/react-carousel-ninja | ||
* version: 0.1.1 | ||
* version: 0.1.3 | ||
* | ||
@@ -223,2 +223,11 @@ * date-now: | ||
CarouselNinjaContainer.prototype.provideMouseEventHandlers = function provideMouseEventHandlers() { | ||
return this.props.swipe ? { | ||
onMouseDown: this.onMouseDown.bind(this), | ||
onMouseMove: this.onMouseMove.bind(this), | ||
onMouseUp: this.onMouseUp.bind(this), | ||
onMouseLeave: this.onMouseLeave.bind(this) | ||
} : null; | ||
}; | ||
CarouselNinjaContainer.prototype.handleSwipe = function handleSwipe() { | ||
@@ -289,3 +298,3 @@ var deltaAbsX = Math.abs(this.state.deltaX); | ||
} | ||
return React.createElement("div", { "className": 'CarouselNinjaContainer ' + (this.state.dragging ? 'CarouselNinjaContainer--dragging' : ''), "onMouseDown": this.onMouseDown.bind(this), "onMouseMove": this.onMouseMove.bind(this), "onMouseUp": this.onMouseUp.bind(this), "onMouseLeave": this.onMouseLeave.bind(this) }, children.map(function (child, i) { | ||
return React.createElement("div", React.__spread({ "className": 'CarouselNinjaContainer ' + (this.state.dragging ? 'CarouselNinjaContainer--dragging' : '') }, this.provideMouseEventHandlers()), children.map(function (child, i) { | ||
var isCenter = i === _this2.props.select; | ||
@@ -337,3 +346,4 @@ var isLeftEdge = false; | ||
onSwipeLeft: function onSwipeLeft() {}, | ||
onSwipeRight: function onSwipeRight() {} | ||
onSwipeRight: function onSwipeRight() {}, | ||
swipe: false | ||
}; | ||
@@ -514,2 +524,2 @@ | ||
},{"./CarouselNinjaContainer":4,"./CarouselNinjaSelector":5,"react":undefined,"throttleit":3}]},{},[6]) | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","node_modules/debounce/index.js","node_modules/debounce/node_modules/date-now/index.js","node_modules/throttleit/index.js","src/CarouselNinjaContainer.tsx","src/CarouselNinjaSelector.tsx","src/index.tsx"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","\n/**\n * Module dependencies.\n */\n\nvar now = require('date-now');\n\n/**\n * Returns a function, that, as long as it continues to be invoked, will not\n * be triggered. The function will be called after it stops being called for\n * N milliseconds. If `immediate` is passed, trigger the function on the\n * leading edge, instead of the trailing.\n *\n * @source underscore.js\n * @see http://unscriptable.com/2009/03/20/debouncing-javascript-methods/\n * @param {Function} function to wrap\n * @param {Number} timeout in ms (`100`)\n * @param {Boolean} whether to execute at the beginning (`false`)\n * @api public\n */\n\nmodule.exports = function debounce(func, wait, immediate){\n  var timeout, args, context, timestamp, result;\n  if (null == wait) wait = 100;\n\n  function later() {\n    var last = now() - timestamp;\n\n    if (last < wait && last > 0) {\n      timeout = setTimeout(later, wait - last);\n    } else {\n      timeout = null;\n      if (!immediate) {\n        result = func.apply(context, args);\n        if (!timeout) context = args = null;\n      }\n    }\n  };\n\n  return function debounced() {\n    context = this;\n    args = arguments;\n    timestamp = now();\n    var callNow = immediate && !timeout;\n    if (!timeout) timeout = setTimeout(later, wait);\n    if (callNow) {\n      result = func.apply(context, args);\n      context = args = null;\n    }\n\n    return result;\n  };\n};\n","module.exports = Date.now || now\n\nfunction now() {\n    return new Date().getTime()\n}\n","module.exports = throttle;\n\n/**\n * Returns a new function that, when invoked, invokes `func` at most once per `wait` milliseconds.\n *\n * @param {Function} func Function to wrap.\n * @param {Number} wait Number of milliseconds that must elapse between `func` invocations.\n * @return {Function} A new function that wraps the `func` function passed in.\n */\n\nfunction throttle (func, wait) {\n  var ctx, args, rtn, timeoutID; // caching\n  var last = 0;\n\n  return function throttled () {\n    ctx = this;\n    args = arguments;\n    var delta = new Date() - last;\n    if (!timeoutID)\n      if (delta >= wait) call();\n      else timeoutID = setTimeout(call, wait - delta);\n    return rtn;\n  };\n\n  function call () {\n    timeoutID = 0;\n    last = +new Date();\n    rtn = func.apply(ctx, args);\n    ctx = null;\n    args = null;\n  }\n}\n","import * as React from 'react';\nimport * as ReactDOM from 'react-dom';\nimport * as debounce from 'debounce';\n\nconst DURATION_DEBOUNCE_RESIZE = 300;\nconst DELTA_PERCENTAGE_SWIPE   = .2;\n\nconst DIRECTION_RIGHT = 0;\nconst DIRECTION_LEFT  = 1;\n\ninterface CarouselNinjaContainerProps extends React.Props<CarouselNinjaContainer> {\n  activeClass?: string;\n  rightEdgeClass?: string;\n  leftEdgeClass?: string;\n  select: number;\n  onSelect? : (nextI: number, curtI: number) => void;\n  onSwipeLeft? : (nextI: number) => void;\n  onSwipeRight? : (nextI: number) => void;\n}\n\ninterface CarouselNinjaContainerState {\n  innerWidth?: number;\n  dragging?: boolean;\n  deltaX?: number;\n  deltaY?: number;\n}\n\nexport default class CarouselNinjaContainer extends React.Component<CarouselNinjaContainerProps, CarouselNinjaContainerState> {\n\n  static defaultProps = {\n    activeClass    : ' is-active',\n    rightEdgeClass : ' is-right',\n    leftEdgeClass  : ' is-left',\n    select         : 0,\n    onSelect       : () => {},\n    onSwipeLeft    : () => {},\n    onSwipeRight   : () => {}\n  };\n\n  state = {\n    outerWidth : 0,\n    innerWidth : 0,\n    dragging   : false,\n    deltaX     : 0,\n    deltaY     : 0\n  };\n\n  startCoordinate: {\n    x: number,\n    y: number\n  } = {\n    x : 0,\n    y : 0\n  };\n\n  calculateWidth() {\n    const firstChild: Element = this.refs[`child-${this.props.select}`] as any;\n    this.setState({\n      innerWidth : firstChild.clientWidth\n    });\n  }\n\n  onMouseDown(evt: MouseEvent) {\n    this.startCoordinate = {\n      x : evt.clientX,\n      y : evt.clientY\n    };\n    this.setState({\n      dragging   : true\n    });\n  }\n\n  onMouseMove(evt: MouseEvent) {\n    if (!this.state.dragging) {\n      return;\n    }\n    evt.preventDefault();\n    this.setState({\n      deltaX : evt.clientX - this.startCoordinate.x,\n      deltaY : evt.clientY - this.startCoordinate.y\n    });\n  }\n\n  onMouseUp(evt: MouseEvent) {\n    if (!this.state.dragging) {\n      return;\n    }\n    this.handleSwipe();\n  }\n\n  onMouseLeave(evt: MouseEvent) {\n    if (!this.state.dragging) {\n      return;\n    }\n    this.handleSwipe();\n  }\n\n  handleSwipe() {\n    const deltaAbsX = Math.abs(this.state.deltaX);\n    const threshold = this.state.innerWidth * DELTA_PERCENTAGE_SWIPE;\n\n    if (deltaAbsX > threshold) {\n\n      const direction = this.state.deltaX > -1 ? DIRECTION_RIGHT : DIRECTION_LEFT;\n\n      if (direction === DIRECTION_LEFT) {\n        this.props.onSwipeLeft(this.props.select + 1);\n      } else if (direction === DIRECTION_RIGHT) {\n        this.props.onSwipeRight(this.props.select - 1);\n      }\n\n    }\n\n    // reset\n    this.startCoordinate = {\n      x : 0,\n      y : 0\n    };\n    this.setState({\n      dragging : false,\n      deltaX   : 0,\n      deltaY   : 0\n    });\n  }\n\n  onResize = debounce((evt: Event) => {\n    this.calculateWidth();\n  }, DURATION_DEBOUNCE_RESIZE);\n\n  componentDidMount() {\n    this.calculateWidth();\n    window.addEventListener('resize', this.onResize);\n  }\n\n  componentWillReceiveProps(nextProps: CarouselNinjaContainerProps) {\n    if (this.props.onSelect) {\n      this.props.onSelect(nextProps.select, this.props.select);\n    }\n  }\n\n  shouldComponentUpdate(nextProps: CarouselNinjaContainerProps, nextState: CarouselNinjaContainerState) {\n    return false ||\n      nextProps.select !== this.props.select ||\n      nextProps.children !== this.props.children ||\n      nextState !== this.state\n    ;\n  }\n\n  componentWillUnmount() {\n    window.addEventListener('resize', this.onResize);\n  }\n\n  render() {\n    /**\n     * 選択された要素が見た目上の中央であるとして、その右側と左側にあるべき要素を分類する\n     *\n     * @example this.props.children = [0, 1, 2, 3, 4]\n     *          this.props.select   = 3\n     */\n    const children: React.ReactNode[] = (React.Children as any).toArray(this.props.children);\n    const halfSideSize = Math.floor(children.length / 2);\n\n    // [0, 1, 2, *3*, 4] => [0, 1, 2]\n    let leftward = children.slice(0, this.props.select);\n    // [0, 1, 2, *3*, 4] => [4]\n    let rightward = children.slice(this.props.select + 1, children.length);\n\n    // 片側にある過剰分の要素を、もう片側に移して結合する\n    if (leftward.length > halfSideSize) {\n      // right:[4] + left:[0](, [1, 2]) => left:[1, 2]/ center:[3] / right:[4, 0]\n      rightward = [].concat(rightward, leftward.splice(0, leftward.length - halfSideSize));\n    } else if (rightward.length > halfSideSize) {\n      // right:(2, 3, )[4] + left:[0] => left:[4, 0] / center:[1] / right:[2, 3]\n      leftward = [].concat(rightward.splice(halfSideSize), leftward);\n    }\n\n    return (\n        <div className={`CarouselNinjaContainer ${this.state.dragging ? 'CarouselNinjaContainer--dragging' : ''}`}\n             onMouseDown={this.onMouseDown.bind(this)}\n             onMouseMove={this.onMouseMove.bind(this)}\n             onMouseUp={this.onMouseUp.bind(this)}\n             onMouseLeave={this.onMouseLeave.bind(this)}>\n\n          {children.map((child: React.ReactNode, i: number) => {\n            const isCenter = (i === this.props.select);\n            let isLeftEdge = false;\n            let isRightEdge = false;\n\n            let arrangedPos: number;\n            let calcFunction: string;\n\n            // TODO multiple translateX で表現できないか？ calc() があると IE10, IE11 で transition されない\n            // TODO 50% のかわりに ラッパーのwidth / 2で実数計算するとか？\n            // 左側・右側・中央のいずれに属しているかで位置の指定を変更する\n            if ((arrangedPos = leftward.indexOf(child)) !== -1) {\n              // Leftward [0=1920, 1=1280, 2=640] 左側は配列の始点に向けてオフセットを大きくとる\n              let baseTranslateX = (leftward.length - arrangedPos) * this.state.innerWidth\n              calcFunction = `calc(50% - ${baseTranslateX - this.state.deltaX}px)`;\n              isLeftEdge = arrangedPos === 0;\n            } else if ((arrangedPos = rightward.indexOf(child)) !== -1) {\n              // Rightward [0=640, 1=1280, 2=1920] 右側は配列の終点に向けてオフセットを大きくとる\n              let baseTranslateX = (arrangedPos + 1) * this.state.innerWidth\n              calcFunction = `calc(50% + ${baseTranslateX + this.state.deltaX}px)`;\n              isRightEdge = arrangedPos === rightward.length - 1;\n            } else {\n              // Center\n              calcFunction = `calc(50% + ${0 + this.state.deltaX}px)`;\n            }\n\n            let className = 'CarouselNinjaContainer__pane';\n            className += isCenter    ? this.props.activeClass    : '';\n            className += isRightEdge ? this.props.rightEdgeClass : '';\n            className += isLeftEdge  ? this.props.leftEdgeClass  : '';\n\n            const style = {\n              left       : calcFunction,\n              marginLeft : `-${this.state.innerWidth / 2}px`\n            };\n\n            return <div ref={`child-${i}`}\n                        className={className}\n                        key={i}\n                        style={style}\n                        aria-hidden={isCenter ? 'false' : 'true'}>{child}</div>;\n          })}\n\n        </div>\n    );\n  }\n}\n","import * as React from 'react';\nimport ReactElement = __React.ReactElement;\n\ninterface CarouselSelectorProps extends React.Props<CarouselNinjaSelector> {\n  activeClass?: string;\n  select: number;\n  length: number;\n  onSelect?: (prevI: number, nextI: number) => void;\n  onClickSelector?: (selectI: number) => void;\n}\n\nexport default class CarouselNinjaSelector extends React.Component<CarouselSelectorProps, any> {\n\n  static defaultProps = {\n    activeClass     : ' is-active',\n    select          : 0,\n    length          : 0,\n    onSelect        : () => {},\n    onClickSelector : () => {},\n  };\n\n  componentWillReceiveProps(nextProps: CarouselSelectorProps) {\n    if (this.props.onSelect) {\n      this.props.onSelect(nextProps.select, this.props.select);\n    }\n  }\n\n  shouldComponentUpdate(nextProps: CarouselSelectorProps) {\n    return false ||\n      nextProps.select !== this.props.select ||\n      nextProps.children !== this.props.children\n    ;\n  }\n\n  renderFromChildren() {\n    return React.Children.map(this.props.children, (child: React.ReactNode, i: number) => {\n      const isSelectedChild = i === this.props.select;\n      let className = 'CarouselNinjaSelector__item';\n      className += isSelectedChild ? this.props.activeClass : '';\n      return (\n        <li className={className}\n            key={i}\n            onClick={this.props.onClickSelector.bind(this, i)}\n            aria-selected={isSelectedChild ? 'true' : 'false'}>\n          {child}\n        </li>\n      );\n    });\n  }\n\n  renderItemsBySelf() {\n    const children: ReactElement<any>[] = [], iz = this.props.length;\n    for (let i = 0; i < iz; i++) {\n      let isSelectedChild = i === this.props.select;\n      let className = 'CarouselNinjaSelector__item';\n      className += isSelectedChild ? this.props.activeClass : '';\n      children.push((\n        <li className={className}\n            key={i}\n            onClick={this.props.onClickSelector.bind(this, i)}\n            aria-selected={isSelectedChild ? 'true' : 'false'}>\n          <button tabIndex={-1} />\n        </li>\n      ))\n    }\n    return children\n  }\n\n  render() {\n    return (\n      <ul className=\"CarouselNinjaSelector\">\n        {React.Children.count(this.props.children) ? this.renderFromChildren() : this.renderItemsBySelf()}\n      </ul>\n    );\n  }\n}\n","/// <reference path=\"../typings/bundle.d.ts\" />\n\nimport * as React from 'react';\nimport * as ReactDOM from 'react-dom';\nimport * as throttle from 'throttleit';\nimport CarouselNinjaContainer from './CarouselNinjaContainer';\nimport CarouselNinjaSelector from './CarouselNinjaSelector';\n\nconst DURATION_THROTTLE_KEYUP = 150;\n\nconst KEYCODE_LEFT  = 37;\nconst KEYCODE_RIGHT = 39;\n\ninterface CarouselNinjaProps extends React.Props<CarouselNinja> {\n  className?: string;\n  activeClass?: string;\n  onSelect?: (prevI: number, nextI: number) => void;\n}\n\nclass CarouselNinja extends React.Component<CarouselNinjaProps, any> {\n\n  static defaultProps = {\n    className   : '',\n    activeClass : ' is-active',\n    onSelect    : () => {},\n  };\n\n  state = {\n    currentSelect : 2\n  };\n\n  updateSelect(select: number) {\n    const lastIndex = React.Children.count(this.props.children) - 1;\n    if (select < 0) {\n      this.setState({\n        currentSelect : lastIndex\n      });\n    } else if (select > lastIndex) {\n      this.setState({\n        currentSelect : 0\n      });\n    } else {\n      this.setState({\n        currentSelect : select\n      });\n    }\n  }\n\n  onKeyUp = throttle((e: KeyboardEvent) => {\n    switch(e.keyCode) {\n      case KEYCODE_LEFT:\n        this.updateSelect(this.state.currentSelect - 1);\n        break;\n      case KEYCODE_RIGHT:\n        this.updateSelect(this.state.currentSelect + 1);\n        break;\n    }\n  }, DURATION_THROTTLE_KEYUP);\n\n  onSelectChange(nextI: number, curtI: number) {\n    this.props.onSelect(nextI, curtI);\n  }\n\n  onClickSelector(selectI: number) {\n    this.updateSelect(selectI);\n  }\n\n  onSwipeLeft(nextI: number) {\n    this.updateSelect(nextI);\n  }\n\n  onSwipeRight(nextI: number) {\n    this.updateSelect(nextI);\n  }\n\n  render() {\n    // TODO [aria-controls]\n\n    return (\n      <div tabIndex={0} className={this.props.className} onKeyUp={this.onKeyUp.bind(this)}>\n        <CarouselNinjaContainer activeClass={this.props.activeClass}\n                                select={this.state.currentSelect}\n                                onSelect={this.onSelectChange.bind(this)}\n                                onSwipeLeft={this.onSwipeLeft.bind(this)}\n                                onSwipeRight={this.onSwipeRight.bind(this)}>\n          {this.props.children}\n        </CarouselNinjaContainer>\n\n        <CarouselNinjaSelector activeClass={this.props.activeClass}\n                               select={this.state.currentSelect}\n                               length={React.Children.count(this.props.children)}\n                               onSelect={this.onSelectChange.bind(this)}\n                               onClickSelector={this.onClickSelector.bind(this)} />\n      </div>\n    );\n  }\n}\n\nexport {\n  CarouselNinja,\n  CarouselNinjaContainer,\n  CarouselNinjaSelector\n};\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","node_modules/debounce/index.js","node_modules/debounce/node_modules/date-now/index.js","node_modules/throttleit/index.js","src/CarouselNinjaContainer.tsx","src/CarouselNinjaSelector.tsx","src/index.tsx"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","\n/**\n * Module dependencies.\n */\n\nvar now = require('date-now');\n\n/**\n * Returns a function, that, as long as it continues to be invoked, will not\n * be triggered. The function will be called after it stops being called for\n * N milliseconds. If `immediate` is passed, trigger the function on the\n * leading edge, instead of the trailing.\n *\n * @source underscore.js\n * @see http://unscriptable.com/2009/03/20/debouncing-javascript-methods/\n * @param {Function} function to wrap\n * @param {Number} timeout in ms (`100`)\n * @param {Boolean} whether to execute at the beginning (`false`)\n * @api public\n */\n\nmodule.exports = function debounce(func, wait, immediate){\n  var timeout, args, context, timestamp, result;\n  if (null == wait) wait = 100;\n\n  function later() {\n    var last = now() - timestamp;\n\n    if (last < wait && last > 0) {\n      timeout = setTimeout(later, wait - last);\n    } else {\n      timeout = null;\n      if (!immediate) {\n        result = func.apply(context, args);\n        if (!timeout) context = args = null;\n      }\n    }\n  };\n\n  return function debounced() {\n    context = this;\n    args = arguments;\n    timestamp = now();\n    var callNow = immediate && !timeout;\n    if (!timeout) timeout = setTimeout(later, wait);\n    if (callNow) {\n      result = func.apply(context, args);\n      context = args = null;\n    }\n\n    return result;\n  };\n};\n","module.exports = Date.now || now\n\nfunction now() {\n    return new Date().getTime()\n}\n","module.exports = throttle;\n\n/**\n * Returns a new function that, when invoked, invokes `func` at most once per `wait` milliseconds.\n *\n * @param {Function} func Function to wrap.\n * @param {Number} wait Number of milliseconds that must elapse between `func` invocations.\n * @return {Function} A new function that wraps the `func` function passed in.\n */\n\nfunction throttle (func, wait) {\n  var ctx, args, rtn, timeoutID; // caching\n  var last = 0;\n\n  return function throttled () {\n    ctx = this;\n    args = arguments;\n    var delta = new Date() - last;\n    if (!timeoutID)\n      if (delta >= wait) call();\n      else timeoutID = setTimeout(call, wait - delta);\n    return rtn;\n  };\n\n  function call () {\n    timeoutID = 0;\n    last = +new Date();\n    rtn = func.apply(ctx, args);\n    ctx = null;\n    args = null;\n  }\n}\n","import * as React from 'react';\nimport * as ReactDOM from 'react-dom';\nimport * as debounce from 'debounce';\n\nconst DURATION_DEBOUNCE_RESIZE = 300;\nconst DELTA_PERCENTAGE_SWIPE   = .2;\n\nconst DIRECTION_RIGHT = 0;\nconst DIRECTION_LEFT  = 1;\n\ninterface CarouselNinjaContainerProps extends React.Props<CarouselNinjaContainer> {\n  activeClass?: string;\n  rightEdgeClass?: string;\n  leftEdgeClass?: string;\n  select: number;\n  onSelect? : (nextI: number, curtI: number) => void;\n  onSwipeLeft? : (nextI: number) => void;\n  onSwipeRight? : (nextI: number) => void;\n  swipe?: boolean;\n}\n\ninterface CarouselNinjaContainerState {\n  innerWidth?: number;\n  dragging?: boolean;\n  deltaX?: number;\n  deltaY?: number;\n}\n\nexport default class CarouselNinjaContainer extends React.Component<CarouselNinjaContainerProps, CarouselNinjaContainerState> {\n\n  static defaultProps = {\n    activeClass    : ' is-active',\n    rightEdgeClass : ' is-right',\n    leftEdgeClass  : ' is-left',\n    select         : 0,\n    onSelect       : () => {},\n    onSwipeLeft    : () => {},\n    onSwipeRight   : () => {},\n    swipe          : false\n  };\n\n  state = {\n    outerWidth : 0,\n    innerWidth : 0,\n    dragging   : false,\n    deltaX     : 0,\n    deltaY     : 0\n  };\n\n  startCoordinate: {\n    x: number,\n    y: number\n  } = {\n    x : 0,\n    y : 0\n  };\n\n  calculateWidth() {\n    const firstChild: Element = this.refs[`child-${this.props.select}`] as any;\n    this.setState({\n      innerWidth : firstChild.clientWidth\n    });\n  }\n\n  onMouseDown(evt: MouseEvent) {\n    this.startCoordinate = {\n      x : evt.clientX,\n      y : evt.clientY\n    };\n    this.setState({\n      dragging   : true\n    });\n  }\n\n  onMouseMove(evt: MouseEvent) {\n    if (!this.state.dragging) {\n      return;\n    }\n    evt.preventDefault();\n    this.setState({\n      deltaX : evt.clientX - this.startCoordinate.x,\n      deltaY : evt.clientY - this.startCoordinate.y\n    });\n  }\n\n  onMouseUp(evt: MouseEvent) {\n    if (!this.state.dragging) {\n      return;\n    }\n    this.handleSwipe();\n  }\n\n  onMouseLeave(evt: MouseEvent) {\n    if (!this.state.dragging) {\n      return;\n    }\n    this.handleSwipe();\n  }\n\n  provideMouseEventHandlers() {\n    return this.props.swipe ? {\n      onMouseDown  : this.onMouseDown.bind(this),\n      onMouseMove  : this.onMouseMove.bind(this),\n      onMouseUp    : this.onMouseUp.bind(this),\n      onMouseLeave : this.onMouseLeave.bind(this)\n    } : null;\n  }\n\n  handleSwipe() {\n    const deltaAbsX = Math.abs(this.state.deltaX);\n    const threshold = this.state.innerWidth * DELTA_PERCENTAGE_SWIPE;\n\n    if (deltaAbsX > threshold) {\n\n      const direction = this.state.deltaX > -1 ? DIRECTION_RIGHT : DIRECTION_LEFT;\n\n      if (direction === DIRECTION_LEFT) {\n        this.props.onSwipeLeft(this.props.select + 1);\n      } else if (direction === DIRECTION_RIGHT) {\n        this.props.onSwipeRight(this.props.select - 1);\n      }\n\n    }\n\n    // reset\n    this.startCoordinate = {\n      x : 0,\n      y : 0\n    };\n    this.setState({\n      dragging : false,\n      deltaX   : 0,\n      deltaY   : 0\n    });\n  }\n\n  onResize = debounce((evt: Event) => {\n    this.calculateWidth();\n  }, DURATION_DEBOUNCE_RESIZE);\n\n  componentDidMount() {\n    this.calculateWidth();\n    window.addEventListener('resize', this.onResize);\n  }\n\n  componentWillReceiveProps(nextProps: CarouselNinjaContainerProps) {\n    if (this.props.onSelect) {\n      this.props.onSelect(nextProps.select, this.props.select);\n    }\n  }\n\n  shouldComponentUpdate(nextProps: CarouselNinjaContainerProps, nextState: CarouselNinjaContainerState) {\n    return false ||\n      nextProps.select !== this.props.select ||\n      nextProps.children !== this.props.children ||\n      nextState !== this.state\n    ;\n  }\n\n  componentWillUnmount() {\n    window.addEventListener('resize', this.onResize);\n  }\n\n  render() {\n    /**\n     * 選択された要素が見た目上の中央であるとして、その右側と左側にあるべき要素を分類する\n     *\n     * @example this.props.children = [0, 1, 2, 3, 4]\n     *          this.props.select   = 3\n     */\n    const children: React.ReactNode[] = (React.Children as any).toArray(this.props.children);\n    const halfSideSize = Math.floor(children.length / 2);\n\n    // [0, 1, 2, *3*, 4] => [0, 1, 2]\n    let leftward = children.slice(0, this.props.select);\n    // [0, 1, 2, *3*, 4] => [4]\n    let rightward = children.slice(this.props.select + 1, children.length);\n\n    // 片側にある過剰分の要素を、もう片側に移して結合する\n    if (leftward.length > halfSideSize) {\n      // right:[4] + left:[0](, [1, 2]) => left:[1, 2]/ center:[3] / right:[4, 0]\n      rightward = [].concat(rightward, leftward.splice(0, leftward.length - halfSideSize));\n    } else if (rightward.length > halfSideSize) {\n      // right:(2, 3, )[4] + left:[0] => left:[4, 0] / center:[1] / right:[2, 3]\n      leftward = [].concat(rightward.splice(halfSideSize), leftward);\n    }\n\n    return (\n        <div className={`CarouselNinjaContainer ${this.state.dragging ? 'CarouselNinjaContainer--dragging' : ''}`}\n             {...this.provideMouseEventHandlers()}>\n\n          {children.map((child: React.ReactNode, i: number) => {\n            const isCenter = (i === this.props.select);\n            let isLeftEdge = false;\n            let isRightEdge = false;\n\n            let arrangedPos: number;\n            let calcFunction: string;\n\n            // TODO multiple translateX で表現できないか？ calc() があると IE10, IE11 で transition されない\n            // TODO 50% のかわりに ラッパーのwidth / 2で実数計算するとか？\n            // 左側・右側・中央のいずれに属しているかで位置の指定を変更する\n            if ((arrangedPos = leftward.indexOf(child)) !== -1) {\n              // Leftward [0=1920, 1=1280, 2=640] 左側は配列の始点に向けてオフセットを大きくとる\n              let baseTranslateX = (leftward.length - arrangedPos) * this.state.innerWidth\n              calcFunction = `calc(50% - ${baseTranslateX - this.state.deltaX}px)`;\n              isLeftEdge = arrangedPos === 0;\n            } else if ((arrangedPos = rightward.indexOf(child)) !== -1) {\n              // Rightward [0=640, 1=1280, 2=1920] 右側は配列の終点に向けてオフセットを大きくとる\n              let baseTranslateX = (arrangedPos + 1) * this.state.innerWidth\n              calcFunction = `calc(50% + ${baseTranslateX + this.state.deltaX}px)`;\n              isRightEdge = arrangedPos === rightward.length - 1;\n            } else {\n              // Center\n              calcFunction = `calc(50% + ${0 + this.state.deltaX}px)`;\n            }\n\n            let className = 'CarouselNinjaContainer__pane';\n            className += isCenter    ? this.props.activeClass    : '';\n            className += isRightEdge ? this.props.rightEdgeClass : '';\n            className += isLeftEdge  ? this.props.leftEdgeClass  : '';\n\n            const style = {\n              left       : calcFunction,\n              marginLeft : `-${this.state.innerWidth / 2}px`\n            };\n\n            return <div ref={`child-${i}`}\n                        className={className}\n                        key={i}\n                        style={style}\n                        aria-hidden={isCenter ? 'false' : 'true'}>{child}</div>;\n          })}\n\n        </div>\n    );\n  }\n}\n","import * as React from 'react';\nimport ReactElement = __React.ReactElement;\n\ninterface CarouselSelectorProps extends React.Props<CarouselNinjaSelector> {\n  activeClass?: string;\n  select: number;\n  length: number;\n  onSelect?: (prevI: number, nextI: number) => void;\n  onClickSelector?: (selectI: number) => void;\n}\n\nexport default class CarouselNinjaSelector extends React.Component<CarouselSelectorProps, any> {\n\n  static defaultProps = {\n    activeClass     : ' is-active',\n    select          : 0,\n    length          : 0,\n    onSelect        : () => {},\n    onClickSelector : () => {},\n  };\n\n  componentWillReceiveProps(nextProps: CarouselSelectorProps) {\n    if (this.props.onSelect) {\n      this.props.onSelect(nextProps.select, this.props.select);\n    }\n  }\n\n  shouldComponentUpdate(nextProps: CarouselSelectorProps) {\n    return false ||\n      nextProps.select !== this.props.select ||\n      nextProps.children !== this.props.children\n    ;\n  }\n\n  renderFromChildren() {\n    return React.Children.map(this.props.children, (child: React.ReactNode, i: number) => {\n      const isSelectedChild = i === this.props.select;\n      let className = 'CarouselNinjaSelector__item';\n      className += isSelectedChild ? this.props.activeClass : '';\n      return (\n        <li className={className}\n            key={i}\n            onClick={this.props.onClickSelector.bind(this, i)}\n            aria-selected={isSelectedChild ? 'true' : 'false'}>\n          {child}\n        </li>\n      );\n    });\n  }\n\n  renderItemsBySelf() {\n    const children: ReactElement<any>[] = [], iz = this.props.length;\n    for (let i = 0; i < iz; i++) {\n      let isSelectedChild = i === this.props.select;\n      let className = 'CarouselNinjaSelector__item';\n      className += isSelectedChild ? this.props.activeClass : '';\n      children.push((\n        <li className={className}\n            key={i}\n            onClick={this.props.onClickSelector.bind(this, i)}\n            aria-selected={isSelectedChild ? 'true' : 'false'}>\n          <button tabIndex={-1} />\n        </li>\n      ))\n    }\n    return children\n  }\n\n  render() {\n    return (\n      <ul className=\"CarouselNinjaSelector\">\n        {React.Children.count(this.props.children) ? this.renderFromChildren() : this.renderItemsBySelf()}\n      </ul>\n    );\n  }\n}\n","/// <reference path=\"../typings/bundle.d.ts\" />\n\nimport * as React from 'react';\nimport * as ReactDOM from 'react-dom';\nimport * as throttle from 'throttleit';\nimport CarouselNinjaContainer from './CarouselNinjaContainer';\nimport CarouselNinjaSelector from './CarouselNinjaSelector';\n\nconst DURATION_THROTTLE_KEYUP = 150;\n\nconst KEYCODE_LEFT  = 37;\nconst KEYCODE_RIGHT = 39;\n\ninterface CarouselNinjaProps extends React.Props<CarouselNinja> {\n  className?: string;\n  activeClass?: string;\n  onSelect?: (prevI: number, nextI: number) => void;\n}\n\nclass CarouselNinja extends React.Component<CarouselNinjaProps, any> {\n\n  static defaultProps = {\n    className   : '',\n    activeClass : ' is-active',\n    onSelect    : () => {},\n  };\n\n  state = {\n    currentSelect : 2\n  };\n\n  updateSelect(select: number) {\n    const lastIndex = React.Children.count(this.props.children) - 1;\n    if (select < 0) {\n      this.setState({\n        currentSelect : lastIndex\n      });\n    } else if (select > lastIndex) {\n      this.setState({\n        currentSelect : 0\n      });\n    } else {\n      this.setState({\n        currentSelect : select\n      });\n    }\n  }\n\n  onKeyUp = throttle((e: KeyboardEvent) => {\n    switch(e.keyCode) {\n      case KEYCODE_LEFT:\n        this.updateSelect(this.state.currentSelect - 1);\n        break;\n      case KEYCODE_RIGHT:\n        this.updateSelect(this.state.currentSelect + 1);\n        break;\n    }\n  }, DURATION_THROTTLE_KEYUP);\n\n  onSelectChange(nextI: number, curtI: number) {\n    this.props.onSelect(nextI, curtI);\n  }\n\n  onClickSelector(selectI: number) {\n    this.updateSelect(selectI);\n  }\n\n  onSwipeLeft(nextI: number) {\n    this.updateSelect(nextI);\n  }\n\n  onSwipeRight(nextI: number) {\n    this.updateSelect(nextI);\n  }\n\n  render() {\n    // TODO [aria-controls]\n\n    return (\n      <div tabIndex={0} className={this.props.className} onKeyUp={this.onKeyUp.bind(this)}>\n        <CarouselNinjaContainer activeClass={this.props.activeClass}\n                                select={this.state.currentSelect}\n                                onSelect={this.onSelectChange.bind(this)}\n                                onSwipeLeft={this.onSwipeLeft.bind(this)}\n                                onSwipeRight={this.onSwipeRight.bind(this)}>\n          {this.props.children}\n        </CarouselNinjaContainer>\n\n        <CarouselNinjaSelector activeClass={this.props.activeClass}\n                               select={this.state.currentSelect}\n                               length={React.Children.count(this.props.children)}\n                               onSelect={this.onSelectChange.bind(this)}\n                               onClickSelector={this.onClickSelector.bind(this)} />\n      </div>\n    );\n  }\n}\n\nexport {\n  CarouselNinja,\n  CarouselNinjaContainer,\n  CarouselNinjaSelector\n};\n"]} |
@@ -9,3 +9,3 @@ /** | ||
* homepage: https://github.com/ahomu/react-carousel-ninja | ||
* version: 0.1.1 | ||
* version: 0.1.3 | ||
* | ||
@@ -36,2 +36,2 @@ * date-now: | ||
*/ | ||
!function t(e,n,o){function r(s,a){if(!n[s]){if(!e[s]){var c="function"==typeof require&&require;if(!a&&c)return c(s,!0);if(i)return i(s,!0);var l=new Error("Cannot find module '"+s+"'");throw l.code="MODULE_NOT_FOUND",l}var p=n[s]={exports:{}};e[s][0].call(p.exports,function(t){var n=e[s][1][t];return r(n?n:t)},p,p.exports,t,e,n,o)}return n[s].exports}for(var i="function"==typeof require&&require,s=0;s<o.length;s++)r(o[s]);return r}({1:[function(t,e){var n=t("date-now");e.exports=function(t,e,o){function r(){var p=n()-c;e>p&&p>0?i=setTimeout(r,e-p):(i=null,o||(l=t.apply(a,s),i||(a=s=null)))}var i,s,a,c,l;return null==e&&(e=100),function(){a=this,s=arguments,c=n();var p=o&&!i;return i||(i=setTimeout(r,e)),p&&(l=t.apply(a,s),a=s=null),l}}},{"date-now":2}],2:[function(t,e){function n(){return(new Date).getTime()}e.exports=Date.now||n},{}],3:[function(t,e){function n(t,e){function n(){s=0,a=+new Date,i=t.apply(o,r),o=null,r=null}var o,r,i,s,a=0;return function(){o=this,r=arguments;var t=new Date-a;return s||(t>=e?n():s=setTimeout(n,e-t)),i}}e.exports=n},{}],4:[function(t,e,n){"use strict";function o(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function r(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var i=t("react"),s=i,a=t("debounce"),c=a,l=300,p=.2,u=0,h=1,f=function(t){function e(){var n=this;o(this,e);for(var r=arguments.length,i=Array(r),s=0;r>s;s++)i[s]=arguments[s];t.call.apply(t,[this].concat(i)),this.state={outerWidth:0,innerWidth:0,dragging:!1,deltaX:0,deltaY:0},this.startCoordinate={x:0,y:0},this.onResize=c(function(){n.calculateWidth()},l)}return r(e,t),e.prototype.calculateWidth=function(){var t=this.refs["child-"+this.props.select];this.setState({innerWidth:t.clientWidth})},e.prototype.onMouseDown=function(t){this.startCoordinate={x:t.clientX,y:t.clientY},this.setState({dragging:!0})},e.prototype.onMouseMove=function(t){this.state.dragging&&(t.preventDefault(),this.setState({deltaX:t.clientX-this.startCoordinate.x,deltaY:t.clientY-this.startCoordinate.y}))},e.prototype.onMouseUp=function(){this.state.dragging&&this.handleSwipe()},e.prototype.onMouseLeave=function(){this.state.dragging&&this.handleSwipe()},e.prototype.handleSwipe=function(){var t=Math.abs(this.state.deltaX),e=this.state.innerWidth*p;if(t>e){var n=this.state.deltaX>-1?u:h;n===h?this.props.onSwipeLeft(this.props.select+1):n===u&&this.props.onSwipeRight(this.props.select-1)}this.startCoordinate={x:0,y:0},this.setState({dragging:!1,deltaX:0,deltaY:0})},e.prototype.componentDidMount=function(){this.calculateWidth(),window.addEventListener("resize",this.onResize)},e.prototype.componentWillReceiveProps=function(t){this.props.onSelect&&this.props.onSelect(t.select,this.props.select)},e.prototype.shouldComponentUpdate=function(t,e){return!1||t.select!==this.props.select||t.children!==this.props.children||e!==this.state},e.prototype.componentWillUnmount=function(){window.addEventListener("resize",this.onResize)},e.prototype.render=function(){var t=this,e=s.Children.toArray(this.props.children),n=Math.floor(e.length/2),o=e.slice(0,this.props.select),r=e.slice(this.props.select+1,e.length);return o.length>n?r=[].concat(r,o.splice(0,o.length-n)):r.length>n&&(o=[].concat(r.splice(n),o)),s.createElement("div",{className:"CarouselNinjaContainer "+(this.state.dragging?"CarouselNinjaContainer--dragging":""),onMouseDown:this.onMouseDown.bind(this),onMouseMove:this.onMouseMove.bind(this),onMouseUp:this.onMouseUp.bind(this),onMouseLeave:this.onMouseLeave.bind(this)},e.map(function(e,n){var i=n===t.props.select,a=!1,c=!1,l=void 0,p=void 0;if(-1!==(l=o.indexOf(e))){var u=(o.length-l)*t.state.innerWidth;p="calc(50% - "+(u-t.state.deltaX)+"px)",a=0===l}else if(-1!==(l=r.indexOf(e))){var u=(l+1)*t.state.innerWidth;p="calc(50% + "+(u+t.state.deltaX)+"px)",c=l===r.length-1}else p="calc(50% + "+(0+t.state.deltaX)+"px)";var h="CarouselNinjaContainer__pane";h+=i?t.props.activeClass:"",h+=c?t.props.rightEdgeClass:"",h+=a?t.props.leftEdgeClass:"";var f={left:p,marginLeft:"-"+t.state.innerWidth/2+"px"};return s.createElement("div",{ref:"child-"+n,className:h,key:n,style:f,"aria-hidden":i?"false":"true"},e)}))},e}(s.Component);n["default"]=f,f.defaultProps={activeClass:" is-active",rightEdgeClass:" is-right",leftEdgeClass:" is-left",select:0,onSelect:function(){},onSwipeLeft:function(){},onSwipeRight:function(){}}},{debounce:1,react:void 0}],5:[function(t,e,n){"use strict";function o(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function r(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var i=t("react"),s=i,a=function(t){function e(){o(this,e),t.apply(this,arguments)}return r(e,t),e.prototype.componentWillReceiveProps=function(t){this.props.onSelect&&this.props.onSelect(t.select,this.props.select)},e.prototype.shouldComponentUpdate=function(t){return!1||t.select!==this.props.select||t.children!==this.props.children},e.prototype.renderFromChildren=function(){var t=this;return s.Children.map(this.props.children,function(e,n){var o=n===t.props.select,r="CarouselNinjaSelector__item";return r+=o?t.props.activeClass:"",s.createElement("li",{className:r,key:n,onClick:t.props.onClickSelector.bind(t,n),"aria-selected":o?"true":"false"},e)})},e.prototype.renderItemsBySelf=function(){for(var t=[],e=this.props.length,n=0;e>n;n++){var o=n===this.props.select,r="CarouselNinjaSelector__item";r+=o?this.props.activeClass:"",t.push(s.createElement("li",{className:r,key:n,onClick:this.props.onClickSelector.bind(this,n),"aria-selected":o?"true":"false"},s.createElement("button",{tabIndex:-1})))}return t},e.prototype.render=function(){return s.createElement("ul",{className:"CarouselNinjaSelector"},s.Children.count(this.props.children)?this.renderFromChildren():this.renderItemsBySelf())},e}(s.Component);n["default"]=a,a.defaultProps={activeClass:" is-active",select:0,length:0,onSelect:function(){},onClickSelector:function(){}}},{react:void 0}],6:[function(t,e,n){"use strict";function o(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function r(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var i=t("react"),s=i,a=t("throttleit"),c=a,l=t("./CarouselNinjaContainer"),p=t("./CarouselNinjaSelector"),u=150,h=37,f=39,d=function(t){function e(){var n=this;o(this,e);for(var r=arguments.length,i=Array(r),s=0;r>s;s++)i[s]=arguments[s];t.call.apply(t,[this].concat(i)),this.state={currentSelect:2},this.onKeyUp=c(function(t){switch(t.keyCode){case h:n.updateSelect(n.state.currentSelect-1);break;case f:n.updateSelect(n.state.currentSelect+1)}},u)}return r(e,t),e.prototype.updateSelect=function(t){var e=s.Children.count(this.props.children)-1;this.setState(0>t?{currentSelect:e}:t>e?{currentSelect:0}:{currentSelect:t})},e.prototype.onSelectChange=function(t,e){this.props.onSelect(t,e)},e.prototype.onClickSelector=function(t){this.updateSelect(t)},e.prototype.onSwipeLeft=function(t){this.updateSelect(t)},e.prototype.onSwipeRight=function(t){this.updateSelect(t)},e.prototype.render=function(){return s.createElement("div",{tabIndex:0,className:this.props.className,onKeyUp:this.onKeyUp.bind(this)},s.createElement(l["default"],{activeClass:this.props.activeClass,select:this.state.currentSelect,onSelect:this.onSelectChange.bind(this),onSwipeLeft:this.onSwipeLeft.bind(this),onSwipeRight:this.onSwipeRight.bind(this)},this.props.children),s.createElement(p["default"],{activeClass:this.props.activeClass,select:this.state.currentSelect,length:s.Children.count(this.props.children),onSelect:this.onSelectChange.bind(this),onClickSelector:this.onClickSelector.bind(this)}))},e}(s.Component);d.defaultProps={className:"",activeClass:" is-active",onSelect:function(){}},n.CarouselNinja=d,n.CarouselNinjaContainer=l["default"],n.CarouselNinjaSelector=p["default"]},{"./CarouselNinjaContainer":4,"./CarouselNinjaSelector":5,react:void 0,throttleit:3}]},{},[6]); | ||
!function t(e,n,o){function r(s,a){if(!n[s]){if(!e[s]){var c="function"==typeof require&&require;if(!a&&c)return c(s,!0);if(i)return i(s,!0);var l=new Error("Cannot find module '"+s+"'");throw l.code="MODULE_NOT_FOUND",l}var p=n[s]={exports:{}};e[s][0].call(p.exports,function(t){var n=e[s][1][t];return r(n?n:t)},p,p.exports,t,e,n,o)}return n[s].exports}for(var i="function"==typeof require&&require,s=0;s<o.length;s++)r(o[s]);return r}({1:[function(t,e){var n=t("date-now");e.exports=function(t,e,o){function r(){var p=n()-c;e>p&&p>0?i=setTimeout(r,e-p):(i=null,o||(l=t.apply(a,s),i||(a=s=null)))}var i,s,a,c,l;return null==e&&(e=100),function(){a=this,s=arguments,c=n();var p=o&&!i;return i||(i=setTimeout(r,e)),p&&(l=t.apply(a,s),a=s=null),l}}},{"date-now":2}],2:[function(t,e){function n(){return(new Date).getTime()}e.exports=Date.now||n},{}],3:[function(t,e){function n(t,e){function n(){s=0,a=+new Date,i=t.apply(o,r),o=null,r=null}var o,r,i,s,a=0;return function(){o=this,r=arguments;var t=new Date-a;return s||(t>=e?n():s=setTimeout(n,e-t)),i}}e.exports=n},{}],4:[function(t,e,n){"use strict";function o(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function r(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var i=t("react"),s=i,a=t("debounce"),c=a,l=300,p=.2,u=0,h=1,f=function(t){function e(){var n=this;o(this,e);for(var r=arguments.length,i=Array(r),s=0;r>s;s++)i[s]=arguments[s];t.call.apply(t,[this].concat(i)),this.state={outerWidth:0,innerWidth:0,dragging:!1,deltaX:0,deltaY:0},this.startCoordinate={x:0,y:0},this.onResize=c(function(){n.calculateWidth()},l)}return r(e,t),e.prototype.calculateWidth=function(){var t=this.refs["child-"+this.props.select];this.setState({innerWidth:t.clientWidth})},e.prototype.onMouseDown=function(t){this.startCoordinate={x:t.clientX,y:t.clientY},this.setState({dragging:!0})},e.prototype.onMouseMove=function(t){this.state.dragging&&(t.preventDefault(),this.setState({deltaX:t.clientX-this.startCoordinate.x,deltaY:t.clientY-this.startCoordinate.y}))},e.prototype.onMouseUp=function(){this.state.dragging&&this.handleSwipe()},e.prototype.onMouseLeave=function(){this.state.dragging&&this.handleSwipe()},e.prototype.provideMouseEventHandlers=function(){return this.props.swipe?{onMouseDown:this.onMouseDown.bind(this),onMouseMove:this.onMouseMove.bind(this),onMouseUp:this.onMouseUp.bind(this),onMouseLeave:this.onMouseLeave.bind(this)}:null},e.prototype.handleSwipe=function(){var t=Math.abs(this.state.deltaX),e=this.state.innerWidth*p;if(t>e){var n=this.state.deltaX>-1?u:h;n===h?this.props.onSwipeLeft(this.props.select+1):n===u&&this.props.onSwipeRight(this.props.select-1)}this.startCoordinate={x:0,y:0},this.setState({dragging:!1,deltaX:0,deltaY:0})},e.prototype.componentDidMount=function(){this.calculateWidth(),window.addEventListener("resize",this.onResize)},e.prototype.componentWillReceiveProps=function(t){this.props.onSelect&&this.props.onSelect(t.select,this.props.select)},e.prototype.shouldComponentUpdate=function(t,e){return!1||t.select!==this.props.select||t.children!==this.props.children||e!==this.state},e.prototype.componentWillUnmount=function(){window.addEventListener("resize",this.onResize)},e.prototype.render=function(){var t=this,e=s.Children.toArray(this.props.children),n=Math.floor(e.length/2),o=e.slice(0,this.props.select),r=e.slice(this.props.select+1,e.length);return o.length>n?r=[].concat(r,o.splice(0,o.length-n)):r.length>n&&(o=[].concat(r.splice(n),o)),s.createElement("div",s.__spread({className:"CarouselNinjaContainer "+(this.state.dragging?"CarouselNinjaContainer--dragging":"")},this.provideMouseEventHandlers()),e.map(function(e,n){var i=n===t.props.select,a=!1,c=!1,l=void 0,p=void 0;if(-1!==(l=o.indexOf(e))){var u=(o.length-l)*t.state.innerWidth;p="calc(50% - "+(u-t.state.deltaX)+"px)",a=0===l}else if(-1!==(l=r.indexOf(e))){var u=(l+1)*t.state.innerWidth;p="calc(50% + "+(u+t.state.deltaX)+"px)",c=l===r.length-1}else p="calc(50% + "+(0+t.state.deltaX)+"px)";var h="CarouselNinjaContainer__pane";h+=i?t.props.activeClass:"",h+=c?t.props.rightEdgeClass:"",h+=a?t.props.leftEdgeClass:"";var f={left:p,marginLeft:"-"+t.state.innerWidth/2+"px"};return s.createElement("div",{ref:"child-"+n,className:h,key:n,style:f,"aria-hidden":i?"false":"true"},e)}))},e}(s.Component);n["default"]=f,f.defaultProps={activeClass:" is-active",rightEdgeClass:" is-right",leftEdgeClass:" is-left",select:0,onSelect:function(){},onSwipeLeft:function(){},onSwipeRight:function(){},swipe:!1}},{debounce:1,react:void 0}],5:[function(t,e,n){"use strict";function o(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function r(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var i=t("react"),s=i,a=function(t){function e(){o(this,e),t.apply(this,arguments)}return r(e,t),e.prototype.componentWillReceiveProps=function(t){this.props.onSelect&&this.props.onSelect(t.select,this.props.select)},e.prototype.shouldComponentUpdate=function(t){return!1||t.select!==this.props.select||t.children!==this.props.children},e.prototype.renderFromChildren=function(){var t=this;return s.Children.map(this.props.children,function(e,n){var o=n===t.props.select,r="CarouselNinjaSelector__item";return r+=o?t.props.activeClass:"",s.createElement("li",{className:r,key:n,onClick:t.props.onClickSelector.bind(t,n),"aria-selected":o?"true":"false"},e)})},e.prototype.renderItemsBySelf=function(){for(var t=[],e=this.props.length,n=0;e>n;n++){var o=n===this.props.select,r="CarouselNinjaSelector__item";r+=o?this.props.activeClass:"",t.push(s.createElement("li",{className:r,key:n,onClick:this.props.onClickSelector.bind(this,n),"aria-selected":o?"true":"false"},s.createElement("button",{tabIndex:-1})))}return t},e.prototype.render=function(){return s.createElement("ul",{className:"CarouselNinjaSelector"},s.Children.count(this.props.children)?this.renderFromChildren():this.renderItemsBySelf())},e}(s.Component);n["default"]=a,a.defaultProps={activeClass:" is-active",select:0,length:0,onSelect:function(){},onClickSelector:function(){}}},{react:void 0}],6:[function(t,e,n){"use strict";function o(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function r(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var i=t("react"),s=i,a=t("throttleit"),c=a,l=t("./CarouselNinjaContainer"),p=t("./CarouselNinjaSelector"),u=150,h=37,f=39,d=function(t){function e(){var n=this;o(this,e);for(var r=arguments.length,i=Array(r),s=0;r>s;s++)i[s]=arguments[s];t.call.apply(t,[this].concat(i)),this.state={currentSelect:2},this.onKeyUp=c(function(t){switch(t.keyCode){case h:n.updateSelect(n.state.currentSelect-1);break;case f:n.updateSelect(n.state.currentSelect+1)}},u)}return r(e,t),e.prototype.updateSelect=function(t){var e=s.Children.count(this.props.children)-1;this.setState(0>t?{currentSelect:e}:t>e?{currentSelect:0}:{currentSelect:t})},e.prototype.onSelectChange=function(t,e){this.props.onSelect(t,e)},e.prototype.onClickSelector=function(t){this.updateSelect(t)},e.prototype.onSwipeLeft=function(t){this.updateSelect(t)},e.prototype.onSwipeRight=function(t){this.updateSelect(t)},e.prototype.render=function(){return s.createElement("div",{tabIndex:0,className:this.props.className,onKeyUp:this.onKeyUp.bind(this)},s.createElement(l["default"],{activeClass:this.props.activeClass,select:this.state.currentSelect,onSelect:this.onSelectChange.bind(this),onSwipeLeft:this.onSwipeLeft.bind(this),onSwipeRight:this.onSwipeRight.bind(this)},this.props.children),s.createElement(p["default"],{activeClass:this.props.activeClass,select:this.state.currentSelect,length:s.Children.count(this.props.children),onSelect:this.onSelectChange.bind(this),onClickSelector:this.onClickSelector.bind(this)}))},e}(s.Component);d.defaultProps={className:"",activeClass:" is-active",onSelect:function(){}},n.CarouselNinja=d,n.CarouselNinjaContainer=l["default"],n.CarouselNinjaSelector=p["default"]},{"./CarouselNinjaContainer":4,"./CarouselNinjaSelector":5,react:void 0,throttleit:3}]},{},[6]); |
Sorry, the diff of this file is not supported yet
155053
0.67%2988
0.57%