UNPKG

@codementor/ui-kit

Version:
270 lines (215 loc) • 16.5 kB
'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;