@codementor/ui-kit
Version: 
270 lines (215 loc) • 16.5 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
  value: true
});
exports.paypalImage = exports.defaultCardImage = exports.CARD_IMAGE = exports.SUPPORTED_PAYMENT_METHODS = undefined;
var _keys = require('babel-runtime/core-js/object/keys');
var _keys2 = _interopRequireDefault(_keys);
var _extends2 = require('babel-runtime/helpers/extends');
var _extends3 = _interopRequireDefault(_extends2);
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of');
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf);
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _style = require('styled-jsx/style');
var _style2 = _interopRequireDefault(_style);
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames);
var _reactFontawesome = require('@fortawesome/react-fontawesome');
var _reactFontawesome2 = _interopRequireDefault(_reactFontawesome);
var _faPlus = require('@fortawesome/fontawesome-free-solid/faPlus');
var _faPlus2 = _interopRequireDefault(_faPlus);
var _CircularProgress = require('./CircularProgress');
var _CircularProgress2 = _interopRequireDefault(_CircularProgress);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* babel-plugin-inline-import '../static/payment/card_visa.png' */var visaImageSrc = '';
/* babel-plugin-inline-import '../static/payment/card_master_card.png' */var masterImageSrc = '';
/* babel-plugin-inline-import '../static/payment/card_american_express.png' */var aeImageSrc = '';
/* babel-plugin-inline-import '../static/payment/card_discover.png' */var discoverImageSrc = '';
/* babel-plugin-inline-import '../static/payment/card_unknown.png' */var unknowmImageSrc = '';
/* babel-plugin-inline-import '../static/payment/ic_paypal.png' */var ppImageSrc = '';
var SUPPORTED_PAYMENT_METHODS = exports.SUPPORTED_PAYMENT_METHODS = {
  CREDIT_CARD: 'credit_card',
  PAYPAL: 'paypal'
};
var CARD_IMAGE = exports.CARD_IMAGE = {
  Visa: visaImageSrc,
  MasterCard: masterImageSrc,
  'American Express': aeImageSrc,
  Discover: discoverImageSrc
};
var defaultCardImage = exports.defaultCardImage = unknowmImageSrc;
var paypalImage = exports.paypalImage = ppImageSrc;
var PaymentMethodRadioGroup = function (_PureComponent) {
  (0, _inherits3.default)(PaymentMethodRadioGroup, _PureComponent);
  function PaymentMethodRadioGroup(props) {
    (0, _classCallCheck3.default)(this, PaymentMethodRadioGroup);
    var _this = (0, _possibleConstructorReturn3.default)(this, (PaymentMethodRadioGroup.__proto__ || (0, _getPrototypeOf2.default)(PaymentMethodRadioGroup)).call(this, props));
    _initialiseProps.call(_this);
    _this._onSelect = _this._onSelect.bind(_this);
    // multiple groups in one page could happen
    _this.radioGroupKey = Math.random();
    return _this;
  }
  (0, _createClass3.default)(PaymentMethodRadioGroup, [{
    key: 'render',
    value: function render() {
      var _props = this.props,
          currentCard = _props.currentCard,
          defaultMethod = _props.defaultMethod,
          allowPaypal = _props.allowPaypal;
      var hasCard = this._hasCard();
      var cardInputProps = this._getCardInputProps();
      return _react2.default.createElement(
        'div',
        {
          className: 'jsx-1204593774' + ' ' + 'method-selector__options'
        },
        _react2.default.createElement(
          'label',
          {
            className: 'jsx-1204593774' + ' ' + ((0, _classnames2.default)('selector__method', {
              'selector__method--disabled': !hasCard
            }) || '')
          },
          _react2.default.createElement('input', (0, _extends3.default)({}, cardInputProps, {
            className: 'jsx-1204593774' + ' ' + (cardInputProps.className != null && cardInputProps.className || '')
          })),
          hasCard ? _react2.default.createElement('img', {
            src: CARD_IMAGE[currentCard.brand] || defaultCardImage, className: 'jsx-1204593774' + ' ' + 'selector__card-icon'
          }) : _react2.default.createElement(
            'div',
            {
              className: 'jsx-1204593774' + ' ' + 'selector__add-card-icon'
            },
            _react2.default.createElement(_reactFontawesome2.default, { icon: _faPlus2.default, color: '#fff' })
          ),
          hasCard ? _react2.default.createElement(
            'div',
            {
              className: 'jsx-1204593774' + ' ' + 'selector__method__title'
            },
            currentCard.brand + ' \u2022\u2022\u2022\u2022 ' + currentCard.last4
          ) : _react2.default.createElement(
            'div',
            {
              className: 'jsx-1204593774' + ' ' + 'selector__method__title'
            },
            _react2.default.createElement(
              'div',
              {
                className: 'jsx-1204593774'
              },
              'Credit Card'
            ),
            _react2.default.createElement(
              'div',
              {
                className: 'jsx-1204593774' + ' ' + 'selector__method__subtitle'
              },
              'Powered by Stripe'
            )
          ),
          this._renderCreditCardAction()
        ),
        allowPaypal && _react2.default.createElement(
          'label',
          {
            className: 'jsx-1204593774' + ' ' + 'selector__method'
          },
          _react2.default.createElement('input', {
            type: 'radio',
            name: this.radioGroupKey,
            value: SUPPORTED_PAYMENT_METHODS.PAYPAL,
            onChange: this._onSelect,
            defaultChecked: defaultMethod === SUPPORTED_PAYMENT_METHODS.PAYPAL, className: 'jsx-1204593774'
          }),
          _react2.default.createElement('img', { src: paypalImage, className: 'jsx-1204593774' + ' ' + 'selector__method-image'
          }),
          'Paypal'
        ),
        _react2.default.createElement(_style2.default, {
          styleId: '1204593774',
          css: '.method-selector__options.jsx-1204593774>label.jsx-1204593774+label.jsx-1204593774{margin-top:5px;}.selector__method.jsx-1204593774{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;border-radius:3px;border:solid 1px #e1e6e6;padding:0px 15px;min-height:50px;font-size:14px;color:#4c4c4c;}.selector__method.jsx-1204593774:hover{background-color:rgba(216,216,216,0.2);border:solid 1px #ccc;}.selector__method.jsx-1204593774:active{background-color:#f0f0f0;border:solid 1px #ccc;}.selector__method--loading.jsx-1204593774:after{content:\'\';vertical-align:middle;margin-right:8px;}.selector__method__title.jsx-1204593774{-webkit-flex:1;-ms-flex:1;flex:1;}.selector__method__subtitle.jsx-1204593774{font-size:12px;line-height:1.17;color:#666;}.selector__method.jsx-1204593774 a{color:#00b5e2;font-weight:bold;cursor:pointer;}.selector__method.jsx-1204593774 input.jsx-1204593774{-webkit-flex:none;-ms-flex:none;flex:none;margin:0;}.selector__method.jsx-1204593774 img.jsx-1204593774{margin:0 15px;}.selector__method-image.jsx-1204593774{height:25px;}.selector__card-icon.jsx-1204593774{width:40px;height:24px;}.selector__add-card-icon.jsx-1204593774{margin:0 15px;width:40px;height:24px;border-radius:4px;background-color:#666;display:-webkit-inline-box;display:-webkit-inline-flex;display:-ms-inline-flexbox;display:inline-flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;}.selector__method--disabled.jsx-1204593774{cursor:default;border:solid 1px rgba(225,230,230,0.4);}.selector__method--disabled.jsx-1204593774>div{opacity:0.6;}'
        })
      );
    }
  }, {
    key: '_renderCreditCardAction',
    value: function _renderCreditCardAction() {
      var _props2 = this.props,
          openStripeModal = _props2.openStripeModal,
          isUpdatingCard = _props2.isUpdatingCard;
      var hasCard = this._hasCard();
      if (isUpdatingCard) {
        return _react2.default.createElement(_CircularProgress2.default, null);
      }
      return _react2.default.createElement(
        'a',
        { onClick: openStripeModal },
        hasCard ? 'CHANGE CARD' : 'ADD CARD'
      );
    }
  }, {
    key: '_hasCard',
    value: function _hasCard() {
      var currentCard = this.props.currentCard;
      return currentCard && (0, _keys2.default)(currentCard).length > 0;
    }
  }, {
    key: '_onSelect',
    value: function _onSelect(e) {
      var onSelect = this.props.onSelect;
      onSelect({
        method: e.target.value
      });
    }
  }]);
  return PaymentMethodRadioGroup;
}(_react.PureComponent);
var _initialiseProps = function _initialiseProps() {
  var _this2 = this;
  this._getCardInputProps = function () {
    var hasCard = _this2._hasCard();
    var _props3 = _this2.props,
        method = _props3.method,
        defaultMethod = _props3.defaultMethod;
    var methodKey = SUPPORTED_PAYMENT_METHODS.CREDIT_CARD;
    var props = {
      type: 'radio',
      name: _this2.radioGroupKey,
      value: methodKey,
      onChange: _this2._onSelect,
      disabled: !hasCard
    };
    if (defaultMethod) {
      props.defaultChecked = defaultMethod === methodKey;
    } else if (method) {
      props.checked = method === methodKey;
    }
    return props;
  };
};
PaymentMethodRadioGroup.propTypes = {
  openStripeModal: _propTypes2.default.func.isRequired,
  onSelect: _propTypes2.default.func.isRequired,
  defaultMethod: _propTypes2.default.string,
  method: _propTypes2.default.string,
  isUpdatingCard: _propTypes2.default.bool,
  allowPaypal: _propTypes2.default.bool,
  currentCard: _propTypes2.default.object
};
PaymentMethodRadioGroup.defaultProps = {
  allowPaypal: true
};
exports.default = PaymentMethodRadioGroup;