react-float-anchor
Advanced tools
Comparing version 1.3.6 to 1.3.7
@@ -152,39 +152,36 @@ 'use strict'; | ||
if (float) { | ||
(function () { | ||
var shouldReposition = forceReposition; | ||
if (!_this3._portalEl) { | ||
(function () { | ||
shouldReposition = true; | ||
var el = (0, _reactDom.findDOMNode)(_this3); | ||
var portalEl = _this3._portalEl = document.createElement('div'); | ||
portalEl.style.zIndex = String(props.zIndex); | ||
portalEl.style.position = 'fixed'; | ||
var target = document.body || document.documentElement; | ||
if (!target) throw new Error('Could not find element to attach portal to'); | ||
target.appendChild(portalEl); | ||
portalEl.rfaAnchor = el; | ||
_this3._portalRemoval.take(1).onValue(function () { | ||
portalEl.rfaAnchor = undefined; | ||
_this3.portal = null; | ||
_reactDom2.default.unmountComponentAtNode(portalEl); | ||
portalEl.remove(); | ||
_this3._portalEl = null; | ||
}); | ||
_kefir2.default.merge([_kefir2.default.fromEvents(window, 'resize'), (0, _fromEventsWithOptions2.default)(window, 'scroll', { capture: true, passive: true }).filter(function (event) { | ||
return event.target.contains(el); | ||
})]).takeUntilBy(_this3._portalRemoval).onValue(function () { | ||
_this3.reposition(); | ||
}); | ||
})(); | ||
var shouldReposition = forceReposition; | ||
if (!this._portalEl) { | ||
shouldReposition = true; | ||
var el = (0, _reactDom.findDOMNode)(this); | ||
if (!el) throw new Error('ReactFloatAnchor missing element'); | ||
var portalEl = this._portalEl = document.createElement('div'); | ||
portalEl.style.zIndex = String(props.zIndex); | ||
portalEl.style.position = 'fixed'; | ||
var target = document.body || document.documentElement; | ||
if (!target) throw new Error('Could not find element to attach portal to'); | ||
target.appendChild(portalEl); | ||
portalEl.rfaAnchor = el; | ||
this._portalRemoval.take(1).onValue(function () { | ||
portalEl.rfaAnchor = undefined; | ||
_this3.portal = null; | ||
_reactDom2.default.unmountComponentAtNode(portalEl); | ||
portalEl.remove(); | ||
_this3._portalEl = null; | ||
}); | ||
_kefir2.default.merge([_kefir2.default.fromEvents(window, 'resize'), (0, _fromEventsWithOptions2.default)(window, 'scroll', { capture: true, passive: true }).filter(function (event) { | ||
return event.target.contains(el); | ||
})]).takeUntilBy(this._portalRemoval).onValue(function () { | ||
_this3.reposition(); | ||
}); | ||
} | ||
this._isRenderingFloat = true; | ||
this.portal = _reactDom2.default.unstable_renderSubtreeIntoContainer(this, float, this._portalEl, function () { | ||
_this3._isRenderingFloat = false; | ||
if (_this3._shouldRepositionOnFloatRender || shouldReposition) { | ||
_this3._shouldRepositionOnFloatRender = false; | ||
_this3.reposition(); | ||
} | ||
_this3._isRenderingFloat = true; | ||
_this3.portal = _reactDom2.default.unstable_renderSubtreeIntoContainer(_this3, float, _this3._portalEl, function () { | ||
_this3._isRenderingFloat = false; | ||
if (_this3._shouldRepositionOnFloatRender || shouldReposition) { | ||
_this3._shouldRepositionOnFloatRender = false; | ||
_this3.reposition(); | ||
} | ||
}); | ||
})(); | ||
}); | ||
} else { | ||
@@ -205,3 +202,5 @@ if (this._portalEl) { | ||
if (portalEl) { | ||
(0, _containByScreen2.default)(portalEl, (0, _reactDom.findDOMNode)(this), this.props.options || {}); | ||
var el = (0, _reactDom.findDOMNode)(this); | ||
if (!(el instanceof HTMLElement)) throw new Error('ReactFloatAnchor missing element'); | ||
(0, _containByScreen2.default)(portalEl, el, this.props.options || {}); | ||
this._repositionEvents.emit(null); | ||
@@ -257,2 +256,2 @@ } | ||
module.exports = exports['default']; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/index.js"],"names":["requestAnimationFrame","global","setTimeout","cb","FloatAnchor","_isRenderingFloat","_shouldRepositionOnFloatRender","_portalRemoval","_unmount","_repositionEvents","portal","floatanchor","repositionEvents","context","_updateFloat","props","parentCtx","_parentCtx","takeUntilBy","onValue","reposition","plug","newProps","forceReposition","options","float","zIndex","prevProps","_portalEl","anchor","rfaAnchor","emit","end","shouldReposition","el","portalEl","document","createElement","style","String","position","target","body","documentElement","Error","appendChild","take","undefined","unmountComponentAtNode","remove","merge","fromEvents","window","capture","passive","filter","event","contains","unstable_renderSubtreeIntoContainer","node","parentNode","Component","propTypes","object","element","isRequired","childContextTypes","PropTypes","contextTypes"],"mappings":"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","file":"index.js","sourcesContent":["/* @flow */\n\nimport fromEventsWithOptions from './lib/fromEventsWithOptions';\nimport Kefir from 'kefir';\nimport kefirBus from 'kefir-bus';\nimport type {Bus} from 'kefir-bus';\nimport React, {PropTypes} from 'react';\nimport ReactDOM, {findDOMNode} from 'react-dom';\nimport containByScreen from 'contain-by-screen';\nimport type {Options} from 'contain-by-screen';\nimport isEqual from 'lodash/isEqual';\n\nconst requestAnimationFrame = global.requestAnimationFrame || (cb => setTimeout(cb, 0));\n\nexport type FloatAnchorContext = {\n  repositionEvents: Object;\n};\n\nexport type {Options} from 'contain-by-screen';\n\ntype Props = {\n  anchor: React.Element<any>;\n  float?: ?React.Element<any>;\n  options?: ?Options;\n  zIndex?: ?number|string;\n};\nexport default class FloatAnchor extends React.Component {\n  props: Props;\n  static propTypes = {\n    options: PropTypes.object,\n    anchor: PropTypes.element.isRequired,\n    float: PropTypes.element\n  };\n\n  _portalEl: ?HTMLElement;\n  _isRenderingFloat: boolean = false;\n  _shouldRepositionOnFloatRender: boolean = false;\n  _portalRemoval: Bus<null> = kefirBus();\n  _unmount: Bus<null> = kefirBus();\n  _repositionEvents: Bus<null> = kefirBus();\n\n  // The floated component. Exposed for test purposes.\n  portal: ?React.Component<any,any,any> = null;\n\n  // Context is used so that when a FloatAnchor has reposition() called on it,\n  // all of its descendant FloatAnchor elements reposition too.\n  static childContextTypes = {\n    floatanchor: React.PropTypes.object\n  };\n  static contextTypes = {\n    floatanchor: React.PropTypes.object\n  };\n  getChildContext(): Object {\n    const floatanchor: FloatAnchorContext = {\n      repositionEvents: this._repositionEvents\n    };\n    return {floatanchor};\n  }\n\n  _parentCtx(): ?FloatAnchorContext {\n    return this.context.floatanchor;\n  }\n\n  static *parentNodes(node: Node) {\n    do {\n      yield (node: Node);\n    } while ((node = (node: any).rfaAnchor || (node: any).parentNode));\n  }\n\n  componentDidMount() {\n    this._updateFloat(this.props);\n    const parentCtx = this._parentCtx();\n    if (parentCtx) {\n      parentCtx.repositionEvents\n        .takeUntilBy(this._unmount)\n        .onValue(() => this.reposition());\n      this._repositionEvents.plug(parentCtx.repositionEvents);\n    }\n    // We need to reposition after the page has had its layout done.\n    requestAnimationFrame(() => {\n      this.reposition();\n    });\n  }\n\n  componentWillReceiveProps(newProps: Props) {\n    let forceReposition = !isEqual(newProps.options, this.props.options);\n    if (\n      forceReposition ||\n      newProps.float !== this.props.float ||\n      newProps.zIndex !== this.props.zIndex\n    ) {\n      this._updateFloat(newProps, forceReposition);\n    }\n  }\n\n  componentDidUpdate(prevProps: Props) {\n    if (this._portalEl && prevProps.anchor !== this.props.anchor) {\n      (this._portalEl: any).rfaAnchor = findDOMNode(this);\n    }\n  }\n\n  componentWillUnmount() {\n    this._portalRemoval.emit(null);\n    this._unmount.emit(null);\n    this._repositionEvents.end();\n  }\n\n  _updateFloat(props: Props, forceReposition: boolean=false) {\n    const {float} = props;\n\n    if (float) {\n      let shouldReposition = forceReposition;\n      if (!this._portalEl) {\n        shouldReposition = true;\n        const el = findDOMNode(this);\n        const portalEl = this._portalEl = document.createElement('div');\n        portalEl.style.zIndex = String(props.zIndex);\n        portalEl.style.position = 'fixed';\n        const target = document.body || document.documentElement;\n        if (!target) throw new Error('Could not find element to attach portal to');\n        target.appendChild(portalEl);\n        (portalEl: any).rfaAnchor = el;\n        this._portalRemoval.take(1).onValue(() => {\n          (portalEl: any).rfaAnchor = undefined;\n          this.portal = null;\n          ReactDOM.unmountComponentAtNode(portalEl);\n          portalEl.remove();\n          this._portalEl = null;\n        });\n        Kefir.merge([\n          Kefir.fromEvents(window, 'resize'),\n          fromEventsWithOptions(window, 'scroll', {capture: true, passive: true})\n            .filter(event => event.target.contains(el))\n        ])\n          .takeUntilBy(this._portalRemoval)\n          .onValue(() => {\n            this.reposition();\n          });\n      }\n\n      this._isRenderingFloat = true;\n      this.portal = (ReactDOM:any).unstable_renderSubtreeIntoContainer(\n        this,\n        float,\n        this._portalEl,\n        () => {\n          this._isRenderingFloat = false;\n          if (this._shouldRepositionOnFloatRender || shouldReposition) {\n            this._shouldRepositionOnFloatRender = false;\n            this.reposition();\n          }\n        }\n      );\n    } else {\n      if (this._portalEl) {\n        this._portalRemoval.emit(null);\n      }\n    }\n  }\n\n  reposition() {\n    if (this._isRenderingFloat) {\n      this._shouldRepositionOnFloatRender = true;\n      return;\n    }\n    const portalEl = this._portalEl;\n    if (portalEl) {\n      containByScreen(portalEl, findDOMNode(this), this.props.options || {});\n      this._repositionEvents.emit(null);\n    }\n  }\n\n  render() {\n    const {anchor} = this.props;\n    return anchor;\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":["requestAnimationFrame","global","setTimeout","cb","FloatAnchor","_isRenderingFloat","_shouldRepositionOnFloatRender","_portalRemoval","_unmount","_repositionEvents","portal","floatanchor","repositionEvents","context","_updateFloat","props","parentCtx","_parentCtx","takeUntilBy","onValue","reposition","plug","newProps","forceReposition","options","float","zIndex","prevProps","_portalEl","anchor","rfaAnchor","emit","end","shouldReposition","el","Error","portalEl","document","createElement","style","String","position","target","body","documentElement","appendChild","take","undefined","unmountComponentAtNode","remove","merge","fromEvents","window","capture","passive","filter","event","contains","unstable_renderSubtreeIntoContainer","HTMLElement","node","parentNode","Component","propTypes","object","element","isRequired","childContextTypes","PropTypes","contextTypes"],"mappings":"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","file":"index.js","sourcesContent":["/* @flow */\n\nimport fromEventsWithOptions from './lib/fromEventsWithOptions';\nimport Kefir from 'kefir';\nimport kefirBus from 'kefir-bus';\nimport type {Bus} from 'kefir-bus';\nimport React, {PropTypes} from 'react';\nimport ReactDOM, {findDOMNode} from 'react-dom';\nimport containByScreen from 'contain-by-screen';\nimport type {Options} from 'contain-by-screen';\nimport isEqual from 'lodash/isEqual';\n\nconst requestAnimationFrame = global.requestAnimationFrame || (cb => setTimeout(cb, 0));\n\nexport type FloatAnchorContext = {\n  repositionEvents: Object;\n};\n\nexport type {Options} from 'contain-by-screen';\n\ntype Props = {\n  anchor: React.Element<any>;\n  float?: ?React.Element<any>;\n  options?: ?Options;\n  zIndex?: ?number|string;\n};\nexport default class FloatAnchor extends React.Component {\n  props: Props;\n  static propTypes = {\n    options: PropTypes.object,\n    anchor: PropTypes.element.isRequired,\n    float: PropTypes.element\n  };\n\n  _portalEl: ?HTMLElement;\n  _isRenderingFloat: boolean = false;\n  _shouldRepositionOnFloatRender: boolean = false;\n  _portalRemoval: Bus<null> = kefirBus();\n  _unmount: Bus<null> = kefirBus();\n  _repositionEvents: Bus<null> = kefirBus();\n\n  // The floated component. Exposed for test purposes.\n  portal: ?React.Component<any,any,any> = null;\n\n  // Context is used so that when a FloatAnchor has reposition() called on it,\n  // all of its descendant FloatAnchor elements reposition too.\n  static childContextTypes = {\n    floatanchor: React.PropTypes.object\n  };\n  static contextTypes = {\n    floatanchor: React.PropTypes.object\n  };\n  getChildContext(): Object {\n    const floatanchor: FloatAnchorContext = {\n      repositionEvents: this._repositionEvents\n    };\n    return {floatanchor};\n  }\n\n  _parentCtx(): ?FloatAnchorContext {\n    return this.context.floatanchor;\n  }\n\n  static *parentNodes(node: Node) {\n    do {\n      yield (node: Node);\n    } while ((node = (node: any).rfaAnchor || (node: any).parentNode));\n  }\n\n  componentDidMount() {\n    this._updateFloat(this.props);\n    const parentCtx = this._parentCtx();\n    if (parentCtx) {\n      parentCtx.repositionEvents\n        .takeUntilBy(this._unmount)\n        .onValue(() => this.reposition());\n      this._repositionEvents.plug(parentCtx.repositionEvents);\n    }\n    // We need to reposition after the page has had its layout done.\n    requestAnimationFrame(() => {\n      this.reposition();\n    });\n  }\n\n  componentWillReceiveProps(newProps: Props) {\n    let forceReposition = !isEqual(newProps.options, this.props.options);\n    if (\n      forceReposition ||\n      newProps.float !== this.props.float ||\n      newProps.zIndex !== this.props.zIndex\n    ) {\n      this._updateFloat(newProps, forceReposition);\n    }\n  }\n\n  componentDidUpdate(prevProps: Props) {\n    if (this._portalEl && prevProps.anchor !== this.props.anchor) {\n      (this._portalEl: any).rfaAnchor = findDOMNode(this);\n    }\n  }\n\n  componentWillUnmount() {\n    this._portalRemoval.emit(null);\n    this._unmount.emit(null);\n    this._repositionEvents.end();\n  }\n\n  _updateFloat(props: Props, forceReposition: boolean=false) {\n    const {float} = props;\n\n    if (float) {\n      let shouldReposition = forceReposition;\n      if (!this._portalEl) {\n        shouldReposition = true;\n        const el = findDOMNode(this);\n        if (!el) throw new Error('ReactFloatAnchor missing element');\n        const portalEl = this._portalEl = document.createElement('div');\n        portalEl.style.zIndex = String(props.zIndex);\n        portalEl.style.position = 'fixed';\n        const target = document.body || document.documentElement;\n        if (!target) throw new Error('Could not find element to attach portal to');\n        target.appendChild(portalEl);\n        (portalEl: any).rfaAnchor = el;\n        this._portalRemoval.take(1).onValue(() => {\n          (portalEl: any).rfaAnchor = undefined;\n          this.portal = null;\n          ReactDOM.unmountComponentAtNode(portalEl);\n          portalEl.remove();\n          this._portalEl = null;\n        });\n        Kefir.merge([\n          Kefir.fromEvents(window, 'resize'),\n          fromEventsWithOptions(window, 'scroll', {capture: true, passive: true})\n            .filter(event => event.target.contains(el))\n        ])\n          .takeUntilBy(this._portalRemoval)\n          .onValue(() => {\n            this.reposition();\n          });\n      }\n\n      this._isRenderingFloat = true;\n      this.portal = (ReactDOM:any).unstable_renderSubtreeIntoContainer(\n        this,\n        float,\n        this._portalEl,\n        () => {\n          this._isRenderingFloat = false;\n          if (this._shouldRepositionOnFloatRender || shouldReposition) {\n            this._shouldRepositionOnFloatRender = false;\n            this.reposition();\n          }\n        }\n      );\n    } else {\n      if (this._portalEl) {\n        this._portalRemoval.emit(null);\n      }\n    }\n  }\n\n  reposition() {\n    if (this._isRenderingFloat) {\n      this._shouldRepositionOnFloatRender = true;\n      return;\n    }\n    const portalEl = this._portalEl;\n    if (portalEl) {\n      const el = findDOMNode(this);\n      if (!(el instanceof HTMLElement)) throw new Error('ReactFloatAnchor missing element');\n      containByScreen(portalEl, el, this.props.options || {});\n      this._repositionEvents.emit(null);\n    }\n  }\n\n  render() {\n    const {anchor} = this.props;\n    return anchor;\n  }\n}\n"]} |
@@ -25,2 +25,2 @@ 'use strict'; | ||
module.exports = exports['default']; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvZnJvbUV2ZW50c1dpdGhPcHRpb25zLmpzIl0sIm5hbWVzIjpbImZyb21FdmVudHNXaXRoT3B0aW9ucyIsInRhcmdldCIsImV2ZW50TmFtZSIsIm9wdGlvbnMiLCJzdHJlYW0iLCJlbWl0dGVyIiwiZW1pdCJdLCJtYXBwaW5ncyI6Ijs7Ozs7a0JBT3dCQSxxQjs7QUFMeEI7Ozs7QUFHQTs7OztBQUVlLFNBQVNBLHFCQUFULENBQStCQyxNQUEvQixFQUFvREMsU0FBcEQsRUFBdUVDLE9BQXZFLEVBQTJIO0FBQ3hJLFNBQU8sZ0JBQU1DLE1BQU4sQ0FBYSxtQkFBVztBQUM3QixvREFBaUJILE1BQWpCLEVBQXlCQyxTQUF6QixFQUFvQ0csUUFBUUMsSUFBNUMsRUFBa0RILE9BQWxEO0FBQ0EsV0FBTyxZQUFNO0FBQ1gseURBQW9CRixNQUFwQixFQUE0QkMsU0FBNUIsRUFBdUNHLFFBQVFDLElBQS9DLEVBQXFESCxPQUFyRDtBQUNELEtBRkQ7QUFHRCxHQUxNLENBQVA7QUFNRCIsImZpbGUiOiJmcm9tRXZlbnRzV2l0aE9wdGlvbnMuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAZmxvdyAqL1xuXG5pbXBvcnQgS2VmaXIgZnJvbSAna2VmaXInO1xuXG5pbXBvcnQgdHlwZSB7T3B0aW9uc30gZnJvbSAnZXZlbnQtbGlzdGVuZXItd2l0aC1vcHRpb25zJztcbmltcG9ydCB7YWRkRXZlbnRMaXN0ZW5lciwgcmVtb3ZlRXZlbnRMaXN0ZW5lcn0gZnJvbSAnZXZlbnQtbGlzdGVuZXItd2l0aC1vcHRpb25zJztcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gZnJvbUV2ZW50c1dpdGhPcHRpb25zKHRhcmdldDogRXZlbnRUYXJnZXQsIGV2ZW50TmFtZTogc3RyaW5nLCBvcHRpb25zOiBPcHRpb25zfGJvb2xlYW4pOiBLZWZpci5PYnNlcnZhYmxlPE9iamVjdD4ge1xuICByZXR1cm4gS2VmaXIuc3RyZWFtKGVtaXR0ZXIgPT4ge1xuICAgIGFkZEV2ZW50TGlzdGVuZXIodGFyZ2V0LCBldmVudE5hbWUsIGVtaXR0ZXIuZW1pdCwgb3B0aW9ucyk7XG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIHJlbW92ZUV2ZW50TGlzdGVuZXIodGFyZ2V0LCBldmVudE5hbWUsIGVtaXR0ZXIuZW1pdCwgb3B0aW9ucyk7XG4gICAgfTtcbiAgfSk7XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvZnJvbUV2ZW50c1dpdGhPcHRpb25zLmpzIl0sIm5hbWVzIjpbImZyb21FdmVudHNXaXRoT3B0aW9ucyIsInRhcmdldCIsImV2ZW50TmFtZSIsIm9wdGlvbnMiLCJzdHJlYW0iLCJlbWl0dGVyIiwiZW1pdCJdLCJtYXBwaW5ncyI6Ijs7Ozs7a0JBT3dCQSxxQjs7QUFMeEI7Ozs7QUFHQTs7OztBQUVlLFNBQVNBLHFCQUFULENBQStCQyxNQUEvQixFQUFvREMsU0FBcEQsRUFBdUVDLE9BQXZFLEVBQTJIO0FBQ3hJLFNBQU8sZ0JBQU1DLE1BQU4sQ0FBYSxtQkFBVztBQUM3QixvREFBaUJILE1BQWpCLEVBQXlCQyxTQUF6QixFQUFvQ0csUUFBUUMsSUFBNUMsRUFBa0RILE9BQWxEO0FBQ0EsV0FBTyxZQUFNO0FBQ1gseURBQW9CRixNQUFwQixFQUE0QkMsU0FBNUIsRUFBdUNHLFFBQVFDLElBQS9DLEVBQXFESCxPQUFyRDtBQUNELEtBRkQ7QUFHRCxHQUxNLENBQVA7QUFNRCIsImZpbGUiOiJmcm9tRXZlbnRzV2l0aE9wdGlvbnMuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAZmxvdyAqL1xuXG5pbXBvcnQgS2VmaXIgZnJvbSAna2VmaXInO1xuXG5pbXBvcnQgdHlwZSB7T3B0aW9uc30gZnJvbSAnZXZlbnQtbGlzdGVuZXItd2l0aC1vcHRpb25zJztcbmltcG9ydCB7YWRkRXZlbnRMaXN0ZW5lciwgcmVtb3ZlRXZlbnRMaXN0ZW5lcn0gZnJvbSAnZXZlbnQtbGlzdGVuZXItd2l0aC1vcHRpb25zJztcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gZnJvbUV2ZW50c1dpdGhPcHRpb25zKHRhcmdldDogRXZlbnRUYXJnZXQsIGV2ZW50TmFtZTogc3RyaW5nLCBvcHRpb25zOiBPcHRpb25zfGJvb2xlYW4pOiBLZWZpci5PYnNlcnZhYmxlPE9iamVjdD4ge1xuICByZXR1cm4gS2VmaXIuc3RyZWFtKGVtaXR0ZXIgPT4ge1xuICAgIGFkZEV2ZW50TGlzdGVuZXIodGFyZ2V0LCBldmVudE5hbWUsIGVtaXR0ZXIuZW1pdCwgb3B0aW9ucyk7XG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIHJlbW92ZUV2ZW50TGlzdGVuZXIodGFyZ2V0LCBldmVudE5hbWUsIGVtaXR0ZXIuZW1pdCwgb3B0aW9ucyk7XG4gICAgfTtcbiAgfSk7XG59XG4iXX0= |
{ | ||
"name": "react-float-anchor", | ||
"version": "1.3.6", | ||
"version": "1.3.7", | ||
"description": "React component for positioning an element aligned to another", | ||
@@ -43,7 +43,7 @@ "main": "js/index.js", | ||
"babelify": "^7.2.0", | ||
"browserify": "^13.0.0", | ||
"browserify": "^14.1.0", | ||
"browserify-hmr": "^0.3.1", | ||
"eslint": "^3.4.0", | ||
"eslint-plugin-react": "^6.2.0", | ||
"flow-bin": "^0.38.0", | ||
"flow-bin": "^0.41.0", | ||
"flow-copy-source": "^1.0.1", | ||
@@ -56,3 +56,3 @@ "jsdom": "^9.4.2", | ||
"sinon": "^1.17.3", | ||
"watchify": "^3.7.0" | ||
"watchify": "^3.9.0" | ||
}, | ||
@@ -59,0 +59,0 @@ "dependencies": { |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
38198
231