/* react-onsenui v1.13.3 - 2023-06-20 */

(function (global, factory) {
  typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('onsenui'), require('prop-types'), require('onsenui/esm/elements/ons-action-sheet'), require('react'), require('react-dom'), require('onsenui/esm/elements/ons-action-sheet-button'), require('onsenui/esm/elements/ons-alert-dialog'), require('onsenui/esm/elements/ons-alert-dialog-button'), require('onsenui/esm/elements/ons-back-button'), require('onsenui/esm/elements/ons-bottom-toolbar'), require('onsenui/esm/elements/ons-button'), require('onsenui/esm/elements/ons-card'), require('onsenui/esm/elements/ons-carousel'), require('onsenui/esm/elements/ons-carousel-item'), require('onsenui/esm/elements/ons-checkbox'), require('onsenui/esm/elements/ons-col'), require('onsenui/esm/elements/ons-dialog'), require('onsenui/esm/elements/ons-fab'), require('onsenui/esm/elements/ons-gesture-detector'), require('onsenui/esm/elements/ons-icon'), require('onsenui/esm/elements/ons-input'), require('onsenui/esm/elements/ons-lazy-repeat'), require('onsenui/esm/elements/ons-list'), require('onsenui/esm/elements/ons-list-header'), require('onsenui/esm/elements/ons-list-item'), require('onsenui/esm/elements/ons-list-title'), require('onsenui/esm/elements/ons-navigator'), require('onsenui/esm/elements/ons-modal'), require('onsenui/esm/elements/ons-page'), require('onsenui/esm/elements/ons-popover'), require('onsenui/esm/elements/ons-progress-bar'), require('onsenui/esm/elements/ons-progress-circular'), require('onsenui/esm/elements/ons-pull-hook'), require('onsenui/esm/elements/ons-radio'), require('onsenui/esm/elements/ons-range'), require('onsenui/esm/elements/ons-ripple'), require('onsenui/esm/elements/ons-row'), require('onsenui/esm/elements/ons-search-input'), require('onsenui/esm/elements/ons-segment'), require('onsenui/esm/elements/ons-select'), require('onsenui/esm/elements/ons-speed-dial'), require('onsenui/esm/elements/ons-speed-dial-item'), require('onsenui/esm/elements/ons-splitter'), require('onsenui/esm/elements/ons-splitter-content'), require('onsenui/esm/elements/ons-splitter-mask'), require('onsenui/esm/elements/ons-splitter-side'), require('onsenui/esm/elements/ons-switch'), require('onsenui/esm/elements/ons-tab'), require('onsenui/esm/elements/ons-tabbar'), require('onsenui/esm/elements/ons-toast'), require('onsenui/esm/elements/ons-toolbar'), require('onsenui/esm/elements/ons-toolbar-button')) :
  typeof define === 'function' && define.amd ? define(['exports', 'onsenui', 'prop-types', 'onsenui/esm/elements/ons-action-sheet', 'react', 'react-dom', 'onsenui/esm/elements/ons-action-sheet-button', 'onsenui/esm/elements/ons-alert-dialog', 'onsenui/esm/elements/ons-alert-dialog-button', 'onsenui/esm/elements/ons-back-button', 'onsenui/esm/elements/ons-bottom-toolbar', 'onsenui/esm/elements/ons-button', 'onsenui/esm/elements/ons-card', 'onsenui/esm/elements/ons-carousel', 'onsenui/esm/elements/ons-carousel-item', 'onsenui/esm/elements/ons-checkbox', 'onsenui/esm/elements/ons-col', 'onsenui/esm/elements/ons-dialog', 'onsenui/esm/elements/ons-fab', 'onsenui/esm/elements/ons-gesture-detector', 'onsenui/esm/elements/ons-icon', 'onsenui/esm/elements/ons-input', 'onsenui/esm/elements/ons-lazy-repeat', 'onsenui/esm/elements/ons-list', 'onsenui/esm/elements/ons-list-header', 'onsenui/esm/elements/ons-list-item', 'onsenui/esm/elements/ons-list-title', 'onsenui/esm/elements/ons-navigator', 'onsenui/esm/elements/ons-modal', 'onsenui/esm/elements/ons-page', 'onsenui/esm/elements/ons-popover', 'onsenui/esm/elements/ons-progress-bar', 'onsenui/esm/elements/ons-progress-circular', 'onsenui/esm/elements/ons-pull-hook', 'onsenui/esm/elements/ons-radio', 'onsenui/esm/elements/ons-range', 'onsenui/esm/elements/ons-ripple', 'onsenui/esm/elements/ons-row', 'onsenui/esm/elements/ons-search-input', 'onsenui/esm/elements/ons-segment', 'onsenui/esm/elements/ons-select', 'onsenui/esm/elements/ons-speed-dial', 'onsenui/esm/elements/ons-speed-dial-item', 'onsenui/esm/elements/ons-splitter', 'onsenui/esm/elements/ons-splitter-content', 'onsenui/esm/elements/ons-splitter-mask', 'onsenui/esm/elements/ons-splitter-side', 'onsenui/esm/elements/ons-switch', 'onsenui/esm/elements/ons-tab', 'onsenui/esm/elements/ons-tabbar', 'onsenui/esm/elements/ons-toast', 'onsenui/esm/elements/ons-toolbar', 'onsenui/esm/elements/ons-toolbar-button'], factory) :
  (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.Ons = {}, global.ons, global.PropTypes, global.ons.elements.ActionSheet, global.React, global.ReactDOM));
})(this, (function (exports, onsenui, PropTypes, onsActionSheet, React, ReactDOM) { 'use strict';

  function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }

  var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
  var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
  var ReactDOM__default = /*#__PURE__*/_interopDefaultLegacy(ReactDOM);

  function _extends() {
    _extends = Object.assign ? Object.assign.bind() : 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;
    };
    return _extends.apply(this, arguments);
  }

  const kebabize = camelString => camelString.replace(/([a-zA-Z])([A-Z])/g, '$1-$2').toLowerCase();
  const addDeprecated = (props, deprecated) => {
    const propsCopy = {
      ...props
    };
    const nameMap = {
      className: 'class',
      ...deprecated
    };

    // eslint-disable-next-line no-unused-vars
    for (const [oldName, newName] of Object.entries(nameMap)) {
      if (propsCopy[newName] === undefined && propsCopy[oldName] !== undefined) {
        propsCopy[newName] = propsCopy[oldName];
        delete propsCopy[oldName];
      }
    }
    return propsCopy;
  };
  function useCustomElementListener(ref, prop, handler) {
    const event = prop.slice(2).toLowerCase();
    React.useEffect(() => {
      const current = ref.current;
      current.addEventListener(event, handler);
      return function cleanup() {
        current.removeEventListener(event, handler);
      };
    }, [ref, handler]);
  }
  function useCustomElement(props) {
    let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
    let ref = arguments.length > 2 ? arguments[2] : undefined;
    const notAttributes = options.notAttributes || [];
    const deprecated = options.deprecated || {};
    const properties = {};
    // eslint-disable-next-line no-unused-vars
    for (const [prop, value] of Object.entries(addDeprecated(props, deprecated))) {
      const jsName = kebabize(prop);
      if (notAttributes.includes(prop)) {
        React.useEffect(() => {
          ref.current[prop] = value;
        });
      } else if (/^on[A-Z]/.test(prop)) {
        useCustomElementListener(ref, prop, value);
      } else if (typeof value === 'boolean') {
        properties[jsName] = value ? '' : null;
      } else if (typeof value === 'object' && value !== null) {
        properties[jsName] = JSON.stringify(value);
      } else {
        properties[jsName] = value;
      }
    }
    return {
      properties
    };
  }
  function onsCustomElement(WrappedComponent, options) {
    return /*#__PURE__*/React__default["default"].forwardRef((props, _ref) => {
      const ref = _ref || React.useRef();
      const {
        style,
        children,
        ...rest
      } = props;
      const {
        properties
      } = useCustomElement(rest, options, ref);
      return /*#__PURE__*/React__default["default"].createElement(WrappedComponent, _extends({
        ref: ref,
        style: style
      }, properties), children);
    });
  }

  class Portal extends React__default["default"].Component {
    constructor(props) {
      super(props);
      this.container = document.createElement('div');
    }
    componentDidMount() {
      document.body.appendChild(this.container);
    }
    componentWillUnmount() {
      document.body.removeChild(this.container);
    }
    render() {
      return /*#__PURE__*/ReactDOM__default["default"].createPortal(this.props.children, this.container);
    }
  }
  const baseDialog = DialogComponent => /*#__PURE__*/React__default["default"].forwardRef((props, ref) => {
    // visible prop should be applied last since it depends on animation and
    // maskColor props being set first
    const {
      visible,
      ...rest
    } = props;
    return /*#__PURE__*/React__default["default"].createElement(Portal, null, /*#__PURE__*/React__default["default"].createElement(DialogComponent, _extends({}, rest, {
      visible: visible,
      ref: ref
    }), props.children));
  });

  const propTypes$7 = {
    /**
     * @name title
     * @type string
     * @required false
     * @description
     *  [en]
     *  Optional title of the action sheet. A new element will be created containing this string.
     *  [/en]
     *  [ja][/ja]
     */
    title: PropTypes__default["default"].string,
    /**
     * @name onDialogCancel
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called only if cancelable is true. It will be called after tapping the background or by pressing the back button on Android devices.
     *  [/en]
     *  [ja][/ja]
     */
    onDialogCancel: PropTypes__default["default"].func,
    /**
     * @name visible
     * @type bool
     * @description
     *  [en]
     *  Indicates whether the dialog is open and shown.
     *  [/en]
     *  [ja][/ja]
     */
    visible: PropTypes__default["default"].bool,
    /**
     * @name cancelable
     * @type bool
     * @required false
     * @description
     *  [en]
     *  Specifies whether the dialog is cancelable or not.
     *  A cancelable dialog will call onCancel  when tapping the background or or  pressing the back button on Android devices
     *  [/en]
     *  [ja][/ja]
     */
    cancelable: PropTypes__default["default"].bool,
    /**
     * @name disabled
     * @type bool
     * @required false
     * @description
     *  [en]
     *  Specifies whether the dialog is disabled.
     *  [/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name onCancel
     * @type function
     * @required false
     * @description
     *  [en]
     *  DEPRECATED! Use `onDialogCancel` instead.
     *  [/en]
     *  [ja][/ja]
     */
    onCancel: PropTypes__default["default"].func,
    /**
     * @name isOpen
     * @type bool
     * @description
     *  [en]
     *  DEPRECATED! Use `visible` instead.
     *  [/en]
     *  [ja][/ja]
     */
    isOpen: PropTypes__default["default"].bool,
    /**
     * @name isCancelable
     * @type bool
     * @required false
     * @description
     *  [en]
     *  DEPRECATED! Use `cancelable` instead.
     *  [/en]
     *  [ja][/ja]
     */
    isCancelable: PropTypes__default["default"].bool,
    /**
     * @name isDisabled
     * @type bool
     * @required false
     * @description
     *  [en]
     *  DEPRECATED! Use `disabled` instead.
     *  [/en]
     *  [ja][/ja]
     */
    isDisabled: PropTypes__default["default"].bool,
    /**
     * @name animation
     * @type string
     * @required false
     * @description
     *  [en]
     *  The animation used when showing and hiding the dialog. Can be either `"none"` or `"default"`.
     *  [/en]
     *  [ja][/ja]
     */
    animation: PropTypes__default["default"].string,
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the dialog.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name maskColor
     * @type string
     * @required false
     * @description
     *  [en]Color of the background mask. Default is "rgba(0, 0, 0, 0.2)"[/en]
     *  [ja][/ja]
     */
    maskColor: PropTypes__default["default"].string,
    /**
     * @name animationOptions
     * @type object
     * @required false
     * @description
     *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]
     *  [ja][/ja]
     */
    animationOptions: PropTypes__default["default"].object,
    /**
     * @name onPreShow
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called just before the action sheet is displayed.
     *  [/en]
     *  [ja][/ja]
     */
    onPreShow: PropTypes__default["default"].func,
    /**
     * @name onPostShow
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called just after the action sheet is displayed.
     *  [/en]
     *  [ja][/ja]
     */
    onPostShow: PropTypes__default["default"].func,
    /**
     * @name onPreHide
     * @type function
     * @required false
     * @description
     *  [en]Called just before the action sheet is hidden.[/en]
     *  [ja][/ja]
     */
    onPreHide: PropTypes__default["default"].func,
    /**
     * @name onPostHide
     * @type function
     * @required false
     * @description
     *  [en]Called just after the action sheet is hidden.[/en]
     *  [ja][/ja]
     */
    onPostHide: PropTypes__default["default"].func,
    /**
     * @name onDeviceBackButton
     * @type function
     * @required false
     * @description
     *  [en]
     *  Custom handler for device back button.
     *  [/en]
     *  [ja][/ja]
     */
    onDeviceBackButton: PropTypes__default["default"].func
  };
  const deprecated$a = {
    onCancel: 'onDialogCancel',
    isOpen: 'visible',
    isDisabled: 'disabled',
    isCancelable: 'cancelable'
  };
  const notAttributes$d = ['onDeviceBackButton'];

  /**
   * @original ons-action-sheet
   * @category dialog
   * @tutorial react/Reference/action-sheet
   * @description
   * [en]
   *  Action/bottom sheet that is displayed on top of current screen.
   *  The action sheet is useful for displaying a list of options and asking the user to make a decision. An ActionSheetButton component is provided for this purpose, although it can contain any type of content.
   *  It will automatically be displayed as Material Design (bottom sheet) when running on an Android device.
   * [/en]
   * [ja][/ja]
   */
  const ActionSheet = onsCustomElement(baseDialog('ons-action-sheet'), {
    propTypes: propTypes$7,
    deprecated: deprecated$a,
    notAttributes: notAttributes$d
  });
  ActionSheet.propTypes = propTypes$7;

  const propTypes$6 = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the action sheet button.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name icon
     * @type string
     * @description
     *  [en]Creates an `Icon` component with this string. Only visible on Android.[/en]
     *  [ja][/ja]
     */
    icon: PropTypes__default["default"].string,
    /**
     * @name onClick
     * @type function
     * @description
     *  [en]This function will be called when the button is clicked.[/en]
     *  [ja][/ja]
     */
    onClick: PropTypes__default["default"].func
  };

  /**
   * @original ons-action-sheet-button
   * @category dialog
   * @tutorial react/Reference/action-sheet
   * @description
   * [en]Component that represent each button of the action sheet.[/en]
   * [ja][/ja]
   */
  const ActionSheetButton = onsCustomElement('ons-action-sheet-button', {
    propTypes: propTypes$6
  });
  ActionSheetButton.propTypes = propTypes$6;

  const deprecated$9 = {
    onCancel: 'onDialogCancel',
    isOpen: 'visible',
    isDisabled: 'disabled',
    isCancelable: 'cancelable'
  };
  const notAttributes$c = ['onDeviceBackButton'];

  /**
   * @original ons-alert-dialog
   * @category dialog
   * @tutorial react/Reference/alert-dialog
   * @description
   * [en]
   *   Alert dialog that is displayed on top of the current screen. Useful for displaying questions, warnings or error messages to the user. The title, content and buttons can be easily customized and it will automatically switch style based on the platform.
   * [/en]
   * [ja][/ja]
   * @example
     <AlertDialog isOpen={this.state.isOpen} onCancel={this.handleCancel.bind(this)} cancelable>
       <div className="alert-dialog-title">Warning!</div>
       <div className="alert-dialog-content">
         An error has occurred!
       </div>
       <div className="alert-dialog-footer">
         <Button onClick={this.handleCancel.bind(this)} className="alert-dialog-button">
           Cancel
         </Button>
         <Button onClick={this.handleCancel.bind(this)} className="alert-dialog-button">
           Ok
         </Button>
       </div>
     </AlertDialog>
   */
  const AlertDialog = onsCustomElement(baseDialog('ons-alert-dialog'), {
    deprecated: deprecated$9,
    notAttributes: notAttributes$c
  });
  AlertDialog.propTypes = {
    /**
     * @name visible
     * @type bool
     * @description
     *  [en]
     *  Indicates whether the dialog is open and shown.
     *  [/en]
     *  [ja][/ja]
     */
    visible: PropTypes__default["default"].bool,
    /**
     * @name disabled
     * @type bool
     * @required false
     * @description
     *  [en]
     *  Specifies whether the dialog is disabled.
     *  [/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name cancelable
     * @type bool
     * @required false
     * @description
     *  [en]
     *  Specifies whether the dialog is cancelable or not.
     *  A cancelable dialog will call `onDialogCancel` when tapping the background or pressing the back button on Android devices.
     *  [/en]
     *  [ja][/ja]
     */
    cancelable: PropTypes__default["default"].bool,
    /**
     * @name onDialogCancel
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called only if `cancelable` is true. It will be called after tapping the background or by pressing the back button on Android devices.
     *  [/en]
     *  [ja][/ja]
     */
    onDialogCancel: PropTypes__default["default"].func,
    /**
     * @name onCancel
     * @type function
     * @required false
     * @description
     *  [en]
     *  DEPRECATED! Use `onDialogCancel` instead.
     *  [/en]
     *  [ja][/ja]
     */
    onCancel: PropTypes__default["default"].func,
    /**
     * @name isOpen
     * @type bool
     * @description
     *  [en]
     *  DEPRECATED! Use `visible` instead.
     *  [/en]
     *  [ja][/ja]
     */
    isOpen: PropTypes__default["default"].bool,
    /**
     * @name isCancelable
     * @type bool
     * @required false
     * @description
     *  [en]
     *  DEPRECATED! Use `cancelable` instead.
     *  [/en]
     *  [ja][/ja]
     */
    isCancelable: PropTypes__default["default"].bool,
    /**
     * @name isDisabled
     * @type bool
     * @required false
     * @description
     *  [en]
     *  DEPRECATED! Use `disabled` instead.
     *  [/en]
     *  [ja][/ja]
     */
    isDisabled: PropTypes__default["default"].bool,
    /**
     * @name animation
     * @type string
     * @required false
     * @description
     *  [en]
     *  The animation used when showing and hiding the dialog. Can be either `"none"` or `"default"`.
     *  [/en]
     *  [ja][/ja]
     */
    animation: PropTypes__default["default"].string,
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the dialog.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name maskColor
     * @type string
     * @required false
     * @description
     *  [en]Color of the background mask. Default is "rgba(0, 0, 0, 0.2)"[/en]
     *  [ja][/ja]
     */
    maskColor: PropTypes__default["default"].string,
    /**
     * @name animationOptions
     * @type object
     * @required false
     * @description
     *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]
     *  [ja][/ja]
     */
    animationOptions: PropTypes__default["default"].object,
    /**
     * @name onPreShow
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called just before the alert dialog is displayed.
     *  [/en]
     *  [ja][/ja]
     */
    onPreShow: PropTypes__default["default"].func,
    /**
     * @name onPostShow
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called just after the alert dialog is displayed.
     *  [/en]
     *  [ja][/ja]
     */
    onPostShow: PropTypes__default["default"].func,
    /**
     * @name onPreHide
     * @type function
     * @required false
     * @description
     *  [en]Called just before the alert dialog is hidden.[/en]
     *  [ja][/ja]
     */
    onPreHide: PropTypes__default["default"].func,
    /**
     * @name onPostHide
     * @type function
     * @required false
     * @description
     *  [en]Called just after the alert dialog is hidden.[/en]
     *  [ja][/ja]
     */
    onPostHide: PropTypes__default["default"].func,
    /**
     * @name onDeviceBackButton
     * @type function
     * @required false
     * @description
     *  [en]
     *  Custom handler for device back button.
     *  [/en]
     *  [ja][/ja]
     */
    onDeviceBackButton: PropTypes__default["default"].func
  };

  /**
   * @original ons-alert-dialog-button
   * @category dialog
   * @tutorial react/Reference/dialog
   * @description
   * [en]Component that represent each button of the alert dialog.[/en]
   * [ja][/ja]
   */
  const AlertDialogButton = onsCustomElement('ons-alert-dialog-button');
  AlertDialogButton.propTypes = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the alert dialog button.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name disabled
     * @type bool
     * @description
     *  [en]
     *  Specifies whether the button is disabled.
     *  [/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name onClick
     * @type function
     * @description
     *  [en]This function will be called when the button is clicked.[/en]
     *  [ja][/ja]
     */
    onClick: PropTypes__default["default"].func
  };

  const notAttributes$b = ['options'];

  /**
   * @original ons-back-button
   * @category navigation
   * @tutorial react/Reference/back-button
   * @description
   * [en]
   *   Back button component for Toolbar. It enables to automatically to pop the top page of the navigator. When only presented with one page, the button is hidden automatically.
   *
   *   The default behavior can be overridden using the `onClick` prop.
   * [/en]
   * [ja][/ja]
   * @example
   * <Toolbar modifier={this.props.modifier} >
        <div className="left"><BackButton modifier={this.props.modifier}>Back</BackButton></div>
        <div className="center">{this.props.title}</div>
     </Toolbar>
   */
  const BackButton = onsCustomElement('ons-back-button', {
    notAttributes: notAttributes$b
  });
  BackButton.propTypes = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the back button.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name onClick
     * @type function
     * @description
     *  [en]This function will be called when the button is clicked. To prevent the default click behaviour, call `event.preventDefault()`.[/en]
     *  [ja][/ja]
     */
    onClick: PropTypes__default["default"].func,
    /**
     * @name options
     * @type object
     * @description
     *  [en]Specifies the animation, animationOptions, and callback.[/en]
     *  [ja][/ja]
     */
    options: PropTypes__default["default"].shape({
      animation: PropTypes__default["default"].string,
      animationOptions: PropTypes__default["default"].object,
      callback: PropTypes__default["default"].func
    })
  };

  const propTypes$5 = {
    /**
     * @name modifier
     * @type string
     * @description
     *  [en]Specify modifier name to specify custom styles. Optional.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string
  };

  /**
   * @original ons-bottom-toolbar
   * @category page
   * @description
   * [en]Toolbar component that is positioned at the bottom of the page.[/en]
   * [ja][/ja]
   * @example
   * <BottomToolbar modifier="material"> Content </BottomToolbar>
   */
  const BottomToolbar = onsCustomElement('ons-bottom-toolbar', {
    propTypes: propTypes$5
  });
  BottomToolbar.propTypes = propTypes$5;

  const propTypes$4 = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the button.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name disabled
     * @type bool
     * @description
     *  [en]
     *  Specifies whether the button is disabled.
     *  [/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name ripple
     * @type bool
     * @description
     *  [en]
     *  Specifies whether the button has a ripple effect.
     *  [/en]
     *  [ja][/ja]
     */
    ripple: PropTypes__default["default"].bool,
    /**
     * @name onClick
     * @type function
     * @description
     *  [en] This function will be called when the button is clicked. [/en]
     *  [ja][/ja]
     */
    onClick: PropTypes__default["default"].func
  };

  /**
   * @original ons-button
   * @category form
   * @tutorial react/Reference/button
   * @description
   * [en] Button component. If you want to place a button in a toolbar, use `ToolbarButton` or `BackButton` instead. Will automatically display as a Material Design button with a ripple effect on Android.
   [/en]
   * [ja][/ja]
   * @example
   * <Button modifier="large--cta">
   *   Tap Me
   * </Button>
   */
  const Button = onsCustomElement('ons-button', {
    propTypes: propTypes$4
  });
  Button.propTypes = propTypes$4;

  /**
   * @original ons-card
   * @category visual
   * @tutorial react/Reference/visual
   * @description
   * [en]Card component that can be used to display content.[/en]
   * [ja][/ja]
   * @example
   *
  <Card>
    <p>Some content</p>
  </Card>
   */
  const Card = onsCustomElement('ons-card');
  Card.propTypes = {
    /**
     * @name modifier
     * @type string
     * @description
     *  [en]
     *  Specify modifier name to specify custom styles. Optional.
     *  [/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string
  };

  const deprecated$8 = {
    index: 'activeIndex'
  };
  const Element$9 = onsCustomElement('ons-carousel', {
    deprecated: deprecated$8
  });

  /**
   * @original ons-carousel
   * @category carousel
   * @tutorial react/Reference/carousel
   * @description
   * [en] Carousel component. A carousel can be used to display several items in the same space.
   *     The component supports displaying content both horizontally and vertically. The user can scroll through the items by dragging and it can also be controller programmatically.
   [/en]
   * [ja][/ja]
   * @example
   *    <Carousel
            onPostChange={() => console.log('onPostChange')}
            onOverscroll={() => console.log('onOverscroll')}
            onRefresh={() => console.log('onRefresh')}
            ref={(carousel) => { this.carousel = carousel; }}
            swipeable
            overscrollable
            autoScroll
            fullscreen
            autoScrollRatio={0.2}
        >
            <CarouselItem style={{backgroundColor: 'gray'}}>
              <div className='item-label'>GRAY</div>
            </CarouselItem>
            <CarouselItem style={{backgroundColor: '#085078'}}>
              <div className='item-label'>BLUE</div>
            </CarouselItem>
          </Carousel>

   */
  const Carousel = /*#__PURE__*/React__default["default"].forwardRef((props, ref) => {
    const {
      itemWidth,
      itemHeight,
      ...rest
    } = props;

    // string values for itemWidth and itemHeight are deprecated but handle them
    // safely anyway to avoid breaking user code
    const stringify = x => typeof x === 'number' ? `${x}px` : x;
    const realItemWidth = stringify(itemWidth);
    const realItemHeight = stringify(itemHeight);
    return /*#__PURE__*/React__default["default"].createElement(Element$9, _extends({
      itemWidth: realItemWidth,
      itemHeight: realItemHeight,
      ref: ref
    }, rest), props.children);
  });
  Carousel.propTypes = {
    /**
     * @name direction
     * @type string
     * @required false
     * @description
     *  [en]The direction of the carousel. Can be either "horizontal" or "vertical". Default is "horizontal".[/en]
     *  [ja][/ja]
     */
    direction: PropTypes__default["default"].oneOf(['horizontal', 'vertical']),
    /**
     * @name fullscreen
     * @type bool
     * @description
     *  [en]If true, the carousel will cover the whole screen.[/en]
     *  [ja][/ja]
     */
    fullscreen: PropTypes__default["default"].bool,
    /**
     * @name overscrollable
     * @type bool
     * @description
     *  [en]If true, the carousel will be scrollable over the edge. It will bounce back when released.[/en]
     *  [ja][/ja]
     */
    overscrollable: PropTypes__default["default"].bool,
    /**
     * @name centered
     * @type bool
     * @description
     *  [en]If true, the carousel then the selected item will be in the center of the carousel instead of the beginning. Useful only when the items are smaller than the carousel.[/en]
     *  [ja][/ja]
     */
    centered: PropTypes__default["default"].bool,
    /**
     * @name itemWidth
     * @type string
     * @description
     *  [en]ons-carousel-item's width. Only works when the direction is set to "horizontal". Can be in pixels or a percentage.[/en]
     *  [ja][/ja]
     */
    itemWidth: PropTypes__default["default"].string,
    /**
     * @name itemHeight
     * @type string
     * @description
     *  [en]ons-carousel-item's height. Only works when the direction is set to "vertical". Can be in pixels or a percentage.[/en]
     *  [ja][/ja]
     */
    itemHeight: PropTypes__default["default"].string,
    /**
     * @name autoScroll
     * @type bool
     * @description
     *  [en]If true, the carousel will be automatically scrolled to the closest item border when released.[/en]
     *  [ja][/ja]
     */
    autoScroll: PropTypes__default["default"].bool,
    /**
     * @name autoScrollRatio
     * @type number
     * @description
     *  [en]A number between 0.0 and 1.0 that specifies how much the user must drag the carousel in order for it to auto scroll to the next item.[/en]
     *  [ja][/ja]
     */
    autoScrollRatio: PropTypes__default["default"].number,
    /**
     * @name swipeable
     * @type bool
     * @description
     *  [en]If true, the carousel can be scrolled by drag or swipe.[/en]
     *  [ja][/ja]
     */
    swipeable: PropTypes__default["default"].bool,
    /**
     * @name disabled
     * @type bool
     * @description
     *  [en]If true, the carousel will be disabled.[/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name activeIndex
     * @type number
     * @description
     *  [en]Specify the index of the ons-carousel-item to show. Default is 0.[/en]
     *  [ja][/ja]
     */
    activeIndex: PropTypes__default["default"].number,
    /**
     * @name index
     * @type number
     * @description
     *  [en]DEPRECATED! Use `activeIndex` instead.[/en]
     *  [ja][/ja]
     */
    index: PropTypes__default["default"].number,
    /**
     * @name autoRefresh
     * @type bool
     * @description
     *  [en]When this attribute is set the carousel will automatically refresh when the number of child nodes change.[/en]
     *  [ja][/ja]
     */
    autoRefresh: PropTypes__default["default"].bool,
    /**
     * @name onPreChange
     * @type function
     * @description
     *  [en]Called just before the current carousel item changes.[/en]
     *  [ja][/ja]
     */
    onPreChange: PropTypes__default["default"].func,
    /**
     * @name onPostChange
     * @type function
     * @description
     *  [en]Called just after the current carousel item has changed.[/en]
     *  [ja][/ja]
     */
    onPostChange: PropTypes__default["default"].func,
    /**
     * @name onRefresh
     * @type function
     * @description
     *  [en]Called when the carousel has been refreshed. [/en]
     *  [ja][/ja]
     */
    onRefresh: PropTypes__default["default"].func,
    /**
     * @name onOverscroll
     * @type function
     * @description
     *  [en]Called when the carousel has been overscrolled. [/en]
     *  [ja][/ja]
     */
    onOverscroll: PropTypes__default["default"].func,
    /**
     * @name animation
     * @type string
     * @required false
     * @description
     *  [en]If this prop is set to "none" the transitions will not be animated.[/en]
     *  [ja][/ja]
     */
    animation: PropTypes__default["default"].string,
    /**
     * @name animationOptions
     * @type object
     * @required false
     * @description
     *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]
     *  [ja][/ja]
     */
    animationOptions: PropTypes__default["default"].object,
    /**
     * @name onSwipe
     * @type function
     * @description
     *  [en]Hook called whenever the user slides the carousel. It gets a decimal index and an animationOptions object as arguments.[/en]
     *  [ja][/ja]
     */
    onSwipe: PropTypes__default["default"].func
  };

  /**
   * @original ons-carousel-item
   * @category carousel
   * @tutorial react/Reference/carousel
   * @description
   * [en] Carousel item component. Used as a child of the `<ons-carousel>` element.
   [/en]
   * [ja][/ja]
   * @example
  *  <Carousel swipeable overscrollable autoScroll fullscreen >
       <CarouselItem style={{backgroundColor: 'gray'}}>
         <div className='item-label'>GRAY</div>
       </CarouselItem>
       <CarouselItem style={{backgroundColor: '#085078'}}>
         <div className='item-label'>BLUE</div>
       </CarouselItem>
     </Carousel>
   */
  const CarouselItem = onsCustomElement('ons-carousel-item');
  CarouselItem.propTypes = {
    /**
     * @name modifier
     * @type string
     * @description
     *  [en]
     *  Specify modifier name to specify custom styles. Optional.
     *  [/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string
  };

  // For a prop with name `defaultProp`, sets the component's `prop` prop to the
  // value of `defaultProp` when the component mounts only.
  //
  // For example, Input has a defaulttValue prop that should set the inner input's
  // value when the component mounted and do nothing afterwards.
  const oneTimeProp = (WrappedComponent, defaultProp, prop) => {
    class OneTimeProp extends React__default["default"].Component {
      constructor(props) {
        super(props);
        this.ref = /*#__PURE__*/React__default["default"].createRef();
      }
      componentDidMount() {
        const value = this.props[defaultProp];
        if (value) {
          this.ref.current[prop] = value;
        }
      }
      render() {
        const {
          innerRef,
          ...rest
        } = this.props;
        delete rest[defaultProp];
        if (innerRef && innerRef !== this.ref) {
          this.ref = innerRef;
        }
        return /*#__PURE__*/React__default["default"].createElement(WrappedComponent, _extends({
          ref: this.ref
        }, rest), this.props.children);
      }
    }
    return /*#__PURE__*/React__default["default"].forwardRef((props, ref) => /*#__PURE__*/React__default["default"].createElement(OneTimeProp, _extends({
      innerRef: ref
    }, props), props.children));
  };

  const INPUT_PROPS = {
    autoCapitalize: 'autocapitalize',
    autoComplete: 'autocomplete',
    autoCorrect: 'autocorrect',
    autoFocus: 'autofocus',
    inputMode: 'inputmode',
    maxLength: 'maxlength',
    minLength: 'minlength',
    readOnly: 'readonly',
    spellCheck: 'spellcheck'
  };

  const nameMap$6 = {
    ...INPUT_PROPS
  };
  const withDefaultChecked$2 = component => oneTimeProp(component, 'defaultChecked', 'checked');

  /**
   * @original ons-checkbox
   * @category form
   * @tutorial react/Reference/checkbox
   * @description
   * [en]
   *  A checkbox element. The component will automatically render as a Material Design checkbox on Android devices.
   *
   *  Most attributes that can be used for a normal `<input type="checkbox">` element can also be used on the `<Checkbox>` component.
   * [/en]
   * [ja][/ja]
   * @example
   * <Checkbox
   *   onChange={event => { this.setState({checked: event.target.checked})} }
   *   modifier='material' />
   */
  const Checkbox = withDefaultChecked$2(onsCustomElement('ons-checkbox', {
    deprecated: nameMap$6
  }));
  Checkbox.propTypes = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the checkbox.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name disabled
     * @type bool
     * @description
     *  [en]
     *  Specifies whether the checkbox is disabled.
     *  [/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name onChange
     * @type function
     * @description
     *  [en]Called when the inner checkbox fires a `change` event.[/en]
     *  [ja][/ja]
     */
    onChange: PropTypes__default["default"].func,
    /**
     * @name onInput
     * @type function
     * @description
     *  [en]Called when the inner checkbox fires an `input` event.[/en]
     *  [ja][/ja]
     */
    onInput: PropTypes__default["default"].func,
    /**
     * @name value
     * @type string
     * @description
     *  [en] Value of the checkbox.[/en]
     *  [ja][/ja]
     */
    value: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].instanceOf(Date)]),
    /**
     * @name checked
     * @type boolean
     * @description
     *  [en]Controls the state of the checkbox (controlled).[/en]
     *  [ja][/ja]
     */
    checked: PropTypes__default["default"].bool,
    /**
     * @name defaultChecked
     * @type boolean
     * @description
     *  [en]Defined the state of the checkbox at first render for uncontrolled inputs.[/en]
     *  [ja][/ja]
     */
    defaultChecked: PropTypes__default["default"].bool,
    /**
     * @name inputId
     * @type string
     * @description
     *  [en]Specify the "id" attribute of the inner `<input>` element. This is useful when using <label for="..."> elements.[/en]
     *  [ja][/ja]
     */
    inputId: PropTypes__default["default"].string
  };

  /**
   * @original ons-col
   * @category grid
   * @description
   * [en]
   * Represents a column in the grid system. Use with `<ons-row>` to layout components.
   * [/en]
   * [ja][/ja]
   * <Row>
   *   <Col width={50}>
    *   <ons-icon icon="fa-twitter"></ons-icon>
   *   </Col>
   *   <Col>Text</Col>
   * </Row>
   */
  const Col = onsCustomElement('ons-col');
  Col.propTypes = {
    /**
    * @name verticalAlign
    * @type {String}
    * @description
    *   [en]Short hand attribute for aligning vertically. Valid values are top, bottom, and center.[/en]
    *   [ja][/ja]
    */
    verticalAlign: PropTypes__default["default"].oneOf(['top', 'bottom', 'center']),
    /**
    * @name width
    * @type {String}
    * @description
    *   [en]The width of the column. Valid values are css width values ("10%", 50).[/en]
    *   [ja][/ja]
    */
    width: PropTypes__default["default"].oneOfType([PropTypes__default["default"].number, PropTypes__default["default"].string])
  };

  const deprecated$7 = {
    onCancel: 'onDialogCancel',
    isOpen: 'visible',
    isDisabled: 'disabled',
    isCancelable: 'cancelable'
  };
  const notAttributes$a = ['onDeviceBackButton'];

  /**
   * @original ons-dialog
   * @category dialog
   * @tutorial react/Reference/dialog
   * @description
   * [en]  Dialog that is displayed on top of current screen. As opposed to the AlertDialog element, this component can contain any kind of content.  The dialog is useful for displaying menus, additional information or to ask the user to make a decision.  It will automatically be displayed as Material Design when running on an Android device.
   [/en]
   * [ja][/ja]
   * @example
     <Dialog onCancel={this.onCancel}
       isOpen={this.props.isOpen}
       style={{height: 250}}  cancelable>
       <Page>
         Page Content
       </Page>
      </Dialog>

   */
  const Dialog = onsCustomElement(baseDialog('ons-dialog'), {
    deprecated: deprecated$7,
    notAttributes: notAttributes$a
  });
  Dialog.propTypes = {
    /**
     * @name visible
     * @type bool
     * @description
     *  [en]
     *  Indicates whether the dialog is open and shown.
     *  [/en]
     *  [ja][/ja]
     */
    visible: PropTypes__default["default"].bool,
    /**
     * @name disabled
     * @type bool
     * @required false
     * @description
     *  [en]
     *  Specifies whether the dialog is disabled.
     *  [/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name cancelable
     * @type bool
     * @required false
     * @description
     *  [en]
     *  Specifies whether the dialog is cancelable or not.
     *  A cancelable dialog will call `onDialogCancel` when tapping the background or pressing the back button on Android devices.
     *  [/en]
     *  [ja][/ja]
     */
    cancelable: PropTypes__default["default"].bool,
    /**
     * @name onDialogCancel
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called only if `cancelable` is true. It will be called after tapping the background or by pressing the back button on Android devices.
     *  [/en]
     *  [ja][/ja]
     */
    onDialogCancel: PropTypes__default["default"].func,
    /**
     * @name onCancel
     * @type function
     * @required false
     * @description
     *  [en]
     *  DEPRECATED! Use `onDialogCancel` instead.
     *  [/en]
     *  [ja][/ja]
     */
    onCancel: PropTypes__default["default"].func,
    /**
     * @name isOpen
     * @type bool
     * @description
     *  [en]
     *  DEPRECATED! Use `visible` instead.
     *  [/en]
     *  [ja][/ja]
     */
    isOpen: PropTypes__default["default"].bool,
    /**
     * @name isCancelable
     * @type bool
     * @required false
     * @description
     *  [en]
     *  DEPRECATED! Use `cancelable` instead.
     *  [/en]
     *  [ja][/ja]
     */
    isCancelable: PropTypes__default["default"].bool,
    /**
     * @name isDisabled
     * @type bool
     * @required false
     * @description
     *  [en]
     *  DEPRECATED! Use `disabled` instead.
     *  [/en]
     *  [ja][/ja]
     */
    isDisabled: PropTypes__default["default"].bool,
    /**
     * @name animation
     * @type string
     * @required false
     * @description
     *  [en]
     *  The animation used when showing and hiding the dialog. Can be either `"none"` or `"default"`.
     *  [/en]
     *  [ja][/ja]
     */
    animation: PropTypes__default["default"].string,
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the dialog.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name maskColor
     * @type string
     * @required false
     * @description
     *  [en]Color of the background mask. Default is "rgba(0, 0, 0, 0.2)"[/en]
     *  [ja][/ja]
     */
    maskColor: PropTypes__default["default"].string,
    /**
     * @name animationOptions
     * @type object
     * @required false
     * @description
     *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]
     *  [ja][/ja]
     */
    animationOptions: PropTypes__default["default"].object,
    /**
     * @name onPreShow
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called just before the alert dialog is displayed.
     *  [/en]
     *  [ja][/ja]
     */
    onPreShow: PropTypes__default["default"].func,
    /**
     * @name onPostShow
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called just after the alert dialog is displayed.
     *  [/en]
     *  [ja][/ja]
     */
    onPostShow: PropTypes__default["default"].func,
    /**
     * @name onPreHide
     * @type function
     * @required false
     * @description
     *  [en]Called just before the alert dialog is hidden.[/en]
     *  [ja][/ja]
     */
    onPreHide: PropTypes__default["default"].func,
    /**
     * @name onPostHide
     * @type function
     * @required false
     * @description
     *  [en]Called just after the alert dialog is hidden.[/en]
     *  [ja][/ja]
     */
    onPostHide: PropTypes__default["default"].func,
    /**
     * @name onDeviceBackButton
     * @type function
     * @required false
     * @description
     *  [en]
     *  Custom handler for device back button.
     *  [/en]
     *  [ja][/ja]
     */
    onDeviceBackButton: PropTypes__default["default"].func
  };

  /**
   * @original ons-fab
   * @category form
   * @tutorial react/Reference/fab
   * @description
   * [en] The Floating action button is a circular button defined in the [Material Design specification](https://www.google.com/design/spec/components/buttons-floating-action-button.html). They are often used to promote the primary action of the app.
   *     It can be displayed either as an inline element or in one of the corners. Normally it will be positioned in the lower right corner of the screen.
   [/en]
   * [ja][/ja]
   * @example
   * <SpeedDial disabled={false} direction='right' onClick={() => console.log('test1')} position='left bottom'>
       <Fab>
         <Icon icon='fa-twitter' size={26} fixedWidth={false} style={{verticalAlign: 'middle'}} />
       </Fab>
       <SpeedDialItem onClick={() => console.log('speed A')}> A </SpeedDialItem>
       <SpeedDialItem onClick={() => console.log('speed B')}> B </SpeedDialItem>
       <SpeedDialItem onClick={() => console.log('speed C')}> C </SpeedDialItem>
       <SpeedDialItem onClick={() => console.log('speed D')}> D </SpeedDialItem>
     </SpeedDial>
    */
  const Fab = onsCustomElement('ons-fab');
  Fab.propTypes = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the button.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name ripple
     * @type bool
     * @description
     *  [en]If true,  the button will have a ripple effect when tapped.[/en]
     *  [ja][/ja]
     */
    ripple: PropTypes__default["default"].bool,
    /**
     * @name position
     * @type string
     * @required false
     * @description
     *  [en]The position of the button. Should be a string like `"bottom right"` or `"top left"`. If this attribute is not defined it will be displayed as an inline element.[/en]
     *  [ja][/ja]
     */
    position: PropTypes__default["default"].string,
    /**
     * @name disabled
     * @type bool
     * @description
     *  [en] If true, the button will be disabled. [/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name onClick
     * @type function
     * @description
     *  [en] This function will be called ones the button is clicked. [/en]
     *  [ja][/ja]
     */
    onClick: PropTypes__default["default"].func
  };

  const propTypes$3 = {
    /**
     * @name onDrag
     * @type function
     * @description
     *  [en]Called when the user drags in any direction.[/en]
     *  [ja][/ja]
     */
    onDrag: PropTypes__default["default"].func,
    /**
     * @name onDragLeft
     * @type function
     * @description
     *  [en]Called when the user drags left.[/en]
     *  [ja][/ja]
     */
    onDragLeft: PropTypes__default["default"].func,
    /**
     * @name onDragRight
     * @type function
     * @description
     *  [en]Called when the user drags right.[/en]
     *  [ja][/ja]
     */
    onDragRight: PropTypes__default["default"].func,
    /**
     * @name onDragUp
     * @type function
     * @description
     *  [en]Called when the user drags up.[/en]
     *  [ja][/ja]
     */
    onDragUp: PropTypes__default["default"].func,
    /**
     * @name onDragDown
     * @type function
     * @description
     *  [en]Called when the user drags down.[/en]
     *  [ja][/ja]
     */
    onDragDown: PropTypes__default["default"].func,
    /**
     * @name onHold
     * @type function
     * @description
     *  [en]Called when the user holds.[/en]
     *  [ja][/ja]
     */
    onHold: PropTypes__default["default"].func,
    /**
     * @name onRelease
     * @type function
     * @description
     *  [en]Called when the user releases.[/en]
     *  [ja][/ja]
     */
    onRelease: PropTypes__default["default"].func,
    /**
     * @name onSwipe
     * @type function
     * @description
     *  [en]Called when the user swipes in any direction.[/en]
     *  [ja][/ja]
     */
    onSwipe: PropTypes__default["default"].func,
    /**
     * @name onSwipeLeft
     * @type function
     * @description
     *  [en]Called when the user swipes left.[/en]
     *  [ja][/ja]
     */
    onSwipeLeft: PropTypes__default["default"].func,
    /**
     * @name onSwipeRight
     * @type function
     * @description
     *  [en]Called when the user swipes right.[/en]
     *  [ja][/ja]
     */
    onSwipeRight: PropTypes__default["default"].func,
    /**
     * @name onSwipeUp
     * @type function
     * @description
     *  [en]Called when the user swipes up.[/en]
     *  [ja][/ja]
     */
    onSwipeUp: PropTypes__default["default"].func,
    /**
     * @name onSwipeDown
     * @type function
     * @description
     *  [en]Called when the user swipes down.[/en]
     *  [ja][/ja]
     */
    onSwipeDown: PropTypes__default["default"].func,
    /**
     * @name onTap
     * @type function
     * @description
     *  [en]Called when the user taps.[/en]
     *  [ja][/ja]
     */
    onTap: PropTypes__default["default"].func,
    /**
     * @name onDoubleTap
     * @type function
     * @description
     *  [en]Called when the user double taps.[/en]
     *  [ja][/ja]
     */
    onDoubleTap: PropTypes__default["default"].func,
    /**
     * @name onPinch
     * @type function
     * @description
     *  [en]Called when the user pinches in or out.[/en]
     *  [ja][/ja]
     */
    onPinch: PropTypes__default["default"].func,
    /**
     * @name onPinchIn
     * @type function
     * @description
     *  [en]Called when the user pinches in.[/en]
     *  [ja][/ja]
     */
    onPinchIn: PropTypes__default["default"].func,
    /**
     * @name onPinchOut
     * @type function
     * @description
     *  [en]Called when the user pinches out.[/en]
     *  [ja][/ja]
     */
    onPinchOut: PropTypes__default["default"].func,
    /**
     * @name onTouch
     * @type function
     * @description
     *  [en]Called when the user touches.[/en]
     *  [ja][/ja]
     */
    onTouch: PropTypes__default["default"].func,
    /**
     * @name onTransform
     * @type function
     * @description
     *  [en]Called when the user transforms.[/en]
     *  [ja][/ja]
     */
    onTransform: PropTypes__default["default"].func,
    /**
     * @name onRotate
     * @type function
     * @description
     *  [en]Called when the user rotates.[/en]
     *  [ja][/ja]
     */
    onRotate: PropTypes__default["default"].func
  };

  /**
   * @original ons-gesture-detector
   * @category gesture
   * @tutorial react/Reference/gesture-detector
   * @description
   * [en]Component to detect finger gestures within a wrapped element.
   [/en]
   * [ja][/ja]
   * @example
   * <GestureDetector
   *   onTap={() => console.log('tap')}
   *   onSwipeleft={() => console.log('swipe left')}
   * >
   *   <div style={{backgroundColor: 'pink', width: '100px', height: '100px'}}>
   *     Swipe Here
   *   </div>
   * </GestureDetector>
   *
   */
  const GestureDetector = onsCustomElement('ons-gesture-detector', {
    propTypes: propTypes$3
  });
  GestureDetector.propTypes = propTypes$3;

  const parseIcon = icon => {
    if (icon) {
      if (typeof icon === 'string') {
        return icon;
      } else {
        const keys = Object.keys(icon).filter(a => a !== 'default');
        const innerString = keys.map(key => key + ':' + icon[key] + '');
        return icon.default + ', ' + innerString.join(',');
      }
    }
  };
  const parseSize = size => {
    if (size) {
      if (typeof size === 'number') {
        return `${size}px`;
      } else {
        const keys = Object.keys(size).filter(a => a !== 'default');
        const innerString = keys.map(key => key + ':' + size[key] + 'px');
        return size.default + 'px, ' + innerString.join(',');
      }
    }
  };
  const Element$8 = onsCustomElement('ons-icon');

  /**
   * @original ons-icon
   * @category visual
   * @tutorial react/Reference/icon
   * @description
   * [en]
   * Displays an icon. The following icon suites are available:
   *   *  [Font Awesome](https://fortawesome.github.io/Font-Awesome/)
   *   *  [Ionicons](http://ionicons.com/)
   *   *  [Material Design Iconic Font](http://zavoloklom.github.io/material-design-iconic-font/)
   * [/en]
   * [ja][/ja]
   * @example
    <Icon
      size={{default: 32, material: 40}}
      icon={{default: 'ion-navicon', material: 'md-menu'}}
    />
  */
  const Icon = /*#__PURE__*/React__default["default"].forwardRef((props, ref) => {
    const {
      icon,
      size,
      ...rest
    } = props;
    return /*#__PURE__*/React__default["default"].createElement(Element$8, _extends({
      icon: parseIcon(icon),
      size: parseSize(size)
    }, rest, {
      ref: ref
    }), props.children);
  });
  Icon.propTypes = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the icon.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name icon
     * @type 'object or string'
     * @description
     *  [en] can be either a string or an object. If it is an string, it is set to an specific icon like 'ions-navicon'. If it is an object, it represents a dictionary of the icons depending on the modifier e.g.   `{{default: 'ion-navicon', material: 'md-menu'}}` [/en]
     *  [ja][/ja]
     */
    icon: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].objectOf(PropTypes__default["default"].string)]),
    /**
     * @name size
     * @type 'object or number'
     * @description
     *  [en] can be either a number or an object. If it is an number, it  specifies the icon size with a number in pixels. If it is an object, it represents a dictionary of the icon sizes depending on the modifier e.g.   `{{default: 20, material: 18}}` [/en]
     *  [ja][/ja]
     */
    size: PropTypes__default["default"].oneOfType([PropTypes__default["default"].number, PropTypes__default["default"].objectOf(PropTypes__default["default"].number)]),
    /**
     * @name rotate
     * @type number
     * @description
     *  [en] Number of degrees to rotate the icon. Valid values are 90, 180 and 270. [/en]
     *  [ja][/ja]
     */
    rotate: PropTypes__default["default"].oneOf([0, 90, 180, 270]),
    /**
     * @name fixedWidth
     * @type bool
     * @description
     * [en] When used in a list, you want the icons to have the same width so that they align vertically by defining this attribute. [/en]
     *  [ja][/ja]
     */
    fixedWidth: PropTypes__default["default"].bool,
    /**
     * @name spin
     * @type bool
     * @description
     * [en] Specify whether the icon should be spinning. [/en]
     *  [ja][/ja]
     */
    spin: PropTypes__default["default"].bool
  };

  const nameMap$5 = {
    ...INPUT_PROPS
  };
  const withDefaultValue$3 = component => oneTimeProp(component, 'defaultValue', 'value');
  const notAttributes$9 = ['value' // value must be applied as property since attribute only works before input is touched
  ];

  /**
   * @original ons-input
   * @category form
   * @tutorial react/Reference/input
   * @description
   * [en]
   * An input element. The `type` attribute can be used to change the input type. All text input types as well as `checkbox` and `radio` are supported. The component will automatically render as a Material Design input on Android devices. Most attributes that can be used for a normal `<input>` element can also be used on the `<ons-input>` element..
   [/en]
   * [ja][/ja]
   * @example
   * <Input
   *   value={this.state.text} float
   *   onChange={(event) => { this.setState({text: event.target.value})} }
   *   modifier='material'
   *   placeholder='Username' />
   */
  const Input = withDefaultValue$3(onsCustomElement('ons-input', {
    deprecated: nameMap$5,
    notAttributes: notAttributes$9
  }));
  Input.propTypes = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the input.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name disabled
     * @type bool
     * @description
     *  [en]Specifies whether the input is disabled.[/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name readOnly
     * @type bool
     * @description
     *  [en]Specifies whether the input is read-only.[/en]
     *  [ja][/ja]
     */
    readOnly: PropTypes__default["default"].bool,
    /**
     * @name onChange
     * @type function
     * @description
     *  [en]Called when the inner input fires a `change` event.[/en]
     *  [ja][/ja]
     */
    onChange: PropTypes__default["default"].func,
    /**
     * @name onInput
     * @type function
     * @description
     *  [en]Called when the inner input fires an `input` event.[/en]
     *  [ja][/ja]
     */
    onInput: PropTypes__default["default"].func,
    /**
     * @name value
     * @type string
     * @description
     *  [en]Content of the input (controlled).[/en]
     *  [ja][/ja]
     */
    value: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].instanceOf(Date)]),
    /**
     * @name defaultValue
     * @type string
     * @description
     *  [en]Content of the input at first render (uncontrolled).[/en]
     *  [ja][/ja]
     */
    defaultValue: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].instanceOf(Date)]),
    /**
     * @name placeholder
     * @type string
     * @description
     *  [en] Placeholder text. In Material Design this placeholder will be a floating label. [/en]
     *  [ja][/ja]
     */
    placeholder: PropTypes__default["default"].string,
    /**
     * @name type
     * @type string
     * @description
     *  [en]
     *    Specify the input type. This is the same as the "type" attribute for normal inputs. It expects strict text types such as `text`, `password`, etc. For checkbox, radio button, select or range, please have a look at the corresponding components.
     *
     *    Please take a look at [MDN](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#attr-type) for an exhaustive list of possible values. Depending on the platform and browser version some of these might not work.
     *  [/en]
     *  [ja][/ja]
     */
    type: PropTypes__default["default"].string,
    /**
     * @name inputId
     * @type string
     * @description
     *  [en]  Specify the "id" attribute of the inner `<input>` element. This is useful when using <label for="..."> elements [/en]
     *  [ja][/ja]
     */
    inputId: PropTypes__default["default"].string,
    /**
     * @name float
     * @type bool
     * @description
     *  [en]  If this attribute is present, the placeholder will be animated in Material Design.  [/en]
     *  [ja][/ja]
     */
    float: PropTypes__default["default"].bool
  };

  const Element$7 = onsCustomElement('ons-list');

  /**
   * @original ons-list
   * @category list
   * @tutorial react/Reference/list
   * @description
   *   [en]
   *     Component for representing a list. It takes an array called datasource and calls renderRow(row, index) for every row.  Furthermore, the header and the footer can be specified with `renderRow` and `renderHeader` respectively. [/en]
   * [ja][/ja]
   * @example
    <List
      dataSource={['Row 1', 'Row 2']}
      renderHeader={this.renderHeader}
      renderRow={(row, idx) => (
        <ListItem modifier={idx === this.state.data.length - 1 ? 'longdivider' : null}>
        {row}
    <Button modifier="quiet" onClick={this.remove.bind(this, idx)}>Remove</Button>
    </ListItem>
    )}
    renderFooter={this.renderFooter}
    />
   */
  const List = /*#__PURE__*/React__default["default"].forwardRef((props, ref) => {
    const {
      renderHeader,
      renderFooter,
      renderRow,
      dataSource,
      ...rest
    } = props;
    const rows = dataSource.map((data, index) => renderRow(data, index));
    return /*#__PURE__*/React__default["default"].createElement(Element$7, _extends({}, rest, {
      ref: ref
    }), renderHeader(), rows, props.children, renderFooter());
  });
  List.propTypes = {
    /**
     * @name modifier
     * @type string
     * @description
     *  [en]
     *  Specify modifier name to specify custom styles.
     *  [/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name dataSource
     * @type string
     * @description
     *  [en]
     *    Source of the list data. Should be an array.
     *  [/en]
     *  [ja][/ja]
     */
    dataSource: PropTypes__default["default"].array,
    /**
     * @name renderRow
     * @type function
     * @description
     *  [en]
     *  Function to specify the rendering function for every element in
     *  in the dataSource.
     *  [/en]
     *  [ja][/ja]
     */
    renderRow: PropTypes__default["default"].func,
    /**
     * @name renderHeader
     * @type function
     * @description
     *  [en]
     *  Function to specify the rendering function for the header
     *  [/en]
     *  [ja][/ja]
     */
    renderHeader: PropTypes__default["default"].func,
    /**
     * @name renderFooter
     * @type function
     * @description
     *  [en]
     *  Function to specify the rendering function for the footer
     *  [/en]
     *  [ja][/ja]
     */
    renderFooter: PropTypes__default["default"].func
  };
  List.defaultProps = {
    dataSource: [],
    renderRow: () => null,
    renderHeader: () => null,
    renderFooter: () => null
  };

  /**
   * @original ons-lazy-repeat
   * @category list
   * @tutorial react/Reference/lazy-list
   * @description
   * [en] Using this component a list with millions of items can be rendered without a drop in performance.
   *     It does that by "lazily" loading elements into the DOM when they come into view and
   *     removing items from the DOM when they are not visible.
   [/en]
   * [ja][/ja]
   * @example
   *
    renderRow(index) {
      return (
        <ListItem key={index}>
          {'Item ' + (index + 1)}
        </ListItem>
      );
    }

    render() {
      return (
        <Page renderToolbar={() => <MyToolbar title='LazyList' />} >
          <div style={{height: 100}}>
            <LazyList
              length={1000}
              renderRow={() =>
                <ListItem key={index}>
                  {'Item ' + (index + 1)}
                </ListItem>
              }
              calculateItemHeight={() => 44}
            />
          </div>
        </Page>
      );
    }
  }
   */
  const LazyList = /*#__PURE__*/React__default["default"].forwardRef((props, forwardedRef) => {
    const ref = forwardedRef || React.useRef();
    const [children, setChildren] = React.useState([]);
    const [, setUpdateTop] = React.useState();
    const {
      calculateItemHeight,
      renderRow,
      length,
      ...rest
    } = props;
    React.useEffect(() => {
      ref.current.delegate = {
        calculateItemHeight: function (index) {
          return calculateItemHeight(index);
        },
        _render: function (start, limit, updateTop) {
          const el = [];
          for (let i = start; i < limit; i++) {
            el.push(renderRow(i));
          }
          setChildren(el);
          setUpdateTop(updateTop); // doesn't work without this, but why? does it just trigger a rerender?
        },

        countItems: function () {
          return length;
        }
      };
    }, [calculateItemHeight, renderRow, length]);
    return /*#__PURE__*/React__default["default"].createElement(List, _extends({}, rest, {
      style: {
        position: 'relative'
      }
    }), /*#__PURE__*/React__default["default"].createElement("ons-lazy-repeat", {
      ref: ref
    }), children);
  });
  LazyList.propTypes = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the lazy list.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name length
     * @type number
     * @description
     *  [en]The length of the list.[/en]
     *  [ja][/ja]
     */
    length: PropTypes__default["default"].number.isRequired,
    /**
     * @name renderRow
     * @type function
     * @description
     *  [en] A function given the index of the to display row, renders it.[/en]
     *  [ja][/ja]
     */
    renderRow: PropTypes__default["default"].func.isRequired,
    /**
     * @name calculateItemHeight
     * @type function
     * @description
     *  [en] A function given the index of the to row, returns the height of it.[/en]
     *  [ja][/ja]
     */
    calculateItemHeight: PropTypes__default["default"].func.isRequired
  };

  /**
   * @original ons-list-header
   * @category list
   * @tutorial react/Reference/list
   * @description
   * [en] Header element for list items. Must be put inside ons-list component.
   [/en]
   * [ja][/ja]
   * @example
     <List
       dataSource={this.state.data}
       renderHeader={() =>
          <ListHeader style={{fontSize: 15}} className="testClass"> Header Text </ListHeader> }
      renderRow={(row, idx) => (
        <ListItem > {row} </ListItem>
      )}
    />
   */
  const ListHeader = onsCustomElement('ons-list-header');
  ListHeader.propTypes = {
    /**
     * @name modifier
     * @type string
     * @description
     *  [en]
     *  Specify modifier name to specify custom styles. Optional.
     *  [/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string
  };

  const propTypes$2 = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en] The appearance of the list item.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name tappable
     * @type bool
     * @description
     *  [en]
     *  Specifies whether the list item is tappable.
     *  [/en]
     *  [ja][/ja]
     */
    tappable: PropTypes__default["default"].bool,
    /**
     * @name tapBackgroundColor
     * @type string
     * @description
     *  [en]
     *  Changes the background color when tapped. For this to work, the attribute "tappable" needs to be set. The default color is "#d9d9d9". It will display as a ripple effect on Android.
     *  [/en]
     *  [ja][/ja]
     */
    tapBackgroundColor: PropTypes__default["default"].string,
    /**
     * @name keepTapBackgroundColor
     * @type bool
     * @description
     *  [en]
     *  Prevent from clearing the background color on `"touchmove"`, `"touchcancel"`, `"touchend"`, `"touchleave"`, `"mouseup"`, and `"mouseout"`. For this to work, the attribute "tappable" needs to be set.
     *  [/en]
     *  [ja][/ja]
     */
    keepTapBackgroundColor: PropTypes__default["default"].bool,
    /**
     * @name lockOnDrag
     * @type bool
     * @description
     *  [en] Prevent vertical scrolling when the user drags horizontally. [/en]
     *  [ja][/ja]
     */
    lockOnDrag: PropTypes__default["default"].bool,
    /**
     * @name expandable
     * @type bool
     * @description
     *  [en]Specifies whether list item can be expanded to reveal hidden content. Expanded content must be defined in `div.expandable-content`.[/en]
     *  [ja][/ja]
     */
    expandable: PropTypes__default["default"].bool,
    /**
     * @name expanded
     * @type bool
     * @description
     *  [en]For expandable list items, specifies whether item is expanded[/en]
     *  [ja][/ja]
     */
    expanded: PropTypes__default["default"].bool,
    /**
     * @name onExpand
     * @type function
     * @description
     *  [en] This function will be called when the expandable list item expands or contracts.[/en]
     *  [ja][/ja]
     */
    onExpand: PropTypes__default["default"].func,
    /**
     * @name animation
     * @type string
     * @description
     *  [en]The animation used when showing and hiding the expandable content. Can be either "default" or "none".[/en]
     *  [ja][/ja]
     */
    animation: PropTypes__default["default"].string
  };

  /**
   * @original ons-list-item
   * @category list
   * @tutorial react/Reference/list
   * @description
   *   [en]
   *   Component that represents each item in the list. Must be put inside the `List` component. The list item is composed of four parts that are represented with the `left`, `center`, `right` and `expandable-content` classes. These classes can be used to ensure that the content of the list items is properly aligned.
   *   [/en]
   * [ja][/ja]
   * @example
     <ListItem>
   *   <div className="left">Left</div>
   *   <div className="center">Center</div>
   *   <div className="right">Right</div>
   *   <div className="expandable-content">Expandable content</div>
   * </ListItem>
   */
  const ListItem = onsCustomElement('ons-list-item', {
    propTypes: propTypes$2
  });
  ListItem.propTypes = propTypes$2;

  const propTypes$1 = {
    /**
     * @name modifier
     * @type string
     * @description
     *  [en]
     *  Specify modifier name to specify custom styles. Optional.
     *  [/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string
  };

  /**
   * @original ons-list-title
   * @category list
   * @tutorial react/Reference/list
   * @description
   * [en] Title element for lists. Usually comes before ons-list component.
   [/en]
   * [ja][/ja]
   * @example
   * <ListTitle>List Title</ListTitle>
     <List
       dataSource={this.state.data}
       renderHeader={() =>
          <ListHeader style={{fontSize: 15}} className="testClass"> Header Text </ListHeader> }
      renderRow={(row, idx) => (
        <ListItem > {row} </ListItem>
      )}
    />
   */
  const ListTitle = onsCustomElement('ons-list-title', {
    propTypes: propTypes$1
  });
  ListTitle.propTypes = propTypes$1;

  const Element$6 = onsCustomElement('ons-navigator');
  class NavigatorClass extends React__default["default"].Component {
    constructor() {
      super(...arguments);
      this.ref = /*#__PURE__*/React__default["default"].createRef();
      this.pages = [];
      this.state = {};
      this._prePush = this._prePush.bind(this);
      this._postPush = this._postPush.bind(this);
      this._prePop = this._prePop.bind(this);
      this._postPop = this._postPop.bind(this);
    }
    update(pages, obj) {
      this.pages = pages || [];
      return new Promise(resolve => {
        this.forceUpdate(resolve);
      });
    }

    /**
     * @method resetPage
     * @signature resetPage(route, options = {})
     * @param {Object} route
     *   [en] The route that the page should be reset to.[/en]
     *   [ja][/ja]
     * @return {Promise}
     *   [en]Promise which resolves to the revealed page.[/en]
     *   [ja]明らかにしたページを解決するPromiseを返します。[/ja]
     * @description
     *   [en]Resets the current page[/en]
     *   [ja][/ja]
     */
    resetPage(route) {
      let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
      return this.resetPageStack([route], options);
    }

    /**
     * @method resetPageStack
     * @signature resetPageStack(route, options = {})
     * @param {Array} routes
     *   [en] The routes that the navigator should be reset to.[/en]
     *   [ja][/ja]
     * @return {Promise}
     *   [en]Promise which resolves to the revealed page.[/en]
     *   [ja]明らかにしたページを解決するPromiseを返します。[/ja]
     * @description
     *   [en] Resets the navigator to the current page stack[/en]
     *   [ja][/ja]
     */
    resetPageStack(routes) {
      let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
      if (this.isRunning()) {
        return Promise.reject('Navigator is already running animation.');
      }
      const hidePages = () => {
        const pageElements = this.ref.current.pages;
        for (let i = pageElements.length - 2; i >= 0; i--) {
          pageElements[i].style.display = 'none';
        }
      };
      if (options.pop) {
        this.routesBeforePop = this.routes.slice();
        this.routesAfterPop = routes;
        this.routes = routes.concat([this.routes[this.routes.length - 1]]);
        const update = () => {
          this.pages.pop();
          this.routes = routes;
          return new Promise(resolve => this.forceUpdate(resolve));
        };
        return this.update(this.pages).then(() => this.ref.current._popPage(options, update)).then(() => hidePages());
      }
      const lastRoute = routes[routes.length - 1];
      const newPage = this.props.renderPage(lastRoute, this);
      this.routes.push(lastRoute);
      const update = () => {
        this.pages.push(newPage);
        return new Promise(resolve => this.forceUpdate(resolve));
      };
      return this.ref.current._pushPage(options, update).then(() => {
        this.routes = routes;
        this.pages = routes.map(route => this.props.renderPage(route, this));
        return this.update(this.pages).then(() => hidePages());
      });
    }

    /**
     * @method pushPage
     * @signature pushPage(route, options = {})
     * @param {Object} route
     *   [en] The route that the navigator should push to.[/en]
     *   [ja][/ja]
     * @return {Promise}
     *   [en] Promise which resolves to the revealed page.[/en]
     *   [ja]明らかにしたページを解決するPromiseを返します。[/ja]
     * @description
     *   [en] Pushes a page to the page stack[/en]
     *   [ja][/ja]
     */
    pushPage(route) {
      let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
      if (this.isRunning()) {
        return Promise.reject('Navigator is already running animation.');
      }
      return new Promise(resolve => {
        const update = () => {
          return new Promise(resolve => {
            this.pages.push(this.props.renderPage(route, this));
            this.forceUpdate(resolve);
          });
        };
        this.routes.push(route);
        this.ref.current._pushPage(options, update).then(resolve).catch(error => {
          this.routes.pop();
          this.pages.pop();
          throw error;
        });
      });
    }
    isRunning() {
      return this.ref.current._isRunning;
    }

    /*
     * @method replacePage
     * @signature replacePage(route, [options])
     * @param {Object} route
     *   [en] The route that the navigator should replace the top page with.[/en]
     *   [ja][/ja]
     * @return {Promise}
     *   [en]Promise which resolves to the new page.[/en]
     *   [ja]新しいページを解決するPromiseを返します。[/ja]
     * @description
     *   [en]Replaces the current top page with the specified one. Extends `pushPage()` parameters.[/en]
     *   [ja]現在表示中のページをを指定したページに置き換えます。[/ja]
     */
    replacePage(route) {
      let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
      if (this.isRunning()) {
        return Promise.reject('Navigator is already running animation.');
      }
      return this.pushPage(route, options).then(() => {
        const pos = this.pages.length - 2;
        this.pages.splice(pos, 1);
        this.routes.splice(pos, 1);
        this.ref.current.topPage.updateBackButton(this.pages.length > 1);
        this.forceUpdate();
      });
    }

    /**
     * @method popPage
     * @signature popPage(options = {})
     * @return {Promise}
     *   [en] Promise which resolves to the revealed page.[/en]
     *   [ja]明らかにしたページを解決するPromiseを返します。[/ja]
     * @description
     *   [en] Pops a page out of the page stack[/en]
     *   [ja][/ja]
     */
    popPage() {
      let options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
      if (this.isRunning()) {
        return Promise.reject('Navigator is already running animation.');
      }
      this.routesBeforePop = this.routes.slice();
      this.routesAfterPop = this.routesBeforePop.slice(0, this.routesBeforePop.length - 1);
      const update = () => {
        return new Promise(resolve => {
          this.pages.pop();
          this.routes.pop();
          ReactDOM__default["default"].flushSync(() => {
            // prevents flickering caused by React 18 batching
            this.forceUpdate(resolve);
          });
        });
      };
      return this.ref.current._popPage(options, update);
    }
    _onDeviceBackButton(event) {
      if (this.pages.length > 1) {
        this.popPage();
      } else {
        event.callParentHandler();
      }
    }
    _prePop(event) {
      if (event.target !== this.ref.current) {
        return;
      }
      event.routes = {
        poppingRoute: this.routesBeforePop[this.routesBeforePop.length - 1],
        routes: this.routesBeforePop
      };
      this.props.onPrePop(event);
    }
    _postPop(event) {
      if (event.target !== this.ref.current) {
        return;
      }
      event.routes = {
        poppedRoute: this.routesBeforePop[this.routesBeforePop.length - 1],
        routes: this.routesAfterPop
      };
      this.props.onPostPop(event);
    }
    _prePush(event) {
      if (event.target !== this.ref.current) {
        return;
      }
      event.routes = {
        pushingRoute: this.routes[this.routes.length - 1],
        routes: this.routes.slice(0, this.routes.length - 1)
      };
      this.props.onPrePush(event);
    }
    _postPush(event) {
      if (event.target !== this.ref.current) {
        return;
      }
      event.routes = {
        pushedRoute: this.routes[this.routes.length - 1],
        routes: this.routes
      };
      this.props.onPostPush(event);
    }
    componentDidMount() {
      const node = this.ref.current;
      node.popPage = this.popPage.bind(this);
      node.addEventListener('prepush', this._prePush);
      node.addEventListener('postpush', this._postPush);
      node.addEventListener('prepop', this._prePop);
      node.addEventListener('postpop', this._postPop);
      node.swipeMax = this.props.swipePop;
      node.onDeviceBackButton = this.props.onDeviceBackButton || this._onDeviceBackButton.bind(this);
      if (this.props.initialRoute && this.props.initialRouteStack) {
        throw new Error('In Navigator either initalRoute or initalRoutes can be set');
      }
      if (this.props.initialRoute) {
        this.routes = [this.props.initialRoute];
      } else if (this.props.initialRouteStack) {
        this.routes = this.props.initialRouteStack;
      } else {
        this.routes = [];
      }
      this.pages = this.routes.map(route => this.props.renderPage(route, this));
      this.forceUpdate();
    }
    componentDidUpdate() {
      if (this.props.onDeviceBackButton !== undefined) {
        this.ref.current.onDeviceBackButton = this.props.onDeviceBackButton;
      }
    }
    componentWillUnmount() {
      const node = this.ref.current;
      node.removeEventListener('prepush', this.props.onPrePush);
      node.removeEventListener('postpush', this.props.onPostPush);
      node.removeEventListener('prepop', this.props.onPrePop);
      node.removeEventListener('postpop', this.props.onPostPop);
    }
    render() {
      const {
        innerRef,
        renderPage,
        // these props should not be passed down
        initialRouteStack,
        initialRoute,
        onPrePush,
        onPostPush,
        onPrePop,
        onPostPop,
        swipePop,
        onDeviceBackButton,
        ...rest
      } = this.props;
      const pages = this.routes ? this.routes.map(route => renderPage(route, this)) : null;
      if (innerRef && innerRef !== this.ref) {
        this.ref = innerRef;
      }
      return /*#__PURE__*/React__default["default"].createElement(Element$6, _extends({
        ref: this.ref
      }, rest), pages);
    }
  }

  /**
   * @original ons-navigator
   * @category navigation
   * @tutorial react/Reference/navigator
   * @description
   * [en] This component is responsible for page transitioning and managing the pages of your OnsenUI application. In order to manage to display the pages, the  navigator needs to define the `renderPage` method, that takes an route and a navigator and  converts it to an page.  [/en]
   * [ja][/ja]
   * @example
    <Navigator
      renderPage={(route, navigator) =>
       <MyPage
         title={route.title}
         onPop={() => navigator.popPage()}
         />
      }
      initialRoute={{
          title: 'First Page'
      }} />
     }
   }
   */
  const Navigator = /*#__PURE__*/React__default["default"].forwardRef((props, ref) => /*#__PURE__*/React__default["default"].createElement(NavigatorClass, _extends({
    innerRef: ref
  }, props), props.children));
  Navigator.propTypes = {
    /**
     * @name renderPage
     * @type function
     * @required true
     * @defaultValue null
     * @description
     *  [en] This function takes the current route object as a parameter and returns a React component.[/en]
     *  [ja][/ja]
     */
    renderPage: PropTypes__default["default"].func.isRequired,
    /**
     * @name initialRouteStack
     * @type array
     * @required false
     * @defaultValue null
     * @description
     *  [en] This array contains the initial routes from the Navigator,
     *  which will be used to render the initial pages in the `renderPage` method.
     *  [/en]
     *  [ja][/ja]
     */
    initialRouteStack: PropTypes__default["default"].array,
    /**
     * @name initialRoute
     * @type object
     * @required false
     * @defaultValue null
     * @description
     *  [en] This array contains the initial route of the navigator,
     *  which will be used to render the initial pages in the
     *  renderPage method.
     *  [/en]
     *  [ja][/ja]
     */
    initialRoute: PropTypes__default["default"].object,
    /**
     * @name onPrePush
     * @type function
     * @required false
     * @description
     *  [en]Called just before a page is pushed. It gets an event object with route information.[/en]
     *  [ja][/ja]
     */
    onPrePush: PropTypes__default["default"].func,
    /**
     * @name onPostPush
     * @type function
     * @required false
     * @description
     *  [en]Called just after a page is pushed. It gets an event object with route information.[/en]
     *  [ja][/ja]
     */
    onPostPush: PropTypes__default["default"].func,
    /**
     * @name onPrePop
     * @type function
     * @required false
     * @description
     *  [en]Called just before a page is popped. It gets an event object with route information.[/en]
     */
    onPrePop: PropTypes__default["default"].func,
    /**
     * @name onPostPop
     * @type function
     * @required false
     * @description
     *  [en]Called just after a page is popped. It gets an event object with route information.[/en]
     *  [ja][/ja]
     */
    onPostPop: PropTypes__default["default"].func,
    /**
     * @name animation
     * @type {String}
     * @description
     *   [en]
     *     Animation name. Available animations are `"slide"`, `"lift"`, `"fade"` and `"none"`.
     *     These are platform based animations. For fixed animations, add `"-ios"` or `"-md"` suffix to the animation name. E.g. `"lift-ios"`, `"lift-md"`. Defaults values are `"slide-ios"` and `"fade-md"`.
     *   [/en]
     *   [ja][/ja]
     */
    animation: PropTypes__default["default"].string,
    /**
     * @name animationOptions
     * @type object
     * @description
     *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]
     *  [ja][/ja]
     */
    animationOptions: PropTypes__default["default"].object,
    /**
     * @name swipeable
     * @type bool|string
     * @required false
     * @description
     *  [en]Enables swipe-to-pop functionality for iOS.[/en]
     *  [ja][/ja]
     */
    swipeable: PropTypes__default["default"].oneOfType([PropTypes__default["default"].bool, PropTypes__default["default"].string]),
    /**
     * @name swipePop
     * @type function
     * @required false
     * @description
     *  [en]Optional function called on swipe-to-pop. If provided, must perform a popPage with the given options object.[/en]
     *  [ja][/ja]
     */
    swipePop: PropTypes__default["default"].func,
    /**
     * @name onDeviceBackButton
     * @type function
     * @required false
     * @description
     *  [en]Custom handler for device back button.[/en]
     *  [ja][/ja]
     */
    onDeviceBackButton: PropTypes__default["default"].func
  };
  const NOOP$1 = () => null;
  Navigator.defaultProps = {
    onPostPush: NOOP$1,
    onPrePush: NOOP$1,
    onPrePop: NOOP$1,
    onPostPop: NOOP$1
  };

  const deprecated$6 = {
    isOpen: 'visible'
  };
  const notAttributes$8 = ['onDeviceBackButton'];

  /**
   * @original ons-modal
   * @category dialog
   * @tutorial react/Reference/modal
   * @description
   * [en]
   *   A modal component covers the entire screen. Underlying components are not
   *   subject to any events while the modal component is shown.
   *
   *   This component can be used to block user input while some operation is
   *   running or to show some information to the user.
   * [/en]
   * [ja]
   *   画面全体をマスクするモーダル用コンポーネントです。下側にあるコンポーネントは、
   *   モーダルが表示されている間はイベント通知が行われません
   * [/ja]
   * @example
    <Page>
      <div> Page content </div>

      <Modal isOpen={this.state.isLoading}>
        Loading ...
      </Modal>
    </Page>
   */
  const Modal = onsCustomElement(baseDialog('ons-modal'), {
    deprecated: deprecated$6,
    notAttributes: notAttributes$8
  });
  Modal.propTypes = {
    /**
     * @name animation
     * @type {String}
     * @description
     *   [en]
     *     Animation name. Available animations are `"fade"`, `"lift"` and `"none"`.
     *   [/en]
     */
    animation: PropTypes__default["default"].oneOf(['none', 'fade', 'lift']),
    /**
     * @name animationOptions
     * @type object
     * @description
     *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]
     */
    animationOptions: PropTypes__default["default"].object,
    /**
     * @name onPreShow
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called just before the modal is displayed.
     *  [/en]
     *  [ja][/ja]
     */
    onPreShow: PropTypes__default["default"].func,
    /**
     * @name onPostShow
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called just after the modal is displayed.
     *  [/en]
     *  [ja][/ja]
     */
    onPostShow: PropTypes__default["default"].func,
    /**
     * @name onPreHide
     * @type function
     * @required false
     * @description
     *  [en]Called just before the modal is hidden.[/en]
     *  [ja][/ja]
     */
    onPreHide: PropTypes__default["default"].func,
    /**
     * @name onPostHide
     * @type function
     * @required false
     * @description
     *  [en]Called just after the modal is hidden.[/en]
     *  [ja][/ja]
     */
    onPostHide: PropTypes__default["default"].func,
    /**
     * @name visible
     * @type boolean
     * @description
     *  [en]When `true` the modal will show itself.[/en]
     */
    visible: PropTypes__default["default"].bool,
    /**
     * @name isOpen
     * @type boolean
     * @description
     *  [en]DEPRECATED! Use `visible` instead.[/en]
     */
    isOpen: PropTypes__default["default"].bool,
    /**
     * @name onDeviceBackButton
     * @type function
     * @required false
     * @description
     *  [en]
     *  Custom handler for device back button.
     *  [/en]
     *  [ja][/ja]
     */
    onDeviceBackButton: PropTypes__default["default"].func
  };

  const notAttributes$7 = ['onInfiniteScroll', 'onDeviceBackButton'];
  const Element$5 = onsCustomElement('ons-page', {
    notAttributes: notAttributes$7
  });

  /**
   * @original ons-page
   * @category page
   * @tutorial react/Reference/page
   * @description
   * [en]
   *   This component is handling the entire page. The content can be scrolled.
   *
   *   To add fixed content that doesn't scroll with the page the `renderFixed` prop is used.
   *
   *   A page toolbar can be added with the `renderToolbar` prop.
   * [/en]
   * [ja][/ja]
   * @example
    <Page
      renderFixed={() => <Fab></Fab>}
      renderToolbar={() => <Toolbar>...</Toolbar>}
      contentStyle={{padding: 40}}>
      <div> Page content </div>
    </Page>
   */
  const Page = /*#__PURE__*/React__default["default"].forwardRef((props, ref) => {
    const {
      renderToolbar,
      renderBottomToolbar,
      renderModal,
      renderFixed,
      contentStyle,
      children,
      ...rest
    } = props;
    return /*#__PURE__*/React__default["default"].createElement(Element$5, _extends({}, rest, {
      ref: ref
    }), renderToolbar(ref), /*#__PURE__*/React__default["default"].createElement("div", {
      className: "page__background"
    }, " "), /*#__PURE__*/React__default["default"].createElement("div", {
      className: "page__content",
      style: contentStyle
    }, children), /*#__PURE__*/React__default["default"].createElement("div", {
      className: "page__extra",
      style: {
        zIndex: 10001
      }
    }, renderModal(ref)), renderFixed(ref), renderBottomToolbar(ref));
  });
  Page.propTypes = {
    /**
     * @name contentStyle
     * @type Object
     * @description
     *  [en]
     *  Specify the style of the page content. Optional.
     *  [/en]
     */
    contentStyle: PropTypes__default["default"].object,
    /**
     * @name modifier
     * @type string
     * @description
     *  [en]
     *  Specify modifier name to specify custom styles. Optional.
     *  [/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name renderModal
     * @type function
     * @required false
     * @defaultValue null
     * @description
     *  [en] This function renders a modal that masks current screen.[/en]
     */
    renderModal: PropTypes__default["default"].func,
    /**
     * @name renderToolbar
     * @type function
     * @required false
     * @defaultValue null
     * @description
     *  [en] This function renders the toolbar of the page.[/en]
     *  [ja][/ja]
     */
    renderToolbar: PropTypes__default["default"].func,
    /**
     * @name renderBottomToolbar
     * @type function
     * @defaultValue null
     * @description
     *  [en] This function renders the bottom toolbar of the page.[/en]
     *  [ja][/ja]
     */
    renderBottomToolbar: PropTypes__default["default"].func,
    /**
     * @name renderFixed
     * @type function
     * @defaultValue null
     * @description
     *  [en] This function renders fixed content of the page. Can be used to render `Fab` or `SpeedDial` components as well as other components that don't scroll with the page.[/en]
     *  [ja][/ja]
     */
    renderFixed: PropTypes__default["default"].func,
    /**
     * @name onInit
     * @type function
     * @required false
     * @description
     *  [en]
     *  	Fired right after the page is attached.
     *  [/en]
     *  [ja][/ja]
     */
    onInit: PropTypes__default["default"].func,
    /**
     * @name onShow
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called Fired right after the page is shown.
     *  [/en]
     *  [ja][/ja]
     */
    onShow: PropTypes__default["default"].func,
    /**
     * @name onHide
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called after the page is hidden.
     *  [/en]
     *  [ja][/ja]
     */
    onHide: PropTypes__default["default"].func,
    /**
     * @name onInfiniteScroll
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called when scrolling to the bottom of the page. It gets a 'done' callback (first argument) that must be called when it's finished.
     *  [/en]
     *  [ja][/ja]
     */
    onInfiniteScroll: PropTypes__default["default"].func,
    /**
     * @name onDeviceBackButton
     * @type function
     * @required false
     * @description
     *  [en]
     *  Custom handler for device back button.
     *  [/en]
     *  [ja][/ja]
     */
    onDeviceBackButton: PropTypes__default["default"].func
  };
  const NOOP = () => null;
  Page.defaultProps = {
    renderToolbar: NOOP,
    renderBottomToolbar: NOOP,
    renderModal: NOOP,
    renderFixed: NOOP
  };

  const deprecated$5 = {
    onCancel: 'onDialogCancel',
    isDisabled: 'disabled',
    isCancelable: 'cancelable'
  };
  const notAttributes$6 = ['onDeviceBackButton'];
  const Elem = onsCustomElement(baseDialog('ons-popover'), {
    deprecated: deprecated$5,
    notAttributes: notAttributes$6
  });

  /**
   * @original ons-popover
   * @category dialog
   * @tutorial react/Reference/popover
   * @description
   *   [en]
   *     A component that displays a popover next to an element. The popover can be used to display extra information about a component or a tooltip.
   *    Another common way to use the popover is to display a menu when a button on the screen is tapped.
   *   [/en]
   * [ja][/ja]
   * @example
   * <Page>
   *  <Button
   *    ref={(btn) => { this.btn = btn; }}
   *    onClick={() =>
   *      this.setState({target: this.btn, isOpen: true})
   *    }
   *  />
      <Popover
        isOpen={this.state.isOpen}
        onCancel={() => this.setState({isOpen: false})}
        getTarget={() => this.state.target}
      >
        <div style={{textAlign: 'center', opacity: 0.5}}>
          <p>This is a popover!</p>
            <p><small>Click the background to remove the popover.</small></p>
          </div>
          </Popover>
   * </Page>
   */
  const Popover = /*#__PURE__*/React__default["default"].forwardRef((props, forwardedRef) => {
    const {
      isOpen,
      getTarget,
      children,
      ...rest
    } = props;
    const ref = forwardedRef || React.useRef();
    React.useEffect(() => {
      if (isOpen !== ref.current.visible) {
        if (isOpen) {
          let target = getTarget();

          // if React ref was returned instead of DOM Element, use ref.current instead
          const isElement = x => x instanceof Element || x instanceof HTMLDocument;
          if (!isElement(target) && target.current) {
            target = target.current;
          }
          ref.current.show({
            target
          });
        } else {
          ref.current.hide();
        }
      }
    });
    return /*#__PURE__*/React__default["default"].createElement(Elem, _extends({
      ref: ref
    }, rest), children);
  });
  Popover.propTypes = {
    /**
     * @name getTarget
     * @type function
     * @required true
     * @description
     *  [en]
     *  This function should return a ref to the DOM node that the popover will target.
     *  [/en]
     *  [ja][/ja]
     */
    getTarget: PropTypes__default["default"].func.isRequired,
    /**
     * @name onDialogCancel
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called only if isCancelable is true. It will be called after tapping the background or by pressing the back button on Android devices.
     *  [/en]
     *  [ja][/ja]
     */
    onDialogCancel: PropTypes__default["default"].func,
    /**
     * @name onCancel
     * @type function
     * @required false
     * @description
     *  [en]
     *  DEPRECATED! Use `onDialogCancel` instead.
     *  [/en]
     *  [ja][/ja]
     */
    onCancel: PropTypes__default["default"].func,
    /**
     * @name isOpen
     * @type bool
     * @required true
     * @description
     *  [en]
     *  Indicates whether the dialog is open and shown.
     *  [/en]
     *  [ja][/ja]
     */
    isOpen: PropTypes__default["default"].bool.isRequired,
    /**
     * @name cancelable
     * @type bool
     * @required false
     * @description
     *  [en]
     *  Specifies whether the dialog is cancelable or not.
     *  A cancelable dialog will call onCancel  when tapping the background or or  pressing the back button on Android devices
     *  [/en]
     *  [ja][/ja]
     */
    cancelable: PropTypes__default["default"].bool,
    /**
     * @name isCancelable
     * @type bool
     * @required false
     * @description
     *  [en]
     *  DEPRECATED! Use `cancelable` instead.
     *  [/en]
     *  [ja][/ja]
     */
    isCancelable: PropTypes__default["default"].bool,
    /**
     * @name disabled
     * @type bool
     * @required false
     * @description
     *  [en]
     *  Specifies whether the dialog is disabled.
     *  [/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name isDisabled
     * @type bool
     * @required false
     * @description
     *  [en]
     *  DEPRECATED! Use `disabled` instead.
     *  [/en]
     *  [ja][/ja]
     */
    isDisabled: PropTypes__default["default"].bool,
    /**
     * @name animation
     * @type string
     * @required false
     * @description
     *  [en]
     *  The animation used when showing and hiding the dialog. Can be either `"none"` or `"default"`.
     *  [/en]
     *  [ja][/ja]
     */
    animation: PropTypes__default["default"].string,
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the dialog.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name maskColor
     * @type string
     * @required false
     * @description
     *  [en]Color of the background mask. Default is "rgba(0, 0, 0, 0.2)"[/en]
     *  [ja][/ja]
     */
    maskColor: PropTypes__default["default"].string,
    /**
     * @name animationOptions
     * @type object
     * @required false
     * @description
     *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]
     *  [ja][/ja]
     */
    animationOptions: PropTypes__default["default"].object,
    /**
     * @name onPreShow
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called just before the alert dialog is displayed.
     *  [/en]
     *  [ja][/ja]
     */
    onPreShow: PropTypes__default["default"].func,
    /**
     * @name onPostShow
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called just after the alert dialog is displayed.
     *  [/en]
     *  [ja][/ja]
     */
    onPostShow: PropTypes__default["default"].func,
    /**
     * @name onPreHide
     * @type function
     * @required false
     * @description
     *  [en]Called just before the alert dialog is hidden.[/en]
     *  [ja][/ja]
     */
    onPreHide: PropTypes__default["default"].func,
    /**
     * @name onPostHide
     * @type function
     * @required false
     * @description
     *  [en]Called just after the alert dialog is hidden.[/en]
     *  [ja][/ja]
     */
    onPostHide: PropTypes__default["default"].func,
    /**
     * @name onDeviceBackButton
     * @type function
     * @required false
     * @description
     *  [en]
     *  Custom handler for device back button.
     *  [/en]
     *  [ja][/ja]
     */
    onDeviceBackButton: PropTypes__default["default"].func
  };

  /**
   * @original ons-progress-bar
   * @category visual
   * @tutorial react/Reference/progress
   * @description
   * [en] The component is used to display a linear progress bar. It can either display a progress bar that shows the user how much of a task has been completed. In the case where the percentage is not known it can be used to display an animated progress bar so the user can see that an operation is in progress.  [/en]
   * [ja][/ja]
   * @example
   *<ProgressBar value={55} secondaryValue={87} />
   *<ProgressBar indeterminate />
   */
  const ProgressBar = onsCustomElement('ons-progress-bar');
  ProgressBar.propTypes = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the progress indicator.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name value
     * @type number
     * @description
     *  [en]
     *  Current progress. Should be a value between 0 and 100.
     *  [/en]
     *  [ja][/ja]
     */
    value: PropTypes__default["default"].number,
    /**
     * @name secondaryValue
     * @type bool
     * @description
     *  [en]
     *  Current secondary progress. Should be a value between 0 and 100.
     *  [/en]
     *  [ja][/ja]
     */
    secondaryValue: PropTypes__default["default"].number,
    /**
     * @name indeterminate
     * @type bool
     * @description
     *  [en] If this property is set, an infinite looping animation will be shown. [/en]
     *  [ja][/ja]
     */
    indeterminate: PropTypes__default["default"].bool
  };

  /**
   * @original ons-progress-circular
   * @category visual
   * @tutorial react/Reference/progress-circular
   * @description
   * [en] This component displays a circular progress indicator. It can either be used to show how much of a task has been completed or to show a looping animation to indicate that an operation is currently running.
   * [/en]
   * [ja][/ja]
   * @example
   *<ProgressCircular value={55} secondaryValue={87} />
   *<ProgressCircular indeterminate />
   */
  const ProgressCircular = onsCustomElement('ons-progress-circular');
  ProgressCircular.propTypes = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the progress indicator.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name value
     * @type number
     * @description
     *  [en]
     *  Current progress. Should be a value between 0 and 100.
     *  [/en]
     *  [ja][/ja]
     */
    value: PropTypes__default["default"].number,
    /**
     * @name secondaryValue
     * @type bool
     * @description
     *  [en]
     *  Current secondary progress. Should be a value between 0 and 100.
     *  [/en]
     *  [ja][/ja]
     */
    secondaryValue: PropTypes__default["default"].number,
    /**
     * @name indeterminate
     * @type bool
     * @description
     *  [en] If this property is set, an infinite looping animation will be shown. [/en]
     *  [ja][/ja]
     */
    indeterminate: PropTypes__default["default"].bool
  };

  const deprecated$4 = {
    onLoad: 'onAction',
    onChange: 'onChangeState'
  };
  const notAttributes$5 = ['onAction'];

  /**
   * @original ons-pull-hook
   * @category control
   * @tutorial react/Reference/pull-hook
   * @description
   * [en]  Component that adds **Pull to refresh** functionality to an `<ons-page>` element.
   *     It can be used to perform a task when the user pulls down at the top of the page. A common usage is to refresh the data displayed in a page.
   [/en]
   * [ja][/ja]
   * @example

      return (
        <PullHook onChange={this.onChange} onLoad={this.onLoad}>
        {
         (this.state.pullHookState === 'initial') ?
          <span >
            <Icon size={35} spin={false} icon='ion-arrow-down-a' />
            Pull down to refresh
          </span> :
          (this.state.pullHookState === 'preaction') ?
           <span>
             <Icon size={35} spin={false} icon='ion-arrow-up-a' />
             Release to refresh
          </span>
          :
          <span><Icon size={35} spin={true} icon='ion-load-d'></Icon> Loading data...</span>
      }
        </PullHook>
      );
   */
  const PullHook = onsCustomElement('ons-pull-hook', {
    deprecated: deprecated$4,
    notAttributes: notAttributes$5
  });
  PullHook.propTypes = {
    /**
     * @name onChangeState
     * @type function
     * @required false
     * @description
     *  [en]Called when the pull hook inner state is changed. The state can be either "initial", "preaction" or "action"[/en]
     *  [ja][/ja]
     */
    onChangeState: PropTypes__default["default"].func,
    /**
     * @name onChange
     * @type function
     * @required false
     * @description
     *  [en]DEPRECATED! Use `onChangeState` instead.[/en]
     *  [ja][/ja]
     */
    onChange: PropTypes__default["default"].func,
    /**
     * @name onAction
     * @type function
     * @required false
     * @description
     *  [en]Called when the pull hook is in the `action` state[/en]
     *  [ja][/ja]
     */
    onAction: PropTypes__default["default"].func,
    /**
     * @name onLoad
     * @type function
     * @required false
     * @description
     *  [en]DEPRECATED! Use `onAction` instead.[/en]
     *  [ja][/ja]
     */
    onLoad: PropTypes__default["default"].func,
    /**
     * @name onPull
     * @type function
     * @required false
     * @description
     *  [en]Hook called whenever the user pulls the element. It gets the pulled distance ratio (scroll / height) and an animationOptions object as arguments.[/en]
     *  [ja][/ja]
     */
    onPull: PropTypes__default["default"].func,
    /**
     * @name disabled
     * @type bool
     * @description
     *  [en] When set to true, the pull hook will be disabled.[/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name height
     * @type number
     * @description
     *  [en] The height of the pull hook in pixels. The default value is 64.[/en]
     *  [ja][/ja]
     */
    height: PropTypes__default["default"].number,
    /**
     * @name thresholdHeight
     * @type number
     * @description
     *  [en] The threshold height of the pull hook in pixels. The default value is 96.[/en]
     *  [ja][/ja]
     */
    thresholdHeight: PropTypes__default["default"].number,
    /**
     * @name fixedContent
     * @type number
     * @description
     *  [en] If set to true, the content of the page will not move when pulling.[/en]
     *  [ja][/ja]
     */
    fixedContent: PropTypes__default["default"].bool
  };

  const nameMap$4 = {
    ...INPUT_PROPS
  };
  const withDefaultChecked$1 = component => oneTimeProp(component, 'defaultChecked', 'checked');

  /**
   * @original ons-radio
   * @category form
   * @tutorial react/Reference/radio
   * @description
   * [en]
   *  A radio button element. The component will automatically render as a Material Design radio button on Android devices.
   *
   *  Most attributes that can be used for a normal `<input type="radio">` element can also be used on the `<Radio>` component.
   * [/en]
   * [ja][/ja]
   * @example
   * <Radio
   *   onChange={event => { this.setState({checked: event.target.checked})} }
   *   modifier='material' />
   */
  const Radio = withDefaultChecked$1(onsCustomElement('ons-radio', {
    deprecated: nameMap$4
  }));
  Radio.propTypes = {
    /**
     * @name name
     * @type string
     * @description
     *  [en]The name of the radio button.[/en]
     *  [ja][/ja]
     */
    name: PropTypes__default["default"].string,
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the radio button.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name disabled
     * @type bool
     * @description
     *  [en]
     *  Specifies whether the radio button is disabled.
     *  [/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name onChange
     * @type function
     * @description
     *  [en] Called when the radio button state changes.[/en]
     *  [ja][/ja]
     */
    onChange: PropTypes__default["default"].func,
    /**
     * @name value
     * @type string
     * @description
     *  [en] Value of the radio button.[/en]
     *  [ja][/ja]
     */
    value: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].instanceOf(Date)]),
    /**
     * @name checked
     * @type boolean
     * @description
     *  [en]Controls the state of the radio button (controlled).[/en]
     *  [ja][/ja]
     */
    checked: PropTypes__default["default"].bool,
    /**
     * @name defaultChecked
     * @type boolean
     * @description
     *  [en]Defined the state of the radio button at first render for uncontrolled inputs.[/en]
     *  [ja][/ja]
     */
    defaultChecked: PropTypes__default["default"].bool,
    /**
     * @name inputId
     * @type string
     * @description
     *  [en]Specify the "id" attribute of the inner `<input>` element. This is useful when using <label for="..."> elements.[/en]
     *  [ja][/ja]
     */
    inputId: PropTypes__default["default"].string
  };

  const nameMap$3 = {
    ...INPUT_PROPS
  };
  const withDefaultValue$2 = component => oneTimeProp(component, 'defaultValue', 'value');

  /**
   * @original ons-range
   * @category form
   * @tutorial react/Reference/range
   * @description
   * [en]
   *   Range input component.
   * [/en]
   * [ja][/ja]
   * @example
   * <Range modifier="material"
   *   value={this.state.value}
   *   onChange={(event) => this.setState({value: parseInt(event.target.value)})}
   *   />
   */
  const Range = withDefaultValue$2(onsCustomElement('ons-range', {
    deprecated: nameMap$3
  }));
  Range.propTypes = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the progress indicator.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name onChange
     * @type function
     * @description
     *  [en] Called when the value of the input changes.[/en]
     *  [ja][/ja]
     */
    onChange: PropTypes__default["default"].func,
    /**
     * @name onInput
     * @type function
     * @description
     *  [en] Called when the inner range fires an `input` event.[/en]
     *  [ja][/ja]
     */
    onInput: PropTypes__default["default"].func,
    /**
     * @name value
     * @type number
     * @description
     *  [en]
     *  Current value of the element.
     *  [/en]
     *  [ja][/ja]
     */
    value: PropTypes__default["default"].number,
    /**
     * @name value
     * @type number
     * @description
     *  [en]
     *  Default value of the element (for uncontrolled components).
     *  [/en]
     *  [ja][/ja]
     */
    defaultValue: PropTypes__default["default"].number,
    /**
     * @name disabled
     * @type bool
     * @description
     *  [en] If true, the element is disabled. [/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool
  };

  /**
   * @original ons-ripple
   * @category visual
   * @tutorial react/Reference/ripple
   * @description
   * [en]
   *   Adds a Material Design "ripple" effect to an element.
   * [/en]
   * [ja][/ja]
   * @example
     <div className='myList'>
       <Ripple color='red' />
     </div>
   */
  const Ripple = onsCustomElement('ons-ripple');
  Ripple.propTypes = {
    /**
     * @name color
     * @type string
     * @required false
     * @description
     *  [en]Color of the ripple effect.[/en]
     *  [ja][/ja]
     */
    color: PropTypes__default["default"].string,
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the ripple effect.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name background
     * @type string
     * @required false
     * @description
     *  [en]Color of the background.[/en]
     *  [ja][/ja]
     */
    background: PropTypes__default["default"].string,
    /**
     * @name size
     * @type string
     * @required false
     * @description
     *  [en]Sizing of the wave on ripple effect. Set "cover" or "contain". Default is "cover".[/en]
     *  [ja][/ja]
     */
    size: PropTypes__default["default"].string,
    /**
     * @name size
     * @type string
     * @required false
     * @description
     *  [en]Changes the position of wave effect to center of the target element.[/en]
     *  [ja][/ja]
     */
    center: PropTypes__default["default"].bool,
    /**
     * @name disabled
     * @type bool
     * @description
     *  [en]
     *  Specifies whether the button is disabled.
     *  [/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool
  };

  const Element$4 = onsCustomElement('ons-navigator');
  class RouterNavigatorClass extends React__default["default"].Component {
    constructor() {
      super(...arguments);
      this.cancelUpdate = false;
      const callback = (name, event) => {
        if (this.props[name]) {
          return this.props[name](event);
        }
      };
      this.onPrePush = callback.bind(this, 'onPrePush');
      this.onPostPush = callback.bind(this, 'onPostPush');
      this.onPrePop = callback.bind(this, 'onPrePop');
      this.onPostPop = callback.bind(this, 'onPostPop');
      this.ref = /*#__PURE__*/React__default["default"].createRef();
      this.state = {
        internalStack: []
      };
    }
    update(cb) {
      if (!this.cancelUpdate) {
        this.setState({}, cb);
      }
    }

    /**
     * @method resetPageStack
     * @signature resetPageStack(route, options = {})
     * @param {Array} [routes]
     *   [en] The routes that the navigator should be reset to.[/en]
     *   [ja][/ja]
     * @return {Promise}
     *   [en]Promise which resolves to the revealed page.[/en]
     *   [ja]明らかにしたページを解決するPromiseを返します。[/ja]
     * @description
     *   [en] Resets the navigator to the current page stack[/en]
     *   [ja][/ja]
     */
    resetPageStack(routes) {
      let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
      if (this.isRunning()) {
        return;
      }
      const update = () => {
        return new Promise(resolve => {
          this.setState({
            internalStack: [...this.state.internalStack, routes[routes.length - 1]]
          }, resolve);
        });
      };
      return this.ref.current._pushPage(options, update).then(() => {
        this.setState({
          internalStack: [...routes]
        });
      });
    }

    /**
     * @method pushPage
     * @signature pushPage(route, options = {})
     * @param {Array} [routes]
     *   [en] The routes that the navigator should push to.[/en]
     *   [ja][/ja]
     * @return {Promise}
     *   [en] Promise which resolves to the revealed page.[/en]
     *   [ja]明らかにしたページを解決するPromiseを返します。[/ja]
     * @description
     *   [en] Pushes a page to the page stack[/en]
     *   [ja][/ja]
     */
    pushPage(route) {
      let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
      if (this.isRunning()) {
        return;
      }
      const update = () => {
        return new Promise(resolve => {
          this.setState({
            internalStack: [...this.state.internalStack, route]
          }, resolve);
        });
      };
      return this.ref.current._pushPage(options, update);
    }
    isRunning() {
      return this.ref.current._isRunning;
    }

    /*
     * @method replacePage
     * @signature replacePage(page, [options])
     * @return {Promise}
     *   [en]Promise which resolves to the new page.[/en]
     *   [ja]新しいページを解決するPromiseを返します。[/ja]
     * @description
     *   [en]Replaces the current top page with the specified one. Extends `pushPage()` parameters.[/en]
     *   [ja]現在表示中のページをを指定したページに置き換えます。[/ja]
     */
    replacePage(route) {
      let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
      if (this.isRunning()) {
        return;
      }
      const update = () => {
        return new Promise(resolve => {
          this.setState({
            internalStack: [...this.state.internalStack, route]
          }, resolve);
        });
      };
      return this.ref.current._pushPage(options, update).then(() => {
        this.setState({
          internalStack: [...this.state.internalStack.slice(0, -2), route]
        });
      });
    }

    /**
     * @method popPage
     * @signature popPage(route, options = {})
     * @return {Promise}
     *   [en] Promise which resolves to the revealed page.[/en]
     *   [ja]明らかにしたページを解決するPromiseを返します。[/ja]
     * @description
     *   [en] Pops a page out of the page stack[/en]
     *   [ja][/ja]
     */
    popPage() {
      let options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
      if (this.isRunning()) {
        return;
      }
      const update = () => {
        return new Promise(resolve => {
          ReactDOM__default["default"].flushSync(() => {
            // prevents flickering caused by React 18 batching
            this.setState({
              internalStack: this.state.internalStack.slice(0, -1)
            }, resolve);
          });
        });
      };
      return this.ref.current._popPage(options, update);
    }
    _onDeviceBackButton(event) {
      if (this.props.routeConfig.routeStack.length > 1) {
        this.popPage();
      } else {
        event.callParentHandler();
      }
    }
    componentDidMount() {
      const node = this.ref.current;
      this.cancelUpdate = false;
      node.addEventListener('prepush', this.onPrePush);
      node.addEventListener('postpush', this.onPostPush);
      node.addEventListener('prepop', this.onPrePop);
      node.addEventListener('postpop', this.onPostPop);
      if (!this.props.routeConfig) {
        throw new Error('In RouterNavigator the property routeConfig needs to be set');
      }
      node.swipeMax = this.props.swipePop;
      node.onDeviceBackButton = this.props.onDeviceBackButton || this._onDeviceBackButton.bind(this);
      this.setState({
        internalStack: this.props.routeConfig.routeStack
      });
    }
    componentWillUnmount() {
      const node = this.ref.current;
      node.removeEventListener('prepush', this.onPrePush);
      node.removeEventListener('postpush', this.onPostPush);
      node.removeEventListener('prepop', this.onPrePop);
      node.removeEventListener('postpop', this.onPostPop);
      this.cancelUpdate = true;
    }
    componentDidUpdate(prevProps) {
      if (this.props.onDeviceBackButton !== undefined) {
        this.ref.current.onDeviceBackButton = this.props.onDeviceBackButton;
      }
      const processStack = [...this.props.routeConfig.processStack];

      /**
       * Fix for Redux Timetravel.
       */
      if (prevProps.routeConfig.processStack.length < this.props.routeConfig.processStack.length && prevProps.routeConfig.routeStack.length > this.props.routeConfig.routeStack.length) {
        return;
      }
      if (processStack.length > 0) {
        const {
          type,
          route,
          options
        } = processStack[0];
        switch (type) {
          case 'push':
            this.pushPage(route, options);
            break;
          case 'pop':
            this.popPage(options);
            break;
          case 'reset':
            if (Array.isArray(route)) {
              this.resetPageStack(route, options);
            } else {
              this.resetPageStack([route], options);
            }
            break;
          case 'replace':
            this.replacePage(route, options);
            break;
          default:
            throw new Error(`Unknown type ${type} in processStack`);
        }
      }
    }
    render() {
      const {
        innerRef,
        renderPage,
        // these props should not be passed down
        onPrePush,
        onPostPush,
        onPrePop,
        onPostPop,
        swipePop,
        onDeviceBackButton,
        ...rest
      } = this.props;
      const pagesToRender = this.state.internalStack.map(route => renderPage(route));
      if (innerRef && innerRef !== this.ref) {
        this.ref = innerRef;
      }
      return /*#__PURE__*/React__default["default"].createElement(Element$4, _extends({}, rest, {
        ref: this.ref
      }), pagesToRender);
    }
  }

  /**
   * @original ons-navigator
   * @category navigation
   * @tutorial react/Reference/navigator
   * @description
   * [en] This component is a variant of the Navigator with a declarative API. In order to manage to display the pages, the  navigator needs to define the `renderPage` method, that takes an route and a navigator and  converts it to an page.[/en]
   * [ja][/ja]
   */
  const RouterNavigator = /*#__PURE__*/React__default["default"].forwardRef((props, ref) => /*#__PURE__*/React__default["default"].createElement(RouterNavigatorClass, _extends({
    innerRef: ref
  }, props), props.children));
  RouterNavigator.propTypes = {
    /**
     * @name renderPage
     * @type function
     * @required true
     * @defaultValue null
     * @description
     *  [en] This function takes the current route object as a parameter and returns a react componen.[/en]
     *  [ja][/ja]
     */
    renderPage: PropTypes__default["default"].func.isRequired,
    /**
     * @name routeConfig
     * @type object
     * @required true
     * @defaultValue null
     * @description
     *  [en] This object must contain two properties:
     *  `routeStack`: An array of route objects,
     *  `processStack`: An array of process objects `{ type: push | pop | reset, route: userRoute }` that
     *  describe the transition from the current state to the next state.
     *  Make sure that the route stack is not emptied before the animations for the `processStack` have completed.
     *  It is recommended to update the `routeStack` and empty the `processStack` in the 'onPostPop' callback.
     *  [/en]
     *  [ja][/ja]
     */
    routeConfig: PropTypes__default["default"].shape({
      routeStack: PropTypes__default["default"].arrayOf(PropTypes__default["default"].object),
      processStack: PropTypes__default["default"].arrayOf(PropTypes__default["default"].object)
    }),
    /**
     * @name onPrePush
     * @type function
     * @required false
     * @description
     *  [en]Called just before a page is pushed.[/en]
     */
    onPrePush: PropTypes__default["default"].func,
    /**
     * @name onPostPush
     * @type function
     * @required false
     * @description
     *  [en]Called just after a page is pushed.[/en]
     */
    onPostPush: PropTypes__default["default"].func,
    /**
     * @name onPrePop
     * @type function
     * @required false
     * @description
     *  [en]Called just before a page is popped.[/en]
     */
    onPrePop: PropTypes__default["default"].func,
    /**
     * @name onPostPop
     * @type function
     * @required false
     * @description
     *  [en]Called just after a page is popped.[/en]
     */
    onPostPop: PropTypes__default["default"].func,
    /**
     * @property animation
     * @type {String}
     * @description
     *   [en]
     *     Animation name. Available animations are `"slide"`, `"lift"`, `"fade"` and `"none"`.
     *     These are platform based animations. For fixed animations, add `"-ios"` or `"-md"` suffix to the animation name. E.g. `"lift-ios"`, `"lift-md"`. Defaults values are `"slide-ios"` and `"fade-md"`.
     *   [/en]
     */
    animation: PropTypes__default["default"].string,
    /**
     * @name animationOptions
     * @type object
     * @description
     *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]
     *  [ja][/ja]
     */
    animationOptions: PropTypes__default["default"].object,
    /**
     * @name swipeable
     * @type bool|string
     * @required false
     * @description
     *  [en]
     *  Enables swipe-to-pop functionality for iOS.
     *  [/en]
     *  [ja][/ja]
     */
    swipeable: PropTypes__default["default"].oneOfType([PropTypes__default["default"].bool, PropTypes__default["default"].string]),
    /**
     * @name swipePop
     * @type function
     * @required false
     * @description
     *  [en]
     *  Function called on swipe-to-pop. Must perform a popPage with the given options object.
     *  [/en]
     *  [ja][/ja]
     */
    swipePop: PropTypes__default["default"].func,
    /**
     * @name onDeviceBackButton
     * @type function
     * @required false
     * @description
     *  [en]
     *  Custom handler for device back button.
     *  [/en]
     *  [ja][/ja]
     */
    onDeviceBackButton: PropTypes__default["default"].func
  };

  /**
   * @original ons-row
   * @category grid
   * @description
   * [en]
   * Represents a row in the grid system. Use with `Col` to layout components.
   * [/en]
   * [ja][/ja]
   * <Row>
   *   <Col width={50}>
    *   <ons-icon icon="fa-twitter"></ons-icon>
   *   </Col>
   *   <Col>Text</Col>
   * </Row>
   */
  const Row = onsCustomElement('ons-row');
  Row.propTypes = {
    /**
    * @name verticalAlign
    * @type {String}
    * @description
    *   [en]Short hand attribute for aligning vertically. Valid values are top, bottom, and center.[/en]
    *   [ja][/ja]
    */
    verticalAlign: PropTypes__default["default"].oneOf(['top', 'bottom', 'center'])
  };

  const nameMap$2 = {
    ...INPUT_PROPS
  };
  const withDefaultValue$1 = component => oneTimeProp(component, 'defaultValue', 'value');
  const notAttributes$4 = ['value' // value must be applied as property since attribute only works before input is touched
  ];

  /**
   * @original ons-search-input
   * @category form
   * @tutorial react/Reference/search-input
   * @description
   * [en]
   *  A search input component. The component will automatically render as a Material Design search input on Android devices.
   *
   *  Most attributes that can be used for a normal `<input>` element can also be used on the `<SearchInput>` component.
   * [/en]
   * [ja][/ja]
   * @example
   * <SearchInput
   *   value={this.state.text}
   *   onChange={(event) => { this.setState({text: event.target.value})} }
   *   modifier='material'
   *   placeholder='Username' />
   */
  const SearchInput = withDefaultValue$1(onsCustomElement('ons-search-input', {
    deprecated: nameMap$2,
    notAttributes: notAttributes$4
  }));
  SearchInput.propTypes = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the input.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name disabled
     * @type bool
     * @description
     *  [en]Specifies whether the input is disabled.[/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name readOnly
     * @type bool
     * @description
     *  [en]Specifies whether the input is read-only.[/en]
     *  [ja][/ja]
     */
    readOnly: PropTypes__default["default"].bool,
    /**
     * @name onChange
     * @type function
     * @description
     *  [en]Called when the inner input fires a `change` event.[/en]
     *  [ja][/ja]
     */
    onChange: PropTypes__default["default"].func,
    /**
     * @name onInput
     * @type function
     * @description
     *  [en]Called when the inner input fires an `input` event.[/en]
     *  [ja][/ja]
     */
    onInput: PropTypes__default["default"].func,
    /**
     * @name value
     * @type string
     * @description
     *  [en]Content of the input (controlled).[/en]
     *  [ja][/ja]
     */
    value: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].instanceOf(Date)]),
    /**
     * @name defaultValue
     * @type string
     * @description
     *  [en]Content of the input at first render (uncontrolled).[/en]
     *  [ja][/ja]
     */
    defaultValue: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].instanceOf(Date)]),
    /**
     * @name placeholder
     * @type string
     * @description
     *  [en] Placeholder text. In Material Design this placeholder will be a floating label. [/en]
     *  [ja][/ja]
     */
    placeholder: PropTypes__default["default"].string,
    /**
     * @name inputId
     * @type string
     * @description
     *  [en]  Specify the "id" attribute of the inner `<input>` element. This is useful when using <label for="..."> elements [/en]
     *  [ja][/ja]
     */
    inputId: PropTypes__default["default"].string
  };

  const deprecated$3 = {
    index: 'activeIndex'
  };

  /**
   * @original ons-segment
   * @category control
   * @tutorial react/Reference/segment
   * @description
   * [en]
   *   Segment component.
   * [/en]
   * [ja][/ja]
   * @example
   * <Segment modifier="material">
   *  <button>Label 1</button>
   *  <button>Label 2</button>
   *  <button>Label 3</button>
   * </Segment>
   */
  const Segment = onsCustomElement('ons-segment', {
    deprecated: deprecated$3
  });
  Segment.propTypes = {
    /**
     * @name activeIndex
     * @type number
     * @description
     *  [en]The index of the button to highlight.[/en]
     *  [ja][/ja]
     */
    activeIndex: PropTypes__default["default"].number,
    /**
     * @name index
     * @type number
     * @description
     *  [en]DEPRECATED! Use `activeIndex` instead.[/en]
     *  [ja][/ja]
     */
    index: PropTypes__default["default"].number,
    /**
     * @name tabbarId
     * @type string
     * @description
     *  [en] ID of the `<Tabbar>` to "connect" to the segment. [/en]
     *  [ja][/ja]
     */
    tabbarId: PropTypes__default["default"].string,
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the segment.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name onPostChange
     * @type function
     * @description
     *  [en] Called after the active button changes.[/en]
     *  [ja][/ja]
     */
    onPostChange: PropTypes__default["default"].func,
    /**
     * @name disabled
     * @type boolean
     * @description
     *   [en]Specifies whether the segment should be disabled.[/en]
     *   [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool
  };

  const nameMap$1 = {
    ...INPUT_PROPS
  };
  const withDefaultValue = component => oneTimeProp(component, 'defaultValue', 'value');
  const Element$3 = withDefaultValue(onsCustomElement('ons-select', {
    deprecated: nameMap$1
  }));

  /**
   * @original ons-select
   * @category form
   * @tutorial react/Reference/select
   * @description
   * [en]
   *   Select input component.
   * [/en]
   * [ja][/ja]
   * @example
   * <Select modifier="material"
   *   value={this.state.value}
   *   onChange={(event) => this.setState({value: event.target.value})}>
   *   <option value="1">1</option>
   *   <option value="2">2nd</option>
   *   <option value="3">3rd option</option>
   * </Select>
   */
  const Select = /*#__PURE__*/React__default["default"].forwardRef((props, ref) => /*#__PURE__*/React__default["default"].createElement(Element$3, _extends({}, props, {
    ref: ref
  }), /*#__PURE__*/React__default["default"].createElement("select", null, props.children)));
  Select.propTypes = {
    /**
     * @name modifier
     * @type string
     * @description
     *  [en]The appearance of the select box.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name disabled
     * @type bool
     * @description
     *  [en]Specifies whether the select is disabled.[/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name onChange
     * @type function
     * @description
     *  [en]Called when the value of the select changes.[/en]
     *  [ja][/ja]
     */
    onChange: PropTypes__default["default"].func,
    /**
     * @name value
     * @type string
     * @description
     *  [en]Use this prop to set the selected option value.[/en]
     *  [ja][/ja]
     */
    value: PropTypes__default["default"].string,
    /**
     * @name defaultValue
     * @type string
     * @description
     *  [en]Use this prop to set the defalut selected option value (uncontrolled components).[/en]
     *  [ja][/ja]
     */
    defaultValue: PropTypes__default["default"].string,
    /**
     * @name multiple
     * @type boolean
     * @description
     *  [en]If this attribute is defined, multiple options can be selected at once.[/en]
     *  [ja][/ja]
     */
    multiple: PropTypes__default["default"].bool,
    /**
     * @name autofocus
     * @type boolean
     * @description
     *  [en]Element automatically gains focus on page load.[/en]
     *  [ja][/ja]
     */
    autofocus: PropTypes__default["default"].bool,
    /**
     * @name required
     * @type boolean
     * @description
     *  [en]Make the select input required for submitting the form it is part of.[/en]
     *  [ja][/ja]
     */
    required: PropTypes__default["default"].bool,
    /**
     * @name form
     * @type string
     * @description
     *  [en]Associate a select element to an existing form on the page, even if not nested.[/en]
     *  [ja][/ja]
     */
    form: PropTypes__default["default"].string,
    /**
     * @name size
     * @type number
     * @description
     *  [en]How many options are displayed; if there are more than the size then a scroll appears to navigate them[/en]
     *  [ja][/ja]
     */
    size: PropTypes__default["default"].number,
    /**
     * @name name
     * @type string
     * @description
     *  [en]Name the select element, useful for instance if it is part of a form.[/en]
     *  [ja][/ja]
     */
    name: PropTypes__default["default"].string
  };

  /**
   * @original ons-speed-dial
   * @category control
   * @tutorial react/Reference/speed-dial
   * @description
   * [en] Element that displays a Material Design Speed Dialog component. It is useful when there are more than one primary action that can be performed in a page.
   *  The Speed dial looks like a `Fab` element but will expand a menu when tapped.
   [/en]
   * [ja][/ja]
   * @example
   * <SpeedDial disabled={false} direction='right' onClick={() => console.log('test1')} position='left bottom'>
       <Fab>
         <Icon icon='fa-twitter' size={26} fixedWidth={false} style={{verticalAlign: 'middle'}} />
       </Fab>
       <SpeedDialItem onClick={() => console.log('speed A')}> A </SpeedDialItem>
       <SpeedDialItem onClick={() => console.log('speed B')}> B </SpeedDialItem>
       <SpeedDialItem onClick={() => console.log('speed C')}> C </SpeedDialItem>
       <SpeedDialItem onClick={() => console.log('speed D')}> D </SpeedDialItem>
     </SpeedDial>
   */
  const SpeedDial = onsCustomElement('ons-speed-dial');
  SpeedDial.propTypes = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the speed dial.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name position
     * @type string
     * @description
     *  [en]Specify the vertical and horizontal position of the component.
     *     I.e. to display it in the top right corner specify "right top".
     *     Choose from "right", "left", "top" and "bottom".
    [/en]
     *  [ja][/ja]
     */
    position: PropTypes__default["default"].string,
    /**
     * @name direction
     * @type string
     * @description
     *  [en]Specify the direction the items are displayed. Possible values are "up", "down", "left" and "right".[/en]
     *  [ja][/ja]
     */
    direction: PropTypes__default["default"].oneOf(['up', 'down', 'left', 'right']),
    /**
     * @name disabled
     * @type string
     * @description
     *  [en]Specify if button should be disabled.[/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool
  };

  /**
   * @original ons-speed-dial-item
   * @category control
   * @tutorial react/Reference/speed-dial
   * @description
   * [en] This component displays the child elements of the Material Design Speed dial component. [/en]
   * [ja][/ja]
   * @example
   * <SpeedDial disabled={false} direction='right' onClick={() => console.log('test1')} position='left bottom'>
       <Fab>
         <Icon icon='fa-twitter' size={26} fixedWidth={false} style={{verticalAlign: 'middle'}} />
       </Fab>
       <SpeedDialItem onClick={() => console.log('speed A')}> A </SpeedDialItem>
       <SpeedDialItem onClick={() => console.log('speed B')}> B </SpeedDialItem>
       <SpeedDialItem onClick={() => console.log('speed C')}> C </SpeedDialItem>
       <SpeedDialItem onClick={() => console.log('speed D')}> D </SpeedDialItem>
     </SpeedDial>
   */
  const SpeedDialItem = onsCustomElement('ons-speed-dial-item');
  SpeedDialItem.propTypes = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the button.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name onClick
     * @type function
     * @description
     *  [en]This function will be called when the button is clicked.[/en]
     *  [ja][/ja]
     */
    onClick: PropTypes__default["default"].func
  };

  const notAttributes$3 = ['onDeviceBackButton'];

  /**
   * @original ons-splitter
   * @category menu
   * @tutorial react/Reference/splitter
   * @description
   * [en]  A component that enables responsive layout by implementing both a two-column layout and a sliding menu layout.
   *
   *    It can be configured to automatically expand into a column layout on large screens and collapse the menu on smaller screens. When the menu is collapsed the user can open it by swiping.
   [/en]
   * [ja][/ja]
   * @example
    <Splitter>
      <SplitterSide
        side="left"
        width={200}
        isSwipeable={true}>
        <Page> Page Left </Page>
      </SplitterSide>
      <SplitterContent>
        <Page> Page Content </Page>
      </SplitterContent>
      <SplitterSide
        side="right"
        width={300}
        collapse={!this.state.showRight}
        isOpen={this.state.openRight}
        onClose={this.handleRightClose.bind(this)}
        onOpen={this.handleRightOpen.bind(this)}
        isSwipeable={true}>
        <Page> Page Right </Page>
      </SplitterSide>
    </Splitter>
   */
  const Splitter = onsCustomElement('ons-splitter', {
    notAttributes: notAttributes$3
  });
  Splitter.propTypes = {
    /**
     * @name onDeviceBackButton
     * @type function
     * @required false
     * @description
     *  [en]
     *  Custom handler for device back button.
     *  [/en]
     *  [ja][/ja]
     */
    onDeviceBackButton: PropTypes__default["default"].func
  };

  /**
   * @original ons-splitter-content
   * @category menu
   * @tutorial react/Reference/splitter
   * @description
   * [en]  The SplitterContent  element is used as a child element of Splitter.
   *    It contains the main content of the page while SplitterSide contains the list.
   [/en]
   * [ja][/ja]
   * @example
    <Splitter>
      <SplitterSide
        side="left"
        width={200}
        isSwipeable={true}>
        <Page> Page Left </Page>
      </SplitterSide>
      <SplitterContent>
        <Page> Page Content </Page>
      </SplitterContent>
      <SplitterSide
        side="right"
        width={300}
        collapse={!this.state.showRight}
        isOpen={this.state.openRight}
        onClose={this.handleRightClose.bind(this)}
        onOpen={this.handleRightOpen.bind(this)}
        isSwipeable={true}>
        <Page> Page Right </Page>
      </SplitterSide>
    </Splitter>
   */
  const SplitterContent = onsCustomElement('ons-splitter-content');

  /**
   * @original ons-splitter-mask
   * @category menu
   * @tutorial react/Reference/splitter
   * @description
   * [en]  The SplitterMask  element is used as a child element of Splitter.
   *    It contains the mask content of the page.
   [/en]
   * [ja][/ja]
   * @example
    <Splitter>
      <SplitterSide
        side="left"
        width={200}
        isSwipeable={true}>
        <Page> Page Left </Page>
      </SplitterSide>
      <SplitterMask>
        <Page> Page Content </Page>
      </SplitterMask>
      <SplitterSide
        side="right"
        width={300}
        collapse={!this.state.showRight}
        isOpen={this.state.openRight}
        onClose={this.handleRightClose.bind(this)}
        onOpen={this.handleRightOpen.bind(this)}
        isSwipeable={true}>
        <Page> Page Right </Page>
      </SplitterSide>
    </Splitter>
   */
  const SplitterMask = onsCustomElement('ons-splitter-mask');

  const deprecated$2 = {
    onOpen: 'onPostOpen',
    onClose: 'onPostClose'
  };
  const notAttributes$2 = ['isOpen'];
  const Element$2 = onsCustomElement('ons-splitter-side', {
    deprecated: deprecated$2,
    notAttributes: notAttributes$2
  });

  /**
   * @original ons-splitter-side
   * @category menu
   * @tutorial react/Reference/splitter
   * @description
   * [en]  The SplitterContent  element is used as a child element of Splitter.
   *    It contains the main content of the page while SplitterSide contains the list.
   [/en]
   * [ja][/ja]
   * @example
    <Splitter>
      <SplitterSide
        side="left"
        width={200}
        swipeable={true}>
        <Page> Page Left </Page>
      </SplitterSide>
      <SplitterContent>
        <Page> Page Content </Page>
      </SplitterContent>
      <SplitterSide
        side="right"
        width={300}
        collapse={!this.state.showRight}
        isOpen={this.state.openRight}
        onClose={this.handleRightClose.bind(this)}
        onOpen={this.handleRightOpen.bind(this)}
        swipeable={true}>
        <Page> Page Right </Page>
      </SplitterSide>
    </Splitter>
   */
  const SplitterSide = /*#__PURE__*/React__default["default"].forwardRef((props, ref) => {
    const {
      width,
      ...rest
    } = props;

    // number values for width are deprecated but handle them safely to avoid breaking user code
    const realWidth = typeof width === 'number' ? `${width}px` : width;
    return /*#__PURE__*/React__default["default"].createElement(Element$2, _extends({
      width: realWidth,
      ref: ref
    }, rest), props.children);
  });
  SplitterSide.propTypes = {
    /**
     * @name collapse
     * @type string
     * @description
     *  [en] Specify the collapse behavior. Valid values are `"portrait"`, `"landscape"` or a media query.
     *     The strings `"portrait"` and `"landscape"` means the view will collapse when device is in landscape or portrait orientation.
     *     If the value is not defined, the view always be in `"collapse"` mode.
    [/en]
     *  [ja][/ja]
     */
    collapse: PropTypes__default["default"].oneOfType([PropTypes__default["default"].bool, PropTypes__default["default"].string]),
    /**
     * @name swipeable
     * @type bool
     * @description
     *  [en]Ennable swipe interaction on collapse mode.[/en]
     *  [ja][/ja]
     */
    swipeable: PropTypes__default["default"].bool,
    /**
     * @name isOpen
     * @type bool
     * @description
     *  [en]Specifies whether the menu is open.[/en]
     *  [ja][/ja]
     */
    isOpen: PropTypes__default["default"].bool,
    /**
     * @name onPostOpen
     * @type function
     * @description
     *  [en]Called after the menu is opened.[/en]
     *  [ja][/ja]
     */
    onPostOpen: PropTypes__default["default"].func,
    /**
     * @name onOpen
     * @type function
     * @description
     *  [en]DEPRECATED! Use `onPostOpen` instead.[/en]
     *  [ja][/ja]
     */
    onOpen: PropTypes__default["default"].func,
    /**
     * @name onPostClose
     * @type function
     * @description
     *  [en]Called after the menu is closed.[/en]
     *  [ja][/ja]
     */
    onPostClose: PropTypes__default["default"].func,
    /**
     * @name onClose
     * @type function
     * @description
     *  [en]DEPRECATED! Use `onPostClose` instead.[/en]
     *  [ja][/ja]
     */
    onClose: PropTypes__default["default"].func,
    /**
     * @name side
     * @type string
     * @description
     *  [en]Specify which side of the screen the SplitterSide element is located. Possible values are `"left"` and `"right"`.[/en]
     *  [ja][/ja]
     */
    side: PropTypes__default["default"].oneOf(['left', 'right']),
    /**
     * @name swipeTargetWidth
     * @type number
     * @description
     *  [en]The width of swipeable area calculated from the edge (in pixels). Use this to enable swipe only when the finger touch on the screen edge.[/en]
     *  [ja][/ja]
     */
    swipeTargetWidth: PropTypes__default["default"].number,
    /**
     * @name width
     * @type  number
     * @description
     *  [en]Specifies the width of the menu. Can be specified in either pixels or as a percentage, e.g. `"90%"` or `"200px"`.[/en]
     *  [ja][/ja]
     */
    width: PropTypes__default["default"].string,
    /**
     * @name animation
     * @type string
     * @required false
     * @description
     *  [en]Specify the animation. Use one of `overlay`, `push`, `reveal`, or `default`.[/en]
     *  [ja][/ja]
     */
    animation: PropTypes__default["default"].string,
    /**
     * @name animationOptions
     * @type object
     * @required false
     * @description
     *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]
     *  [ja][/ja]
     */
    animationOptions: PropTypes__default["default"].object,
    /**
     * @name openThreshold
     * @type object
     * @required false
     * @description
     *  [en] Specify how much the menu needs to be swiped before opening. A value between `0` and `1`.  [/en]
     *  [ja][/ja]
     */
    openThreshold: PropTypes__default["default"].number,
    /**
     * @name onPreOpen
     * @type string
     * @description
     *  [en] Called before the menu opens.  [/en]
     *  [ja][/ja]
     */
    onPreOpen: PropTypes__default["default"].func,
    /**
     * @name onPreClose
     * @type string
     * @description
     *  [en] Called before the menu closes.  [/en]
     *  [ja][/ja]
     */
    onPreClose: PropTypes__default["default"].func,
    /**
     * @name onModeChange
     * @type string
     * @description
     *  [en] Called after the component's mode changes. [/en]
     *  [ja][/ja]
     */
    onModeChange: PropTypes__default["default"].func
  };

  const nameMap = {
    ...INPUT_PROPS
  };
  const withDefaultChecked = component => oneTimeProp(component, 'defaultChecked', 'checked');

  /**
   * @original ons-switch
   * @category form
   * @tutorial react/Reference/switch
   * @description
   * [en]   Switch component. The switch can be toggled both by dragging and tapping.
   *     Will automatically displays a Material Design switch on Android devices.
   [/en]
   * [ja][/ja]
   * @example
   * <Switch checked={this.state.checked} onChange={this.onChange} />
   */
  const Switch = withDefaultChecked(onsCustomElement('ons-switch', {
    deprecated: nameMap
  }));
  Switch.propTypes = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the checkbox.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name onChange
     * @type function
     * @description
     *  [en] Called when the value of the switch changes (checked/unchecked) [/en]
     *  [ja][/ja]
     */
    onChange: PropTypes__default["default"].func,
    /**
     * @name checked
     * @type bool
     * @description
     *  [en] Whether the switch is checked.[/en]
     *  [ja][/ja]
     */
    checked: PropTypes__default["default"].bool,
    /**
     * @name defaultChecked
     * @type boolean
     * @description
     *  [en]Defined the state of the switch at first render for uncontrolled inputs.[/en]
     *  [ja][/ja]
     */
    defaultChecked: PropTypes__default["default"].bool,
    /**
     * @name disabled
     * @type bool
     * @description
     *  [en] If set, the switch is disabled.[/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name inputId
     * @type string
     * @description
     *  [en] Specify the `id` attribute of the inner `<input>` element. This is useful when using `<label for="...">` elements.[/en]
     *  [ja][/ja]
     */
    inputId: PropTypes__default["default"].string
  };

  /**
   * @original ons-tab
   * @category tabbar
   * @tutorial react/Reference/tabbar
   * @description
   * [en] Represents a tab inside tab bar.
   [/en]
   * [ja][/ja]
   * @example
   * <Tap>
   *   Home
   * </Tap>
   */
  const Tab = onsCustomElement('ons-tab');
  Tab.propTypes = {
    /**
     * @name icon
     * @type string
     * @description
     *  [en]The icon name for the tab. Can specify the same icon name as <ons-icon>.[/en]
     *  [ja][/ja]
     */
    icon: PropTypes__default["default"].string,
    /**
     * @name activeIcon
     * @type string
     * @description
     *  [en]The name of the icon when the tab is active.[/en]
     *  [ja][/ja]
     */
    activeIcon: PropTypes__default["default"].string,
    /**
     * @name label
     * @type string
     * @description
     *  [en]The label of the tab item.[/en]
     *  [ja][/ja]
     */
    label: PropTypes__default["default"].string,
    /**
     * @name badge
     * @type string
     * @description
     *  [en]Display a notification badge on top of the tab.[/en]
     *  [ja][/ja]
     */
    badge: PropTypes__default["default"].string
  };

  const deprecated$1 = {
    index: 'activeIndex'
  };
  const Element$1 = onsCustomElement('ons-tabbar', {
    deprecated: deprecated$1
  });

  /**
   * @original ons-tabbar
   * @category tabbar
   * @tutorial react/Reference/tabbar
   * @description
   * [en] Component to display a tabbar on either the top or the bottom of a page.
   * To define the tabs and the content the property renderTabs need to be implemented, that returns an array of tabs and their content. See the example for specifics. [/en]* [ja][/ja]
   * @example

    <Page>
      <Tabbar
        onPreChange={({index}) => this.setState(index)}
        onPostChange={() => console.log('postChange')}
        onReactive={() => console.log('postChange')}
        position='bottom'
        index={this.state.index}
        renderTabs={(activeIndex, tabbar) => [
          {
            content: <TabPage title="Home" active={activeIndex === 0} tabbar={tabbar} />,
            tab: <Tab label="Home" icon="md-home" />
          },
          {
            content: <TabPage title="Settings" active={activeIndex === 1} tabbar={tabbar} />,
            tab: <Tab label="Settings" icon="md-settings" />
          }]
        }
      />
    </Page>
   */
  const Tabbar = /*#__PURE__*/React__default["default"].forwardRef((props, ref) => {
    const {
      visible,
      hideTabs,
      renderTabs,
      ...rest
    } = props;
    const tabs = renderTabs(props.activeIndex, ref);

    // visible is deprecated in favour of hideTabs, but if visible is defined and
    // hideTabs is not, we use its negation as the value of hideTabs
    let reallyHideTabs;
    if (hideTabs === undefined && visible !== undefined) {
      reallyHideTabs = !visible;
    } else {
      reallyHideTabs = hideTabs;
    }
    return /*#__PURE__*/React__default["default"].createElement(Element$1, _extends({
      hideTabs: reallyHideTabs
    }, rest, {
      ref: ref
    }), /*#__PURE__*/React__default["default"].createElement("div", {
      className: "tabbar__content"
    }, /*#__PURE__*/React__default["default"].createElement("div", null, tabs.map(tab => tab.content)), /*#__PURE__*/React__default["default"].createElement("div", null)), /*#__PURE__*/React__default["default"].createElement("div", {
      className: "tabbar"
    }, tabs.map(tab => tab.tab), /*#__PURE__*/React__default["default"].createElement("div", {
      className: "tabbar__border"
    })));
  });
  Tabbar.propTypes = {
    /**
     * @name activeIndex
     * @type number
     * @description
     *  [en]The index of the tab to highlight.[/en]
     *  [ja][/ja]
     */
    activeIndex: PropTypes__default["default"].number,
    /**
     * @name index
     * @type number
     * @description
     *  [en]DEPRECATED! Use `activeIndex` instead.[/en]
     *  [ja][/ja]
     */
    index: PropTypes__default["default"].number,
    /**
     * @name renderTabs
     * @type function
     * @description
     *  [en]Function that returns an array of objects with the keys `content` and `tab`.[/en]
     *  [ja][/ja]
     */
    renderTabs: PropTypes__default["default"].func.isRequired,
    /**
     * @name position
     * @type string
     * @description
     *  [en]Tabbar's position. Available values are `"bottom"` and `"top"`. Use `"auto"` to choose position depending on platform (iOS bottom, Android top). [/en]
     *  [ja][/ja]
     */
    position: PropTypes__default["default"].string,
    /**
     * @name swipeable
     * @type bool
     * @description
     *  [en]Enable swipe interaction.[/en]
     *  [ja][/ja]
     */
    swipeable: PropTypes__default["default"].bool,
    /**
     * @name ignoreEdgeWidth
     * @type number
     * @description
     *  [en]Distance in pixels from both edges. Swiping on these areas will prioritize parent components such as `Splitter` or `Navigator`.[/en]
     *  [ja][/ja]
     */
    ignoreEdgeWidth: PropTypes__default["default"].number,
    /**
     * @name animation
     * @type string
     * @description
     *  [en]If this attribute is set to `"none"` the transitions will not be animated.[/en]
     *  [ja][/ja]
     */
    animation: PropTypes__default["default"].oneOf(['none', 'slide']),
    /**
     * @name animationOptions
     * @type object
     * @required false
     * @description
     *  [en]Specify the animation's duration, delay and timing. E.g. `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]
     *  [ja][/ja]
     */
    animationOptions: PropTypes__default["default"].object,
    /**
     * @name tabBorder
     * @type bool
     * @description
     *  [en]If true, the tabs show a dynamic bottom border. Only works for iOS since the border is always visible in Material Design.[/en]
     *  [ja][/ja]
     */
    tabBorder: PropTypes__default["default"].bool,
    /**
     * @name onPreChange
     * @type function
     * @description
     *  [en]Called just before the tab is changed.[/en]
     *  [ja][/ja]
     */
    onPreChange: PropTypes__default["default"].func,
    /**
     * @name onPostChange
     * @type function
     * @description
     *  [en]Called just after the tab is changed.[/en]
     *  [ja][/ja]
     */
    onPostChange: PropTypes__default["default"].func,
    /**
     * @name onReactive
     * @type function
     * @description
     *  [en]Called if the already open tab is tapped again.[/en]
     *  [ja][/ja]
     */
    onReactive: PropTypes__default["default"].func,
    /**
     * @name onSwipe
     * @type function
     * @description
     *  [en]Hook called whenever the user slides the tabbar. It gets a decimal index and an animationOptions object as arguments.[/en]
     *  [ja][/ja]
     */
    onSwipe: PropTypes__default["default"].func,
    /**
     * @name visible
     * @type bool
     * @description
     *  [en]If true, the tabbar is not shown on the screen. Otherwise, the tabbar is shown.[/en]
     *  [ja][/ja]
     */
    hideTabs: PropTypes__default["default"].bool,
    /**
     * @name visible
     * @type bool
     * @description
     *  [en]DEPRECATED! Use `hideTabs` instead.[/en]
     *  [ja][/ja]
     */
    visible: PropTypes__default["default"].bool,
    /**
     * @name modifier
     * @type string
     * @description
     *  [en]The appearance of the tabbar.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string
  };

  const propTypes = {
    /**
     * @name visible
     * @type bool
     * @description
     *  [en]
     *  Indicates whether the toast open and shown.
     *  [/en]
     *  [ja][/ja]
     */
    visible: PropTypes__default["default"].bool,
    /**
     * @name isOpen
     * @type bool
     * @description
     *  [en]
     *  DEPRECATED! Use `visible` instead.
     *  [/en]
     *  [ja][/ja]
     */
    isOpen: PropTypes__default["default"].bool,
    /**
     * @name animation
     * @type string
     * @required false
     * @description
     *  [en]Animation name. Available animations are `"default"`, `"ascend"` (Android), `"lift"` (iOS), `"fall"`, `"fade"` or `"none"`.[/en]
     *  [ja][/ja]
     */
    animation: PropTypes__default["default"].string,
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the toast.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name animationOptions
     * @type object
     * @required false
     * @description
     *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]
     *  [ja][/ja]
     */
    animationOptions: PropTypes__default["default"].object,
    /**
     * @name onPreShow
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called just before the toast is displayed.
     *  [/en]
     *  [ja][/ja]
     */
    onPreShow: PropTypes__default["default"].func,
    /**
     * @name onPostShow
     * @type function
     * @required false
     * @description
     *  [en]
     *  Called just after the toast is displayed.
     *  [/en]
     *  [ja][/ja]
     */
    onPostShow: PropTypes__default["default"].func,
    /**
     * @name onPreHide
     * @type function
     * @required false
     * @description
     *  [en]Called just before the toast is hidden.[/en]
     *  [ja][/ja]
     */
    onPreHide: PropTypes__default["default"].func,
    /**
     * @name onPostHide
     * @type function
     * @required false
     * @description
     *  [en]Called just after the toast is hidden.[/en]
     *  [ja][/ja]
     */
    onPostHide: PropTypes__default["default"].func,
    /**
     * @name onDeviceBackButton
     * @type function
     * @required false
     * @description
     *  [en]
     *  Custom handler for device back button.
     *  [/en]
     *  [ja][/ja]
     */
    onDeviceBackButton: PropTypes__default["default"].func
  };
  const deprecated = {
    isOpen: 'visible'
  };
  const notAttributes$1 = ['onDeviceBackButton'];

  /**
   * @original ons-toast
   * @category dialog
   * @tutorial react/Reference/toast
   * @description
   * [en]
   *  The Toast or Snackbar component is useful for displaying dismissable information or simple actions at (normally) the bottom of the page.
   *
   *  This component does not block user input, allowing the app to continue its flow. Furthermore, it can be automatically hidden after a timeout.
   * [/en]
   * [ja][/ja]
   */
  const Toast = onsCustomElement(baseDialog('ons-toast'), {
    propTypes,
    deprecated,
    notAttributes: notAttributes$1
  });
  Toast.propTypes = propTypes;

  const notAttributes = ['visible'];

  /**
   * @original ons-toolbar
   * @category page
   * @tutorial react/Reference/toolbar
   * @description
   * [en]Toolbar component that can be used with navigation. Left, center and right container can be specified by class names. This component will automatically displays as a Material Design toolbar when running on Android devices.[/en]
   * [ja][/ja]
   * @example
   *
  <Page renderToolbar={() =>
    <Toolbar>
      <div className="left">
        <BackButton>
            Back
        </BackButton>
      </div>
      <div className="center">
        Title
      </div>
      <div className="right">
        <ToolbarButton>
          <Icon icon="md-menu" />
        </ToolbarButton>
      </div>
    </Toolbar> }
  />
   */
  const Toolbar = onsCustomElement('ons-toolbar', {
    notAttributes
  });
  Toolbar.propTypes = {
    /**
     * @name modifier
     * @type string
     * @description
     *  [en]
     *  Specify modifier name to specify custom styles. Optional.
     *  [/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name visible
     * @type bool
     * @description
     *  [en]If true, the toolbar is shown on the screen. Otherwise, the toolbar is not shown.[/en]
     *  [ja][/ja]
     */
    visible: PropTypes__default["default"].bool,
    /**
     * @name static
     * @type bool
     * @description
     *   [en]Static toolbars are not animated by `ons-navigator` when pushing or popping pages. This can be useful to improve performance in some situations.[/en]
     *  [ja][/ja]
     */
    static: PropTypes__default["default"].bool,
    /**
     * @name inline
     * @type bool
     * @description
     *   [en]Display the toolbar as an inline element.[/en]
     *   [ja]ツールバーをインラインに置きます。スクロール領域内にそのまま表示されます。[/ja]
     */
    inline: PropTypes__default["default"].bool
  };

  /**
   * @original ons-toolbar-button
   * @category page
   * @tutorial react/Reference/page
   * @description
   *   [en]
   *   Button component for the Toolbar. Using this component gives a nice default style.
   *
   *
   *   [/en]
   * [ja][/ja]
   * @example
   * <Page
       renderToolbar = { () =>
        <Toolbar>
          <div className='left'><BackButton>Back</BackButton></div>
          <div className='center'>Input</div>
          <div className='right'>
            <ToolbarButton onClick={this.add} >Add</ToolbarButton>
          </div>
        </Toolbar>
       }>
        Page Content
      </Page>
   */
  const ToolbarButton = onsCustomElement('ons-toolbar-button');
  ToolbarButton.propTypes = {
    /**
     * @name modifier
     * @type string
     * @required false
     * @description
     *  [en]The appearance of the button.[/en]
     *  [ja][/ja]
     */
    modifier: PropTypes__default["default"].string,
    /**
     * @name disabled
     * @type bool
     * @description
     *  [en]
     *  Indicates whether the button is disabled.
     *  [/en]
     *  [ja][/ja]
     */
    disabled: PropTypes__default["default"].bool,
    /**
     * @name icon
     * @type string
     * @description
     *  [en]Creates an `Icon` component with this string.[/en]
     *  [ja][/ja]
     */
    icon: PropTypes__default["default"].string,
    /**
     * @name onClick
     * @type function
     * @description
     *  [en]This function will be called when the button is clicked.[/en]
     *  [ja][/ja]
     */
    onClick: PropTypes__default["default"].func
  };

  /*
   * routeStack : [userRoute, userRoute2, ...]
   * processStack: [
   * { type: push | pop | reset, route: userRoute },
   * { type: push | pop | reset, route: userRoute2 },
   * ...
   * ]
   */

  var RouterUtil = {
    init: routes => {
      return {
        routeStack: [...routes],
        processStack: []
      };
    },
    replace: _ref => {
      let {
        routeConfig,
        route,
        options,
        key
      } = _ref;
      const config = {
        ...routeConfig
      };
      const routeStack = [...config.routeStack];
      let processStack = [...config.processStack];
      if (key == null || processStack.filter(el => el.key === key).length === 0) {
        const process = {
          type: 'replace',
          route,
          options,
          key
        };
        processStack = [...processStack, process];
      }
      return {
        routeStack,
        processStack
      };
    },
    reset: _ref2 => {
      let {
        routeConfig,
        route,
        options,
        key
      } = _ref2;
      const config = {
        ...routeConfig
      };
      const routeStack = [...config.routeStack];
      let processStack = [...config.processStack];
      if (key == null || processStack.filter(el => el.key === key).length === 0) {
        const process = {
          type: 'reset',
          route,
          options,
          key
        };
        processStack = [...processStack, process];
      }
      return {
        routeStack,
        processStack
      };
    },
    push: _ref3 => {
      let {
        routeConfig,
        route,
        options,
        key
      } = _ref3;
      const config = {
        ...routeConfig
      };
      const routeStack = [...config.routeStack];
      let processStack = [...config.processStack];
      if (key == null || config.processStack.filter(el => el.key === key).length === 0) {
        const process = {
          type: 'push',
          route,
          options,
          key
        };
        processStack = [...processStack, process];
      }
      return {
        routeStack,
        processStack
      };
    },
    pop: _ref4 => {
      let {
        routeConfig,
        options,
        key
      } = _ref4;
      const config = {
        ...routeConfig
      };
      const routeStack = [...config.routeStack];
      let processStack = [...config.processStack];

      /**
       * Safegaurd to ensure that not
       * too many pages are popped from
       * the stack.
       */
      const pops = processStack.filter(x => x.type === 'pop').length;
      if (pops + 1 >= routeStack.length) {
        console.warn('Page stack is already empty');
        return config;
      }
      const process = {
        type: 'pop',
        key,
        options
      };
      processStack = [...processStack, process];
      return {
        routeStack,
        processStack
      };
    },
    postPush: routeConfig => {
      const config = {
        ...routeConfig
      };
      let routeStack = [...config.routeStack];
      const processStack = [...config.processStack];
      const next = processStack.shift();
      const type = next.type;
      let route = next.route;
      if (type === 'push') {
        if (route !== null) {
          routeStack = [...routeStack, route];
        }
      } else if (type === 'reset') {
        if (!Array.isArray(route)) route = [route];
        routeStack = route;
      } else if (type === 'replace') {
        routeStack.pop();
        routeStack.push(route);
      }
      return {
        routeStack,
        processStack
      };
    },
    postPop: routeConfig => {
      const config = {
        ...routeConfig
      };
      let routeStack = [...config.routeStack];
      let processStack = [...config.processStack];
      routeStack = routeStack.slice(0, routeStack.length - 1);
      processStack = processStack.slice(1);
      return {
        routeStack,
        processStack
      };
    }
  };

  exports.ActionSheet = ActionSheet;
  exports.ActionSheetButton = ActionSheetButton;
  exports.AlertDialog = AlertDialog;
  exports.AlertDialogButton = AlertDialogButton;
  exports.BackButton = BackButton;
  exports.BottomToolbar = BottomToolbar;
  exports.Button = Button;
  exports.Card = Card;
  exports.Carousel = Carousel;
  exports.CarouselItem = CarouselItem;
  exports.Checkbox = Checkbox;
  exports.Col = Col;
  exports.Dialog = Dialog;
  exports.Fab = Fab;
  exports.GestureDetector = GestureDetector;
  exports.Icon = Icon;
  exports.Input = Input;
  exports.LazyList = LazyList;
  exports.List = List;
  exports.ListHeader = ListHeader;
  exports.ListItem = ListItem;
  exports.ListTitle = ListTitle;
  exports.Modal = Modal;
  exports.Navigator = Navigator;
  exports.Page = Page;
  exports.Popover = Popover;
  exports.ProgressBar = ProgressBar;
  exports.ProgressCircular = ProgressCircular;
  exports.PullHook = PullHook;
  exports.Radio = Radio;
  exports.Range = Range;
  exports.Ripple = Ripple;
  exports.RouterNavigator = RouterNavigator;
  exports.RouterUtil = RouterUtil;
  exports.Row = Row;
  exports.SearchInput = SearchInput;
  exports.Segment = Segment;
  exports.Select = Select;
  exports.SpeedDial = SpeedDial;
  exports.SpeedDialItem = SpeedDialItem;
  exports.Splitter = Splitter;
  exports.SplitterContent = SplitterContent;
  exports.SplitterMask = SplitterMask;
  exports.SplitterSide = SplitterSide;
  exports.Switch = Switch;
  exports.Tab = Tab;
  exports.Tabbar = Tabbar;
  exports.Toast = Toast;
  exports.Toolbar = Toolbar;
  exports.ToolbarButton = ToolbarButton;

  Object.defineProperty(exports, '__esModule', { value: true });

}));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"react-onsenui.js","sources":["../src/onsCustomElement.jsx","../src/baseDialog.jsx","../src/components/ActionSheet.jsx","../src/components/ActionSheetButton.jsx","../src/components/AlertDialog.jsx","../src/components/AlertDialogButton.jsx","../src/components/BackButton.jsx","../src/components/BottomToolbar.jsx","../src/components/Button.jsx","../src/components/Card.jsx","../src/components/Carousel.jsx","../src/components/CarouselItem.jsx","../src/oneTimeProp.jsx","../src/inputProps.jsx","../src/components/Checkbox.jsx","../src/components/Col.jsx","../src/components/Dialog.jsx","../src/components/Fab.jsx","../src/components/GestureDetector.jsx","../src/components/Icon.jsx","../src/components/Input.jsx","../src/components/List.jsx","../src/components/LazyList.jsx","../src/components/ListHeader.jsx","../src/components/ListItem.jsx","../src/components/ListTitle.jsx","../src/components/Navigator.jsx","../src/components/Modal.jsx","../src/components/Page.jsx","../src/components/Popover.jsx","../src/components/ProgressBar.jsx","../src/components/ProgressCircular.jsx","../src/components/PullHook.jsx","../src/components/Radio.jsx","../src/components/Range.jsx","../src/components/Ripple.jsx","../src/components/RouterNavigator.jsx","../src/components/Row.jsx","../src/components/SearchInput.jsx","../src/components/Segment.jsx","../src/components/Select.jsx","../src/components/SpeedDial.jsx","../src/components/SpeedDialItem.jsx","../src/components/Splitter.jsx","../src/components/SplitterContent.jsx","../src/components/SplitterMask.jsx","../src/components/SplitterSide.jsx","../src/components/Switch.jsx","../src/components/Tab.jsx","../src/components/Tabbar.jsx","../src/components/Toast.jsx","../src/components/Toolbar.jsx","../src/components/ToolbarButton.jsx","../src/RouterUtil.js"],"sourcesContent":["import React, { useRef, useEffect } from 'react';\nconst kebabize = camelString =>\n  camelString.replace(/([a-zA-Z])([A-Z])/g, '$1-$2').toLowerCase();\n\nconst addDeprecated = (props, deprecated) => {\n  const propsCopy = { ...props };\n\n  const nameMap = {\n    className: 'class',\n    ...deprecated\n  };\n\n  // eslint-disable-next-line no-unused-vars\n  for (const [oldName, newName] of Object.entries(nameMap)) {\n    if (propsCopy[newName] === undefined && propsCopy[oldName] !== undefined) {\n      propsCopy[newName] = propsCopy[oldName];\n      delete propsCopy[oldName];\n    }\n  }\n\n  return propsCopy;\n};\n\nfunction useCustomElementListener(ref, prop, handler) {\n  const event = prop.slice(2).toLowerCase();\n  useEffect(() => {\n    const current = ref.current;\n    current.addEventListener(event, handler);\n\n    return function cleanup() {\n      current.removeEventListener(event, handler);\n    };\n  }, [ref, handler]);\n}\n\nfunction useCustomElement(props, options = {}, ref) {\n  const notAttributes = options.notAttributes || [];\n  const deprecated = options.deprecated || {};\n\n  const properties = {};\n  // eslint-disable-next-line no-unused-vars\n  for (const [prop, value] of Object.entries(addDeprecated(props, deprecated))) {\n    const jsName = kebabize(prop);\n\n    if (notAttributes.includes(prop)) {\n      useEffect(() => {\n        ref.current[prop] = value;\n      });\n    } else if (/^on[A-Z]/.test(prop)) {\n      useCustomElementListener(ref, prop, value);\n    } else if (typeof value === 'boolean') {\n      properties[jsName] = value ? '' : null;\n    } else if (typeof value === 'object' && value !== null) {\n      properties[jsName] = JSON.stringify(value);\n    } else {\n      properties[jsName] = value;\n    }\n  }\n\n  return {properties};\n}\n\nexport default function onsCustomElement(WrappedComponent, options) {\n  return React.forwardRef((props, _ref) => {\n    const ref = _ref || useRef();\n\n    const {style, children, ...rest} = props;\n    const {properties} = useCustomElement(rest, options, ref);\n\n    return (\n      <WrappedComponent\n        ref={ref}\n        style={style}\n        {...properties}\n      >\n        {children}\n      </WrappedComponent>\n    );\n  });\n}\n","import React from 'react';\nimport ReactDOM from 'react-dom';\n\nclass Portal extends React.Component {\n  constructor(props) {\n    super(props);\n    this.container = document.createElement('div');\n  }\n\n  componentDidMount() {\n    document.body.appendChild(this.container);\n  }\n\n  componentWillUnmount() {\n    document.body.removeChild(this.container);\n  }\n\n  render() {\n    return ReactDOM.createPortal(\n      this.props.children,\n      this.container\n    );\n  }\n}\n\nconst baseDialog = DialogComponent =>\n  React.forwardRef((props, ref) => {\n    // visible prop should be applied last since it depends on animation and\n    // maskColor props being set first\n    const {visible, ...rest} = props;\n\n    return (\n      <Portal>\n        <DialogComponent\n          {...rest}\n          visible={visible}\n\n          ref={ref}\n        >\n          {props.children}\n        </DialogComponent>\n      </Portal>\n    );\n  });\n\nexport default baseDialog;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-action-sheet';\n\nimport onsCustomElement from '../onsCustomElement';\nimport baseDialog from '../baseDialog';\n\nconst propTypes = {\n  /**\n   * @name title\n   * @type string\n   * @required false\n   * @description\n   *  [en]\n   *  Optional title of the action sheet. A new element will be created containing this string.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  title: PropTypes.string,\n\n  /**\n   * @name onDialogCancel\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called only if cancelable is true. It will be called after tapping the background or by pressing the back button on Android devices.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onDialogCancel: PropTypes.func,\n\n  /**\n   * @name visible\n   * @type bool\n   * @description\n   *  [en]\n   *  Indicates whether the dialog is open and shown.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  visible: PropTypes.bool,\n\n  /**\n   * @name cancelable\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  Specifies whether the dialog is cancelable or not.\n   *  A cancelable dialog will call onCancel  when tapping the background or or  pressing the back button on Android devices\n   *  [/en]\n   *  [ja][/ja]\n   */\n  cancelable: PropTypes.bool,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  Specifies whether the dialog is disabled.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name onCancel\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `onDialogCancel` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onCancel: PropTypes.func,\n\n  /**\n   * @name isOpen\n   * @type bool\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `visible` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  isOpen: PropTypes.bool,\n\n  /**\n   * @name isCancelable\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `cancelable` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  isCancelable: PropTypes.bool,\n\n  /**\n   * @name isDisabled\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `disabled` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  isDisabled: PropTypes.bool,\n\n  /**\n   * @name animation\n   * @type string\n   * @required false\n   * @description\n   *  [en]\n   *  The animation used when showing and hiding the dialog. Can be either `\"none\"` or `\"default\"`.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  animation: PropTypes.string,\n\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the dialog.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name maskColor\n   * @type string\n   * @required false\n   * @description\n   *  [en]Color of the background mask. Default is \"rgba(0, 0, 0, 0.2)\"[/en]\n   *  [ja][/ja]\n   */\n  maskColor: PropTypes.string,\n\n  /**\n   * @name animationOptions\n   * @type object\n   * @required false\n   * @description\n   *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]\n   *  [ja][/ja]\n   */\n  animationOptions: PropTypes.object,\n\n  /**\n   * @name onPreShow\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called just before the action sheet is displayed.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onPreShow: PropTypes.func,\n\n  /**\n   * @name onPostShow\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called just after the action sheet is displayed.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onPostShow: PropTypes.func,\n\n  /**\n   * @name onPreHide\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just before the action sheet is hidden.[/en]\n   *  [ja][/ja]\n   */\n  onPreHide: PropTypes.func,\n\n  /**\n   * @name onPostHide\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just after the action sheet is hidden.[/en]\n   *  [ja][/ja]\n   */\n  onPostHide: PropTypes.func,\n\n  /**\n   * @name onDeviceBackButton\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Custom handler for device back button.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onDeviceBackButton: PropTypes.func\n};\n\nconst deprecated = {\n  onCancel: 'onDialogCancel',\n  isOpen: 'visible',\n  isDisabled: 'disabled',\n  isCancelable: 'cancelable'\n};\n\nconst notAttributes = ['onDeviceBackButton'];\n\n/**\n * @original ons-action-sheet\n * @category dialog\n * @tutorial react/Reference/action-sheet\n * @description\n * [en]\n *  Action/bottom sheet that is displayed on top of current screen.\n *  The action sheet is useful for displaying a list of options and asking the user to make a decision. An ActionSheetButton component is provided for this purpose, although it can contain any type of content.\n *  It will automatically be displayed as Material Design (bottom sheet) when running on an Android device.\n * [/en]\n * [ja][/ja]\n */\nconst ActionSheet = onsCustomElement(baseDialog('ons-action-sheet'), {propTypes, deprecated, notAttributes});\nActionSheet.propTypes = propTypes;\n\nexport default ActionSheet;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-action-sheet-button';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the action sheet button.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name icon\n   * @type string\n   * @description\n   *  [en]Creates an `Icon` component with this string. Only visible on Android.[/en]\n   *  [ja][/ja]\n   */\n  icon: PropTypes.string,\n\n  /**\n   * @name onClick\n   * @type function\n   * @description\n   *  [en]This function will be called when the button is clicked.[/en]\n   *  [ja][/ja]\n   */\n  onClick: PropTypes.func\n};\n\n/**\n * @original ons-action-sheet-button\n * @category dialog\n * @tutorial react/Reference/action-sheet\n * @description\n * [en]Component that represent each button of the action sheet.[/en]\n * [ja][/ja]\n */\nconst ActionSheetButton = onsCustomElement('ons-action-sheet-button', {propTypes});\nActionSheetButton.propTypes = propTypes;\n\nexport default ActionSheetButton;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-alert-dialog';\n\nimport onsCustomElement from '../onsCustomElement';\nimport baseDialog from '../baseDialog';\n\nconst deprecated = {\n  onCancel: 'onDialogCancel',\n  isOpen: 'visible',\n  isDisabled: 'disabled',\n  isCancelable: 'cancelable'\n};\n\nconst notAttributes = ['onDeviceBackButton'];\n\n/**\n * @original ons-alert-dialog\n * @category dialog\n * @tutorial react/Reference/alert-dialog\n * @description\n * [en]\n *   Alert dialog that is displayed on top of the current screen. Useful for displaying questions, warnings or error messages to the user. The title, content and buttons can be easily customized and it will automatically switch style based on the platform.\n * [/en]\n * [ja][/ja]\n * @example\n   <AlertDialog isOpen={this.state.isOpen} onCancel={this.handleCancel.bind(this)} cancelable>\n     <div className=\"alert-dialog-title\">Warning!</div>\n     <div className=\"alert-dialog-content\">\n       An error has occurred!\n     </div>\n     <div className=\"alert-dialog-footer\">\n       <Button onClick={this.handleCancel.bind(this)} className=\"alert-dialog-button\">\n         Cancel\n       </Button>\n       <Button onClick={this.handleCancel.bind(this)} className=\"alert-dialog-button\">\n         Ok\n       </Button>\n     </div>\n   </AlertDialog>\n */\nconst AlertDialog = onsCustomElement(baseDialog('ons-alert-dialog'), {deprecated, notAttributes});\n\nAlertDialog.propTypes = {\n  /**\n   * @name visible\n   * @type bool\n   * @description\n   *  [en]\n   *  Indicates whether the dialog is open and shown.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  visible: PropTypes.bool,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  Specifies whether the dialog is disabled.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name cancelable\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  Specifies whether the dialog is cancelable or not.\n   *  A cancelable dialog will call `onDialogCancel` when tapping the background or pressing the back button on Android devices.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  cancelable: PropTypes.bool,\n\n  /**\n   * @name onDialogCancel\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called only if `cancelable` is true. It will be called after tapping the background or by pressing the back button on Android devices.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onDialogCancel: PropTypes.func,\n\n  /**\n   * @name onCancel\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `onDialogCancel` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onCancel: PropTypes.func,\n\n  /**\n   * @name isOpen\n   * @type bool\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `visible` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  isOpen: PropTypes.bool,\n\n  /**\n   * @name isCancelable\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `cancelable` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  isCancelable: PropTypes.bool,\n\n  /**\n   * @name isDisabled\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `disabled` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  isDisabled: PropTypes.bool,\n\n  /**\n   * @name animation\n   * @type string\n   * @required false\n   * @description\n   *  [en]\n   *  The animation used when showing and hiding the dialog. Can be either `\"none\"` or `\"default\"`.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  animation: PropTypes.string,\n\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the dialog.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name maskColor\n   * @type string\n   * @required false\n   * @description\n   *  [en]Color of the background mask. Default is \"rgba(0, 0, 0, 0.2)\"[/en]\n   *  [ja][/ja]\n   */\n  maskColor: PropTypes.string,\n\n  /**\n   * @name animationOptions\n   * @type object\n   * @required false\n   * @description\n   *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]\n   *  [ja][/ja]\n   */\n  animationOptions: PropTypes.object,\n\n  /**\n   * @name onPreShow\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called just before the alert dialog is displayed.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onPreShow: PropTypes.func,\n\n  /**\n   * @name onPostShow\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called just after the alert dialog is displayed.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onPostShow: PropTypes.func,\n\n  /**\n   * @name onPreHide\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just before the alert dialog is hidden.[/en]\n   *  [ja][/ja]\n   */\n  onPreHide: PropTypes.func,\n\n  /**\n   * @name onPostHide\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just after the alert dialog is hidden.[/en]\n   *  [ja][/ja]\n   */\n  onPostHide: PropTypes.func,\n\n  /**\n   * @name onDeviceBackButton\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Custom handler for device back button.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onDeviceBackButton: PropTypes.func\n};\n\nexport default AlertDialog;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-alert-dialog-button';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-alert-dialog-button\n * @category dialog\n * @tutorial react/Reference/dialog\n * @description\n * [en]Component that represent each button of the alert dialog.[/en]\n * [ja][/ja]\n */\nconst AlertDialogButton = onsCustomElement('ons-alert-dialog-button');\n\nAlertDialogButton.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the alert dialog button.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @description\n   *  [en]\n   *  Specifies whether the button is disabled.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name onClick\n   * @type function\n   * @description\n   *  [en]This function will be called when the button is clicked.[/en]\n   *  [ja][/ja]\n   */\n  onClick: PropTypes.func\n};\n\nexport default AlertDialogButton;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-back-button';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst notAttributes = ['options'];\n\n/**\n * @original ons-back-button\n * @category navigation\n * @tutorial react/Reference/back-button\n * @description\n * [en]\n *   Back button component for Toolbar. It enables to automatically to pop the top page of the navigator. When only presented with one page, the button is hidden automatically.\n *\n *   The default behavior can be overridden using the `onClick` prop.\n * [/en]\n * [ja][/ja]\n * @example\n * <Toolbar modifier={this.props.modifier} >\n      <div className=\"left\"><BackButton modifier={this.props.modifier}>Back</BackButton></div>\n      <div className=\"center\">{this.props.title}</div>\n   </Toolbar>\n */\nconst BackButton = onsCustomElement('ons-back-button', {notAttributes});\n\nBackButton.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the back button.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name onClick\n   * @type function\n   * @description\n   *  [en]This function will be called when the button is clicked. To prevent the default click behaviour, call `event.preventDefault()`.[/en]\n   *  [ja][/ja]\n   */\n  onClick: PropTypes.func,\n\n  /**\n   * @name options\n   * @type object\n   * @description\n   *  [en]Specifies the animation, animationOptions, and callback.[/en]\n   *  [ja][/ja]\n   */\n  options: PropTypes.shape({\n    animation: PropTypes.string,\n    animationOptions: PropTypes.object,\n    callback: PropTypes.func\n  })\n};\n\nexport default BackButton;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-bottom-toolbar';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @description\n   *  [en]Specify modifier name to specify custom styles. Optional.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string\n};\n\n/**\n * @original ons-bottom-toolbar\n * @category page\n * @description\n * [en]Toolbar component that is positioned at the bottom of the page.[/en]\n * [ja][/ja]\n * @example\n * <BottomToolbar modifier=\"material\"> Content </BottomToolbar>\n */\nconst BottomToolbar = onsCustomElement('ons-bottom-toolbar', {propTypes});\nBottomToolbar.propTypes = propTypes;\n\nexport default BottomToolbar;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-button';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the button.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @description\n   *  [en]\n   *  Specifies whether the button is disabled.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name ripple\n   * @type bool\n   * @description\n   *  [en]\n   *  Specifies whether the button has a ripple effect.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  ripple: PropTypes.bool,\n\n  /**\n   * @name onClick\n   * @type function\n   * @description\n   *  [en] This function will be called when the button is clicked. [/en]\n   *  [ja][/ja]\n   */\n  onClick: PropTypes.func\n};\n\n/**\n * @original ons-button\n * @category form\n * @tutorial react/Reference/button\n * @description\n * [en] Button component. If you want to place a button in a toolbar, use `ToolbarButton` or `BackButton` instead. Will automatically display as a Material Design button with a ripple effect on Android.\n [/en]\n * [ja][/ja]\n * @example\n * <Button modifier=\"large--cta\">\n *   Tap Me\n * </Button>\n */\nconst Button = onsCustomElement('ons-button', {propTypes});\nButton.propTypes = propTypes;\n\nexport default Button;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-card';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-card\n * @category visual\n * @tutorial react/Reference/visual\n * @description\n * [en]Card component that can be used to display content.[/en]\n * [ja][/ja]\n * @example\n *\n<Card>\n  <p>Some content</p>\n</Card>\n */\nconst Card = onsCustomElement('ons-card');\n\nCard.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @description\n   *  [en]\n   *  Specify modifier name to specify custom styles. Optional.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string\n};\n\nexport default Card;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-carousel';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst deprecated = {\n  index: 'activeIndex'\n};\n\nconst Element = onsCustomElement('ons-carousel', {deprecated});\n\n/**\n * @original ons-carousel\n * @category carousel\n * @tutorial react/Reference/carousel\n * @description\n * [en] Carousel component. A carousel can be used to display several items in the same space.\n *     The component supports displaying content both horizontally and vertically. The user can scroll through the items by dragging and it can also be controller programmatically.\n [/en]\n * [ja][/ja]\n * @example\n *    <Carousel\n          onPostChange={() => console.log('onPostChange')}\n          onOverscroll={() => console.log('onOverscroll')}\n          onRefresh={() => console.log('onRefresh')}\n          ref={(carousel) => { this.carousel = carousel; }}\n          swipeable\n          overscrollable\n          autoScroll\n          fullscreen\n          autoScrollRatio={0.2}\n      >\n          <CarouselItem style={{backgroundColor: 'gray'}}>\n            <div className='item-label'>GRAY</div>\n          </CarouselItem>\n          <CarouselItem style={{backgroundColor: '#085078'}}>\n            <div className='item-label'>BLUE</div>\n          </CarouselItem>\n        </Carousel>\n\n */\nconst Carousel = React.forwardRef((props, ref) => {\n  const {itemWidth, itemHeight, ...rest} = props;\n\n  // string values for itemWidth and itemHeight are deprecated but handle them\n  // safely anyway to avoid breaking user code\n  const stringify = x => typeof x === 'number' ? `${x}px` : x;\n  const realItemWidth = stringify(itemWidth);\n  const realItemHeight = stringify(itemHeight);\n\n  return (\n    <Element\n      itemWidth={realItemWidth}\n      itemHeight={realItemHeight}\n      ref={ref}\n      {...rest}\n    >\n      {props.children}\n    </Element>\n  );\n});\n\nCarousel.propTypes = {\n\n  /**\n   * @name direction\n   * @type string\n   * @required false\n   * @description\n   *  [en]The direction of the carousel. Can be either \"horizontal\" or \"vertical\". Default is \"horizontal\".[/en]\n   *  [ja][/ja]\n   */\n  direction: PropTypes.oneOf(['horizontal', 'vertical']),\n\n  /**\n   * @name fullscreen\n   * @type bool\n   * @description\n   *  [en]If true, the carousel will cover the whole screen.[/en]\n   *  [ja][/ja]\n   */\n  fullscreen: PropTypes.bool,\n\n  /**\n   * @name overscrollable\n   * @type bool\n   * @description\n   *  [en]If true, the carousel will be scrollable over the edge. It will bounce back when released.[/en]\n   *  [ja][/ja]\n   */\n  overscrollable: PropTypes.bool,\n\n  /**\n   * @name centered\n   * @type bool\n   * @description\n   *  [en]If true, the carousel then the selected item will be in the center of the carousel instead of the beginning. Useful only when the items are smaller than the carousel.[/en]\n   *  [ja][/ja]\n   */\n  centered: PropTypes.bool,\n\n  /**\n   * @name itemWidth\n   * @type string\n   * @description\n   *  [en]ons-carousel-item's width. Only works when the direction is set to \"horizontal\". Can be in pixels or a percentage.[/en]\n   *  [ja][/ja]\n   */\n  itemWidth: PropTypes.string,\n\n  /**\n   * @name itemHeight\n   * @type string\n   * @description\n   *  [en]ons-carousel-item's height. Only works when the direction is set to \"vertical\". Can be in pixels or a percentage.[/en]\n   *  [ja][/ja]\n   */\n  itemHeight: PropTypes.string,\n\n  /**\n   * @name autoScroll\n   * @type bool\n   * @description\n   *  [en]If true, the carousel will be automatically scrolled to the closest item border when released.[/en]\n   *  [ja][/ja]\n   */\n  autoScroll: PropTypes.bool,\n\n  /**\n   * @name autoScrollRatio\n   * @type number\n   * @description\n   *  [en]A number between 0.0 and 1.0 that specifies how much the user must drag the carousel in order for it to auto scroll to the next item.[/en]\n   *  [ja][/ja]\n   */\n  autoScrollRatio: PropTypes.number,\n\n  /**\n   * @name swipeable\n   * @type bool\n   * @description\n   *  [en]If true, the carousel can be scrolled by drag or swipe.[/en]\n   *  [ja][/ja]\n   */\n  swipeable: PropTypes.bool,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @description\n   *  [en]If true, the carousel will be disabled.[/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name activeIndex\n   * @type number\n   * @description\n   *  [en]Specify the index of the ons-carousel-item to show. Default is 0.[/en]\n   *  [ja][/ja]\n   */\n  activeIndex: PropTypes.number,\n\n  /**\n   * @name index\n   * @type number\n   * @description\n   *  [en]DEPRECATED! Use `activeIndex` instead.[/en]\n   *  [ja][/ja]\n   */\n  index: PropTypes.number,\n\n  /**\n   * @name autoRefresh\n   * @type bool\n   * @description\n   *  [en]When this attribute is set the carousel will automatically refresh when the number of child nodes change.[/en]\n   *  [ja][/ja]\n   */\n  autoRefresh: PropTypes.bool,\n\n  /**\n   * @name onPreChange\n   * @type function\n   * @description\n   *  [en]Called just before the current carousel item changes.[/en]\n   *  [ja][/ja]\n   */\n  onPreChange: PropTypes.func,\n\n  /**\n   * @name onPostChange\n   * @type function\n   * @description\n   *  [en]Called just after the current carousel item has changed.[/en]\n   *  [ja][/ja]\n   */\n  onPostChange: PropTypes.func,\n\n  /**\n   * @name onRefresh\n   * @type function\n   * @description\n   *  [en]Called when the carousel has been refreshed. [/en]\n   *  [ja][/ja]\n   */\n  onRefresh: PropTypes.func,\n\n  /**\n   * @name onOverscroll\n   * @type function\n   * @description\n   *  [en]Called when the carousel has been overscrolled. [/en]\n   *  [ja][/ja]\n   */\n  onOverscroll: PropTypes.func,\n\n  /**\n   * @name animation\n   * @type string\n   * @required false\n   * @description\n   *  [en]If this prop is set to \"none\" the transitions will not be animated.[/en]\n   *  [ja][/ja]\n   */\n  animation: PropTypes.string,\n\n  /**\n   * @name animationOptions\n   * @type object\n   * @required false\n   * @description\n   *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]\n   *  [ja][/ja]\n   */\n  animationOptions: PropTypes.object,\n\n  /**\n   * @name onSwipe\n   * @type function\n   * @description\n   *  [en]Hook called whenever the user slides the carousel. It gets a decimal index and an animationOptions object as arguments.[/en]\n   *  [ja][/ja]\n   */\n  onSwipe: PropTypes.func\n};\n\nexport default Carousel;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-carousel-item';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-carousel-item\n * @category carousel\n * @tutorial react/Reference/carousel\n * @description\n * [en] Carousel item component. Used as a child of the `<ons-carousel>` element.\n [/en]\n * [ja][/ja]\n * @example\n*  <Carousel swipeable overscrollable autoScroll fullscreen >\n     <CarouselItem style={{backgroundColor: 'gray'}}>\n       <div className='item-label'>GRAY</div>\n     </CarouselItem>\n     <CarouselItem style={{backgroundColor: '#085078'}}>\n       <div className='item-label'>BLUE</div>\n     </CarouselItem>\n   </Carousel>\n */\nconst CarouselItem = onsCustomElement('ons-carousel-item');\n\nCarouselItem.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @description\n   *  [en]\n   *  Specify modifier name to specify custom styles. Optional.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string\n};\n\nexport default CarouselItem;\n","import React from 'react';\n\n// For a prop with name `defaultProp`, sets the component's `prop` prop to the\n// value of `defaultProp` when the component mounts only.\n//\n// For example, Input has a defaulttValue prop that should set the inner input's\n// value when the component mounted and do nothing afterwards.\nconst oneTimeProp = (WrappedComponent, defaultProp, prop) => {\n  class OneTimeProp extends React.Component {\n    constructor(props) {\n      super(props);\n      this.ref = React.createRef();\n    }\n\n    componentDidMount() {\n      const value = this.props[defaultProp];\n      if (value) {\n        this.ref.current[prop] = value;\n      }\n    }\n\n    render() {\n      const {innerRef, ...rest} = this.props;\n      delete rest[defaultProp];\n\n      if (innerRef && innerRef !== this.ref) {\n        this.ref = innerRef;\n      }\n\n      return (\n        <WrappedComponent\n          ref={this.ref}\n          {...rest}\n        >\n          {this.props.children}\n        </WrappedComponent>\n      );\n    }\n  }\n\n  return React.forwardRef((props, ref) =>\n    <OneTimeProp innerRef={ref} {...props}>{props.children}</OneTimeProp>\n  );\n};\n\nexport default oneTimeProp;\n","const INPUT_PROPS = {\n  autoCapitalize: 'autocapitalize',\n  autoComplete: 'autocomplete',\n  autoCorrect: 'autocorrect',\n  autoFocus: 'autofocus',\n  inputMode: 'inputmode',\n  maxLength: 'maxlength',\n  minLength: 'minlength',\n  readOnly: 'readonly',\n  spellCheck: 'spellcheck'\n};\n\nexport default INPUT_PROPS;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-checkbox';\n\nimport onsCustomElement from '../onsCustomElement';\nimport oneTimeProp from '../oneTimeProp';\nimport INPUT_PROPS from '../inputProps';\n\nconst nameMap = {\n  ...INPUT_PROPS\n};\n\nconst withDefaultChecked = component => oneTimeProp(component, 'defaultChecked', 'checked');\n\n/**\n * @original ons-checkbox\n * @category form\n * @tutorial react/Reference/checkbox\n * @description\n * [en]\n *  A checkbox element. The component will automatically render as a Material Design checkbox on Android devices.\n *\n *  Most attributes that can be used for a normal `<input type=\"checkbox\">` element can also be used on the `<Checkbox>` component.\n * [/en]\n * [ja][/ja]\n * @example\n * <Checkbox\n *   onChange={event => { this.setState({checked: event.target.checked})} }\n *   modifier='material' />\n */\nconst Checkbox = withDefaultChecked(onsCustomElement('ons-checkbox', {deprecated: nameMap}));\n\nCheckbox.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the checkbox.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @description\n   *  [en]\n   *  Specifies whether the checkbox is disabled.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name onChange\n   * @type function\n   * @description\n   *  [en]Called when the inner checkbox fires a `change` event.[/en]\n   *  [ja][/ja]\n   */\n  onChange: PropTypes.func,\n\n  /**\n   * @name onInput\n   * @type function\n   * @description\n   *  [en]Called when the inner checkbox fires an `input` event.[/en]\n   *  [ja][/ja]\n   */\n  onInput: PropTypes.func,\n\n  /**\n   * @name value\n   * @type string\n   * @description\n   *  [en] Value of the checkbox.[/en]\n   *  [ja][/ja]\n   */\n  value: PropTypes.oneOfType([\n    PropTypes.string,\n    PropTypes.instanceOf(Date)\n  ]),\n\n  /**\n   * @name checked\n   * @type boolean\n   * @description\n   *  [en]Controls the state of the checkbox (controlled).[/en]\n   *  [ja][/ja]\n   */\n  checked: PropTypes.bool,\n\n  /**\n   * @name defaultChecked\n   * @type boolean\n   * @description\n   *  [en]Defined the state of the checkbox at first render for uncontrolled inputs.[/en]\n   *  [ja][/ja]\n   */\n  defaultChecked: PropTypes.bool,\n\n  /**\n   * @name inputId\n   * @type string\n   * @description\n   *  [en]Specify the \"id\" attribute of the inner `<input>` element. This is useful when using <label for=\"...\"> elements.[/en]\n   *  [ja][/ja]\n   */\n  inputId: PropTypes.string\n};\n\nexport default Checkbox;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-col';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-col\n * @category grid\n * @description\n * [en]\n * Represents a column in the grid system. Use with `<ons-row>` to layout components.\n * [/en]\n * [ja][/ja]\n * <Row>\n *   <Col width={50}>\n  *   <ons-icon icon=\"fa-twitter\"></ons-icon>\n *   </Col>\n *   <Col>Text</Col>\n * </Row>\n */\nconst Col = onsCustomElement('ons-col');\n\nCol.propTypes = {\n\n  /**\n  * @name verticalAlign\n  * @type {String}\n  * @description\n  *   [en]Short hand attribute for aligning vertically. Valid values are top, bottom, and center.[/en]\n  *   [ja][/ja]\n  */\n  verticalAlign: PropTypes.oneOf(['top', 'bottom', 'center']),\n\n  /**\n  * @name width\n  * @type {String}\n  * @description\n  *   [en]The width of the column. Valid values are css width values (\"10%\", 50).[/en]\n  *   [ja][/ja]\n  */\n  width: PropTypes.oneOfType([PropTypes.number, PropTypes.string])\n};\n\nexport default Col;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-dialog';\n\nimport onsCustomElement from '../onsCustomElement';\nimport baseDialog from '../baseDialog';\n\nconst deprecated = {\n  onCancel: 'onDialogCancel',\n  isOpen: 'visible',\n  isDisabled: 'disabled',\n  isCancelable: 'cancelable'\n};\n\nconst notAttributes = ['onDeviceBackButton'];\n\n/**\n * @original ons-dialog\n * @category dialog\n * @tutorial react/Reference/dialog\n * @description\n * [en]  Dialog that is displayed on top of current screen. As opposed to the AlertDialog element, this component can contain any kind of content.  The dialog is useful for displaying menus, additional information or to ask the user to make a decision.  It will automatically be displayed as Material Design when running on an Android device.\n [/en]\n * [ja][/ja]\n * @example\n   <Dialog onCancel={this.onCancel}\n     isOpen={this.props.isOpen}\n     style={{height: 250}}  cancelable>\n     <Page>\n       Page Content\n     </Page>\n    </Dialog>\n\n */\nconst Dialog = onsCustomElement(baseDialog('ons-dialog'), {deprecated, notAttributes});\n\nDialog.propTypes = {\n  /**\n   * @name visible\n   * @type bool\n   * @description\n   *  [en]\n   *  Indicates whether the dialog is open and shown.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  visible: PropTypes.bool,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  Specifies whether the dialog is disabled.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name cancelable\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  Specifies whether the dialog is cancelable or not.\n   *  A cancelable dialog will call `onDialogCancel` when tapping the background or pressing the back button on Android devices.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  cancelable: PropTypes.bool,\n\n  /**\n   * @name onDialogCancel\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called only if `cancelable` is true. It will be called after tapping the background or by pressing the back button on Android devices.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onDialogCancel: PropTypes.func,\n\n  /**\n   * @name onCancel\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `onDialogCancel` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onCancel: PropTypes.func,\n\n  /**\n   * @name isOpen\n   * @type bool\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `visible` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  isOpen: PropTypes.bool,\n\n  /**\n   * @name isCancelable\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `cancelable` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  isCancelable: PropTypes.bool,\n\n  /**\n   * @name isDisabled\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `disabled` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  isDisabled: PropTypes.bool,\n\n  /**\n   * @name animation\n   * @type string\n   * @required false\n   * @description\n   *  [en]\n   *  The animation used when showing and hiding the dialog. Can be either `\"none\"` or `\"default\"`.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  animation: PropTypes.string,\n\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the dialog.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name maskColor\n   * @type string\n   * @required false\n   * @description\n   *  [en]Color of the background mask. Default is \"rgba(0, 0, 0, 0.2)\"[/en]\n   *  [ja][/ja]\n   */\n  maskColor: PropTypes.string,\n\n  /**\n   * @name animationOptions\n   * @type object\n   * @required false\n   * @description\n   *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]\n   *  [ja][/ja]\n   */\n  animationOptions: PropTypes.object,\n\n  /**\n   * @name onPreShow\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called just before the alert dialog is displayed.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onPreShow: PropTypes.func,\n\n  /**\n   * @name onPostShow\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called just after the alert dialog is displayed.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onPostShow: PropTypes.func,\n\n  /**\n   * @name onPreHide\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just before the alert dialog is hidden.[/en]\n   *  [ja][/ja]\n   */\n  onPreHide: PropTypes.func,\n\n  /**\n   * @name onPostHide\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just after the alert dialog is hidden.[/en]\n   *  [ja][/ja]\n   */\n  onPostHide: PropTypes.func,\n\n  /**\n   * @name onDeviceBackButton\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Custom handler for device back button.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onDeviceBackButton: PropTypes.func\n};\n\nexport default Dialog;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-fab';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-fab\n * @category form\n * @tutorial react/Reference/fab\n * @description\n * [en] The Floating action button is a circular button defined in the [Material Design specification](https://www.google.com/design/spec/components/buttons-floating-action-button.html). They are often used to promote the primary action of the app.\n *     It can be displayed either as an inline element or in one of the corners. Normally it will be positioned in the lower right corner of the screen.\n [/en]\n * [ja][/ja]\n * @example\n * <SpeedDial disabled={false} direction='right' onClick={() => console.log('test1')} position='left bottom'>\n     <Fab>\n       <Icon icon='fa-twitter' size={26} fixedWidth={false} style={{verticalAlign: 'middle'}} />\n     </Fab>\n     <SpeedDialItem onClick={() => console.log('speed A')}> A </SpeedDialItem>\n     <SpeedDialItem onClick={() => console.log('speed B')}> B </SpeedDialItem>\n     <SpeedDialItem onClick={() => console.log('speed C')}> C </SpeedDialItem>\n     <SpeedDialItem onClick={() => console.log('speed D')}> D </SpeedDialItem>\n   </SpeedDial>\n  */\nconst Fab = onsCustomElement('ons-fab');\n\nFab.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the button.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name ripple\n   * @type bool\n   * @description\n   *  [en]If true,  the button will have a ripple effect when tapped.[/en]\n   *  [ja][/ja]\n   */\n  ripple: PropTypes.bool,\n\n  /**\n   * @name position\n   * @type string\n   * @required false\n   * @description\n   *  [en]The position of the button. Should be a string like `\"bottom right\"` or `\"top left\"`. If this attribute is not defined it will be displayed as an inline element.[/en]\n   *  [ja][/ja]\n   */\n  position: PropTypes.string,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @description\n   *  [en] If true, the button will be disabled. [/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name onClick\n   * @type function\n   * @description\n   *  [en] This function will be called ones the button is clicked. [/en]\n   *  [ja][/ja]\n   */\n  onClick: PropTypes.func\n};\n\nexport default Fab;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-gesture-detector';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst propTypes = {\n\n  /**\n   * @name onDrag\n   * @type function\n   * @description\n   *  [en]Called when the user drags in any direction.[/en]\n   *  [ja][/ja]\n   */\n  onDrag: PropTypes.func,\n\n  /**\n   * @name onDragLeft\n   * @type function\n   * @description\n   *  [en]Called when the user drags left.[/en]\n   *  [ja][/ja]\n   */\n  onDragLeft: PropTypes.func,\n\n  /**\n   * @name onDragRight\n   * @type function\n   * @description\n   *  [en]Called when the user drags right.[/en]\n   *  [ja][/ja]\n   */\n  onDragRight: PropTypes.func,\n\n  /**\n   * @name onDragUp\n   * @type function\n   * @description\n   *  [en]Called when the user drags up.[/en]\n   *  [ja][/ja]\n   */\n  onDragUp: PropTypes.func,\n\n  /**\n   * @name onDragDown\n   * @type function\n   * @description\n   *  [en]Called when the user drags down.[/en]\n   *  [ja][/ja]\n   */\n  onDragDown: PropTypes.func,\n\n  /**\n   * @name onHold\n   * @type function\n   * @description\n   *  [en]Called when the user holds.[/en]\n   *  [ja][/ja]\n   */\n  onHold: PropTypes.func,\n\n  /**\n   * @name onRelease\n   * @type function\n   * @description\n   *  [en]Called when the user releases.[/en]\n   *  [ja][/ja]\n   */\n  onRelease: PropTypes.func,\n\n  /**\n   * @name onSwipe\n   * @type function\n   * @description\n   *  [en]Called when the user swipes in any direction.[/en]\n   *  [ja][/ja]\n   */\n  onSwipe: PropTypes.func,\n\n  /**\n   * @name onSwipeLeft\n   * @type function\n   * @description\n   *  [en]Called when the user swipes left.[/en]\n   *  [ja][/ja]\n   */\n  onSwipeLeft: PropTypes.func,\n\n  /**\n   * @name onSwipeRight\n   * @type function\n   * @description\n   *  [en]Called when the user swipes right.[/en]\n   *  [ja][/ja]\n   */\n  onSwipeRight: PropTypes.func,\n\n  /**\n   * @name onSwipeUp\n   * @type function\n   * @description\n   *  [en]Called when the user swipes up.[/en]\n   *  [ja][/ja]\n   */\n  onSwipeUp: PropTypes.func,\n\n  /**\n   * @name onSwipeDown\n   * @type function\n   * @description\n   *  [en]Called when the user swipes down.[/en]\n   *  [ja][/ja]\n   */\n  onSwipeDown: PropTypes.func,\n\n  /**\n   * @name onTap\n   * @type function\n   * @description\n   *  [en]Called when the user taps.[/en]\n   *  [ja][/ja]\n   */\n  onTap: PropTypes.func,\n\n  /**\n   * @name onDoubleTap\n   * @type function\n   * @description\n   *  [en]Called when the user double taps.[/en]\n   *  [ja][/ja]\n   */\n  onDoubleTap: PropTypes.func,\n\n  /**\n   * @name onPinch\n   * @type function\n   * @description\n   *  [en]Called when the user pinches in or out.[/en]\n   *  [ja][/ja]\n   */\n  onPinch: PropTypes.func,\n\n  /**\n   * @name onPinchIn\n   * @type function\n   * @description\n   *  [en]Called when the user pinches in.[/en]\n   *  [ja][/ja]\n   */\n  onPinchIn: PropTypes.func,\n\n  /**\n   * @name onPinchOut\n   * @type function\n   * @description\n   *  [en]Called when the user pinches out.[/en]\n   *  [ja][/ja]\n   */\n  onPinchOut: PropTypes.func,\n\n  /**\n   * @name onTouch\n   * @type function\n   * @description\n   *  [en]Called when the user touches.[/en]\n   *  [ja][/ja]\n   */\n  onTouch: PropTypes.func,\n\n  /**\n   * @name onTransform\n   * @type function\n   * @description\n   *  [en]Called when the user transforms.[/en]\n   *  [ja][/ja]\n   */\n  onTransform: PropTypes.func,\n\n  /**\n   * @name onRotate\n   * @type function\n   * @description\n   *  [en]Called when the user rotates.[/en]\n   *  [ja][/ja]\n   */\n  onRotate: PropTypes.func\n};\n\n/**\n * @original ons-gesture-detector\n * @category gesture\n * @tutorial react/Reference/gesture-detector\n * @description\n * [en]Component to detect finger gestures within a wrapped element.\n [/en]\n * [ja][/ja]\n * @example\n * <GestureDetector\n *   onTap={() => console.log('tap')}\n *   onSwipeleft={() => console.log('swipe left')}\n * >\n *   <div style={{backgroundColor: 'pink', width: '100px', height: '100px'}}>\n *     Swipe Here\n *   </div>\n * </GestureDetector>\n *\n */\nconst GestureDetector = onsCustomElement('ons-gesture-detector', {propTypes});\nGestureDetector.propTypes = propTypes;\n\nexport default GestureDetector;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-icon';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst parseIcon = icon => {\n  if (icon) {\n    if ((typeof icon) === 'string') {\n      return icon;\n    } else {\n      const keys = Object.keys(icon).filter((a) => a !== 'default');\n      const innerString = keys.map((key) => key + ':' + icon[key] + '');\n      return icon.default + ', ' + innerString.join(',');\n    }\n  }\n};\n\nconst parseSize = size => {\n  if (size) {\n    if ((typeof size) === 'number') {\n      return `${size}px`;\n    } else {\n      const keys = Object.keys(size).filter((a) => a !== 'default');\n      const innerString = keys.map((key) => key + ':' + size[key] + 'px');\n      return size.default + 'px, ' + innerString.join(',');\n    }\n  }\n};\n\nconst Element = onsCustomElement('ons-icon');\n\n/**\n * @original ons-icon\n * @category visual\n * @tutorial react/Reference/icon\n * @description\n * [en]\n * Displays an icon. The following icon suites are available:\n *   *  [Font Awesome](https://fortawesome.github.io/Font-Awesome/)\n *   *  [Ionicons](http://ionicons.com/)\n *   *  [Material Design Iconic Font](http://zavoloklom.github.io/material-design-iconic-font/)\n * [/en]\n * [ja][/ja]\n * @example\n  <Icon\n    size={{default: 32, material: 40}}\n    icon={{default: 'ion-navicon', material: 'md-menu'}}\n  />\n*/\nconst Icon = React.forwardRef((props, ref) => {\n  const {icon, size, ...rest} = props;\n\n  return (\n    <Element\n      icon={parseIcon(icon)}\n      size={parseSize(size)}\n      {...rest}\n      ref={ref}\n    >\n      {props.children}\n    </Element>\n  );\n});\n\nIcon.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the icon.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name icon\n   * @type 'object or string'\n   * @description\n   *  [en] can be either a string or an object. If it is an string, it is set to an specific icon like 'ions-navicon'. If it is an object, it represents a dictionary of the icons depending on the modifier e.g.   `{{default: 'ion-navicon', material: 'md-menu'}}` [/en]\n   *  [ja][/ja]\n   */\n  icon: PropTypes.oneOfType([\n    PropTypes.string,\n    PropTypes.objectOf(PropTypes.string)\n  ]),\n\n  /**\n   * @name size\n   * @type 'object or number'\n   * @description\n   *  [en] can be either a number or an object. If it is an number, it  specifies the icon size with a number in pixels. If it is an object, it represents a dictionary of the icon sizes depending on the modifier e.g.   `{{default: 20, material: 18}}` [/en]\n   *  [ja][/ja]\n   */\n  size: PropTypes.oneOfType([\n    PropTypes.number,\n    PropTypes.objectOf(PropTypes.number)\n  ]),\n\n  /**\n   * @name rotate\n   * @type number\n   * @description\n   *  [en] Number of degrees to rotate the icon. Valid values are 90, 180 and 270. [/en]\n   *  [ja][/ja]\n   */\n  rotate: PropTypes.oneOf([0, 90, 180, 270]),\n\n  /**\n   * @name fixedWidth\n   * @type bool\n   * @description\n   * [en] When used in a list, you want the icons to have the same width so that they align vertically by defining this attribute. [/en]\n   *  [ja][/ja]\n   */\n  fixedWidth: PropTypes.bool,\n\n  /**\n   * @name spin\n   * @type bool\n   * @description\n   * [en] Specify whether the icon should be spinning. [/en]\n   *  [ja][/ja]\n   */\n  spin: PropTypes.bool\n};\n\nexport default Icon;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-input';\n\nimport onsCustomElement from '../onsCustomElement';\nimport oneTimeProp from '../oneTimeProp';\nimport INPUT_PROPS from '../inputProps';\n\nconst nameMap = {\n  ...INPUT_PROPS\n};\n\nconst withDefaultValue = component => oneTimeProp(component, 'defaultValue', 'value');\n\nconst notAttributes = [\n  'value' // value must be applied as property since attribute only works before input is touched\n];\n\n/**\n * @original ons-input\n * @category form\n * @tutorial react/Reference/input\n * @description\n * [en]\n * An input element. The `type` attribute can be used to change the input type. All text input types as well as `checkbox` and `radio` are supported. The component will automatically render as a Material Design input on Android devices. Most attributes that can be used for a normal `<input>` element can also be used on the `<ons-input>` element..\n [/en]\n * [ja][/ja]\n * @example\n * <Input\n *   value={this.state.text} float\n *   onChange={(event) => { this.setState({text: event.target.value})} }\n *   modifier='material'\n *   placeholder='Username' />\n */\nconst Input = withDefaultValue(onsCustomElement('ons-input', {deprecated: nameMap, notAttributes}));\n\nInput.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the input.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @description\n   *  [en]Specifies whether the input is disabled.[/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name readOnly\n   * @type bool\n   * @description\n   *  [en]Specifies whether the input is read-only.[/en]\n   *  [ja][/ja]\n   */\n  readOnly: PropTypes.bool,\n\n  /**\n   * @name onChange\n   * @type function\n   * @description\n   *  [en]Called when the inner input fires a `change` event.[/en]\n   *  [ja][/ja]\n   */\n  onChange: PropTypes.func,\n\n  /**\n   * @name onInput\n   * @type function\n   * @description\n   *  [en]Called when the inner input fires an `input` event.[/en]\n   *  [ja][/ja]\n   */\n  onInput: PropTypes.func,\n\n  /**\n   * @name value\n   * @type string\n   * @description\n   *  [en]Content of the input (controlled).[/en]\n   *  [ja][/ja]\n   */\n  value: PropTypes.oneOfType([\n    PropTypes.string,\n    PropTypes.instanceOf(Date)\n  ]),\n\n  /**\n   * @name defaultValue\n   * @type string\n   * @description\n   *  [en]Content of the input at first render (uncontrolled).[/en]\n   *  [ja][/ja]\n   */\n  defaultValue: PropTypes.oneOfType([\n    PropTypes.string,\n    PropTypes.instanceOf(Date)\n  ]),\n\n  /**\n   * @name placeholder\n   * @type string\n   * @description\n   *  [en] Placeholder text. In Material Design this placeholder will be a floating label. [/en]\n   *  [ja][/ja]\n   */\n  placeholder: PropTypes.string,\n\n  /**\n   * @name type\n   * @type string\n   * @description\n   *  [en]\n   *    Specify the input type. This is the same as the \"type\" attribute for normal inputs. It expects strict text types such as `text`, `password`, etc. For checkbox, radio button, select or range, please have a look at the corresponding components.\n   *\n   *    Please take a look at [MDN](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#attr-type) for an exhaustive list of possible values. Depending on the platform and browser version some of these might not work.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  type: PropTypes.string,\n\n  /**\n   * @name inputId\n   * @type string\n   * @description\n   *  [en]  Specify the \"id\" attribute of the inner `<input>` element. This is useful when using <label for=\"...\"> elements [/en]\n   *  [ja][/ja]\n   */\n  inputId: PropTypes.string,\n\n  /**\n   * @name float\n   * @type bool\n   * @description\n   *  [en]  If this attribute is present, the placeholder will be animated in Material Design.  [/en]\n   *  [ja][/ja]\n   */\n  float: PropTypes.bool\n};\n\nexport default Input;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-list';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst Element = onsCustomElement('ons-list');\n\n/**\n * @original ons-list\n * @category list\n * @tutorial react/Reference/list\n * @description\n *   [en]\n *     Component for representing a list. It takes an array called datasource and calls renderRow(row, index) for every row.  Furthermore, the header and the footer can be specified with `renderRow` and `renderHeader` respectively. [/en]\n * [ja][/ja]\n * @example\n  <List\n    dataSource={['Row 1', 'Row 2']}\n    renderHeader={this.renderHeader}\n    renderRow={(row, idx) => (\n      <ListItem modifier={idx === this.state.data.length - 1 ? 'longdivider' : null}>\n      {row}\n  <Button modifier=\"quiet\" onClick={this.remove.bind(this, idx)}>Remove</Button>\n  </ListItem>\n  )}\n  renderFooter={this.renderFooter}\n  />\n */\nconst List = React.forwardRef((props, ref) => {\n  const {renderHeader, renderFooter, renderRow, dataSource, ...rest} = props;\n\n  const rows = dataSource.map((data, index) => renderRow(data, index));\n\n  return (\n    <Element\n      {...rest}\n      ref={ref}\n    >\n      {renderHeader()}\n      {rows}\n      {props.children}\n      {renderFooter()}\n    </Element>\n  );\n});\n\nList.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @description\n   *  [en]\n   *  Specify modifier name to specify custom styles.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name dataSource\n   * @type string\n   * @description\n   *  [en]\n   *    Source of the list data. Should be an array.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  dataSource: PropTypes.array,\n\n  /**\n   * @name renderRow\n   * @type function\n   * @description\n   *  [en]\n   *  Function to specify the rendering function for every element in\n   *  in the dataSource.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  renderRow: PropTypes.func,\n\n  /**\n   * @name renderHeader\n   * @type function\n   * @description\n   *  [en]\n   *  Function to specify the rendering function for the header\n   *  [/en]\n   *  [ja][/ja]\n   */\n  renderHeader: PropTypes.func,\n\n  /**\n   * @name renderFooter\n   * @type function\n   * @description\n   *  [en]\n   *  Function to specify the rendering function for the footer\n   *  [/en]\n   *  [ja][/ja]\n   */\n  renderFooter: PropTypes.func\n};\n\nList.defaultProps = {\n  dataSource: [],\n  renderRow: () => null,\n  renderHeader: () => null,\n  renderFooter: () => null\n};\n\nexport default List;\n","import React, { useRef, useEffect, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-lazy-repeat';\n\nimport List from './List';\n\n/**\n * @original ons-lazy-repeat\n * @category list\n * @tutorial react/Reference/lazy-list\n * @description\n * [en] Using this component a list with millions of items can be rendered without a drop in performance.\n *     It does that by \"lazily\" loading elements into the DOM when they come into view and\n *     removing items from the DOM when they are not visible.\n [/en]\n * [ja][/ja]\n * @example\n *\n  renderRow(index) {\n    return (\n      <ListItem key={index}>\n        {'Item ' + (index + 1)}\n      </ListItem>\n    );\n  }\n\n  render() {\n    return (\n      <Page renderToolbar={() => <MyToolbar title='LazyList' />} >\n        <div style={{height: 100}}>\n          <LazyList\n            length={1000}\n            renderRow={() =>\n              <ListItem key={index}>\n                {'Item ' + (index + 1)}\n              </ListItem>\n            }\n            calculateItemHeight={() => 44}\n          />\n        </div>\n      </Page>\n    );\n  }\n}\n */\nconst LazyList = React.forwardRef((props, forwardedRef) => {\n  const ref = forwardedRef || useRef();\n  const [children, setChildren] = useState([]);\n  const [, setUpdateTop] = useState();\n\n  const {calculateItemHeight, renderRow, length, ...rest} = props;\n\n  useEffect(() => {\n    ref.current.delegate = {\n      calculateItemHeight: function(index) {\n        return calculateItemHeight(index);\n      },\n      _render: function(start, limit, updateTop) {\n        const el = [];\n        for (let i = start; i < limit; i++) {\n          el.push(renderRow(i));\n        }\n        setChildren(el);\n        setUpdateTop(updateTop); // doesn't work without this, but why? does it just trigger a rerender?\n      },\n      countItems: function() {\n        return length;\n      }\n    };\n  }, [calculateItemHeight, renderRow, length]);\n\n  return (\n    <List\n      {...rest}\n      style={{position: 'relative'}}\n    >\n      <ons-lazy-repeat ref={ref} />\n      {children}\n    </List>\n  );\n});\n\nLazyList.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the lazy list.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name length\n   * @type number\n   * @description\n   *  [en]The length of the list.[/en]\n   *  [ja][/ja]\n   */\n  length: PropTypes.number.isRequired,\n\n  /**\n   * @name renderRow\n   * @type function\n   * @description\n   *  [en] A function given the index of the to display row, renders it.[/en]\n   *  [ja][/ja]\n   */\n  renderRow: PropTypes.func.isRequired,\n\n  /**\n   * @name calculateItemHeight\n   * @type function\n   * @description\n   *  [en] A function given the index of the to row, returns the height of it.[/en]\n   *  [ja][/ja]\n   */\n  calculateItemHeight: PropTypes.func.isRequired\n};\n\nexport default LazyList;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-list-header';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-list-header\n * @category list\n * @tutorial react/Reference/list\n * @description\n * [en] Header element for list items. Must be put inside ons-list component.\n [/en]\n * [ja][/ja]\n * @example\n   <List\n     dataSource={this.state.data}\n     renderHeader={() =>\n        <ListHeader style={{fontSize: 15}} className=\"testClass\"> Header Text </ListHeader> }\n    renderRow={(row, idx) => (\n      <ListItem > {row} </ListItem>\n    )}\n  />\n */\nconst ListHeader = onsCustomElement('ons-list-header');\n\nListHeader.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @description\n   *  [en]\n   *  Specify modifier name to specify custom styles. Optional.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string\n};\n\nexport default ListHeader;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-list-item';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en] The appearance of the list item.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name tappable\n   * @type bool\n   * @description\n   *  [en]\n   *  Specifies whether the list item is tappable.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  tappable: PropTypes.bool,\n\n  /**\n   * @name tapBackgroundColor\n   * @type string\n   * @description\n   *  [en]\n   *  Changes the background color when tapped. For this to work, the attribute \"tappable\" needs to be set. The default color is \"#d9d9d9\". It will display as a ripple effect on Android.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  tapBackgroundColor: PropTypes.string,\n\n  /**\n   * @name keepTapBackgroundColor\n   * @type bool\n   * @description\n   *  [en]\n   *  Prevent from clearing the background color on `\"touchmove\"`, `\"touchcancel\"`, `\"touchend\"`, `\"touchleave\"`, `\"mouseup\"`, and `\"mouseout\"`. For this to work, the attribute \"tappable\" needs to be set.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  keepTapBackgroundColor: PropTypes.bool,\n\n  /**\n   * @name lockOnDrag\n   * @type bool\n   * @description\n   *  [en] Prevent vertical scrolling when the user drags horizontally. [/en]\n   *  [ja][/ja]\n   */\n  lockOnDrag: PropTypes.bool,\n\n  /**\n   * @name expandable\n   * @type bool\n   * @description\n   *  [en]Specifies whether list item can be expanded to reveal hidden content. Expanded content must be defined in `div.expandable-content`.[/en]\n   *  [ja][/ja]\n   */\n  expandable: PropTypes.bool,\n\n  /**\n   * @name expanded\n   * @type bool\n   * @description\n   *  [en]For expandable list items, specifies whether item is expanded[/en]\n   *  [ja][/ja]\n   */\n  expanded: PropTypes.bool,\n\n  /**\n   * @name onExpand\n   * @type function\n   * @description\n   *  [en] This function will be called when the expandable list item expands or contracts.[/en]\n   *  [ja][/ja]\n   */\n  onExpand: PropTypes.func,\n\n  /**\n   * @name animation\n   * @type string\n   * @description\n   *  [en]The animation used when showing and hiding the expandable content. Can be either \"default\" or \"none\".[/en]\n   *  [ja][/ja]\n   */\n  animation: PropTypes.string\n};\n\n/**\n * @original ons-list-item\n * @category list\n * @tutorial react/Reference/list\n * @description\n *   [en]\n *   Component that represents each item in the list. Must be put inside the `List` component. The list item is composed of four parts that are represented with the `left`, `center`, `right` and `expandable-content` classes. These classes can be used to ensure that the content of the list items is properly aligned.\n *   [/en]\n * [ja][/ja]\n * @example\n   <ListItem>\n *   <div className=\"left\">Left</div>\n *   <div className=\"center\">Center</div>\n *   <div className=\"right\">Right</div>\n *   <div className=\"expandable-content\">Expandable content</div>\n * </ListItem>\n */\nconst ListItem = onsCustomElement('ons-list-item', {propTypes});\nListItem.propTypes = propTypes;\n\nexport default ListItem;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-list-title';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @description\n   *  [en]\n   *  Specify modifier name to specify custom styles. Optional.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string\n};\n\n/**\n * @original ons-list-title\n * @category list\n * @tutorial react/Reference/list\n * @description\n * [en] Title element for lists. Usually comes before ons-list component.\n [/en]\n * [ja][/ja]\n * @example\n * <ListTitle>List Title</ListTitle>\n   <List\n     dataSource={this.state.data}\n     renderHeader={() =>\n        <ListHeader style={{fontSize: 15}} className=\"testClass\"> Header Text </ListHeader> }\n    renderRow={(row, idx) => (\n      <ListItem > {row} </ListItem>\n    )}\n  />\n */\nconst ListTitle = onsCustomElement('ons-list-title', {propTypes});\nListTitle.propTypes = propTypes;\n\nexport default ListTitle;\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-navigator';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst Element = onsCustomElement('ons-navigator');\n\nclass NavigatorClass extends React.Component {\n  constructor(...args) {\n    super(...args);\n    this.ref = React.createRef();\n    this.pages = [];\n    this.state = { };\n    this._prePush = this._prePush.bind(this);\n    this._postPush = this._postPush.bind(this);\n    this._prePop = this._prePop.bind(this);\n    this._postPop = this._postPop.bind(this);\n  }\n\n  update(pages, obj) {\n    this.pages = pages || [];\n    return new Promise((resolve) => {\n      this.forceUpdate(resolve);\n    });\n  }\n\n  /**\n   * @method resetPage\n   * @signature resetPage(route, options = {})\n   * @param {Object} route\n   *   [en] The route that the page should be reset to.[/en]\n   *   [ja][/ja]\n   * @return {Promise}\n   *   [en]Promise which resolves to the revealed page.[/en]\n   *   [ja]明らかにしたページを解決するPromiseを返します。[/ja]\n   * @description\n   *   [en]Resets the current page[/en]\n   *   [ja][/ja]\n   */\n  resetPage(route, options = {}) {\n    return this.resetPageStack([route], options);\n  }\n\n  /**\n   * @method resetPageStack\n   * @signature resetPageStack(route, options = {})\n   * @param {Array} routes\n   *   [en] The routes that the navigator should be reset to.[/en]\n   *   [ja][/ja]\n   * @return {Promise}\n   *   [en]Promise which resolves to the revealed page.[/en]\n   *   [ja]明らかにしたページを解決するPromiseを返します。[/ja]\n   * @description\n   *   [en] Resets the navigator to the current page stack[/en]\n   *   [ja][/ja]\n   */\n  resetPageStack(routes, options = {}) {\n    if (this.isRunning()) {\n      return Promise.reject('Navigator is already running animation.');\n    }\n\n    const hidePages = () => {\n      const pageElements = this.ref.current.pages;\n      for (let i = pageElements.length - 2; i >= 0; i--) {\n        pageElements[i].style.display = 'none';\n      }\n    };\n\n    if (options.pop) {\n      this.routesBeforePop = this.routes.slice();\n      this.routesAfterPop = routes;\n      this.routes = routes.concat([this.routes[this.routes.length - 1]]);\n\n      const update = () => {\n        this.pages.pop();\n        this.routes = routes;\n        return new Promise((resolve) => this.forceUpdate(resolve));\n      };\n\n      return this.update(this.pages)\n        .then(() => this.ref.current._popPage(options, update))\n        .then(() => hidePages());\n    }\n\n    const lastRoute = routes[routes.length - 1];\n    const newPage = this.props.renderPage(lastRoute, this);\n    this.routes.push(lastRoute);\n\n    const update = () => {\n      this.pages.push(newPage);\n      return new Promise((resolve) => this.forceUpdate(resolve));\n    };\n\n    return this.ref.current._pushPage(options, update).then(() => {\n      this.routes = routes;\n      this.pages = routes.map(route => this.props.renderPage(route, this));\n      return this.update(this.pages).then(() => hidePages());\n    });\n  }\n\n  /**\n   * @method pushPage\n   * @signature pushPage(route, options = {})\n   * @param {Object} route\n   *   [en] The route that the navigator should push to.[/en]\n   *   [ja][/ja]\n   * @return {Promise}\n   *   [en] Promise which resolves to the revealed page.[/en]\n   *   [ja]明らかにしたページを解決するPromiseを返します。[/ja]\n   * @description\n   *   [en] Pushes a page to the page stack[/en]\n   *   [ja][/ja]\n   */\n  pushPage(route, options = {}) {\n    if (this.isRunning()) {\n      return Promise.reject('Navigator is already running animation.');\n    }\n\n    return new Promise((resolve) => {\n      const update = () => {\n        return new Promise((resolve) => {\n          this.pages.push(this.props.renderPage(route, this));\n          this.forceUpdate(resolve);\n        });\n      };\n\n      this.routes.push(route);\n      this.ref.current\n        ._pushPage(\n          options,\n          update\n        )\n        .then(resolve)\n        .catch((error) => {\n          this.routes.pop();\n          this.pages.pop();\n          throw error;\n        });\n    });\n  }\n\n  isRunning() {\n    return this.ref.current._isRunning;\n  }\n\n  /*\n   * @method replacePage\n   * @signature replacePage(route, [options])\n   * @param {Object} route\n   *   [en] The route that the navigator should replace the top page with.[/en]\n   *   [ja][/ja]\n   * @return {Promise}\n   *   [en]Promise which resolves to the new page.[/en]\n   *   [ja]新しいページを解決するPromiseを返します。[/ja]\n   * @description\n   *   [en]Replaces the current top page with the specified one. Extends `pushPage()` parameters.[/en]\n   *   [ja]現在表示中のページをを指定したページに置き換えます。[/ja]\n   */\n  replacePage(route, options = {}) {\n    if (this.isRunning()) {\n      return Promise.reject('Navigator is already running animation.');\n    }\n\n    return this.pushPage(route, options).then(() => {\n      const pos = this.pages.length - 2;\n      this.pages.splice(pos, 1);\n      this.routes.splice(pos, 1);\n      this.ref.current.topPage.updateBackButton(this.pages.length > 1);\n      this.forceUpdate();\n    });\n  }\n\n  /**\n   * @method popPage\n   * @signature popPage(options = {})\n   * @return {Promise}\n   *   [en] Promise which resolves to the revealed page.[/en]\n   *   [ja]明らかにしたページを解決するPromiseを返します。[/ja]\n   * @description\n   *   [en] Pops a page out of the page stack[/en]\n   *   [ja][/ja]\n   */\n  popPage(options = {}) {\n    if (this.isRunning()) {\n      return Promise.reject('Navigator is already running animation.');\n    }\n\n    this.routesBeforePop = this.routes.slice();\n    this.routesAfterPop = this.routesBeforePop.slice(0, this.routesBeforePop.length - 1);\n\n    const update = () => {\n      return new Promise((resolve) => {\n        this.pages.pop();\n        this.routes.pop();\n\n        ReactDOM.flushSync(() => { // prevents flickering caused by React 18 batching\n          this.forceUpdate(resolve);\n        });\n      });\n    };\n\n    return this.ref.current._popPage(options, update);\n  }\n\n  _onDeviceBackButton(event) {\n    if (this.pages.length > 1) {\n      this.popPage();\n    } else {\n      event.callParentHandler();\n    }\n  }\n\n  _prePop(event) {\n    if (event.target !== this.ref.current) {\n      return;\n    }\n\n    event.routes = {\n      poppingRoute: this.routesBeforePop[this.routesBeforePop.length - 1],\n      routes: this.routesBeforePop\n    };\n\n    this.props.onPrePop(event);\n  }\n\n  _postPop(event) {\n    if (event.target !== this.ref.current) {\n      return;\n    }\n\n    event.routes = {\n      poppedRoute: this.routesBeforePop[this.routesBeforePop.length - 1],\n      routes: this.routesAfterPop\n    };\n\n    this.props.onPostPop(event);\n  }\n\n  _prePush(event) {\n    if (event.target !== this.ref.current) {\n      return;\n    }\n\n    event.routes = {\n      pushingRoute: this.routes[this.routes.length - 1],\n      routes: this.routes.slice(0, this.routes.length - 1)\n    };\n\n    this.props.onPrePush(event);\n  }\n\n  _postPush(event) {\n    if (event.target !== this.ref.current) {\n      return;\n    }\n\n    event.routes = {\n      pushedRoute: this.routes[this.routes.length - 1],\n      routes: this.routes\n    };\n\n    this.props.onPostPush(event);\n  }\n\n  componentDidMount() {\n    const node = this.ref.current;\n    node.popPage = this.popPage.bind(this);\n\n    node.addEventListener('prepush', this._prePush);\n    node.addEventListener('postpush', this._postPush);\n    node.addEventListener('prepop', this._prePop);\n    node.addEventListener('postpop', this._postPop);\n\n    node.swipeMax = this.props.swipePop;\n    node.onDeviceBackButton = this.props.onDeviceBackButton || this._onDeviceBackButton.bind(this);\n\n    if (this.props.initialRoute && this.props.initialRouteStack) {\n      throw new Error('In Navigator either initalRoute or initalRoutes can be set');\n    }\n\n    if (this.props.initialRoute) {\n      this.routes = [this.props.initialRoute];\n    } else if (this.props.initialRouteStack) {\n      this.routes = this.props.initialRouteStack;\n    } else {\n      this.routes = [];\n    }\n\n    this.pages = this.routes.map(\n      (route) => this.props.renderPage(route, this)\n    );\n    this.forceUpdate();\n  }\n\n  componentDidUpdate() {\n    if (this.props.onDeviceBackButton !== undefined) {\n      this.ref.current.onDeviceBackButton = this.props.onDeviceBackButton;\n    }\n  }\n\n  componentWillUnmount() {\n    const node = this.ref.current;\n    node.removeEventListener('prepush', this.props.onPrePush);\n    node.removeEventListener('postpush', this.props.onPostPush);\n    node.removeEventListener('prepop', this.props.onPrePop);\n    node.removeEventListener('postpop', this.props.onPostPop);\n  }\n\n  render() {\n    const {\n      innerRef,\n      renderPage,\n\n      // these props should not be passed down\n      initialRouteStack,\n      initialRoute,\n      onPrePush,\n      onPostPush,\n      onPrePop,\n      onPostPop,\n      swipePop,\n      onDeviceBackButton,\n\n      ...rest\n    } = this.props;\n\n    const pages = this.routes ? this.routes.map((route) => renderPage(route, this)) : null;\n\n    if (innerRef && innerRef !== this.ref) {\n      this.ref = innerRef;\n    }\n\n    return (\n      <Element\n        ref={this.ref}\n        {...rest}\n      >\n        {pages}\n      </Element>\n    );\n  }\n}\n\n/**\n * @original ons-navigator\n * @category navigation\n * @tutorial react/Reference/navigator\n * @description\n * [en] This component is responsible for page transitioning and managing the pages of your OnsenUI application. In order to manage to display the pages, the  navigator needs to define the `renderPage` method, that takes an route and a navigator and  converts it to an page.  [/en]\n * [ja][/ja]\n * @example\n  <Navigator\n    renderPage={(route, navigator) =>\n     <MyPage\n       title={route.title}\n       onPop={() => navigator.popPage()}\n       />\n    }\n    initialRoute={{\n        title: 'First Page'\n    }} />\n   }\n }\n */\nconst Navigator = React.forwardRef((props, ref) => (\n  <NavigatorClass innerRef={ref} {...props}>{props.children}</NavigatorClass>\n));\n\nNavigator.propTypes = {\n  /**\n   * @name renderPage\n   * @type function\n   * @required true\n   * @defaultValue null\n   * @description\n   *  [en] This function takes the current route object as a parameter and returns a React component.[/en]\n   *  [ja][/ja]\n   */\n  renderPage: PropTypes.func.isRequired,\n  /**\n   * @name initialRouteStack\n   * @type array\n   * @required false\n   * @defaultValue null\n   * @description\n   *  [en] This array contains the initial routes from the Navigator,\n   *  which will be used to render the initial pages in the `renderPage` method.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  initialRouteStack: PropTypes.array,\n\n  /**\n   * @name initialRoute\n   * @type object\n   * @required false\n   * @defaultValue null\n   * @description\n   *  [en] This array contains the initial route of the navigator,\n   *  which will be used to render the initial pages in the\n   *  renderPage method.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  initialRoute: PropTypes.object,\n\n  /**\n   * @name onPrePush\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just before a page is pushed. It gets an event object with route information.[/en]\n   *  [ja][/ja]\n   */\n  onPrePush: PropTypes.func,\n\n  /**\n   * @name onPostPush\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just after a page is pushed. It gets an event object with route information.[/en]\n   *  [ja][/ja]\n   */\n  onPostPush: PropTypes.func,\n\n  /**\n   * @name onPrePop\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just before a page is popped. It gets an event object with route information.[/en]\n   */\n  onPrePop: PropTypes.func,\n\n  /**\n   * @name onPostPop\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just after a page is popped. It gets an event object with route information.[/en]\n   *  [ja][/ja]\n   */\n  onPostPop: PropTypes.func,\n\n  /**\n   * @name animation\n   * @type {String}\n   * @description\n   *   [en]\n   *     Animation name. Available animations are `\"slide\"`, `\"lift\"`, `\"fade\"` and `\"none\"`.\n   *     These are platform based animations. For fixed animations, add `\"-ios\"` or `\"-md\"` suffix to the animation name. E.g. `\"lift-ios\"`, `\"lift-md\"`. Defaults values are `\"slide-ios\"` and `\"fade-md\"`.\n   *   [/en]\n   *   [ja][/ja]\n   */\n  animation: PropTypes.string,\n\n  /**\n   * @name animationOptions\n   * @type object\n   * @description\n   *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]\n   *  [ja][/ja]\n   */\n  animationOptions: PropTypes.object,\n\n  /**\n   * @name swipeable\n   * @type bool|string\n   * @required false\n   * @description\n   *  [en]Enables swipe-to-pop functionality for iOS.[/en]\n   *  [ja][/ja]\n   */\n  swipeable: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),\n\n  /**\n   * @name swipePop\n   * @type function\n   * @required false\n   * @description\n   *  [en]Optional function called on swipe-to-pop. If provided, must perform a popPage with the given options object.[/en]\n   *  [ja][/ja]\n   */\n  swipePop: PropTypes.func,\n  /**\n   * @name onDeviceBackButton\n   * @type function\n   * @required false\n   * @description\n   *  [en]Custom handler for device back button.[/en]\n   *  [ja][/ja]\n   */\n  onDeviceBackButton: PropTypes.func\n};\n\nconst NOOP = () => null;\n\nNavigator.defaultProps = {\n  onPostPush: NOOP,\n  onPrePush: NOOP,\n  onPrePop: NOOP,\n  onPostPop: NOOP\n};\n\nexport default Navigator;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-modal';\n\nimport onsCustomElement from '../onsCustomElement';\nimport baseDialog from '../baseDialog';\n\nconst deprecated = {\n  isOpen: 'visible'\n};\n\nconst notAttributes = ['onDeviceBackButton'];\n\n/**\n * @original ons-modal\n * @category dialog\n * @tutorial react/Reference/modal\n * @description\n * [en]\n *   A modal component covers the entire screen. Underlying components are not\n *   subject to any events while the modal component is shown.\n *\n *   This component can be used to block user input while some operation is\n *   running or to show some information to the user.\n * [/en]\n * [ja]\n *   画面全体をマスクするモーダル用コンポーネントです。下側にあるコンポーネントは、\n *   モーダルが表示されている間はイベント通知が行われません\n * [/ja]\n * @example\n  <Page>\n    <div> Page content </div>\n\n    <Modal isOpen={this.state.isLoading}>\n      Loading ...\n    </Modal>\n  </Page>\n */\nconst Modal = onsCustomElement(baseDialog('ons-modal'), {deprecated, notAttributes});\n\nModal.propTypes = {\n  /**\n   * @name animation\n   * @type {String}\n   * @description\n   *   [en]\n   *     Animation name. Available animations are `\"fade\"`, `\"lift\"` and `\"none\"`.\n   *   [/en]\n   */\n  animation: PropTypes.oneOf(['none', 'fade', 'lift']),\n\n  /**\n   * @name animationOptions\n   * @type object\n   * @description\n   *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]\n   */\n  animationOptions: PropTypes.object,\n\n  /**\n   * @name onPreShow\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called just before the modal is displayed.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onPreShow: PropTypes.func,\n\n  /**\n   * @name onPostShow\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called just after the modal is displayed.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onPostShow: PropTypes.func,\n\n  /**\n   * @name onPreHide\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just before the modal is hidden.[/en]\n   *  [ja][/ja]\n   */\n  onPreHide: PropTypes.func,\n\n  /**\n   * @name onPostHide\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just after the modal is hidden.[/en]\n   *  [ja][/ja]\n   */\n  onPostHide: PropTypes.func,\n\n  /**\n   * @name visible\n   * @type boolean\n   * @description\n   *  [en]When `true` the modal will show itself.[/en]\n   */\n  visible: PropTypes.bool,\n\n  /**\n   * @name isOpen\n   * @type boolean\n   * @description\n   *  [en]DEPRECATED! Use `visible` instead.[/en]\n   */\n  isOpen: PropTypes.bool,\n\n  /**\n   * @name onDeviceBackButton\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Custom handler for device back button.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onDeviceBackButton: PropTypes.func\n};\n\nexport default Modal;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-page';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst notAttributes = ['onInfiniteScroll', 'onDeviceBackButton'];\nconst Element = onsCustomElement('ons-page', {notAttributes});\n\n/**\n * @original ons-page\n * @category page\n * @tutorial react/Reference/page\n * @description\n * [en]\n *   This component is handling the entire page. The content can be scrolled.\n *\n *   To add fixed content that doesn't scroll with the page the `renderFixed` prop is used.\n *\n *   A page toolbar can be added with the `renderToolbar` prop.\n * [/en]\n * [ja][/ja]\n * @example\n  <Page\n    renderFixed={() => <Fab></Fab>}\n    renderToolbar={() => <Toolbar>...</Toolbar>}\n    contentStyle={{padding: 40}}>\n    <div> Page content </div>\n  </Page>\n */\nconst Page = React.forwardRef((props, ref) => {\n  const {\n    renderToolbar,\n    renderBottomToolbar,\n    renderModal,\n    renderFixed,\n    contentStyle,\n    children,\n    ...rest\n  } = props;\n\n  return (\n    <Element\n      {...rest}\n      ref={ref}\n    >\n      {renderToolbar(ref)}\n      <div className='page__background'> </div>\n      <div className='page__content' style={contentStyle}>\n        {children}\n      </div>\n      <div className='page__extra' style={{zIndex: 10001}}>\n        {renderModal(ref)}\n      </div>\n      {renderFixed(ref)}\n      {renderBottomToolbar(ref)}\n    </Element>\n  );\n});\n\nPage.propTypes = {\n\n  /**\n   * @name contentStyle\n   * @type Object\n   * @description\n   *  [en]\n   *  Specify the style of the page content. Optional.\n   *  [/en]\n   */\n  contentStyle: PropTypes.object,\n\n  /**\n   * @name modifier\n   * @type string\n   * @description\n   *  [en]\n   *  Specify modifier name to specify custom styles. Optional.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name renderModal\n   * @type function\n   * @required false\n   * @defaultValue null\n   * @description\n   *  [en] This function renders a modal that masks current screen.[/en]\n   */\n  renderModal: PropTypes.func,\n\n  /**\n   * @name renderToolbar\n   * @type function\n   * @required false\n   * @defaultValue null\n   * @description\n   *  [en] This function renders the toolbar of the page.[/en]\n   *  [ja][/ja]\n   */\n  renderToolbar: PropTypes.func,\n\n  /**\n   * @name renderBottomToolbar\n   * @type function\n   * @defaultValue null\n   * @description\n   *  [en] This function renders the bottom toolbar of the page.[/en]\n   *  [ja][/ja]\n   */\n  renderBottomToolbar: PropTypes.func,\n\n  /**\n   * @name renderFixed\n   * @type function\n   * @defaultValue null\n   * @description\n   *  [en] This function renders fixed content of the page. Can be used to render `Fab` or `SpeedDial` components as well as other components that don't scroll with the page.[/en]\n   *  [ja][/ja]\n   */\n  renderFixed: PropTypes.func,\n\n  /**\n   * @name onInit\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  \tFired right after the page is attached.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onInit: PropTypes.func,\n\n  /**\n   * @name onShow\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called Fired right after the page is shown.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onShow: PropTypes.func,\n\n  /**\n   * @name onHide\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called after the page is hidden.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onHide: PropTypes.func,\n\n  /**\n   * @name onInfiniteScroll\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called when scrolling to the bottom of the page. It gets a 'done' callback (first argument) that must be called when it's finished.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onInfiniteScroll: PropTypes.func,\n\n  /**\n   * @name onDeviceBackButton\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Custom handler for device back button.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onDeviceBackButton: PropTypes.func\n};\n\nconst NOOP = () => null;\n\nPage.defaultProps = {\n  renderToolbar: NOOP,\n  renderBottomToolbar: NOOP,\n  renderModal: NOOP,\n  renderFixed: NOOP\n};\n\nexport default Page;\n","import React, { useEffect, useRef } from 'react';\nimport PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-popover';\n\nimport onsCustomElement from '../onsCustomElement';\nimport baseDialog from '../baseDialog';\n\nconst deprecated = {\n  onCancel: 'onDialogCancel',\n  isDisabled: 'disabled',\n  isCancelable: 'cancelable'\n};\n\nconst notAttributes = ['onDeviceBackButton'];\n\nconst Elem = onsCustomElement(baseDialog('ons-popover'), {deprecated, notAttributes});\n\n/**\n * @original ons-popover\n * @category dialog\n * @tutorial react/Reference/popover\n * @description\n *   [en]\n *     A component that displays a popover next to an element. The popover can be used to display extra information about a component or a tooltip.\n *    Another common way to use the popover is to display a menu when a button on the screen is tapped.\n *   [/en]\n * [ja][/ja]\n * @example\n * <Page>\n *  <Button\n *    ref={(btn) => { this.btn = btn; }}\n *    onClick={() =>\n *      this.setState({target: this.btn, isOpen: true})\n *    }\n *  />\n    <Popover\n      isOpen={this.state.isOpen}\n      onCancel={() => this.setState({isOpen: false})}\n      getTarget={() => this.state.target}\n    >\n      <div style={{textAlign: 'center', opacity: 0.5}}>\n        <p>This is a popover!</p>\n          <p><small>Click the background to remove the popover.</small></p>\n        </div>\n        </Popover>\n * </Page>\n */\nconst Popover = React.forwardRef((props, forwardedRef) => {\n  const {isOpen, getTarget, children, ...rest} = props;\n  const ref = forwardedRef || useRef();\n\n  useEffect(() => {\n    if (isOpen !== ref.current.visible) {\n      if (isOpen) {\n        let target = getTarget();\n\n        // if React ref was returned instead of DOM Element, use ref.current instead\n        const isElement = x => x instanceof Element || x instanceof HTMLDocument;\n        if (!isElement(target) && target.current) {\n          target = target.current;\n        }\n\n        ref.current.show({target});\n      } else {\n        ref.current.hide();\n      }\n    }\n  });\n\n  return (\n    <Elem\n      ref={ref}\n      {...rest}\n    >\n      {children}\n    </Elem>\n  );\n});\n\nPopover.propTypes = {\n  /**\n   * @name getTarget\n   * @type function\n   * @required true\n   * @description\n   *  [en]\n   *  This function should return a ref to the DOM node that the popover will target.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  getTarget: PropTypes.func.isRequired,\n\n  /**\n   * @name onDialogCancel\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called only if isCancelable is true. It will be called after tapping the background or by pressing the back button on Android devices.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onDialogCancel: PropTypes.func,\n\n  /**\n   * @name onCancel\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `onDialogCancel` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onCancel: PropTypes.func,\n\n  /**\n   * @name isOpen\n   * @type bool\n   * @required true\n   * @description\n   *  [en]\n   *  Indicates whether the dialog is open and shown.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  isOpen: PropTypes.bool.isRequired,\n\n  /**\n   * @name cancelable\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  Specifies whether the dialog is cancelable or not.\n   *  A cancelable dialog will call onCancel  when tapping the background or or  pressing the back button on Android devices\n   *  [/en]\n   *  [ja][/ja]\n   */\n  cancelable: PropTypes.bool,\n\n  /**\n   * @name isCancelable\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `cancelable` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  isCancelable: PropTypes.bool,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  Specifies whether the dialog is disabled.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name isDisabled\n   * @type bool\n   * @required false\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `disabled` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  isDisabled: PropTypes.bool,\n\n  /**\n   * @name animation\n   * @type string\n   * @required false\n   * @description\n   *  [en]\n   *  The animation used when showing and hiding the dialog. Can be either `\"none\"` or `\"default\"`.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  animation: PropTypes.string,\n\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the dialog.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name maskColor\n   * @type string\n   * @required false\n   * @description\n   *  [en]Color of the background mask. Default is \"rgba(0, 0, 0, 0.2)\"[/en]\n   *  [ja][/ja]\n   */\n  maskColor: PropTypes.string,\n\n  /**\n   * @name animationOptions\n   * @type object\n   * @required false\n   * @description\n   *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]\n   *  [ja][/ja]\n   */\n  animationOptions: PropTypes.object,\n\n  /**\n   * @name onPreShow\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called just before the alert dialog is displayed.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onPreShow: PropTypes.func,\n\n  /**\n   * @name onPostShow\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called just after the alert dialog is displayed.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onPostShow: PropTypes.func,\n\n  /**\n   * @name onPreHide\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just before the alert dialog is hidden.[/en]\n   *  [ja][/ja]\n   */\n  onPreHide: PropTypes.func,\n\n  /**\n   * @name onPostHide\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just after the alert dialog is hidden.[/en]\n   *  [ja][/ja]\n   */\n  onPostHide: PropTypes.func,\n\n  /**\n   * @name onDeviceBackButton\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Custom handler for device back button.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onDeviceBackButton: PropTypes.func\n};\n\nexport default Popover;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-progress-bar';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-progress-bar\n * @category visual\n * @tutorial react/Reference/progress\n * @description\n * [en] The component is used to display a linear progress bar. It can either display a progress bar that shows the user how much of a task has been completed. In the case where the percentage is not known it can be used to display an animated progress bar so the user can see that an operation is in progress.  [/en]\n * [ja][/ja]\n * @example\n *<ProgressBar value={55} secondaryValue={87} />\n *<ProgressBar indeterminate />\n */\nconst ProgressBar = onsCustomElement('ons-progress-bar');\n\nProgressBar.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the progress indicator.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name value\n   * @type number\n   * @description\n   *  [en]\n   *  Current progress. Should be a value between 0 and 100.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  value: PropTypes.number,\n\n  /**\n   * @name secondaryValue\n   * @type bool\n   * @description\n   *  [en]\n   *  Current secondary progress. Should be a value between 0 and 100.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  secondaryValue: PropTypes.number,\n\n  /**\n   * @name indeterminate\n   * @type bool\n   * @description\n   *  [en] If this property is set, an infinite looping animation will be shown. [/en]\n   *  [ja][/ja]\n   */\n  indeterminate: PropTypes.bool\n};\n\nexport default ProgressBar;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-progress-circular';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-progress-circular\n * @category visual\n * @tutorial react/Reference/progress-circular\n * @description\n * [en] This component displays a circular progress indicator. It can either be used to show how much of a task has been completed or to show a looping animation to indicate that an operation is currently running.\n * [/en]\n * [ja][/ja]\n * @example\n *<ProgressCircular value={55} secondaryValue={87} />\n *<ProgressCircular indeterminate />\n */\nconst ProgressCircular = onsCustomElement('ons-progress-circular');\n\nProgressCircular.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the progress indicator.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name value\n   * @type number\n   * @description\n   *  [en]\n   *  Current progress. Should be a value between 0 and 100.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  value: PropTypes.number,\n\n  /**\n   * @name secondaryValue\n   * @type bool\n   * @description\n   *  [en]\n   *  Current secondary progress. Should be a value between 0 and 100.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  secondaryValue: PropTypes.number,\n\n  /**\n   * @name indeterminate\n   * @type bool\n   * @description\n   *  [en] If this property is set, an infinite looping animation will be shown. [/en]\n   *  [ja][/ja]\n   */\n  indeterminate: PropTypes.bool\n};\n\nexport default ProgressCircular;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-pull-hook';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst deprecated = {\n  onLoad: 'onAction',\n  onChange: 'onChangeState'\n};\n\nconst notAttributes = ['onAction'];\n\n/**\n * @original ons-pull-hook\n * @category control\n * @tutorial react/Reference/pull-hook\n * @description\n * [en]  Component that adds **Pull to refresh** functionality to an `<ons-page>` element.\n *     It can be used to perform a task when the user pulls down at the top of the page. A common usage is to refresh the data displayed in a page.\n [/en]\n * [ja][/ja]\n * @example\n\n    return (\n      <PullHook onChange={this.onChange} onLoad={this.onLoad}>\n      {\n       (this.state.pullHookState === 'initial') ?\n        <span >\n          <Icon size={35} spin={false} icon='ion-arrow-down-a' />\n          Pull down to refresh\n        </span> :\n        (this.state.pullHookState === 'preaction') ?\n         <span>\n           <Icon size={35} spin={false} icon='ion-arrow-up-a' />\n           Release to refresh\n        </span>\n        :\n        <span><Icon size={35} spin={true} icon='ion-load-d'></Icon> Loading data...</span>\n    }\n      </PullHook>\n    );\n */\nconst PullHook = onsCustomElement('ons-pull-hook', {deprecated, notAttributes});\n\nPullHook.propTypes = {\n  /**\n   * @name onChangeState\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called when the pull hook inner state is changed. The state can be either \"initial\", \"preaction\" or \"action\"[/en]\n   *  [ja][/ja]\n   */\n  onChangeState: PropTypes.func,\n\n  /**\n   * @name onChange\n   * @type function\n   * @required false\n   * @description\n   *  [en]DEPRECATED! Use `onChangeState` instead.[/en]\n   *  [ja][/ja]\n   */\n  onChange: PropTypes.func,\n\n  /**\n   * @name onAction\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called when the pull hook is in the `action` state[/en]\n   *  [ja][/ja]\n   */\n  onAction: PropTypes.func,\n\n  /**\n   * @name onLoad\n   * @type function\n   * @required false\n   * @description\n   *  [en]DEPRECATED! Use `onAction` instead.[/en]\n   *  [ja][/ja]\n   */\n  onLoad: PropTypes.func,\n\n  /**\n   * @name onPull\n   * @type function\n   * @required false\n   * @description\n   *  [en]Hook called whenever the user pulls the element. It gets the pulled distance ratio (scroll / height) and an animationOptions object as arguments.[/en]\n   *  [ja][/ja]\n   */\n  onPull: PropTypes.func,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @description\n   *  [en] When set to true, the pull hook will be disabled.[/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name height\n   * @type number\n   * @description\n   *  [en] The height of the pull hook in pixels. The default value is 64.[/en]\n   *  [ja][/ja]\n   */\n  height: PropTypes.number,\n\n  /**\n   * @name thresholdHeight\n   * @type number\n   * @description\n   *  [en] The threshold height of the pull hook in pixels. The default value is 96.[/en]\n   *  [ja][/ja]\n   */\n  thresholdHeight: PropTypes.number,\n\n  /**\n   * @name fixedContent\n   * @type number\n   * @description\n   *  [en] If set to true, the content of the page will not move when pulling.[/en]\n   *  [ja][/ja]\n   */\n  fixedContent: PropTypes.bool\n};\n\nexport default PullHook;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-radio';\n\nimport onsCustomElement from '../onsCustomElement';\nimport oneTimeProp from '../oneTimeProp';\nimport INPUT_PROPS from '../inputProps';\n\nconst nameMap = {\n  ...INPUT_PROPS\n};\n\nconst withDefaultChecked = component => oneTimeProp(component, 'defaultChecked', 'checked');\n\n/**\n * @original ons-radio\n * @category form\n * @tutorial react/Reference/radio\n * @description\n * [en]\n *  A radio button element. The component will automatically render as a Material Design radio button on Android devices.\n *\n *  Most attributes that can be used for a normal `<input type=\"radio\">` element can also be used on the `<Radio>` component.\n * [/en]\n * [ja][/ja]\n * @example\n * <Radio\n *   onChange={event => { this.setState({checked: event.target.checked})} }\n *   modifier='material' />\n */\nconst Radio = withDefaultChecked(onsCustomElement('ons-radio', {deprecated: nameMap}));\n\nRadio.propTypes = {\n  /**\n   * @name name\n   * @type string\n   * @description\n   *  [en]The name of the radio button.[/en]\n   *  [ja][/ja]\n   */\n  name: PropTypes.string,\n\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the radio button.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @description\n   *  [en]\n   *  Specifies whether the radio button is disabled.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name onChange\n   * @type function\n   * @description\n   *  [en] Called when the radio button state changes.[/en]\n   *  [ja][/ja]\n   */\n  onChange: PropTypes.func,\n\n  /**\n   * @name value\n   * @type string\n   * @description\n   *  [en] Value of the radio button.[/en]\n   *  [ja][/ja]\n   */\n  value: PropTypes.oneOfType([\n    PropTypes.string,\n    PropTypes.instanceOf(Date)\n  ]),\n\n  /**\n   * @name checked\n   * @type boolean\n   * @description\n   *  [en]Controls the state of the radio button (controlled).[/en]\n   *  [ja][/ja]\n   */\n  checked: PropTypes.bool,\n\n  /**\n   * @name defaultChecked\n   * @type boolean\n   * @description\n   *  [en]Defined the state of the radio button at first render for uncontrolled inputs.[/en]\n   *  [ja][/ja]\n   */\n  defaultChecked: PropTypes.bool,\n\n  /**\n   * @name inputId\n   * @type string\n   * @description\n   *  [en]Specify the \"id\" attribute of the inner `<input>` element. This is useful when using <label for=\"...\"> elements.[/en]\n   *  [ja][/ja]\n   */\n  inputId: PropTypes.string\n};\n\nexport default Radio;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-range';\n\nimport onsCustomElement from '../onsCustomElement';\nimport oneTimeProp from '../oneTimeProp';\nimport INPUT_PROPS from '../inputProps';\n\nconst nameMap = {\n  ...INPUT_PROPS\n};\n\nconst withDefaultValue = component => oneTimeProp(component, 'defaultValue', 'value');\n\n/**\n * @original ons-range\n * @category form\n * @tutorial react/Reference/range\n * @description\n * [en]\n *   Range input component.\n * [/en]\n * [ja][/ja]\n * @example\n * <Range modifier=\"material\"\n *   value={this.state.value}\n *   onChange={(event) => this.setState({value: parseInt(event.target.value)})}\n *   />\n */\nconst Range = withDefaultValue(onsCustomElement('ons-range', {deprecated: nameMap}));\n\nRange.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the progress indicator.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name onChange\n   * @type function\n   * @description\n   *  [en] Called when the value of the input changes.[/en]\n   *  [ja][/ja]\n   */\n  onChange: PropTypes.func,\n\n  /**\n   * @name onInput\n   * @type function\n   * @description\n   *  [en] Called when the inner range fires an `input` event.[/en]\n   *  [ja][/ja]\n   */\n  onInput: PropTypes.func,\n\n  /**\n   * @name value\n   * @type number\n   * @description\n   *  [en]\n   *  Current value of the element.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  value: PropTypes.number,\n\n  /**\n   * @name value\n   * @type number\n   * @description\n   *  [en]\n   *  Default value of the element (for uncontrolled components).\n   *  [/en]\n   *  [ja][/ja]\n   */\n  defaultValue: PropTypes.number,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @description\n   *  [en] If true, the element is disabled. [/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool\n};\n\nexport default Range;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-ripple';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-ripple\n * @category visual\n * @tutorial react/Reference/ripple\n * @description\n * [en]\n *   Adds a Material Design \"ripple\" effect to an element.\n * [/en]\n * [ja][/ja]\n * @example\n   <div className='myList'>\n     <Ripple color='red' />\n   </div>\n */\nconst Ripple = onsCustomElement('ons-ripple');\n\nRipple.propTypes = {\n  /**\n   * @name color\n   * @type string\n   * @required false\n   * @description\n   *  [en]Color of the ripple effect.[/en]\n   *  [ja][/ja]\n   */\n  color: PropTypes.string,\n\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the ripple effect.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name background\n   * @type string\n   * @required false\n   * @description\n   *  [en]Color of the background.[/en]\n   *  [ja][/ja]\n   */\n  background: PropTypes.string,\n\n  /**\n   * @name size\n   * @type string\n   * @required false\n   * @description\n   *  [en]Sizing of the wave on ripple effect. Set \"cover\" or \"contain\". Default is \"cover\".[/en]\n   *  [ja][/ja]\n   */\n  size: PropTypes.string,\n\n  /**\n   * @name size\n   * @type string\n   * @required false\n   * @description\n   *  [en]Changes the position of wave effect to center of the target element.[/en]\n   *  [ja][/ja]\n   */\n  center: PropTypes.bool,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @description\n   *  [en]\n   *  Specifies whether the button is disabled.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool\n};\n\nexport default Ripple;\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-navigator';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst Element = onsCustomElement('ons-navigator');\n\nclass RouterNavigatorClass extends React.Component {\n  constructor(...args) {\n    super(...args);\n\n    this.cancelUpdate = false;\n\n    const callback = (name, event) => {\n      if (this.props[name]) {\n        return this.props[name](event);\n      }\n    };\n    this.onPrePush = callback.bind(this, 'onPrePush');\n    this.onPostPush = callback.bind(this, 'onPostPush');\n    this.onPrePop = callback.bind(this, 'onPrePop');\n    this.onPostPop = callback.bind(this, 'onPostPop');\n\n    this.ref = React.createRef();\n\n    this.state = {\n      internalStack: []\n    };\n  }\n\n  update(cb) {\n    if (!this.cancelUpdate) {\n      this.setState({}, cb);\n    }\n  }\n\n  /**\n   * @method resetPageStack\n   * @signature resetPageStack(route, options = {})\n   * @param {Array} [routes]\n   *   [en] The routes that the navigator should be reset to.[/en]\n   *   [ja][/ja]\n   * @return {Promise}\n   *   [en]Promise which resolves to the revealed page.[/en]\n   *   [ja]明らかにしたページを解決するPromiseを返します。[/ja]\n   * @description\n   *   [en] Resets the navigator to the current page stack[/en]\n   *   [ja][/ja]\n   */\n  resetPageStack(routes, options = {}) {\n    if (this.isRunning()) {\n      return;\n    }\n\n    const update = () => {\n      return new Promise(resolve => {\n        this.setState({internalStack: [...this.state.internalStack, routes[routes.length - 1]]}, resolve);\n      });\n    };\n\n    return this.ref.current._pushPage(options, update)\n      .then(() => {\n        this.setState({internalStack: [...routes]});\n      });\n  }\n\n  /**\n   * @method pushPage\n   * @signature pushPage(route, options = {})\n   * @param {Array} [routes]\n   *   [en] The routes that the navigator should push to.[/en]\n   *   [ja][/ja]\n   * @return {Promise}\n   *   [en] Promise which resolves to the revealed page.[/en]\n   *   [ja]明らかにしたページを解決するPromiseを返します。[/ja]\n   * @description\n   *   [en] Pushes a page to the page stack[/en]\n   *   [ja][/ja]\n   */\n  pushPage(route, options = {}) {\n    if (this.isRunning()) {\n      return;\n    }\n\n    const update = () => {\n      return new Promise(resolve => {\n        this.setState({internalStack: [...this.state.internalStack, route]}, resolve);\n      });\n    };\n\n    return this.ref.current._pushPage(options, update);\n  }\n\n  isRunning() {\n    return this.ref.current._isRunning;\n  }\n\n  /*\n   * @method replacePage\n   * @signature replacePage(page, [options])\n   * @return {Promise}\n   *   [en]Promise which resolves to the new page.[/en]\n   *   [ja]新しいページを解決するPromiseを返します。[/ja]\n   * @description\n   *   [en]Replaces the current top page with the specified one. Extends `pushPage()` parameters.[/en]\n   *   [ja]現在表示中のページをを指定したページに置き換えます。[/ja]\n   */\n  replacePage(route, options = {}) {\n    if (this.isRunning()) {\n      return;\n    }\n\n    const update = () => {\n      return new Promise(resolve => {\n        this.setState({internalStack: [...this.state.internalStack, route]}, resolve);\n      });\n    };\n\n    return this.ref.current._pushPage(options, update)\n      .then(() => {\n        this.setState({internalStack: [...this.state.internalStack.slice(0, -2), route]});\n      });\n  }\n\n  /**\n   * @method popPage\n   * @signature popPage(route, options = {})\n   * @return {Promise}\n   *   [en] Promise which resolves to the revealed page.[/en]\n   *   [ja]明らかにしたページを解決するPromiseを返します。[/ja]\n   * @description\n   *   [en] Pops a page out of the page stack[/en]\n   *   [ja][/ja]\n   */\n  popPage(options = {}) {\n    if (this.isRunning()) {\n      return;\n    }\n\n    const update = () => {\n      return new Promise(resolve => {\n        ReactDOM.flushSync(() => { // prevents flickering caused by React 18 batching\n          this.setState({internalStack: this.state.internalStack.slice(0, -1)}, resolve);\n        });\n      });\n    };\n\n    return this.ref.current._popPage(options, update);\n  }\n\n  _onDeviceBackButton(event) {\n    if (this.props.routeConfig.routeStack.length > 1) {\n      this.popPage();\n    } else {\n      event.callParentHandler();\n    }\n  }\n\n  componentDidMount() {\n    const node = this.ref.current;\n\n    this.cancelUpdate = false;\n\n    node.addEventListener('prepush', this.onPrePush);\n    node.addEventListener('postpush', this.onPostPush);\n    node.addEventListener('prepop', this.onPrePop);\n    node.addEventListener('postpop', this.onPostPop);\n\n    if (!this.props.routeConfig) {\n      throw new Error('In RouterNavigator the property routeConfig needs to be set');\n    }\n\n    node.swipeMax = this.props.swipePop;\n    node.onDeviceBackButton = this.props.onDeviceBackButton || this._onDeviceBackButton.bind(this);\n\n    this.setState({internalStack: this.props.routeConfig.routeStack});\n  }\n\n  componentWillUnmount() {\n    const node = this.ref.current;\n    node.removeEventListener('prepush', this.onPrePush);\n    node.removeEventListener('postpush', this.onPostPush);\n    node.removeEventListener('prepop', this.onPrePop);\n    node.removeEventListener('postpop', this.onPostPop);\n    this.cancelUpdate = true;\n  }\n\n  componentDidUpdate(prevProps) {\n    if (this.props.onDeviceBackButton !== undefined) {\n      this.ref.current.onDeviceBackButton = this.props.onDeviceBackButton;\n    }\n\n    const processStack = [...this.props.routeConfig.processStack];\n\n    /**\n     * Fix for Redux Timetravel.\n     */\n    if (prevProps.routeConfig.processStack.length < this.props.routeConfig.processStack.length &&\n      prevProps.routeConfig.routeStack.length > this.props.routeConfig.routeStack.length) {\n      return;\n    }\n\n    if (processStack.length > 0) {\n      const {type, route, options} = processStack[0];\n\n      switch (type) {\n        case 'push':\n          this.pushPage(route, options);\n          break;\n        case 'pop':\n          this.popPage(options);\n          break;\n        case 'reset':\n          if (Array.isArray(route)) {\n            this.resetPageStack(route, options);\n          } else {\n            this.resetPageStack([route], options);\n          }\n          break;\n        case 'replace':\n          this.replacePage(route, options);\n          break;\n        default:\n          throw new Error(`Unknown type ${type} in processStack`);\n      }\n    }\n  }\n\n  render() {\n    const {\n      innerRef,\n      renderPage,\n\n      // these props should not be passed down\n      onPrePush,\n      onPostPush,\n      onPrePop,\n      onPostPop,\n      swipePop,\n      onDeviceBackButton,\n\n      ...rest\n    } = this.props;\n\n    const pagesToRender = this.state.internalStack.map(route => renderPage(route));\n\n    if (innerRef && innerRef !== this.ref) {\n      this.ref = innerRef;\n    }\n\n    return (\n      <Element {...rest} ref={this.ref}>\n        {pagesToRender}\n      </Element>\n    );\n  }\n}\n\n/**\n * @original ons-navigator\n * @category navigation\n * @tutorial react/Reference/navigator\n * @description\n * [en] This component is a variant of the Navigator with a declarative API. In order to manage to display the pages, the  navigator needs to define the `renderPage` method, that takes an route and a navigator and  converts it to an page.[/en]\n * [ja][/ja]\n */\nconst RouterNavigator = React.forwardRef((props, ref) => (\n  <RouterNavigatorClass innerRef={ref} {...props}>{props.children}</RouterNavigatorClass>\n));\n\nRouterNavigator.propTypes = {\n  /**\n   * @name renderPage\n   * @type function\n   * @required true\n   * @defaultValue null\n   * @description\n   *  [en] This function takes the current route object as a parameter and returns a react componen.[/en]\n   *  [ja][/ja]\n   */\n  renderPage: PropTypes.func.isRequired,\n  /**\n   * @name routeConfig\n   * @type object\n   * @required true\n   * @defaultValue null\n   * @description\n   *  [en] This object must contain two properties:\n   *  `routeStack`: An array of route objects,\n   *  `processStack`: An array of process objects `{ type: push | pop | reset, route: userRoute }` that\n   *  describe the transition from the current state to the next state.\n   *  Make sure that the route stack is not emptied before the animations for the `processStack` have completed.\n   *  It is recommended to update the `routeStack` and empty the `processStack` in the 'onPostPop' callback.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  routeConfig: PropTypes.shape({\n    routeStack: PropTypes.arrayOf(PropTypes.object),\n    processStack: PropTypes.arrayOf(PropTypes.object)\n  }),\n\n  /**\n   * @name onPrePush\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just before a page is pushed.[/en]\n   */\n  onPrePush: PropTypes.func,\n\n  /**\n   * @name onPostPush\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just after a page is pushed.[/en]\n   */\n  onPostPush: PropTypes.func,\n\n  /**\n   * @name onPrePop\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just before a page is popped.[/en]\n   */\n  onPrePop: PropTypes.func,\n\n  /**\n   * @name onPostPop\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just after a page is popped.[/en]\n   */\n  onPostPop: PropTypes.func,\n\n  /**\n   * @property animation\n   * @type {String}\n   * @description\n   *   [en]\n   *     Animation name. Available animations are `\"slide\"`, `\"lift\"`, `\"fade\"` and `\"none\"`.\n   *     These are platform based animations. For fixed animations, add `\"-ios\"` or `\"-md\"` suffix to the animation name. E.g. `\"lift-ios\"`, `\"lift-md\"`. Defaults values are `\"slide-ios\"` and `\"fade-md\"`.\n   *   [/en]\n   */\n  animation: PropTypes.string,\n\n  /**\n   * @name animationOptions\n   * @type object\n   * @description\n   *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]\n   *  [ja][/ja]\n   */\n  animationOptions: PropTypes.object,\n\n  /**\n   * @name swipeable\n   * @type bool|string\n   * @required false\n   * @description\n   *  [en]\n   *  Enables swipe-to-pop functionality for iOS.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  swipeable: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),\n\n  /**\n   * @name swipePop\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Function called on swipe-to-pop. Must perform a popPage with the given options object.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  swipePop: PropTypes.func,\n\n  /**\n   * @name onDeviceBackButton\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Custom handler for device back button.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onDeviceBackButton: PropTypes.func\n};\n\nexport default RouterNavigator;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-row';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-row\n * @category grid\n * @description\n * [en]\n * Represents a row in the grid system. Use with `Col` to layout components.\n * [/en]\n * [ja][/ja]\n * <Row>\n *   <Col width={50}>\n  *   <ons-icon icon=\"fa-twitter\"></ons-icon>\n *   </Col>\n *   <Col>Text</Col>\n * </Row>\n */\nconst Row = onsCustomElement('ons-row');\n\nRow.propTypes = {\n\n  /**\n  * @name verticalAlign\n  * @type {String}\n  * @description\n  *   [en]Short hand attribute for aligning vertically. Valid values are top, bottom, and center.[/en]\n  *   [ja][/ja]\n  */\n  verticalAlign: PropTypes.oneOf(['top', 'bottom', 'center'])\n\n};\n\nexport default Row;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-search-input';\n\nimport onsCustomElement from '../onsCustomElement';\nimport oneTimeProp from '../oneTimeProp';\nimport INPUT_PROPS from '../inputProps';\n\nconst nameMap = {\n  ...INPUT_PROPS\n};\n\nconst withDefaultValue = component => oneTimeProp(component, 'defaultValue', 'value');\n\nconst notAttributes = [\n  'value' // value must be applied as property since attribute only works before input is touched\n];\n\n/**\n * @original ons-search-input\n * @category form\n * @tutorial react/Reference/search-input\n * @description\n * [en]\n *  A search input component. The component will automatically render as a Material Design search input on Android devices.\n *\n *  Most attributes that can be used for a normal `<input>` element can also be used on the `<SearchInput>` component.\n * [/en]\n * [ja][/ja]\n * @example\n * <SearchInput\n *   value={this.state.text}\n *   onChange={(event) => { this.setState({text: event.target.value})} }\n *   modifier='material'\n *   placeholder='Username' />\n */\nconst SearchInput = withDefaultValue(onsCustomElement('ons-search-input', {deprecated: nameMap, notAttributes}));\n\nSearchInput.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the input.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @description\n   *  [en]Specifies whether the input is disabled.[/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name readOnly\n   * @type bool\n   * @description\n   *  [en]Specifies whether the input is read-only.[/en]\n   *  [ja][/ja]\n   */\n  readOnly: PropTypes.bool,\n\n  /**\n   * @name onChange\n   * @type function\n   * @description\n   *  [en]Called when the inner input fires a `change` event.[/en]\n   *  [ja][/ja]\n   */\n  onChange: PropTypes.func,\n\n  /**\n   * @name onInput\n   * @type function\n   * @description\n   *  [en]Called when the inner input fires an `input` event.[/en]\n   *  [ja][/ja]\n   */\n  onInput: PropTypes.func,\n\n  /**\n   * @name value\n   * @type string\n   * @description\n   *  [en]Content of the input (controlled).[/en]\n   *  [ja][/ja]\n   */\n  value: PropTypes.oneOfType([\n    PropTypes.string,\n    PropTypes.instanceOf(Date)\n  ]),\n\n  /**\n   * @name defaultValue\n   * @type string\n   * @description\n   *  [en]Content of the input at first render (uncontrolled).[/en]\n   *  [ja][/ja]\n   */\n  defaultValue: PropTypes.oneOfType([\n    PropTypes.string,\n    PropTypes.instanceOf(Date)\n  ]),\n\n  /**\n   * @name placeholder\n   * @type string\n   * @description\n   *  [en] Placeholder text. In Material Design this placeholder will be a floating label. [/en]\n   *  [ja][/ja]\n   */\n  placeholder: PropTypes.string,\n\n  /**\n   * @name inputId\n   * @type string\n   * @description\n   *  [en]  Specify the \"id\" attribute of the inner `<input>` element. This is useful when using <label for=\"...\"> elements [/en]\n   *  [ja][/ja]\n   */\n  inputId: PropTypes.string\n};\n\nexport default SearchInput;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-segment';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst deprecated = {\n  index: 'activeIndex'\n};\n\n/**\n * @original ons-segment\n * @category control\n * @tutorial react/Reference/segment\n * @description\n * [en]\n *   Segment component.\n * [/en]\n * [ja][/ja]\n * @example\n * <Segment modifier=\"material\">\n *  <button>Label 1</button>\n *  <button>Label 2</button>\n *  <button>Label 3</button>\n * </Segment>\n */\nconst Segment = onsCustomElement('ons-segment', {deprecated});\n\nSegment.propTypes = {\n  /**\n   * @name activeIndex\n   * @type number\n   * @description\n   *  [en]The index of the button to highlight.[/en]\n   *  [ja][/ja]\n   */\n  activeIndex: PropTypes.number,\n\n  /**\n   * @name index\n   * @type number\n   * @description\n   *  [en]DEPRECATED! Use `activeIndex` instead.[/en]\n   *  [ja][/ja]\n   */\n  index: PropTypes.number,\n\n  /**\n   * @name tabbarId\n   * @type string\n   * @description\n   *  [en] ID of the `<Tabbar>` to \"connect\" to the segment. [/en]\n   *  [ja][/ja]\n   */\n  tabbarId: PropTypes.string,\n\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the segment.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name onPostChange\n   * @type function\n   * @description\n   *  [en] Called after the active button changes.[/en]\n   *  [ja][/ja]\n   */\n  onPostChange: PropTypes.func,\n\n  /**\n   * @name disabled\n   * @type boolean\n   * @description\n   *   [en]Specifies whether the segment should be disabled.[/en]\n   *   [ja][/ja]\n   */\n  disabled: PropTypes.bool\n};\n\nexport default Segment;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-select';\n\nimport onsCustomElement from '../onsCustomElement';\nimport oneTimeProp from '../oneTimeProp';\nimport INPUT_PROPS from '../inputProps';\n\nconst nameMap = {\n  ...INPUT_PROPS\n};\n\nconst withDefaultValue = component => oneTimeProp(component, 'defaultValue', 'value');\nconst Element = withDefaultValue(onsCustomElement('ons-select', {deprecated: nameMap}));\n\n/**\n * @original ons-select\n * @category form\n * @tutorial react/Reference/select\n * @description\n * [en]\n *   Select input component.\n * [/en]\n * [ja][/ja]\n * @example\n * <Select modifier=\"material\"\n *   value={this.state.value}\n *   onChange={(event) => this.setState({value: event.target.value})}>\n *   <option value=\"1\">1</option>\n *   <option value=\"2\">2nd</option>\n *   <option value=\"3\">3rd option</option>\n * </Select>\n */\nconst Select = React.forwardRef((props, ref) => (\n  <Element {...props} ref={ref}>\n    <select>\n      {props.children}\n    </select>\n  </Element>\n));\n\nSelect.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @description\n   *  [en]The appearance of the select box.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @description\n   *  [en]Specifies whether the select is disabled.[/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name onChange\n   * @type function\n   * @description\n   *  [en]Called when the value of the select changes.[/en]\n   *  [ja][/ja]\n   */\n  onChange: PropTypes.func,\n\n  /**\n   * @name value\n   * @type string\n   * @description\n   *  [en]Use this prop to set the selected option value.[/en]\n   *  [ja][/ja]\n   */\n  value: PropTypes.string,\n\n  /**\n   * @name defaultValue\n   * @type string\n   * @description\n   *  [en]Use this prop to set the defalut selected option value (uncontrolled components).[/en]\n   *  [ja][/ja]\n   */\n  defaultValue: PropTypes.string,\n\n  /**\n   * @name multiple\n   * @type boolean\n   * @description\n   *  [en]If this attribute is defined, multiple options can be selected at once.[/en]\n   *  [ja][/ja]\n   */\n  multiple: PropTypes.bool,\n\n  /**\n   * @name autofocus\n   * @type boolean\n   * @description\n   *  [en]Element automatically gains focus on page load.[/en]\n   *  [ja][/ja]\n   */\n  autofocus: PropTypes.bool,\n\n  /**\n   * @name required\n   * @type boolean\n   * @description\n   *  [en]Make the select input required for submitting the form it is part of.[/en]\n   *  [ja][/ja]\n   */\n  required: PropTypes.bool,\n\n  /**\n   * @name form\n   * @type string\n   * @description\n   *  [en]Associate a select element to an existing form on the page, even if not nested.[/en]\n   *  [ja][/ja]\n   */\n  form: PropTypes.string,\n\n  /**\n   * @name size\n   * @type number\n   * @description\n   *  [en]How many options are displayed; if there are more than the size then a scroll appears to navigate them[/en]\n   *  [ja][/ja]\n   */\n  size: PropTypes.number,\n\n  /**\n   * @name name\n   * @type string\n   * @description\n   *  [en]Name the select element, useful for instance if it is part of a form.[/en]\n   *  [ja][/ja]\n   */\n  name: PropTypes.string\n};\n\nexport default Select;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-speed-dial';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-speed-dial\n * @category control\n * @tutorial react/Reference/speed-dial\n * @description\n * [en] Element that displays a Material Design Speed Dialog component. It is useful when there are more than one primary action that can be performed in a page.\n *  The Speed dial looks like a `Fab` element but will expand a menu when tapped.\n [/en]\n * [ja][/ja]\n * @example\n * <SpeedDial disabled={false} direction='right' onClick={() => console.log('test1')} position='left bottom'>\n     <Fab>\n       <Icon icon='fa-twitter' size={26} fixedWidth={false} style={{verticalAlign: 'middle'}} />\n     </Fab>\n     <SpeedDialItem onClick={() => console.log('speed A')}> A </SpeedDialItem>\n     <SpeedDialItem onClick={() => console.log('speed B')}> B </SpeedDialItem>\n     <SpeedDialItem onClick={() => console.log('speed C')}> C </SpeedDialItem>\n     <SpeedDialItem onClick={() => console.log('speed D')}> D </SpeedDialItem>\n   </SpeedDial>\n */\nconst SpeedDial = onsCustomElement('ons-speed-dial');\n\nSpeedDial.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the speed dial.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name position\n   * @type string\n   * @description\n   *  [en]Specify the vertical and horizontal position of the component.\n   *     I.e. to display it in the top right corner specify \"right top\".\n   *     Choose from \"right\", \"left\", \"top\" and \"bottom\".\n[/en]\n   *  [ja][/ja]\n   */\n  position: PropTypes.string,\n\n  /**\n   * @name direction\n   * @type string\n   * @description\n   *  [en]Specify the direction the items are displayed. Possible values are \"up\", \"down\", \"left\" and \"right\".[/en]\n   *  [ja][/ja]\n   */\n  direction: PropTypes.oneOf(['up', 'down', 'left', 'right']),\n\n  /**\n   * @name disabled\n   * @type string\n   * @description\n   *  [en]Specify if button should be disabled.[/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool\n};\n\nexport default SpeedDial;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-speed-dial-item';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-speed-dial-item\n * @category control\n * @tutorial react/Reference/speed-dial\n * @description\n * [en] This component displays the child elements of the Material Design Speed dial component. [/en]\n * [ja][/ja]\n * @example\n * <SpeedDial disabled={false} direction='right' onClick={() => console.log('test1')} position='left bottom'>\n     <Fab>\n       <Icon icon='fa-twitter' size={26} fixedWidth={false} style={{verticalAlign: 'middle'}} />\n     </Fab>\n     <SpeedDialItem onClick={() => console.log('speed A')}> A </SpeedDialItem>\n     <SpeedDialItem onClick={() => console.log('speed B')}> B </SpeedDialItem>\n     <SpeedDialItem onClick={() => console.log('speed C')}> C </SpeedDialItem>\n     <SpeedDialItem onClick={() => console.log('speed D')}> D </SpeedDialItem>\n   </SpeedDial>\n */\nconst SpeedDialItem = onsCustomElement('ons-speed-dial-item');\n\nSpeedDialItem.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the button.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name onClick\n   * @type function\n   * @description\n   *  [en]This function will be called when the button is clicked.[/en]\n   *  [ja][/ja]\n   */\n  onClick: PropTypes.func\n};\n\nexport default SpeedDialItem;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-splitter';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst notAttributes = ['onDeviceBackButton'];\n\n/**\n * @original ons-splitter\n * @category menu\n * @tutorial react/Reference/splitter\n * @description\n * [en]  A component that enables responsive layout by implementing both a two-column layout and a sliding menu layout.\n *\n *    It can be configured to automatically expand into a column layout on large screens and collapse the menu on smaller screens. When the menu is collapsed the user can open it by swiping.\n [/en]\n * [ja][/ja]\n * @example\n  <Splitter>\n    <SplitterSide\n      side=\"left\"\n      width={200}\n      isSwipeable={true}>\n      <Page> Page Left </Page>\n    </SplitterSide>\n    <SplitterContent>\n      <Page> Page Content </Page>\n    </SplitterContent>\n    <SplitterSide\n      side=\"right\"\n      width={300}\n      collapse={!this.state.showRight}\n      isOpen={this.state.openRight}\n      onClose={this.handleRightClose.bind(this)}\n      onOpen={this.handleRightOpen.bind(this)}\n      isSwipeable={true}>\n      <Page> Page Right </Page>\n    </SplitterSide>\n  </Splitter>\n */\nconst Splitter = onsCustomElement('ons-splitter', {notAttributes});\n\nSplitter.propTypes = {\n  /**\n   * @name onDeviceBackButton\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Custom handler for device back button.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onDeviceBackButton: PropTypes.func\n};\n\nexport default Splitter;\n","import 'onsenui/esm/elements/ons-splitter-content';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-splitter-content\n * @category menu\n * @tutorial react/Reference/splitter\n * @description\n * [en]  The SplitterContent  element is used as a child element of Splitter.\n *    It contains the main content of the page while SplitterSide contains the list.\n [/en]\n * [ja][/ja]\n * @example\n  <Splitter>\n    <SplitterSide\n      side=\"left\"\n      width={200}\n      isSwipeable={true}>\n      <Page> Page Left </Page>\n    </SplitterSide>\n    <SplitterContent>\n      <Page> Page Content </Page>\n    </SplitterContent>\n    <SplitterSide\n      side=\"right\"\n      width={300}\n      collapse={!this.state.showRight}\n      isOpen={this.state.openRight}\n      onClose={this.handleRightClose.bind(this)}\n      onOpen={this.handleRightOpen.bind(this)}\n      isSwipeable={true}>\n      <Page> Page Right </Page>\n    </SplitterSide>\n  </Splitter>\n */\nconst SplitterContent = onsCustomElement('ons-splitter-content');\n\nexport default SplitterContent;\n","import 'onsenui/esm/elements/ons-splitter-mask';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-splitter-mask\n * @category menu\n * @tutorial react/Reference/splitter\n * @description\n * [en]  The SplitterMask  element is used as a child element of Splitter.\n *    It contains the mask content of the page.\n [/en]\n * [ja][/ja]\n * @example\n  <Splitter>\n    <SplitterSide\n      side=\"left\"\n      width={200}\n      isSwipeable={true}>\n      <Page> Page Left </Page>\n    </SplitterSide>\n    <SplitterMask>\n      <Page> Page Content </Page>\n    </SplitterMask>\n    <SplitterSide\n      side=\"right\"\n      width={300}\n      collapse={!this.state.showRight}\n      isOpen={this.state.openRight}\n      onClose={this.handleRightClose.bind(this)}\n      onOpen={this.handleRightOpen.bind(this)}\n      isSwipeable={true}>\n      <Page> Page Right </Page>\n    </SplitterSide>\n  </Splitter>\n */\nconst SplitterMask = onsCustomElement('ons-splitter-mask');\n\nexport default SplitterMask;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-splitter-side';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst deprecated = {\n  onOpen: 'onPostOpen',\n  onClose: 'onPostClose'\n};\nconst notAttributes = ['isOpen'];\n\nconst Element = onsCustomElement('ons-splitter-side', {deprecated, notAttributes});\n\n/**\n * @original ons-splitter-side\n * @category menu\n * @tutorial react/Reference/splitter\n * @description\n * [en]  The SplitterContent  element is used as a child element of Splitter.\n *    It contains the main content of the page while SplitterSide contains the list.\n [/en]\n * [ja][/ja]\n * @example\n  <Splitter>\n    <SplitterSide\n      side=\"left\"\n      width={200}\n      swipeable={true}>\n      <Page> Page Left </Page>\n    </SplitterSide>\n    <SplitterContent>\n      <Page> Page Content </Page>\n    </SplitterContent>\n    <SplitterSide\n      side=\"right\"\n      width={300}\n      collapse={!this.state.showRight}\n      isOpen={this.state.openRight}\n      onClose={this.handleRightClose.bind(this)}\n      onOpen={this.handleRightOpen.bind(this)}\n      swipeable={true}>\n      <Page> Page Right </Page>\n    </SplitterSide>\n  </Splitter>\n */\nconst SplitterSide = React.forwardRef((props, ref) => {\n  const {width, ...rest} = props;\n\n  // number values for width are deprecated but handle them safely to avoid breaking user code\n  const realWidth = typeof width === 'number' ? `${width}px` : width;\n\n  return (\n    <Element\n      width={realWidth}\n      ref={ref}\n      {...rest}\n    >\n      {props.children}\n    </Element>\n  );\n});\n\nSplitterSide.propTypes = {\n  /**\n   * @name collapse\n   * @type string\n   * @description\n   *  [en] Specify the collapse behavior. Valid values are `\"portrait\"`, `\"landscape\"` or a media query.\n   *     The strings `\"portrait\"` and `\"landscape\"` means the view will collapse when device is in landscape or portrait orientation.\n   *     If the value is not defined, the view always be in `\"collapse\"` mode.\n[/en]\n   *  [ja][/ja]\n   */\n  collapse: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),\n\n  /**\n   * @name swipeable\n   * @type bool\n   * @description\n   *  [en]Ennable swipe interaction on collapse mode.[/en]\n   *  [ja][/ja]\n   */\n  swipeable: PropTypes.bool,\n\n  /**\n   * @name isOpen\n   * @type bool\n   * @description\n   *  [en]Specifies whether the menu is open.[/en]\n   *  [ja][/ja]\n   */\n  isOpen: PropTypes.bool,\n\n  /**\n   * @name onPostOpen\n   * @type function\n   * @description\n   *  [en]Called after the menu is opened.[/en]\n   *  [ja][/ja]\n   */\n  onPostOpen: PropTypes.func,\n\n  /**\n   * @name onOpen\n   * @type function\n   * @description\n   *  [en]DEPRECATED! Use `onPostOpen` instead.[/en]\n   *  [ja][/ja]\n   */\n  onOpen: PropTypes.func,\n\n  /**\n   * @name onPostClose\n   * @type function\n   * @description\n   *  [en]Called after the menu is closed.[/en]\n   *  [ja][/ja]\n   */\n  onPostClose: PropTypes.func,\n\n  /**\n   * @name onClose\n   * @type function\n   * @description\n   *  [en]DEPRECATED! Use `onPostClose` instead.[/en]\n   *  [ja][/ja]\n   */\n  onClose: PropTypes.func,\n\n  /**\n   * @name side\n   * @type string\n   * @description\n   *  [en]Specify which side of the screen the SplitterSide element is located. Possible values are `\"left\"` and `\"right\"`.[/en]\n   *  [ja][/ja]\n   */\n  side: PropTypes.oneOf(['left', 'right']),\n\n  /**\n   * @name swipeTargetWidth\n   * @type number\n   * @description\n   *  [en]The width of swipeable area calculated from the edge (in pixels). Use this to enable swipe only when the finger touch on the screen edge.[/en]\n   *  [ja][/ja]\n   */\n  swipeTargetWidth: PropTypes.number,\n\n  /**\n   * @name width\n   * @type  number\n   * @description\n   *  [en]Specifies the width of the menu. Can be specified in either pixels or as a percentage, e.g. `\"90%\"` or `\"200px\"`.[/en]\n   *  [ja][/ja]\n   */\n  width: PropTypes.string,\n\n  /**\n   * @name animation\n   * @type string\n   * @required false\n   * @description\n   *  [en]Specify the animation. Use one of `overlay`, `push`, `reveal`, or `default`.[/en]\n   *  [ja][/ja]\n   */\n  animation: PropTypes.string,\n\n  /**\n   * @name animationOptions\n   * @type object\n   * @required false\n   * @description\n   *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]\n   *  [ja][/ja]\n   */\n  animationOptions: PropTypes.object,\n\n  /**\n   * @name openThreshold\n   * @type object\n   * @required false\n   * @description\n   *  [en] Specify how much the menu needs to be swiped before opening. A value between `0` and `1`.  [/en]\n   *  [ja][/ja]\n   */\n  openThreshold: PropTypes.number,\n\n  /**\n   * @name onPreOpen\n   * @type string\n   * @description\n   *  [en] Called before the menu opens.  [/en]\n   *  [ja][/ja]\n   */\n  onPreOpen: PropTypes.func,\n\n  /**\n   * @name onPreClose\n   * @type string\n   * @description\n   *  [en] Called before the menu closes.  [/en]\n   *  [ja][/ja]\n   */\n  onPreClose: PropTypes.func,\n\n  /**\n   * @name onModeChange\n   * @type string\n   * @description\n   *  [en] Called after the component's mode changes. [/en]\n   *  [ja][/ja]\n   */\n  onModeChange: PropTypes.func\n};\n\nexport default SplitterSide;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-switch';\n\nimport onsCustomElement from '../onsCustomElement';\nimport oneTimeProp from '../oneTimeProp';\nimport INPUT_PROPS from '../inputProps';\n\nconst nameMap = {\n  ...INPUT_PROPS\n};\n\nconst withDefaultChecked = component => oneTimeProp(component, 'defaultChecked', 'checked');\n\n/**\n * @original ons-switch\n * @category form\n * @tutorial react/Reference/switch\n * @description\n * [en]   Switch component. The switch can be toggled both by dragging and tapping.\n *     Will automatically displays a Material Design switch on Android devices.\n [/en]\n * [ja][/ja]\n * @example\n * <Switch checked={this.state.checked} onChange={this.onChange} />\n */\nconst Switch = withDefaultChecked(onsCustomElement('ons-switch', {deprecated: nameMap}));\n\nSwitch.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the checkbox.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name onChange\n   * @type function\n   * @description\n   *  [en] Called when the value of the switch changes (checked/unchecked) [/en]\n   *  [ja][/ja]\n   */\n  onChange: PropTypes.func,\n\n  /**\n   * @name checked\n   * @type bool\n   * @description\n   *  [en] Whether the switch is checked.[/en]\n   *  [ja][/ja]\n   */\n  checked: PropTypes.bool,\n\n  /**\n   * @name defaultChecked\n   * @type boolean\n   * @description\n   *  [en]Defined the state of the switch at first render for uncontrolled inputs.[/en]\n   *  [ja][/ja]\n   */\n  defaultChecked: PropTypes.bool,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @description\n   *  [en] If set, the switch is disabled.[/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name inputId\n   * @type string\n   * @description\n   *  [en] Specify the `id` attribute of the inner `<input>` element. This is useful when using `<label for=\"...\">` elements.[/en]\n   *  [ja][/ja]\n   */\n  inputId: PropTypes.string\n};\n\nexport default Switch;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-tab';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-tab\n * @category tabbar\n * @tutorial react/Reference/tabbar\n * @description\n * [en] Represents a tab inside tab bar.\n [/en]\n * [ja][/ja]\n * @example\n * <Tap>\n *   Home\n * </Tap>\n */\nconst Tab = onsCustomElement('ons-tab');\n\nTab.propTypes = {\n  /**\n   * @name icon\n   * @type string\n   * @description\n   *  [en]The icon name for the tab. Can specify the same icon name as <ons-icon>.[/en]\n   *  [ja][/ja]\n   */\n  icon: PropTypes.string,\n\n  /**\n   * @name activeIcon\n   * @type string\n   * @description\n   *  [en]The name of the icon when the tab is active.[/en]\n   *  [ja][/ja]\n   */\n  activeIcon: PropTypes.string,\n\n  /**\n   * @name label\n   * @type string\n   * @description\n   *  [en]The label of the tab item.[/en]\n   *  [ja][/ja]\n   */\n  label: PropTypes.string,\n\n  /**\n   * @name badge\n   * @type string\n   * @description\n   *  [en]Display a notification badge on top of the tab.[/en]\n   *  [ja][/ja]\n   */\n  badge: PropTypes.string\n};\n\nexport default Tab;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-tabbar';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst deprecated = {\n  index: 'activeIndex'\n};\nconst Element = onsCustomElement('ons-tabbar', {deprecated});\n\n/**\n * @original ons-tabbar\n * @category tabbar\n * @tutorial react/Reference/tabbar\n * @description\n * [en] Component to display a tabbar on either the top or the bottom of a page.\n * To define the tabs and the content the property renderTabs need to be implemented, that returns an array of tabs and their content. See the example for specifics. [/en]* [ja][/ja]\n * @example\n\n  <Page>\n    <Tabbar\n      onPreChange={({index}) => this.setState(index)}\n      onPostChange={() => console.log('postChange')}\n      onReactive={() => console.log('postChange')}\n      position='bottom'\n      index={this.state.index}\n      renderTabs={(activeIndex, tabbar) => [\n        {\n          content: <TabPage title=\"Home\" active={activeIndex === 0} tabbar={tabbar} />,\n          tab: <Tab label=\"Home\" icon=\"md-home\" />\n        },\n        {\n          content: <TabPage title=\"Settings\" active={activeIndex === 1} tabbar={tabbar} />,\n          tab: <Tab label=\"Settings\" icon=\"md-settings\" />\n        }]\n      }\n    />\n  </Page>\n */\nconst Tabbar = React.forwardRef((props, ref) => {\n  const {visible, hideTabs, renderTabs, ...rest} = props;\n\n  const tabs = renderTabs(props.activeIndex, ref);\n\n  // visible is deprecated in favour of hideTabs, but if visible is defined and\n  // hideTabs is not, we use its negation as the value of hideTabs\n  let reallyHideTabs;\n  if (hideTabs === undefined && visible !== undefined) {\n    reallyHideTabs = !visible;\n  } else {\n    reallyHideTabs = hideTabs;\n  }\n\n  return (\n    <Element\n      hideTabs={reallyHideTabs}\n      {...rest}\n\n      ref={ref}\n    >\n      <div className='tabbar__content'>\n        <div>\n          {tabs.map(tab => tab.content)}\n        </div>\n        <div></div>\n      </div>\n      <div className='tabbar'>\n        {tabs.map(tab => tab.tab)}\n        <div className='tabbar__border'></div>\n      </div>\n    </Element>\n  );\n});\n\nTabbar.propTypes = {\n  /**\n   * @name activeIndex\n   * @type number\n   * @description\n   *  [en]The index of the tab to highlight.[/en]\n   *  [ja][/ja]\n   */\n  activeIndex: PropTypes.number,\n\n  /**\n   * @name index\n   * @type number\n   * @description\n   *  [en]DEPRECATED! Use `activeIndex` instead.[/en]\n   *  [ja][/ja]\n   */\n  index: PropTypes.number,\n\n  /**\n   * @name renderTabs\n   * @type function\n   * @description\n   *  [en]Function that returns an array of objects with the keys `content` and `tab`.[/en]\n   *  [ja][/ja]\n   */\n  renderTabs: PropTypes.func.isRequired,\n\n  /**\n   * @name position\n   * @type string\n   * @description\n   *  [en]Tabbar's position. Available values are `\"bottom\"` and `\"top\"`. Use `\"auto\"` to choose position depending on platform (iOS bottom, Android top). [/en]\n   *  [ja][/ja]\n   */\n  position: PropTypes.string,\n\n  /**\n   * @name swipeable\n   * @type bool\n   * @description\n   *  [en]Enable swipe interaction.[/en]\n   *  [ja][/ja]\n   */\n  swipeable: PropTypes.bool,\n\n  /**\n   * @name ignoreEdgeWidth\n   * @type number\n   * @description\n   *  [en]Distance in pixels from both edges. Swiping on these areas will prioritize parent components such as `Splitter` or `Navigator`.[/en]\n   *  [ja][/ja]\n   */\n  ignoreEdgeWidth: PropTypes.number,\n\n  /**\n   * @name animation\n   * @type string\n   * @description\n   *  [en]If this attribute is set to `\"none\"` the transitions will not be animated.[/en]\n   *  [ja][/ja]\n   */\n  animation: PropTypes.oneOf(['none', 'slide']),\n\n  /**\n   * @name animationOptions\n   * @type object\n   * @required false\n   * @description\n   *  [en]Specify the animation's duration, delay and timing. E.g. `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]\n   *  [ja][/ja]\n   */\n  animationOptions: PropTypes.object,\n\n  /**\n   * @name tabBorder\n   * @type bool\n   * @description\n   *  [en]If true, the tabs show a dynamic bottom border. Only works for iOS since the border is always visible in Material Design.[/en]\n   *  [ja][/ja]\n   */\n  tabBorder: PropTypes.bool,\n\n  /**\n   * @name onPreChange\n   * @type function\n   * @description\n   *  [en]Called just before the tab is changed.[/en]\n   *  [ja][/ja]\n   */\n  onPreChange: PropTypes.func,\n\n  /**\n   * @name onPostChange\n   * @type function\n   * @description\n   *  [en]Called just after the tab is changed.[/en]\n   *  [ja][/ja]\n   */\n  onPostChange: PropTypes.func,\n\n  /**\n   * @name onReactive\n   * @type function\n   * @description\n   *  [en]Called if the already open tab is tapped again.[/en]\n   *  [ja][/ja]\n   */\n  onReactive: PropTypes.func,\n\n  /**\n   * @name onSwipe\n   * @type function\n   * @description\n   *  [en]Hook called whenever the user slides the tabbar. It gets a decimal index and an animationOptions object as arguments.[/en]\n   *  [ja][/ja]\n   */\n  onSwipe: PropTypes.func,\n\n  /**\n   * @name visible\n   * @type bool\n   * @description\n   *  [en]If true, the tabbar is not shown on the screen. Otherwise, the tabbar is shown.[/en]\n   *  [ja][/ja]\n   */\n  hideTabs: PropTypes.bool,\n\n  /**\n   * @name visible\n   * @type bool\n   * @description\n   *  [en]DEPRECATED! Use `hideTabs` instead.[/en]\n   *  [ja][/ja]\n   */\n  visible: PropTypes.bool,\n\n  /**\n   * @name modifier\n   * @type string\n   * @description\n   *  [en]The appearance of the tabbar.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string\n};\n\nexport default Tabbar;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-toast';\n\nimport onsCustomElement from '../onsCustomElement';\nimport baseDialog from '../baseDialog';\n\nconst propTypes = {\n  /**\n   * @name visible\n   * @type bool\n   * @description\n   *  [en]\n   *  Indicates whether the toast open and shown.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  visible: PropTypes.bool,\n\n  /**\n   * @name isOpen\n   * @type bool\n   * @description\n   *  [en]\n   *  DEPRECATED! Use `visible` instead.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  isOpen: PropTypes.bool,\n\n  /**\n   * @name animation\n   * @type string\n   * @required false\n   * @description\n   *  [en]Animation name. Available animations are `\"default\"`, `\"ascend\"` (Android), `\"lift\"` (iOS), `\"fall\"`, `\"fade\"` or `\"none\"`.[/en]\n   *  [ja][/ja]\n   */\n  animation: PropTypes.string,\n\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the toast.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name animationOptions\n   * @type object\n   * @required false\n   * @description\n   *  [en]Specify the animation's duration, delay and timing. E.g.  `{duration: 0.2, delay: 0.4, timing: 'ease-in'}`.[/en]\n   *  [ja][/ja]\n   */\n  animationOptions: PropTypes.object,\n\n  /**\n   * @name onPreShow\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called just before the toast is displayed.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onPreShow: PropTypes.func,\n\n  /**\n   * @name onPostShow\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Called just after the toast is displayed.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onPostShow: PropTypes.func,\n\n  /**\n   * @name onPreHide\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just before the toast is hidden.[/en]\n   *  [ja][/ja]\n   */\n  onPreHide: PropTypes.func,\n\n  /**\n   * @name onPostHide\n   * @type function\n   * @required false\n   * @description\n   *  [en]Called just after the toast is hidden.[/en]\n   *  [ja][/ja]\n   */\n  onPostHide: PropTypes.func,\n\n  /**\n   * @name onDeviceBackButton\n   * @type function\n   * @required false\n   * @description\n   *  [en]\n   *  Custom handler for device back button.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  onDeviceBackButton: PropTypes.func\n};\n\nconst deprecated = {\n  isOpen: 'visible'\n};\n\nconst notAttributes = ['onDeviceBackButton'];\n\n/**\n * @original ons-toast\n * @category dialog\n * @tutorial react/Reference/toast\n * @description\n * [en]\n *  The Toast or Snackbar component is useful for displaying dismissable information or simple actions at (normally) the bottom of the page.\n *\n *  This component does not block user input, allowing the app to continue its flow. Furthermore, it can be automatically hidden after a timeout.\n * [/en]\n * [ja][/ja]\n */\nconst Toast = onsCustomElement(baseDialog('ons-toast'), {propTypes, deprecated, notAttributes});\nToast.propTypes = propTypes;\n\nexport default Toast;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-toolbar';\n\nimport onsCustomElement from '../onsCustomElement';\n\nconst notAttributes = ['visible'];\n\n/**\n * @original ons-toolbar\n * @category page\n * @tutorial react/Reference/toolbar\n * @description\n * [en]Toolbar component that can be used with navigation. Left, center and right container can be specified by class names. This component will automatically displays as a Material Design toolbar when running on Android devices.[/en]\n * [ja][/ja]\n * @example\n *\n<Page renderToolbar={() =>\n  <Toolbar>\n    <div className=\"left\">\n      <BackButton>\n          Back\n      </BackButton>\n    </div>\n    <div className=\"center\">\n      Title\n    </div>\n    <div className=\"right\">\n      <ToolbarButton>\n        <Icon icon=\"md-menu\" />\n      </ToolbarButton>\n    </div>\n  </Toolbar> }\n/>\n */\nconst Toolbar = onsCustomElement('ons-toolbar', {notAttributes});\n\nToolbar.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @description\n   *  [en]\n   *  Specify modifier name to specify custom styles. Optional.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name visible\n   * @type bool\n   * @description\n   *  [en]If true, the toolbar is shown on the screen. Otherwise, the toolbar is not shown.[/en]\n   *  [ja][/ja]\n   */\n  visible: PropTypes.bool,\n\n  /**\n   * @name static\n   * @type bool\n   * @description\n   *   [en]Static toolbars are not animated by `ons-navigator` when pushing or popping pages. This can be useful to improve performance in some situations.[/en]\n   *  [ja][/ja]\n   */\n  static: PropTypes.bool,\n\n  /**\n   * @name inline\n   * @type bool\n   * @description\n   *   [en]Display the toolbar as an inline element.[/en]\n   *   [ja]ツールバーをインラインに置きます。スクロール領域内にそのまま表示されます。[/ja]\n   */\n  inline: PropTypes.bool\n};\n\nexport default Toolbar;\n","import PropTypes from 'prop-types';\nimport 'onsenui/esm/elements/ons-toolbar-button';\n\nimport onsCustomElement from '../onsCustomElement';\n\n/**\n * @original ons-toolbar-button\n * @category page\n * @tutorial react/Reference/page\n * @description\n *   [en]\n *   Button component for the Toolbar. Using this component gives a nice default style.\n *\n *\n *   [/en]\n * [ja][/ja]\n * @example\n * <Page\n     renderToolbar = { () =>\n      <Toolbar>\n        <div className='left'><BackButton>Back</BackButton></div>\n        <div className='center'>Input</div>\n        <div className='right'>\n          <ToolbarButton onClick={this.add} >Add</ToolbarButton>\n        </div>\n      </Toolbar>\n     }>\n      Page Content\n    </Page>\n */\nconst ToolbarButton = onsCustomElement('ons-toolbar-button');\n\nToolbarButton.propTypes = {\n  /**\n   * @name modifier\n   * @type string\n   * @required false\n   * @description\n   *  [en]The appearance of the button.[/en]\n   *  [ja][/ja]\n   */\n  modifier: PropTypes.string,\n\n  /**\n   * @name disabled\n   * @type bool\n   * @description\n   *  [en]\n   *  Indicates whether the button is disabled.\n   *  [/en]\n   *  [ja][/ja]\n   */\n  disabled: PropTypes.bool,\n\n  /**\n   * @name icon\n   * @type string\n   * @description\n   *  [en]Creates an `Icon` component with this string.[/en]\n   *  [ja][/ja]\n   */\n  icon: PropTypes.string,\n\n  /**\n   * @name onClick\n   * @type function\n   * @description\n   *  [en]This function will be called when the button is clicked.[/en]\n   *  [ja][/ja]\n   */\n  onClick: PropTypes.func\n};\n\nexport default ToolbarButton;\n","/*\n * routeStack : [userRoute, userRoute2, ...]\n * processStack: [\n * { type: push | pop | reset, route: userRoute },\n * { type: push | pop | reset, route: userRoute2 },\n * ...\n * ]\n */\n\nexport default {\n  init: (routes) => {\n    return {\n      routeStack: [...routes],\n      processStack: []\n    };\n  },\n\n  replace: ({routeConfig, route, options, key}) => {\n    const config = {...routeConfig};\n    const routeStack = [...config.routeStack];\n    let processStack = [...config.processStack];\n\n    if (key == null || processStack.filter((el) => el.key === key).length === 0) {\n      const process = {\n        type: 'replace',\n        route,\n        options,\n        key\n      };\n      processStack = [\n        ...processStack,\n        process\n      ];\n    }\n\n    return {\n      routeStack,\n      processStack\n    };\n  },\n\n  reset: ({routeConfig, route, options, key}) => {\n    const config = {...routeConfig};\n    const routeStack = [...config.routeStack];\n    let processStack = [...config.processStack];\n\n    if (key == null || processStack.filter((el) => el.key === key).length === 0) {\n      const process = {\n        type: 'reset',\n        route,\n        options,\n        key\n      };\n\n      processStack = [\n        ...processStack,\n        process\n      ];\n    }\n\n    return {\n      routeStack,\n      processStack\n    };\n  },\n\n  push: ({routeConfig, route, options, key}) => {\n    const config = {...routeConfig};\n    const routeStack = [...config.routeStack];\n    let processStack = [...config.processStack];\n\n    if (key == null || config.processStack.filter((el) => el.key === key).length === 0) {\n      const process = {\n        type: 'push',\n        route,\n        options,\n        key\n      };\n\n      processStack = [\n        ...processStack,\n        process\n      ];\n    }\n\n    return {\n      routeStack,\n      processStack\n    };\n  },\n\n  pop: ({routeConfig, options, key}) => {\n    const config = {...routeConfig};\n    const routeStack = [...config.routeStack];\n    let processStack = [...config.processStack];\n\n    /**\n     * Safegaurd to ensure that not\n     * too many pages are popped from\n     * the stack.\n     */\n    const pops = processStack\n      .filter(x => x.type === 'pop')\n      .length;\n\n    if (pops + 1 >= routeStack.length) {\n      console.warn('Page stack is already empty');\n      return config;\n    }\n\n    const process = {\n      type: 'pop',\n      key,\n      options\n    };\n\n    processStack = [\n      ...processStack,\n      process\n    ];\n\n    return {\n      routeStack,\n      processStack\n    };\n  },\n\n  postPush: (routeConfig) => {\n    const config = {...routeConfig};\n    let routeStack = [...config.routeStack];\n    const processStack = [...config.processStack];\n\n    const next = processStack.shift();\n    const type = next.type;\n    let route = next.route;\n\n    if (type === 'push') {\n      if (route !== null) {\n        routeStack = [\n          ...routeStack,\n          route\n        ];\n      }\n    } else if (type === 'reset') {\n      if (!Array.isArray(route)) route = [route];\n      routeStack = route;\n    } else if (type === 'replace') {\n      routeStack.pop();\n      routeStack.push(route);\n    }\n\n    return {\n      routeStack,\n      processStack\n    };\n  },\n\n  postPop: (routeConfig) => {\n    const config = {...routeConfig};\n    let routeStack = [...config.routeStack];\n    let processStack = [...config.processStack];\n    routeStack = routeStack.slice(0, routeStack.length - 1);\n    processStack = processStack.slice(1);\n\n    return {\n      routeStack,\n      processStack\n    };\n  }\n};\n"],"names":["kebabize","camelString","replace","toLowerCase","addDeprecated","props","deprecated","propsCopy","nameMap","className","oldName","newName","Object","entries","undefined","useCustomElementListener","ref","prop","handler","event","slice","useEffect","current","addEventListener","cleanup","removeEventListener","useCustomElement","options","notAttributes","properties","value","jsName","includes","test","JSON","stringify","onsCustomElement","WrappedComponent","React","forwardRef","_ref","useRef","style","children","rest","Portal","Component","constructor","container","document","createElement","componentDidMount","body","appendChild","componentWillUnmount","removeChild","render","ReactDOM","createPortal","baseDialog","DialogComponent","visible","propTypes","title","PropTypes","string","onDialogCancel","func","bool","cancelable","disabled","onCancel","isOpen","isCancelable","isDisabled","animation","modifier","maskColor","animationOptions","object","onPreShow","onPostShow","onPreHide","onPostHide","onDeviceBackButton","ActionSheet","icon","onClick","ActionSheetButton","AlertDialog","AlertDialogButton","BackButton","shape","callback","BottomToolbar","ripple","Button","Card","index","Element","Carousel","itemWidth","itemHeight","x","realItemWidth","realItemHeight","direction","oneOf","fullscreen","overscrollable","centered","autoScroll","autoScrollRatio","number","swipeable","activeIndex","autoRefresh","onPreChange","onPostChange","onRefresh","onOverscroll","onSwipe","CarouselItem","oneTimeProp","defaultProp","OneTimeProp","createRef","innerRef","INPUT_PROPS","autoCapitalize","autoComplete","autoCorrect","autoFocus","inputMode","maxLength","minLength","readOnly","spellCheck","withDefaultChecked","component","Checkbox","onChange","onInput","oneOfType","instanceOf","Date","checked","defaultChecked","inputId","Col","verticalAlign","width","Dialog","Fab","position","onDrag","onDragLeft","onDragRight","onDragUp","onDragDown","onHold","onRelease","onSwipeLeft","onSwipeRight","onSwipeUp","onSwipeDown","onTap","onDoubleTap","onPinch","onPinchIn","onPinchOut","onTouch","onTransform","onRotate","GestureDetector","parseIcon","keys","filter","a","innerString","map","key","default","join","parseSize","size","Icon","objectOf","rotate","fixedWidth","spin","withDefaultValue","Input","defaultValue","placeholder","type","float","List","renderHeader","renderFooter","renderRow","dataSource","rows","data","array","defaultProps","LazyList","forwardedRef","setChildren","useState","setUpdateTop","calculateItemHeight","length","delegate","_render","start","limit","updateTop","el","i","push","countItems","isRequired","ListHeader","tappable","tapBackgroundColor","keepTapBackgroundColor","lockOnDrag","expandable","expanded","onExpand","ListItem","ListTitle","NavigatorClass","pages","state","_prePush","bind","_postPush","_prePop","_postPop","update","obj","Promise","resolve","forceUpdate","resetPage","route","resetPageStack","routes","isRunning","reject","hidePages","pageElements","display","pop","routesBeforePop","routesAfterPop","concat","then","_popPage","lastRoute","newPage","renderPage","_pushPage","pushPage","catch","error","_isRunning","replacePage","pos","splice","topPage","updateBackButton","popPage","flushSync","_onDeviceBackButton","callParentHandler","target","poppingRoute","onPrePop","poppedRoute","onPostPop","pushingRoute","onPrePush","pushedRoute","onPostPush","node","swipeMax","swipePop","initialRoute","initialRouteStack","Error","componentDidUpdate","Navigator","NOOP","Modal","Page","renderToolbar","renderBottomToolbar","renderModal","renderFixed","contentStyle","zIndex","onInit","onShow","onHide","onInfiniteScroll","Elem","Popover","getTarget","isElement","HTMLDocument","show","hide","ProgressBar","secondaryValue","indeterminate","ProgressCircular","onLoad","PullHook","onChangeState","onAction","onPull","height","thresholdHeight","fixedContent","Radio","name","Range","Ripple","color","background","center","RouterNavigatorClass","cancelUpdate","internalStack","cb","setState","routeConfig","routeStack","prevProps","processStack","Array","isArray","pagesToRender","RouterNavigator","arrayOf","Row","SearchInput","Segment","tabbarId","Select","multiple","autofocus","required","form","SpeedDial","SpeedDialItem","Splitter","SplitterContent","SplitterMask","onOpen","onClose","SplitterSide","realWidth","collapse","onPostOpen","onPostClose","side","swipeTargetWidth","openThreshold","onPreOpen","onPreClose","onModeChange","Switch","Tab","activeIcon","label","badge","Tabbar","hideTabs","renderTabs","tabs","reallyHideTabs","tab","content","ignoreEdgeWidth","tabBorder","onReactive","Toast","Toolbar","static","inline","ToolbarButton","init","config","process","reset","pops","console","warn","postPush","next","shift","postPop"],"mappings":"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A,aAAA,CAAA,eAAe,eACVM,IAAI,EAAA;EACR,IAAA,OAAO,EAAEiB,OAAQ;EAEjB,IAAA,GAAG,EAAE7C,GAAAA;EAAI,GAAA,CAAA,EAERX,KAAK,CAACsC,QAAQ,CACC,CACX,CAAA;EAEb,CAAC,CAAC;;ECrCJ,MAAMmB,WAAS,GAAG;EAChB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEC,KAAK,EAAEC,6BAAS,CAACC,MAAM;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEC,cAAc,EAAEF,6BAAS,CAACG,IAAI;EAE9B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEN,OAAO,EAAEG,6BAAS,CAACI,IAAI;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEC,UAAU,EAAEL,6BAAS,CAACI,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEE,QAAQ,EAAEN,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEG,QAAQ,EAAEP,6BAAS,CAACG,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEK,MAAM,EAAER,6BAAS,CAACI,IAAI;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEK,YAAY,EAAET,6BAAS,CAACI,IAAI;EAE5B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEM,UAAU,EAAEV,6BAAS,CAACI,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEO,SAAS,EAAEX,6BAAS,CAACC,MAAM;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEW,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEY,SAAS,EAAEb,6BAAS,CAACC,MAAM;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEa,gBAAgB,EAAEd,6BAAS,CAACe,MAAM;EAElC;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEC,SAAS,EAAEhB,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,UAAU,EAAEjB,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEe,SAAS,EAAElB,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEgB,UAAU,EAAEnB,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEiB,kBAAkB,EAAEpB,6BAAS,CAACG,IAAAA;EAChC,CAAC,CAAA;EAED,MAAM7D,YAAU,GAAG;EACjBiE,EAAAA,QAAQ,EAAE,gBAAgB;EAC1BC,EAAAA,MAAM,EAAE,SAAS;EACjBE,EAAAA,UAAU,EAAE,UAAU;EACtBD,EAAAA,YAAY,EAAE,YAAA;EAChB,CAAC,CAAA;EAED,MAAM7C,eAAa,GAAG,CAAC,oBAAoB,CAAC,CAAA;;EAE5C;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACMyD,QAAAA,WAAW,GAAGjD,gBAAgB,CAACuB,UAAU,CAAC,kBAAkB,CAAC,EAAE;eAACG,WAAS;gBAAExD,YAAU;EAAEsB,iBAAAA,eAAAA;EAAa,CAAC,EAAC;EAC5GyD,WAAW,CAACvB,SAAS,GAAGA,WAAS;;ECtOjC,MAAMA,WAAS,GAAG;EAChB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACEqB,IAAI,EAAEtB,6BAAS,CAACC,MAAM;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;IACEsB,OAAO,EAAEvB,6BAAS,CAACG,IAAAA;EACrB,CAAC,CAAA;;EAED;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAMqB,iBAAiB,GAAGpD,gBAAgB,CAAC,yBAAyB,EAAE;EAAC0B,aAAAA,WAAAA;EAAS,CAAC,EAAC;EAClF0B,iBAAiB,CAAC1B,SAAS,GAAGA,WAAS;;ECtCvC,MAAMxD,YAAU,GAAG;EACjBiE,EAAAA,QAAQ,EAAE,gBAAgB;EAC1BC,EAAAA,MAAM,EAAE,SAAS;EACjBE,EAAAA,UAAU,EAAE,UAAU;EACtBD,EAAAA,YAAY,EAAE,YAAA;EAChB,CAAC,CAAA;EAED,MAAM7C,eAAa,GAAG,CAAC,oBAAoB,CAAC,CAAA;;EAE5C;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACM6D,QAAAA,WAAW,GAAGrD,gBAAgB,CAACuB,UAAU,CAAC,kBAAkB,CAAC,EAAE;gBAACrD,YAAU;EAAEsB,iBAAAA,eAAAA;EAAa,CAAC,EAAC;EAEjG6D,WAAW,CAAC3B,SAAS,GAAG;EACtB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACED,OAAO,EAAEG,6BAAS,CAACI,IAAI;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEE,QAAQ,EAAEN,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEC,UAAU,EAAEL,6BAAS,CAACI,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEF,cAAc,EAAEF,6BAAS,CAACG,IAAI;EAE9B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEI,QAAQ,EAAEP,6BAAS,CAACG,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEK,MAAM,EAAER,6BAAS,CAACI,IAAI;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEK,YAAY,EAAET,6BAAS,CAACI,IAAI;EAE5B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEM,UAAU,EAAEV,6BAAS,CAACI,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEO,SAAS,EAAEX,6BAAS,CAACC,MAAM;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEW,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEY,SAAS,EAAEb,6BAAS,CAACC,MAAM;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEa,gBAAgB,EAAEd,6BAAS,CAACe,MAAM;EAElC;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEC,SAAS,EAAEhB,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,UAAU,EAAEjB,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEe,SAAS,EAAElB,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEgB,UAAU,EAAEnB,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEiB,kBAAkB,EAAEpB,6BAAS,CAACG,IAAAA;EAChC,CAAC;;ECtOD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAMuB,iBAAiB,GAAGtD,gBAAgB,CAAC,yBAAyB,EAAC;EAErEsD,iBAAiB,CAAC5B,SAAS,GAAG;EAC5B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEK,QAAQ,EAAEN,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACEmB,OAAO,EAAEvB,6BAAS,CAACG,IAAAA;EACrB,CAAC;;ECxCD,MAAMvC,eAAa,GAAG,CA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AAU,EAAEC,cAAe;EAC3B,IAAA,GAAG,EAAEzF,GAAAA;EAAI,GAAA,EACL4B,IAAI,CAAA,EAEPvC,KAAK,CAACsC,QAAQ,CACP,CAAA;EAEd,CAAC,EAAC;EAEFyD,QAAQ,CAACtC,SAAS,GAAG;EAEnB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACE4C,SAAS,EAAE1C,6BAAS,CAAC2C,KAAK,CAAC,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC;EAEtD;EACF;EACA;EACA;EACA;EACA;EACA;IACEC,UAAU,EAAE5C,6BAAS,CAACI,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACEyC,cAAc,EAAE7C,6BAAS,CAACI,IAAI;EAE9B;EACF;EACA;EACA;EACA;EACA;EACA;IACE0C,QAAQ,EAAE9C,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACEiC,SAAS,EAAErC,6BAAS,CAACC,MAAM;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;IACEqC,UAAU,EAAEtC,6BAAS,CAACC,MAAM;EAE5B;EACF;EACA;EACA;EACA;EACA;EACA;IACE8C,UAAU,EAAE/C,6BAAS,CAACI,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACE4C,eAAe,EAAEhD,6BAAS,CAACiD,MAAM;EAEjC;EACF;EACA;EACA;EACA;EACA;EACA;IACEC,SAAS,EAAElD,6BAAS,CAACI,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;IACEE,QAAQ,EAAEN,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACE+C,WAAW,EAAEnD,6BAAS,CAACiD,MAAM;EAE7B;EACF;EACA;EACA;EACA;EACA;EACA;IACEf,KAAK,EAAElC,6BAAS,CAACiD,MAAM;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;IACEG,WAAW,EAAEpD,6BAAS,CAACI,IAAI;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;IACEiD,WAAW,EAAErD,6BAAS,CAACG,IAAI;EAE3B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AU,GAAG;EACjBiE,EAAAA,QAAQ,EAAE,gBAAgB;EAC1BC,EAAAA,MAAM,EAAE,SAAS;EACjBE,EAAAA,UAAU,EAAE,UAAU;EACtBD,EAAAA,YAAY,EAAE,YAAA;EAChB,CAAC,CAAA;EAED,MAAM7C,eAAa,GAAG,CAAC,oBAAoB,CAAC,CAAA;;EAE5C;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA;EACA;AACM4H,QAAAA,MAAM,GAAGpH,gBAAgB,CAACuB,UAAU,CAAC,YAAY,CAAC,EAAE;gBAACrD,YAAU;EAAEsB,iBAAAA,eAAAA;EAAa,CAAC,EAAC;EAEtF4H,MAAM,CAAC1F,SAAS,GAAG;EACjB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACED,OAAO,EAAEG,6BAAS,CAACI,IAAI;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEE,QAAQ,EAAEN,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEC,UAAU,EAAEL,6BAAS,CAACI,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEF,cAAc,EAAEF,6BAAS,CAACG,IAAI;EAE9B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEI,QAAQ,EAAEP,6BAAS,CAACG,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEK,MAAM,EAAER,6BAAS,CAACI,IAAI;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEK,YAAY,EAAET,6BAAS,CAACI,IAAI;EAE5B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEM,UAAU,EAAEV,6BAAS,CAACI,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEO,SAAS,EAAEX,6BAAS,CAACC,MAAM;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEW,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEY,SAAS,EAAEb,6BAAS,CAACC,MAAM;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEa,gBAAgB,EAAEd,6BAAS,CAACe,MAAM;EAElC;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEC,SAAS,EAAEhB,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,UAAU,EAAEjB,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEe,SAAS,EAAElB,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEgB,UAAU,EAAEnB,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEiB,kBAAkB,EAAEpB,6BAAS,CAACG,IAAAA;EAChC,CAAC;;EC/ND;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAMsF,GAAG,GAAGrH,gBAAgB,CAAC,SAAS,EAAC;EAEvCqH,GAAG,CAAC3F,SAAS,GAAG;EACd;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACE8B,MAAM,EAAE/B,6BAAS,CAACI,IAAI;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEsF,QAAQ,EAAE1F,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACEK,QAAQ,EAAEN,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACEmB,OAAO,EAAEvB,6BAAS,CAACG,IAAAA;EACrB,CAAC;;ECrED,MAAML,WAAS,GAAG;EAEhB;EACF;EACA;EACA;EACA;EACA;EACA;IACE6F,MAAM,EAAE3F,6BAAS,CAACG,IAAI;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;IACEyF,UAAU,EAAE5F,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACE0F,WAAW,EAAE7F,6BAAS,CAACG,IAAI;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;IACE2F,QAAQ,EAAE9F,6BAAS,CAACG,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACE4F,UAAU,EAAE/F,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACE6F,MAAM,EAAEhG,6BAAS,CAACG,IAAI;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;IACE8F,SAAS,EAAEjG,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;IACEsD,OAAO,EAAEzD,6BAAS,CAACG,IAAI;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;IACE+F,WAAW,EAAElG,6BAAS,CAACG,IAAI;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;IACEgG,YAAY,EAAEnG,6BAAS,CAACG,IAAI;EAE5B;EACF;EACA;EACA;EACA;EACA;EACA;IACEiG,SAAS,EAAEpG,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;IACEkG,WAAW,EAAErG,6BAAS,CAACG,IAAI;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;IACEmG,KAAK,EAAEtG,6BAAS,CAACG,IAAI;EAErB;EACF;EACA;EACA;EACA;EACA;EACA;IACEoG,WAAW,EAAEvG,6BAAS,CAACG,IAAI;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;IACEqG,OAAO,EAAExG,6BAAS,CAACG,IAAI;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;IACEsG,SAAS,EAAEzG,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;IACE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AAC2J,UAAU;EAEpC;EACF;EACA;EACA;EACA;EACA;EACA;EACEX,EAAAA,mBAAmB,EAAEnJ,6BAAS,CAACG,IAAI,CAAC2J,UAAAA;EACtC,CAAC;;EClHD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAMC,UAAU,GAAG3L,gBAAgB,CAAC,iBAAiB,EAAC;EAEtD2L,UAAU,CAACjK,SAAS,GAAG;EACrB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,QAAQ,EAAEZ,6BAAS,CAACC,MAAAA;EACtB,CAAC;;EC/BD,MAAMH,WAAS,GAAG;EAChB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACE+J,QAAQ,EAAEhK,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACE6J,kBAAkB,EAAEjK,6BAAS,CAACC,MAAM;EAEpC;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEiK,sBAAsB,EAAElK,6BAAS,CAACI,IAAI;EAEtC;EACF;EACA;EACA;EACA;EACA;EACA;IACE+J,UAAU,EAAEnK,6BAAS,CAACI,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACEgK,UAAU,EAAEpK,6BAAS,CAACI,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACEiK,QAAQ,EAAErK,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACEkK,QAAQ,EAAEtK,6BAAS,CAACG,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACEQ,SAAS,EAAEX,6BAAS,CAACC,MAAAA;EACvB,CAAC,CAAA;;EAED;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAMsK,QAAQ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A,CAAC,cAAc,EAAA,QAAA,CAAA;EAAC,EAAA,QAAQ,EAAEtB,GAAAA;EAAI,CAAA,EAAKX,KAAK,CAAGA,EAAAA,KAAK,CAACsC,QAAQ,CAC1D,EAAC;EAEF2P,SAAS,CAACxO,SAAS,GAAG;EACpB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACEyM,EAAAA,UAAU,EAAEvM,6BAAS,CAACG,IAAI,CAAC2J,UAAU;EACrC;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEqE,iBAAiB,EAAEnO,6BAAS,CAAC4I,KAAK;EAElC;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEsF,YAAY,EAAElO,6BAAS,CAACe,MAAM;EAE9B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACE6M,SAAS,EAAE5N,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACE2N,UAAU,EAAE9N,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACEqN,QAAQ,EAAExN,6BAAS,CAACG,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEuN,SAAS,EAAE1N,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEQ,SAAS,EAAEX,6BAAS,CAACC,MAAM;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;IACEa,gBAAgB,EAAEd,6BAAS,CAACe,MAAM;EAElC;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACEmC,EAAAA,SAAS,EAAElD,6BAAS,CAAC+E,SAAS,CAAC,CAAC/E,6BAAS,CAACI,IAAI,EAAEJ,6BAAS,CAACC,MAAM,CAAC,CAAC;EAElE;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEgO,QAAQ,EAAEjO,6BAAS,CAACG,IAAI;EACxB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEiB,kBAAkB,EAAEpB,6BAAS,CAACG,IAAAA;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R,IAAI,CAAC3O,SAAS,GAAG;EAEf;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEgP,YAAY,EAAE9O,6BAAS,CAACe,MAAM;EAE9B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEH,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACE2O,WAAW,EAAE5O,6BAAS,CAACG,IAAI;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEuO,aAAa,EAAE1O,6BAAS,CAACG,IAAI;EAE7B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEwO,mBAAmB,EAAE3O,6BAAS,CAACG,IAAI;EAEnC;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACE0O,WAAW,EAAE7O,6BAAS,CAACG,IAAI;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACE6O,MAAM,EAAEhP,6BAAS,CAACG,IAAI;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACE8O,MAAM,EAAEjP,6BAAS,CAACG,IAAI;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACE+O,MAAM,EAAElP,6BAAS,CAACG,IAAI;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEgP,gBAAgB,EAAEnP,6BAAS,CAACG,IAAI;EAEhC;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEiB,kBAAkB,EAAEpB,6BAAS,CAACG,IAAAA;EAChC,CAAC,CAAA;EAED,MAAMoO,IAAI,GAAG,MAAM,IAAI,CAAA;EAEvBE,IAAI,CAAC5F,YAAY,GAAG;EAClB6F,EAAAA,aAAa,EAAEH,IAAI;EACnBI,EAAAA,mBAAmB,EAAEJ,IAAI;EACzBK,EAAAA,WAAW,EAAEL,IAAI;EACjBM,EAAAA,WAAW,EAAEN,IAAAA;EACf,CAAC;;ECzLD,MAAMjS,YAAU,GAAG;EACjBiE,EAAAA,QAAQ,EAAE,gBAAgB;EAC1BG,EAAAA,UAAU,EAAE,UAAU;EACtBD,EAAAA,YAAY,EAAE,YAAA;EAChB,CAAC,CAAA;EAED,MAAM7C,eAAa,GAAG,CAAC,oBAAoB,CAAC,CAAA;EAE5C,MAAMwR,IAAI,GAAGhR,gBAAgB,CAACuB,UAAU,CAAC,aAAa,CAAC,EAAE;gBAACrD,YAAU;EAAEsB,iBAAAA,eAAAA;EAAa,CAAC,CAAC,CAAA;;EAErF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACMyR,QAAAA,OAAO,gBAAG/Q,yBAAK,CAACC,UAAU,CAAC,CAAClC,KAAK,EAAE0M,YAAY,KAAK;IACxD,MAAM;MAACvI,MAAM;MAAE8O,SAAS;MAAE3Q,QAAQ;MAAE,GAAGC,IAAAA;EAAI,GAAC,GAAGvC,KAAK,CAAA;EACpD,EAAA,MAAMW,GAAG,GAAG+L,YAAY,IAAItK,YAAM,EAAE,CAAA;EAEpCpB,EAAAA,eAAS,CAAC,MAAM;EACd,IAAA,IAAImD,MAAM,KAAKxD,GAAG,CAACM,OAAO,CAACuC,OAAO,EAAE;EAClC,MAAA,IAAIW,MAAM,EAAE;UACV,IAAI8M,MAAM,GAAGgC,SAAS,EAAE,CAAA;;EAExB;UACA,MAAMC,SAAS,GAAGhN,CAAC,IAAIA,CAAC,YAAYJ,OAAO,IAAII,CAAC,YAAYiN,YAAY,CAAA;UACxE,IAAI,CAACD,SAAS,CAACjC,MAAM,CAAC,IAAIA,MAAM,CAAChQ,OAAO,EAAE;YACxCgQ,MAAM,GAAGA,MAAM,CAAChQ,OAAO,CAAA;EACzB,SAAA;EAEAN,QAAAA,GAAG,CAACM,OAAO,CAACmS,IAAI,CAAC;EAACnC,UAAAA,MAAAA;EAAM,SAAC,CAAC,CAAA;EAC5B,OAAC,MAAM;EACLtQ,QAAAA,GAAG,CAACM,OAAO,CAACoS,IAAI,EAAE,CAAA;EACpB,OAAA;EACF,KAAA;EACF,GAAC,CAAC,CAAA;EAEF,EAAA,oBACEpR,wCAAC,IAAI,EAAA,QAAA,CAAA;EACH,IAAA,GAAG,EAAEtB,GAAAA;KACD4B,EAAAA,IAAI,CAEPD,EAAAA,QAAQ,CACJ,CAAA;EAEX,CAAC,EAAC;EAEF0Q,OAAO,CAACvP,SAAS,GAAG;EAClB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACEwP,EAAAA,SAAS,EAAEtP,6BAAS,CAACG,IAAI,CAAC2J,UAAU;EAEpC;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACE5J,cAAc,EAAEF,6BAAS,CAACG,IAAI;EAE9B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEI,QAAQ,EAAEP,6BAAS,CAACG,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACEK,EAAAA,MAAM,EAAER,6BAAS,CAACI,IAAI,CAAC0J,UAAU;EAEjC;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEzJ,UAAU,EAAEL,6BAAS,CAACI,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEK,YAAY,EAAET,6BAAS,CAACI,IAAI;EAE5B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEE,QAAQ,EAAEN,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEM,UAAU,EAAEV,6BAAS,CAACI,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEO,SAAS,EAAEX,6BAAS,CAACC,MAAM;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEW,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEY,SAAS,EAAEb,6BAAS,CAACC,MAAM;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEa,gBAAgB,EAAEd,6BAAS,CAACe,MAAM;EAElC;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEC,SAAS,EAAEhB,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,UAAU,EAAEjB,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEe,SAAS,EAAElB,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEgB,UAAU,EAAEnB,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEiB,kBAAkB,EAAEpB,6BAAS,CAACG,IAAAA;EAChC,CAAC;;EC7QD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAMwP,WAAW,GAAGvR,gBAAgB,CAAC,kBAAkB,EAAC;EAExDuR,WAAW,CAAC7P,SAAS,GAAG;EACtB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEnC,KAAK,EAAEkC,6BAAS,CAACiD,MAAM;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACE2M,cAAc,EAAE5P,6BAAS,CAACiD,MAAM;EAEhC;EACF;EACA;EACA;EACA;EACA;EACA;IACE4M,aAAa,EAAE7P,6BAAS,CAACI,IAAAA;EAC3B,CAAC;;ECtDD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAM0P,gBAAgB,GAAG1R,gBAAgB,CAAC,uBAAuB,EAAC;EAElE0R,gBAAgB,CAAChQ,SAAS,GAAG;EAC3B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEnC,KAAK,EAAEkC,6BAAS,CAACiD,MAAM;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACE2M,cAAc,EAAE5P,6BAAS,CAACiD,MAAM;EAEhC;EACF;EACA;EACA;EACA;EACA;EACA;IACE4M,aAAa,EAAE7P,6BAAS,CAACI,IAAAA;EAC3B,CAAC;;ECvDD,MAAM9D,YAAU,GAAG;EACjByT,EAAAA,MAAM,EAAE,UAAU;EAClBlL,EAAAA,QAAQ,EAAE,eAAA;EACZ,CAAC,CAAA;EAED,MAAMjH,eAAa,GAAG,CAAC,UAAU,CAAC,CAAA;;EAElC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAMoS,QAAQ,GAAG5R,gBAAgB,CAAC,eAAe,EAAE;gBAAC9B,YAAU;EAAEsB,iBAAAA,eAAAA;EAAa,CAAC,EAAC;EAE/EoS,QAAQ,CAAClQ,SAAS,GAAG;EACnB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEmQ,aAAa,EAAEjQ,6BAAS,CAACG,IAAI;EAE7B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACE0E,QAAQ,EAAE7E,6BAAS,CAACG,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACE+P,QAAQ,EAAElQ,6BAAS,CAACG,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACE4P,MAAM,EAAE/P,6BAAS,CAACG,IAAI;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEgQ,MAAM,EAAEnQ,6BAAS,CAACG,IAAI;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;IACEG,QAAQ,EAAEN,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACEgQ,MAAM,EAAEpQ,6BAAS,CAACiD,MAAM;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACEoN,eAAe,EAAErQ,6BAAS,CAACiD,MAAM;EAEjC;EACF;EACA;EACA;EACA;EACA;EACA;IACEqN,YAAY,EAAEtQ,6BAAS,CAACI,IAAAA;EAC1B,CAAC;;EC3HD,MAAM5D,SAAO,GAAG;IACd,GAAGwH,WAAAA;EACL,CAAC,CAAA;EAED,MAAMU,oBAAkB,GAAGC,SAAS,IAAIhB,WAAW,CAACgB,SAAS,EAAE,gBAAgB,EAAE,SAAS,CAAC,CAAA;;EAE3F;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAM4L,KAAK,GAAG7L,oBAAkB,CAACtG,gBAAgB,CAAC,WAAW,EAAE;EAAC9B,EAAAA,UAAU,EAAEE,SAAAA;EAAO,CAAC,CAAC,EAAC;EAEtF+T,KAAK,CAACzQ,SAAS,GAAG;EAChB;EACF;EACA;EACA;EACA;EACA;EACA;IACE0Q,IAAI,EAAExQ,6BAAS,CAACC,MAAM;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEW,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEK,QAAQ,EAAEN,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACEyE,QAAQ,EAAE7E,6BAAS,CAACG,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;EACErC,EAAAA,KAAK,EAAEkC,6BAAS,CAAC+E,SAAS,CAAC,CACzB/E,6BAAS,CAACC,MAAM,EAChBD,6BAAS,CAACgF,UAAU,CAACC,IAAI,CAAC,CAC3B,CAAC;EAEF;EACF;EACA;EACA;EACA;EACA;EACA;IACEC,OAAO,EAAElF,6BAAS,CAACI,IAAI;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;IACE+E,cAAc,EAAEnF,6BAAS,CAACI,IAAI;EAE9B;EACF;EACA;EACA;EACA;EACA;EACA;IACEgF,OAAO,EAAEpF,6BAAS,CAACC,MAAAA;EACrB,CAAC;;ECtGD,MAAMzD,SAAO,GAAG;IACd,GAAGwH,WAAAA;EACL,CAAC,CAAA;EAED,MAAM+D,kBAAgB,GAAGpD,SAAS,IAAIhB,WAAW,CAACgB,SAAS,EAAE,cAAc,EAAE,OAAO,CAAC,CAAA;;EAErF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAM8L,KAAK,GAAG1I,kBAAgB,CAAC3J,gBAAgB,CAAC,WAAW,EAAE;EAAC9B,EAAAA,UAAU,EAAEE,SAAAA;EAAO,CAAC,CAAC,EAAC;EAEpFiU,KAAK,CAAC3Q,SAAS,GAAG;EAChB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACE4E,QAAQ,EAAE7E,6BAAS,CAACG,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACE2E,OAAO,EAAE9E,6BAAS,CAACG,IAAI;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACErC,KAAK,EAAEkC,6BAAS,CAACiD,MAAM;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEgF,YAAY,EAAEjI,6BAAS,CAACiD,MAAM;EAE9B;EACF;EACA;EACA;EACA;EACA;EACA;IACE3C,QAAQ,EAAEN,6BAAS,CAACI,IAAAA;EACtB,CAAC;;ECpFD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAMsQ,MAAM,GAAGtS,gBAAgB,CAAC,YAAY,EAAC;EAE7CsS,MAAM,CAAC5Q,SAAS,GAAG;EACjB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACE6Q,KAAK,EAAE3Q,6BAAS,CAACC,MAAM;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEW,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACE2Q,UAAU,EAAE5Q,6BAAS,CAACC,MAAM;EAE5B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEwH,IAAI,EAAEzH,6BAAS,CAACC,MAAM;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACE4Q,MAAM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CtB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACEK,QAAQ,EAAEN,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACEoE,QAAQ,EAAExE,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACEyE,QAAQ,EAAE7E,6BAAS,CAACG,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACE2E,OAAO,EAAE9E,6BAAS,CAACG,IAAI;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;EACErC,EAAAA,KAAK,EAAEkC,6BAAS,CAAC+E,SAAS,CAAC,CACzB/E,6BAAS,CAACC,MAAM,EAChBD,6BAAS,CAACgF,UAAU,CAACC,IAAI,CAAC,CAC3B,CAAC;EAEF;EACF;EACA;EACA;EACA;EACA;EACA;EACEgD,EAAAA,YAAY,EAAEjI,6BAAS,CAAC+E,SAAS,CAAC,CAChC/E,6BAAS,CAACC,MAAM,EAChBD,6BAAS,CAACgF,UAAU,CAACC,IAAI,CAAC,CAC3B,CAAC;EAEF;EACF;EACA;EACA;EACA;EACA;EACA;IACEiD,WAAW,EAAElI,6BAAS,CAACC,MAAM;EAE7B;EACF;EACA;EACA;EACA;EACA;EACA;IACEmF,OAAO,EAAEpF,6BAAS,CAACC,MAAAA;EACrB,CAAC;;ECxHD,MAAM3D,YAAU,GAAG;EACjB4F,EAAAA,KAAK,EAAE,aAAA;EACT,CAAC,CAAA;;EAED;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAM4P,OAAO,GAAG1T,gBAAgB,CAAC,aAAa,EAAE;EAAC9B,cAAAA,YAAAA;EAAU,CAAC,EAAC;EAE7DwV,OAAO,CAAChS,SAAS,GAAG;EAClB;EACF;EACA;EACA;EACA;EACA;EACA;IACEqD,WAAW,EAAEnD,6BAAS,CAACiD,MAAM;EAE7B;EACF;EACA;EACA;EACA;EACA;EACA;IACEf,KAAK,EAAElC,6BAAS,CAACiD,MAAM;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;IACE8O,QAAQ,EAAE/R,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEW,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACEqD,YAAY,EAAEtD,6BAAS,CAACG,IAAI;EAE5B;EACF;EACA;EACA;EACA;EACA;EACA;IACEG,QAAQ,EAAEN,6BAAS,CAACI,IAAAA;EACtB,CAAC;;EC1ED,MAAM5D,SAAO,GAAG;IACd,GAAGwH,WAAAA;EACL,CAAC,CAAA;EAED,MAAM+D,gBAAgB,GAAGpD,SAAS,IAAIhB,WAAW,CAACgB,SAAS,EAAE,cAAc,EAAE,OAAO,CAAC,CAAA;EACrF,MAAMxC,SAAO,GAAG4F,gBAAgB,CAAC3J,gBAAgB,CAAC,YAAY,EAAE;EAAC9B,EAAAA,UAAU,EAAEE,SAAAA;EAAO,CAAC,CAAC,CAAC,CAAA;;EAEvF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAMwV,MAAM,gBAAG1T,yBAAK,CAACC,UAAU,CAAC,CAAClC,KAAK,EAAEW,GAAG,kBACzCsB,yBAAC,CAAA,aAAA,CAAA6D,SAAO,eAAK9F,KAAK,EAAA;EAAE,EAAA,GAAG,EAAEW,GAAAA;EAAI,CAAA,CAAA,eAC3BsB,wDACGjC,KAAK,CAACsC,QAAQ,CACR,CAEZ,EAAC;EAEFqT,MAAM,CAAClS,SAAS,GAAG;EACjB;EACF;EACA;EACA;EACA;EACA;EACA;IACEc,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACEK,QAAQ,EAAEN,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACEyE,QAAQ,EAAE7E,6BAAS,CAACG,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACErC,KAAK,EAAEkC,6BAAS,CAACC,MAAM;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;IACEgI,YAAY,EAAEjI,6BAAS,CAACC,MAAM;EAE9B;EACF;EACA;EACA;EACA;EACA;EACA;IACEgS,QAAQ,EAAEjS,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACE8R,SAAS,EAAElS,6BAAS,CAACI,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;IACE+R,QAAQ,EAAEnS,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACEgS,IAAI,EAAEpS,6BAAS,CAACC,MAAM;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;IACEwH,IAAI,EAAEzH,6BAAS,CAACiD,MAAM;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;IACEuN,IAAI,EAAExQ,6BAAS,CAACC,MAAAA;EAClB,CAAC;;ECvID;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAMoS,SAAS,GAAGjU,gBAAgB,CAAC,gBAAgB,EAAC;EAEpDiU,SAAS,CAACvS,SAAS,GAAG;EACpB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEyF,QAAQ,EAAE1F,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACEyC,EAAAA,SAAS,EAAE1C,6BAAS,CAAC2C,KAAK,CAAC,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;EAE3D;EACF;EACA;EACA;EACA;EACA;EACA;IACErC,QAAQ,EAAEN,6BAAS,CAACI,IAAAA;EACtB,CAAC;;EC9DD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAMkS,aAAa,GAAGlU,gBAAgB,CAAC,qBAAqB,EAAC;EAE7DkU,aAAa,CAACxS,SAAS,GAAG;EACxB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACEsB,OAAO,EAAEvB,6BAAS,CAACG,IAAAA;EACrB,CAAC;;ECvCD,MAAMvC,eAAa,GAAG,CAAC,oBAAoB,CAAC,CAAA;;EAE5C;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAM2U,QAAQ,GAAGnU,gBAAgB,CAAC,cAAc,EAAE;EAACR,iBAAAA,eAAAA;EAAa,CAAC,EAAC;EAElE2U,QAAQ,CAACzS,SAAS,GAAG;EACnB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEsB,kBAAkB,EAAEpB,6BAAS,CAACG,IAAAA;EAChC,CAAC;;EClDD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAMqS,eAAe,GAAGpU,gBAAgB,CAAC,sBAAsB;;EChC/D;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAMqU,YAAY,GAAGrU,gBAAgB,CAAC,mBAAmB;;EC9BzD,MAAM9B,YAAU,GAAG;EACjBoW,EAAAA,MAAM,EAAE,YAAY;EACpBC,EAAAA,OAAO,EAAE,aAAA;EACX,CAAC,CAAA;EACD,MAAM/U,eAAa,GAAG,CAAC,QAAQ,CAAC,CAAA;EAEhC,MAAMuE,SAAO,GAAG/D,gBAAgB,CAAC,mBAAmB,EAAE;gBAAC9B,YAAU;EAAEsB,iBAAAA,eAAAA;EAAa,CAAC,CAAC,CAAA;;EAElF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACMgV,QAAAA,YAAY,gBAAGtU,yBAAK,CAACC,UAAU,CAAC,CAAClC,KAAK,EAAEW,GAAG,KAAK;IACpD,MAAM;MAACuI,KAAK;MAAE,GAAG3G,IAAAA;EAAI,GAAC,GAAGvC,KAAK,CAAA;;EAE9B;IACA,MAAMwW,SAAS,GAAG,OAAOtN,KAAK,KAAK,QAAQ,GAAI,CAAEA,EAAAA,KAAM,CAAG,EAAA,CAAA,GAAGA,KAAK,CAAA;EAElE,EAAA,oBACEjH,wCAAC6D,SAAO,EAAA,QAAA,CAAA;EACN,IAAA,KAAK,EAAE0Q,SAAU;EACjB,IAAA,GAAG,EAAE7V,GAAAA;EAAI,GAAA,EACL4B,IAAI,CAAA,EAEPvC,KAAK,CAACsC,QAAQ,CACP,CAAA;EAEd,CAAC,EAAC;EAEFiU,YAAY,CAAC9S,SAAS,GAAG;EACvB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACEgT,EAAAA,QAAQ,EAAE9S,6BAAS,CAAC+E,SAAS,CAAC,CAAC/E,6BAAS,CAACI,IAAI,EAAEJ,6BAAS,CAACC,MAAM,CAAC,CAAC;EAEjE;EACF;EACA;EACA;EACA;EACA;EACA;IACEiD,SAAS,EAAElD,6BAAS,CAACI,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;IACEI,MAAM,EAAER,6BAAS,CAACI,IAAI;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;IACE2S,UAAU,EAAE/S,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACEuS,MAAM,EAAE1S,6BAAS,CAACG,IAAI;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;IACE6S,WAAW,EAAEhT,6BAAS,CAACG,IAAI;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;IACEwS,OAAO,EAAE3S,6BAAS,CAACG,IAAI;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;IACE8S,IAAI,EAAEjT,6BAAS,CAAC2C,KAAK,CAAC,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;EAExC;EACF;EACA;EACA;EACA;EACA;EACA;IACEuQ,gBAAgB,EAAElT,6BAAS,CAACiD,MAAM;EAElC;EACF;EACA;EACA;EACA;EACA;EACA;IACEsC,KAAK,EAAEvF,6BAAS,CAACC,MAAM;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEU,SAAS,EAAEX,6BAAS,CAACC,MAAM;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEa,gBAAgB,EAAEd,6BAAS,CAACe,MAAM;EAElC;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEoS,aAAa,EAAEnT,6BAAS,CAACiD,MAAM;EAE/B;EACF;EACA;EACA;EACA;EACA;EACA;IACEmQ,SAAS,EAAEpT,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;IACEkT,UAAU,EAAErT,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACEmT,YAAY,EAAEtT,6BAAS,CAACG,IAAAA;EAC1B,CAAC;;EC9MD,MAAM3D,OAAO,GAAG;IACd,GAAGwH,WAAAA;EACL,CAAC,CAAA;EAED,MAAMU,kBAAkB,GAAGC,SAAS,IAAIhB,WAAW,CAACgB,SAAS,EAAE,gBAAgB,EAAE,SAAS,CAAC,CAAA;;EAE3F;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAM4O,MAAM,GAAG7O,kBAAkB,CAACtG,gBAAgB,CAAC,YAAY,EAAE;EAAC9B,EAAAA,UAAU,EAAEE,OAAAA;EAAO,CAAC,CAAC,EAAC;EAExF+W,MAAM,CAACzT,SAAS,GAAG;EACjB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACE4E,QAAQ,EAAE7E,6BAAS,CAACG,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACE+E,OAAO,EAAElF,6BAAS,CAACI,IAAI;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;IACE+E,cAAc,EAAEnF,6BAAS,CAACI,IAAI;EAE9B;EACF;EACA;EACA;EACA;EACA;EACA;IACEE,QAAQ,EAAEN,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACEgF,OAAO,EAAEpF,6BAAS,CAACC,MAAAA;EACrB,CAAC;;EC7ED;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAMuT,GAAG,GAAGpV,gBAAgB,CAAC,SAAS,EAAC;EAEvCoV,GAAG,CAAC1T,SAAS,GAAG;EACd;EACF;EACA;EACA;EACA;EACA;EACA;IACEwB,IAAI,EAAEtB,6BAAS,CAACC,MAAM;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;IACEwT,UAAU,EAAEzT,6BAAS,CAACC,MAAM;EAE5B;EACF;EACA;EACA;EACA;EACA;EACA;IACEyT,KAAK,EAAE1T,6BAAS,CAACC,MAAM;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;IACE0T,KAAK,EAAE3T,6BAAS,CAACC,MAAAA;EACnB,CAAC;;EClDD,MAAM3D,YAAU,GAAG;EACjB4F,EAAAA,KAAK,EAAE,aAAA;EACT,CAAC,CAAA;EACD,MAAMC,SAAO,GAAG/D,gBAAgB,CAAC,YAAY,EAAE;EAAC9B,cAAAA,YAAAA;EAAU,CAAC,CAAC,CAAA;;EAE5D;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACMsX,QAAAA,MAAM,gBAAGtV,yBAAK,CAACC,UAAU,CAAC,CAAClC,KAAK,EAAEW,GAAG,KAAK;IAC9C,MAAM;MAAC6C,OAAO;MAAEgU,QAAQ;MAAEC,UAAU;MAAE,GAAGlV,IAAAA;EAAI,GAAC,GAAGvC,KAAK,CAAA;IAEtD,MAAM0X,IAAI,GAAGD,UAAU,CAACzX,KAAK,CAAC8G,WAAW,EAAEnG,GAAG,CAAC,CAAA;;EAE/C;EACA;EACA,EAAA,IAAIgX,cAAc,CAAA;EAClB,EAAA,IAAIH,QAAQ,KAAK/W,SAAS,IAAI+C,OAAO,KAAK/C,SAAS,EAAE;MACnDkX,cAAc,GAAG,CAACnU,OAAO,CAAA;EAC3B,GAAC,MAAM;EACLmU,IAAAA,cAAc,GAAGH,QAAQ,CAAA;EAC3B,GAAA;EAEA,EAAA,oBACEvV,wCAAC6D,SAAO,EAAA,QAAA,CAAA;EACN,IAAA,QAAQ,EAAE6R,cAAAA;EAAe,GAAA,EACrBpV,IAAI,EAAA;EAER,IAAA,GAAG,EAAE5B,GAAAA;KAEL,CAAA,eAAAsB,yBAAA,CAAA,aAAA,CAAA,KAAA,EAAA;EAAK,IAAA,SAAS,EAAC,iBAAA;EAAiB,GAAA,eAC9BA,yBACGyV,CAAAA,aAAAA,CAAAA,KAAAA,EAAAA,IAAAA,EAAAA,IAAI,CAAC3M,GAAG,CAAC6M,GAAG,IAAIA,GAAG,CAACC,OAAO,CAAC,CACzB,eACN5V,yBAAA,CAAA,aAAA,CAAA,KAAA,EAAA,IAAA,CAAW,CACP,eACNA,yBAAA,CAAA,aAAA,CAAA,KAAA,EAAA;EAAK,IAAA,SAAS,EAAC,QAAA;KACZyV,EAAAA,IAAI,CAAC3M,GAAG,CAAC6M,GAAG,IAAIA,GAAG,CAACA,GAAG,CAAC,eACzB3V,yBAAA,CAAA,aAAA,CAAA,KAAA,EAAA;EAAK,IAAA,SAAS,EAAC,gBAAA;EAAgB,GAAA,CAAO,CAClC,CACE,CAAA;EAEd,CAAC,EAAC;EAEFsV,MAAM,CAAC9T,SAAS,GAAG;EACjB;EACF;EACA;EACA;EACA;EACA;EACA;IACEqD,WAAW,EAAEnD,6BAAS,CAACiD,MAAM;EAE7B;EACF;EACA;EACA;EACA;EACA;EACA;IACEf,KAAK,EAAElC,6BAAS,CAACiD,MAAM;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;EACE6Q,EAAAA,UAAU,EAAE9T,6BAAS,CAACG,IAAI,CAAC2J,UAAU;EAErC;EACF;EACA;EACA;EACA;EACA;EACA;IACEpE,QAAQ,EAAE1F,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACEiD,SAAS,EAAElD,6BAAS,CAACI,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;IACE+T,eAAe,EAAEnU,6BAAS,CAACiD,MAAM;EAEjC;EACF;EACA;EACA;EACA;EACA;EACA;IACEtC,SAAS,EAAEX,6BAAS,CAAC2C,KAAK,CAAC,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;EAE7C;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACE7B,gBAAgB,EAAEd,6BAAS,CAACe,MAAM;EAElC;EACF;EACA;EACA;EACA;EACA;EACA;IACEqT,SAAS,EAAEpU,6BAAS,CAACI,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;IACEiD,WAAW,EAAErD,6BAAS,CAACG,IAAI;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;IACEmD,YAAY,EAAEtD,6BAAS,CAACG,IAAI;EAE5B;EACF;EACA;EACA;EACA;EACA;EACA;IACEkU,UAAU,EAAErU,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACEsD,OAAO,EAAEzD,6BAAS,CAACG,IAAI;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;IACE0T,QAAQ,EAAE7T,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACEP,OAAO,EAAEG,6BAAS,CAACI,IAAI;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;IACEQ,QAAQ,EAAEZ,6BAAS,CAACC,MAAAA;EACtB,CAAC;;ECtND,MAAMH,SAAS,GAAG;EAChB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACED,OAAO,EAAEG,6BAAS,CAACI,IAAI;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEI,MAAM,EAAER,6BAAS,CAACI,IAAI;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEO,SAAS,EAAEX,6BAAS,CAACC,MAAM;EAE3B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEW,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEa,gBAAgB,EAAEd,6BAAS,CAACe,MAAM;EAElC;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEC,SAAS,EAAEhB,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,UAAU,EAAEjB,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEe,SAAS,EAAElB,6BAAS,CAACG,IAAI;EAEzB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEgB,UAAU,EAAEnB,6BAAS,CAACG,IAAI;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEiB,kBAAkB,EAAEpB,6BAAS,CAACG,IAAAA;EAChC,CAAC,CAAA;EAED,MAAM7D,UAAU,GAAG;EACjBkE,EAAAA,MAAM,EAAE,SAAA;EACV,CAAC,CAAA;EAED,MAAM5C,eAAa,GAAG,CAAC,oBAAoB,CAAC,CAAA;;EAE5C;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACM0W,QAAAA,KAAK,GAAGlW,gBAAgB,CAACuB,UAAU,CAAC,WAAW,CAAC,EAAE;IAACG,SAAS;IAAExD,UAAU;EAAEsB,iBAAAA,eAAAA;EAAa,CAAC,EAAC;EAC/F0W,KAAK,CAACxU,SAAS,GAAGA,SAAS;;EClI3B,MAAMlC,aAAa,GAAG,CAAC,SAAS,CAAC,CAAA;;EAEjC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAM2W,OAAO,GAAGnW,gBAAgB,CAAC,aAAa,EAAE;EAACR,EAAAA,aAAAA;EAAa,CAAC,EAAC;EAEhE2W,OAAO,CAACzU,SAAS,GAAG;EAClB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;IACEJ,OAAO,EAAEG,6BAAS,CAACI,IAAI;EAEvB;EACF;EACA;EACA;EACA;EACA;EACA;IACEoU,MAAM,EAAExU,6BAAS,CAACI,IAAI;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;IACEqU,MAAM,EAAEzU,6BAAS,CAACI,IAAAA;EACpB,CAAC;;ECrED;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA,QAAMsU,aAAa,GAAGtW,gBAAgB,CAAC,oBAAoB,EAAC;EAE5DsW,aAAa,CAAC5U,SAAS,GAAG;EACxB;EACF;EACA;EACA;EACA;EACA;EACA;EACA;IACEc,QAAQ,EAAEZ,6BAAS,CAACC,MAAM;EAE1B;EACF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;IACEK,QAAQ,EAAEN,6BAAS,CAACI,IAAI;EAExB;EACF;EACA;EACA;EACA;EACA;EACA;IACEkB,IAAI,EAAEtB,6BAAS,CAACC,MAAM;EAEtB;EACF;EACA;EACA;EACA;EACA;EACA;IACEsB,OAAO,EAAEvB,6BAAS,CAACG,IAAAA;EACrB,CAAC;;ECvED;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA,mBAAe;IACbwU,IAAI,EAAGlJ,MAAM,IAAK;MAChB,OAAO;EACL2F,MAAAA,UAAU,EAAE,CAAC,GAAG3F,MAAM,CAAC;EACvB6F,MAAAA,YAAY,EAAE,EAAA;OACf,CAAA;KACF;EAEDpV,EAAAA,OAAO,EAAE,IAAwC,IAAA;MAAA,IAAvC;QAACiV,WAAW;QAAE5F,KAAK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"}
