import React, { useState } from 'react';
import { s as styleInject } from '../style-inject.es-1f59c1d0.js';
import { _ as _defineProperty } from '../defineProperty-18999f8e.js';
import { c as classnames } from '../index-e3cf212a.js';
import { e as exportStyleSizeClass } from '../utils-6b513b37.js';
import { _ as _slicedToArray } from '../slicedToArray-4cd9e6d3.js';
import { Input } from 'antd';

var css = ".PriceOptions_options__ifYbC p {\n  font-size: 14px;\n  font-weight: 400;\n  color: #616a79;\n  margin-bottom: 20px;\n}\n.PriceOptions_options__ifYbC .PriceOptions_infoItem__246mx {\n  padding-right: 0;\n}\n.PriceOptions_options__ifYbC .PriceOptions_infoItem__246mx .PriceOptions_priceItem__3CPe3 {\n  background: rgba(243, 243, 243, 0.14);\n  border-radius: 4px;\n  border: 1px solid #cfcfcf;\n  font-size: 14px;\n  font-weight: 600;\n  color: #616a79;\n  display: inline-block;\n  text-align: center;\n  vertical-align: top;\n  height: 30px;\n  width: 70px;\n  line-height: 30px;\n  cursor: pointer;\n  margin: 6px;\n}\n.PriceOptions_options__ifYbC .PriceOptions_infoItem__246mx .PriceOptions_priceItem__3CPe3.PriceOptions_active__154by {\n  background: rgba(255, 50, 102, 0.1);\n  border-radius: 4px;\n  border: 1px solid #ff3266;\n  color: #616a79;\n}\n.PriceOptions_options__ifYbC .PriceOptions_infoItem__246mx .PriceOptions_priceInput__2JFc0 {\n  display: inline-block;\n  min-width: 70px;\n  width: auto;\n  margin: 6px;\n  text-align: center;\n}\n.PriceOptions_options__ifYbC .PriceOptions_infoItem__246mx button {\n  border-top-left-radius: 0;\n  border-bottom-left-radius: 0;\n  height: 30px;\n  width: 50px;\n  vertical-align: top;\n  padding: 0 5px;\n}\n.PriceOptions_options__ifYbC .PriceOptions_infoItem__246mx .PriceOptions_rate__17U-9 {\n  margin-left: 10px;\n}\n.PriceOptions_options__ifYbC .PriceOptions_infoItem__246mx .PriceOptions_rate__17U-9 i {\n  margin-right: 5px;\n  color: #1790ff;\n}\n.PriceOptions_options__ifYbC.PriceOptions_multi__2fM8z p {\n  font-size: 14px;\n  font-weight: 400;\n  color: #616a79;\n}\n.PriceOptions_options__ifYbC.PriceOptions_multi__2fM8z .PriceOptions_infoItem__246mx {\n  padding-right: 0;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n}\n.PriceOptions_options__ifYbC.PriceOptions_multi__2fM8z .PriceOptions_infoItem__246mx .PriceOptions_priceBtn__1UaE8 {\n  display: flex;\n  justify-content: space-between;\n}\n.PriceOptions_options__ifYbC.PriceOptions_multi__2fM8z .PriceOptions_infoItem__246mx .PriceOptions_priceItem__3CPe3 {\n  display: inline-block;\n  background-color: #fff;\n  border-radius: 4px;\n  border: 1px solid #cfcfcf;\n}\n.PriceOptions_options__ifYbC.PriceOptions_multi__2fM8z .PriceOptions_infoItem__246mx .PriceOptions_priceItem__3CPe3.PriceOptions_active__154by {\n  background-color: #fff;\n  color: #ff3266ff;\n  border: 1px solid #ff3266;\n}\n.PriceOptions_options__ifYbC.PriceOptions_multi__2fM8z .PriceOptions_infoItem__246mx .PriceOptions_priceInput__2JFc0 {\n  width: 222px;\n  width: auto;\n}\n";
var styles = {
  "options": "PriceOptions_options__ifYbC",
  "infoItem": "PriceOptions_infoItem__246mx",
  "priceItem": "PriceOptions_priceItem__3CPe3",
  "active": "PriceOptions_active__154by",
  "priceInput": "PriceOptions_priceInput__2JFc0",
  "rate": "PriceOptions_rate__17U-9",
  "multi": "PriceOptions_multi__2fM8z",
  "priceBtn": "PriceOptions_priceBtn__1UaE8"
};
styleInject(css);

function ownKeys(object, enumerableOnly) {
  var keys = Object.keys(object);

  if (Object.getOwnPropertySymbols) {
    var symbols = Object.getOwnPropertySymbols(object);
    if (enumerableOnly) symbols = symbols.filter(function (sym) {
      return Object.getOwnPropertyDescriptor(object, sym).enumerable;
    });
    keys.push.apply(keys, symbols);
  }

  return keys;
}

function _objectSpread(target) {
  for (var i = 1; i < arguments.length; i++) {
    var source = arguments[i] != null ? arguments[i] : {};

    if (i % 2) {
      ownKeys(Object(source), true).forEach(function (key) {
        _defineProperty(target, key, source[key]);
      });
    } else if (Object.getOwnPropertyDescriptors) {
      Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
    } else {
      ownKeys(Object(source)).forEach(function (key) {
        Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
      });
    }
  }

  return target;
}

var PriceOptions = function PriceOptions(_ref) {
  var price = _ref.price,
      onPriceChange = _ref.onPriceChange,
      allowZero = _ref.allowZero,
      _ref$rowMode = _ref.rowMode,
      rowMode = _ref$rowMode === void 0 ? "single" : _ref$rowMode,
      _ref$size = _ref.size,
      size = _ref$size === void 0 ? "normal" : _ref$size,
      _ref$focusScroll = _ref.focusScroll,
      focusScroll = _ref$focusScroll === void 0 ? true : _ref$focusScroll,
      _ref$withTitle = _ref.withTitle,
      withTitle = _ref$withTitle === void 0 ? true : _ref$withTitle,
      _ref$titleText = _ref.titleText,
      titleText = _ref$titleText === void 0 ? "Price" : _ref$titleText,
      _ref$inputPlaceholder = _ref.inputPlaceholderText,
      inputPlaceholderText = _ref$inputPlaceholder === void 0 ? "Others" : _ref$inputPlaceholder,
      _ref$priceOptions = _ref.priceOptions,
      priceOptions = _ref$priceOptions === void 0 ? [100, 600, 800] : _ref$priceOptions,
      _ref$priceRender = _ref.priceRender,
      priceRender = _ref$priceRender === void 0 ? function (i) {
    return i / 100;
  } : _ref$priceRender,
      _ref$inputPriceRender = _ref.inputPriceRender,
      inputPriceRender = _ref$inputPriceRender === void 0 ? function (i) {
    return i ? i / 100 : "";
  } : _ref$inputPriceRender,
      _ref$inputSuffix = _ref.inputSuffix,
      inputSuffix = _ref$inputSuffix === void 0 ? "¥" : _ref$inputSuffix,
      _ref$injectOptions = _ref.injectOptions,
      injectOptions = _ref$injectOptions === void 0 ? {
    priceBtnClass: function priceBtnClass() {
      return undefined;
    },
    priceInputClass: function priceInputClass() {
      return undefined;
    }
  } : _ref$injectOptions,
      inputRef = _ref.inputRef;
  var defaultOptions = priceOptions;

  var _useState = useState(false),
      _useState2 = _slicedToArray(_useState, 2),
      inputStatus = _useState2[0],
      setInputStatus = _useState2[1];

  var _useState3 = useState(''),
      _useState4 = _slicedToArray(_useState3, 2),
      inputPrice = _useState4[0],
      setInputPrice = _useState4[1];

  return React.createElement("div", {
    className: classnames(styles.options, _objectSpread(_defineProperty({}, styles.multi, rowMode === "multi"), exportStyleSizeClass(styles, size)))
  }, withTitle ? titleText || null : null, React.createElement("div", {
    className: styles.infoItem
  }, React.createElement("span", {
    className: styles.priceBtn
  }, defaultOptions.map(function (item) {
    var _objectSpread3;

    var isActive = price === item && !inputStatus;
    return React.createElement("span", {
      className: classnames(_objectSpread((_objectSpread3 = {}, _defineProperty(_objectSpread3, styles.priceItem, true), _defineProperty(_objectSpread3, styles.active, !injectOptions.priceBtnClass(isActive) && isActive), _objectSpread3), injectOptions.priceBtnClass(isActive))),
      key: item,
      onClick: function onClick() {
        onPriceChange(item);
        setInputStatus(false);
      }
    }, priceRender(item));
  })), React.createElement(Input, {
    ref: inputRef,
    className: classnames(styles.priceInput, _objectSpread({}, injectOptions.priceInputClass())),
    onMouseEnter: function onMouseEnter() {
      if (inputStatus && inputRef && inputRef.current) {
        inputRef.current.focus();
        inputRef.current.select();
      }
    },
    suffix: inputSuffix,
    value: inputStatus ? inputPriceRender(inputPrice) : "",
    placeholder: inputPlaceholderText,
    onChange: function onChange(e) {
      var n = +e.target.value;

      if (Number.isNaN(n)) {
        return;
      }

      if (!allowZero && n === 0) {
        return;
      }

      setInputPrice("".concat(n * 100));
      onPriceChange(n * 100);
    },
    onClick: function onClick(e) {
      if (!inputStatus) {
        setInputPrice('');
        setInputStatus(true);
      }
    },
    onFocus: function onFocus(e) {
      e.target.placeholder = "";

      if (inputStatus) {
        setInputPrice("".concat(price));
      } else {
        setInputPrice('');
        setInputStatus(true);
      }

      if (focusScroll) {
        e.target.scrollIntoView();
      }
    },
    onBlur: function onBlur(e) {
      e.target.placeholder = inputPlaceholderText;

      if (inputPrice) {
        setInputStatus(true);
      } else {
        setInputStatus(false);
      }
    }
  })));
};

export default PriceOptions;
//# sourceMappingURL=index.js.map