@dnb/eufemia
Version:
DNB Eufemia Design System UI Library
245 lines (244 loc) • 9.76 kB
JavaScript
"use client";
import _extends from "@babel/runtime/helpers/esm/extends";
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
const _excluded = ["product_code", "card_number", "card_status", "variant", "digits", "id", "raw_data", "locale", "skeleton", "className", "class", "children"];
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
import React from 'react';
import PropTypes from 'prop-types';
import classnames from 'classnames';
import Context from '../../shared/Context';
import Provider from '../../shared/Provider';
import { isTrue, validateDOMAttributes, extendPropsWithContextInClassComponent } from '../../shared/component-helper';
import { spacingPropTypes, createSpacingClasses } from '../../components/space/SpacingHelper';
import { skeletonDOMAttributes, createSkeletonClass } from '../../components/skeleton/SkeletonHelper';
import P from '../../elements/P';
import { ProductType, CardType, BankAxeptType } from './utils/Types';
import Designs, { defaultDesign } from './utils/CardDesigns';
import cardProducts from './utils/cardProducts';
import { ProductLogo, TypeLogo, BankLogo, StatusIcon, BankAxeptLogo } from './icons';
export { Designs, ProductType, CardType, BankAxeptType };
const cardDataPropTypes = process.env.NODE_ENV !== "production" ? PropTypes.shape({
productCode: PropTypes.string.isRequired,
productName: PropTypes.string.isRequired,
displayName: PropTypes.string.isRequired,
cardDesign: PropTypes.object.isRequired,
cardType: PropTypes.object.isRequired,
productType: PropTypes.object.isRequired,
bankAxept: PropTypes.object.isRequired
}) : {};
const translationDefaultPropsProps = {
text_card_number: null,
text_expired: null,
text_blocked: null,
text_not_active: null,
text_order_in_process: null,
text_renewed: null,
text_replaced: null,
text_unknown: null
};
export default class PaymentCard extends React.PureComponent {
render() {
var _this$context;
const props = extendPropsWithContextInClassComponent(this.props, PaymentCard.defaultProps, {
locale: this.context.locale
}, {
skeleton: (_this$context = this.context) === null || _this$context === void 0 ? void 0 : _this$context.skeleton
});
const {
product_code,
card_number,
card_status,
variant,
digits,
id,
raw_data,
locale,
skeleton,
className,
class: _className,
children
} = props,
attributes = _objectWithoutProperties(props, _excluded);
const cardData = raw_data || getCardData(product_code);
const params = _objectSpread({
className: classnames(`dnb-payment-card dnb-payment-card--${variant}`, createSkeletonClass(null, skeleton, this.context), createSpacingClasses(props), className, _className)
}, attributes);
skeletonDOMAttributes(params, skeleton, this.context);
validateDOMAttributes(this.props, params);
return React.createElement(Provider, {
locale: locale
}, React.createElement(Context.Consumer, null, ({
translation
}) => {
const translations = extendPropsWithContextInClassComponent(this.props, translationDefaultPropsProps, translation.PaymentCard);
return React.createElement("figure", params, React.createElement("figcaption", {
className: "dnb-sr-only dnb-payment-card__figcaption"
}, cardData.productName), React.createElement(NormalCard, {
id: id,
skeleton: isTrue(skeleton),
data: cardData,
cardStatus: card_status,
cardNumber: formatCardNumber(card_number, parseFloat(digits)),
translations: translations
}));
}));
}
}
_defineProperty(PaymentCard, "contextType", Context);
_defineProperty(PaymentCard, "defaultProps", _objectSpread({
digits: 8,
locale: null,
card_status: 'active',
variant: 'normal',
id: null,
raw_data: null,
skeleton: false,
className: null,
children: null
}, translationDefaultPropsProps));
process.env.NODE_ENV !== "production" ? PaymentCard.propTypes = _objectSpread(_objectSpread({
product_code: PropTypes.string.isRequired,
card_number: PropTypes.string.isRequired,
card_status: PropTypes.oneOf(['active', 'blocked', 'expired', 'not_active', 'order_in_process', 'renewed', 'replaced', 'unknown']),
variant: PropTypes.oneOf(['normal', 'compact']),
digits: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
raw_data: cardDataPropTypes,
id: PropTypes.string,
locale: PropTypes.string,
skeleton: PropTypes.oneOfType([PropTypes.string, PropTypes.bool])
}, spacingPropTypes), {}, {
className: PropTypes.string,
children: PropTypes.oneOfType([PropTypes.string, PropTypes.node, PropTypes.func])
}) : void 0;
const formatCardNumberRegex = /(?=(?:....)*$)/g;
export const formatCardNumber = (cardNumber, digits = 8) => {
if (!cardNumber) {
return cardNumber;
}
if (digits && digits <= cardNumber.length) {
return cardNumber.slice(cardNumber.length - digits, cardNumber.length).replace(formatCardNumberRegex, ' ').trim();
}
return cardNumber.replace(formatCardNumberRegex, ' ').trim();
};
export const getCardData = productCode => {
const card = cardProducts.find(item => item.productCode === productCode);
return card || defaultCard(productCode);
};
const defaultCard = productCode => ({
productCode,
productName: '',
displayName: '',
cardDesign: defaultDesign,
cardType: CardType.None,
productType: ProductType.None,
bankAxept: BankAxeptType.None
});
process.env.NODE_ENV !== "production" ? StatusOverlay.propTypes = {
cardStatus: PropTypes.string.isRequired,
translations: PropTypes.object.isRequired
} : void 0;
const BlockingOverlay = ({
cardStatus,
text
}, skeleton) => {
return React.createElement("div", {
className: classnames('dnb-payment-card__blocking__overlay', createSkeletonClass('font', skeleton))
}, React.createElement("div", {
className: "dnb-payment-card__blocking__center"
}, React.createElement(StatusIcon, {
status: cardStatus
}), React.createElement(P, {
top: "xx-small"
}, text)));
};
function StatusOverlay({
cardStatus,
translations
}) {
const cardStatusMap = {
not_active: translations.text_not_active,
order_in_process: translations.text_order_in_process,
renewed: translations.text_renewed,
replaced: translations.text_replaced,
blocked: translations.text_blocked,
expired: translations.text_expired,
unknown: translations.text_unknown
};
return cardStatusMap[cardStatus] ? React.createElement(BlockingOverlay, {
cardStatus: cardStatus,
text: cardStatusMap[cardStatus]
}) : null;
}
process.env.NODE_ENV !== "production" ? CardText.propTypes = {
cardNumber: PropTypes.string.isRequired,
translations: PropTypes.object.isRequired,
skeleton: PropTypes.bool.isRequired
} : void 0;
function CardText({
cardNumber,
translations,
skeleton
}) {
return React.createElement("span", {
className: classnames('dnb-payment-card__card__wrapper', createSkeletonClass('font', skeleton))
}, React.createElement(P, {
className: "dnb-payment-card__card__holder",
modifier: "x-small medium"
}, translations.text_card_number), React.createElement(P, {
className: "dnb-payment-card__card__numbers"
}, cardNumber));
}
process.env.NODE_ENV !== "production" ? NormalCard.propTypes = {
id: PropTypes.string,
skeleton: PropTypes.bool,
data: cardDataPropTypes.isRequired,
cardStatus: PropTypes.string.isRequired,
cardNumber: PropTypes.string.isRequired,
translations: PropTypes.object.isRequired
} : void 0;
function NormalCard({
data,
cardStatus,
cardNumber,
id = null,
skeleton = null,
translations
}) {
var _data$cardDesign;
return React.createElement("div", _extends({
id: id,
className: `dnb-payment-card__card dnb-payment-card__${data.cardDesign.cardStyle}`
}, (_data$cardDesign = data.cardDesign) !== null && _data$cardDesign !== void 0 && _data$cardDesign.backgroundImage ? {
style: {
backgroundImage: `url(${data.cardDesign.backgroundImage})`
}
} : {}), React.createElement("div", {
className: "dnb-payment-card__card__content"
}, React.createElement("div", {
className: "dnb-payment-card__card__top"
}, React.createElement(BankLogo, {
logoType: data.cardDesign.bankLogo
}), React.createElement(ProductLogo, {
productType: data.productType,
cardDesign: data.cardDesign
}), React.createElement(BankAxeptLogo, {
bankAxept: data.bankAxept,
cardDesign: data.cardDesign
})), React.createElement("div", {
className: "dnb-payment-card__card__bottom"
}, React.createElement(CardText, {
cardNumber: cardNumber,
displayName: data.displayName,
translations: translations,
skeleton: skeleton
}), React.createElement(TypeLogo, {
cardType: data.cardType,
cardDesign: data.cardDesign
}))), React.createElement(StatusOverlay, {
cardStatus: cardStatus,
translations: translations
}));
}
//# sourceMappingURL=PaymentCard.js.map