diff --git a/packages/dnb-design-system-portal/src/docs/uilib/about-the-lib/releases/eufemia/v10-info.mdx b/packages/dnb-design-system-portal/src/docs/uilib/about-the-lib/releases/eufemia/v10-info.mdx index 8aea9ef946e..fcf2fb50ff9 100644 --- a/packages/dnb-design-system-portal/src/docs/uilib/about-the-lib/releases/eufemia/v10-info.mdx +++ b/packages/dnb-design-system-portal/src/docs/uilib/about-the-lib/releases/eufemia/v10-info.mdx @@ -309,7 +309,15 @@ Removed `small` as prop. Use `size="small"` instead. ### [PaymentCard](/uilib/extensions/payment-card/) -1. `Type`'s value/option `Metalic` was renamed to `Metallic`. Find `Metalic` and replace with `Metallic`. -2. `Type`'s value/option `BlackMetalic` was renamed to `BlackMetallic`. Find `BlackMetalic` and replace with `BlackMetallic`. +1. `Type`'s `DNB` value/option `Metalic` was removed. +2. `Type`'s `Saga` value/option `VisaPlatinum` was removed. +3. `Type`'s `PB` value/option `Platinum` was removed. +4. `Type`'s `Mastercard` value/option `DefaultWhite` was removed. +5. `Type`'s `Mastercard` value/option `Metalic` was removed. +6. `Type`'s `Mastercard` value/option `BlackMetalic` was removed. +7. `Type`'s `Visa` value/option `Metalic` was removed. +8. `CardDesign`'s value/option `white` was removed. +9. `CardDesign`'s value/option `silver` was removed. +10. `ProductType`'s value/option `BankAxept` was removed. _April, 20. 2023_ diff --git a/packages/dnb-design-system-portal/src/docs/uilib/extensions/payment-card/CardProductsTable.js b/packages/dnb-design-system-portal/src/docs/uilib/extensions/payment-card/CardProductsTable.js index dc6f32d4f30..c89fed283e7 100644 --- a/packages/dnb-design-system-portal/src/docs/uilib/extensions/payment-card/CardProductsTable.js +++ b/packages/dnb-design-system-portal/src/docs/uilib/extensions/payment-card/CardProductsTable.js @@ -61,9 +61,11 @@ const getTypeVariant = (type, design) => const getProductVariant = (type, design) => type.cata({ - BankAxept: () => prettiePrint(design.bankAxept.toString()), Saga: () => prettiePrint(design.saga.toString()), Pluss: () => '-', + Intro: () => '-', + Bedrift: () => '-', + Business: () => '-', PrivateBanking: () => prettiePrint(design.privateBanking.toString()), None: () => '-', }) @@ -71,5 +73,4 @@ const getProductVariant = (type, design) => const getProductLogo = (bankLogo) => bankLogo.cata({ Colored: (color) => color, - Metallic: () => 'Metallic', }) diff --git a/packages/dnb-design-system-portal/src/docs/uilib/extensions/payment-card/Examples.tsx b/packages/dnb-design-system-portal/src/docs/uilib/extensions/payment-card/Examples.tsx index a21f51d4805..ca488af93a1 100644 --- a/packages/dnb-design-system-portal/src/docs/uilib/extensions/payment-card/Examples.tsx +++ b/packages/dnb-design-system-portal/src/docs/uilib/extensions/payment-card/Examples.tsx @@ -10,6 +10,7 @@ import PaymentCard, { Designs, ProductType, CardType, + BankAxeptType, } from '@dnb/eufemia/src/extensions/payment-card' import { H4 } from '@dnb/eufemia/src' @@ -21,18 +22,46 @@ export function PaymentCardAllCardsExample() { > {() => { const demoCards = [ + 'NK1', + 'NK4', + 'NK5', 'VE1', + 'VE2', + 'VG1', + 'VG4', + '053', + 'VK2', + 'VK4', + '084', + 'VL1', 'VL2', + 'VL3', + 'VL4', + 'VL6', + '085', + 'VO1', + 'VP2', + 'VP3', + 'VP4', + '069', + 'VP5', + '080', 'VX1', 'VX3', - 'VL1', + 'VX4', + 'VX5', '096', - 'VG1', - 'VP2', - 'VP3', - 'P101', + '044', + '043', + '098', + '074', + '062', 'BK1', + 'BP1', + 'VB1', 'VB2', + 'VB5', + 'P101', ] const Cards = () => ( @@ -41,7 +70,9 @@ export function PaymentCardAllCardsExample() { const cardData = getCardData(product_code) return (
-

{cardData.cardDesign.name}

+

+ {cardData.cardDesign.name}({product_code}) +

( ) export const PaymentCardCustomExample = () => ( - + {() => { const customData = { productCode: 'UNDEFINED', @@ -76,7 +109,8 @@ export const PaymentCardCustomExample = () => ( displayName: 'Custom card', cardDesign: Designs.gold, cardType: CardType.Visa, - productType: ProductType.BankAxept, + productType: ProductType.None, + bankAxept: BankAxeptType.BankAxept, } return ( diff --git a/packages/dnb-design-system-portal/src/docs/uilib/extensions/payment-card/properties.mdx b/packages/dnb-design-system-portal/src/docs/uilib/extensions/payment-card/properties.mdx index d54b41856f8..f3d2b3e521a 100644 --- a/packages/dnb-design-system-portal/src/docs/uilib/extensions/payment-card/properties.mdx +++ b/packages/dnb-design-system-portal/src/docs/uilib/extensions/payment-card/properties.mdx @@ -18,37 +18,37 @@ showTabs: true ## Card Data -| Properties | Type | Description | -| ------------- | ------------ | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -| `productCode` | `string` | _(required)_ product code for the given card. | -| `productName` | `string` | _(required)_ product name. Can be blank. | -| `displayName` | `string` | _(required)_ the visible product name. Can be empty. | -| `cardDesign` | `object` | _(required)_ object that describes the style properties of the card. can be imported from `@dnb/eufemia/extensions/payment-card/utils/CardDesigns` (see available designs below) or a custom one can be created. | -| `cardType` | `Union Type` | _(required)_ import CardType from `@dnb/eufemia/extensions/payment-card/utils/Types` to use. Can be CardType.Visa, CardType.Mastercard or CardType.None | -| `productType` | `Union Type` | _(required)_ import ProductType from `@dnb/eufemia/extensions/payment-card/utils/Types` to use. Can be ProductType.BankAxept, ProductType.Saga, ProductType.PrivateBanking or ProductType.None | +| Properties | Type | Description | +| ------------- | ------------ | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `productCode` | `string` | _(required)_ product code for the given card. | +| `productName` | `string` | _(required)_ product name. Can be blank. | +| `displayName` | `string` | _(required)_ the visible product name. Can be empty. | +| `cardDesign` | `object` | _(required)_ object that describes the style properties of the card. can be imported from `@dnb/eufemia/extensions/payment-card/utils/CardDesigns` (see available designs below) or a custom one can be created. | +| `cardType` | `Union Type` | _(required)_ import CardType from `@dnb/eufemia/extensions/payment-card/utils/Types` to use. Can be CardType.Visa, CardType.Mastercard or CardType.None | +| `productType` | `Union Type` | _(required)_ import ProductType from `@dnb/eufemia/extensions/payment-card/utils/Types` to use. Can be ProductType.Saga, ProductType.Pluss, ProductType.Intro, ProductType.Business, ProductType.Bedrift, ProductType.PrivateBanking or ProductType.None | ## Card Design -| Properties | Type | Description | -| ---------------- | ------------ | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -| `name` | `string` | _(required)_ string Name of design | -| `cardStyle` | `string` | _(required)_ css class. mainly to set background and color | -| `bankLogo` | `Union Type` | _(required)_ Union Type. import DNB from ./card/utils/Types to use. Can be DNB.Colored('HexValue') or DNB.Metallic | -| `visa` | `Union Type` | _(required)_ Union Type. import Visa from ./card/utils/Types to use. Can be Visa.Colored('HexValue') or Visa.Metallic | -| `mastercard` | `Union Type` | _(required)_ Union Type. import Mastercard from ./card/utils/Types to use. Can be Mastercard.Default, Mastercard.DefaultWhite Mastercard.Metallic or Mastercard.MetallicBlack | -| `bankAxept` | `Union Type` | _(required)_ Union Type. import BankAxept from ./card/utils/Types to use. Can be BankAxept.White or BankAxept.Black | -| `saga` | `Union Type` | _(required)_ Union Type. import Saga from ./card/utils/Types to use. Can be Saga.Gold, Saga.Platinum, Saga.VisaPlatinum, or Saga.None | -| `privateBanking` | `Union Type` | _(required)_ Union Type. import PB from ./card/utils/Types to use. Can be PB.Default, PB.Platinum or PB.None | +| Properties | Type | Description | +| ---------------- | ------------ | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `name` | `string` | _(required)_ string Name of design | +| `cardStyle` | `string` | _(required)_ css class. mainly to set background and color | +| `bankLogo` | `Union Type` | _(required)_ Union Type. import DNB from ./card/utils/Types to use. Can be DNB.Colored('HexValue') | +| `visa` | `Union Type` | _(required)_ Union Type. import Visa from ./card/utils/Types to use. Can be Visa.Colored('HexValue') or Visa.Platinum | +| `mastercard` | `Union Type` | _(required)_ Union Type. import Mastercard from ./card/utils/Types to use. Can be Mastercard.Default or Mastercard.Dark | +| `bankAxept` | `Union Type` | _(required)_ Union Type. import BankAxept from ./card/utils/Types to use. Can be BankAxept.White, BankAxept.Black, BankAxept.Gold, BankAxept.Black20 or BankAxept.Gray | +| `saga` | `Union Type` | _(required)_ Union Type. import Saga from ./card/utils/Types to use. Can be Saga.Gold, Saga.Platinum or Saga.None | +| `privateBanking` | `Union Type` | _(required)_ Union Type. import PB from ./card/utils/Types to use. Can be PB.Default or PB.None | ## List of designs | Properties | Type | Description | | ------------------ | -------- | ---------------------- | | `defaultDesign` | `object` | Default | -| `white` | `object` | White | +| `pluss` | `object` | Pluss | +| `young` | `object` | Ung | | `myFirst` | `object` | My first | | `youth` | `object` | Youth | -| `silver` | `object` | Silver | | `gold` | `object` | Gold | | `saga` | `object` | Saga | | `sagaPlatinum` | `object` | Saga platinum | @@ -63,24 +63,22 @@ showTabs: true | ---------------- | | **DNB** | | `Colored` | -| `Metallic` | | **Saga** | | `Gold` | | `Platinum` | -| `VisaPlatinum` | | `None` | | **PB** | | `Default` | -| `Platinum` | | `None` | | **Mastercard** | | `Default` | -| `DefaultWhite` | -| `Metallic` | -| `BlackMetallic` | +| `Dark` | | **ProductType** | -| `BankAxept` | | `Saga` | +| `Pluss` | +| `Intro` | +| `Bedrift` | +| `Business` | | `PrivateBanking` | | `None` | | **CardType** | @@ -90,9 +88,12 @@ showTabs: true | **BankAxept** | | `White` | | `Black` | +| `Gold` | +| `Black20` | +| `Gray` | | **Visa** | | `Colored` | -| `Metallic` | +| `Platinum` | | **Status** | | `Expired` | | `Blocked` | diff --git a/packages/dnb-eufemia/src/extensions/payment-card/PaymentCard.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/PaymentCard.d.ts index 00830013a14..15c8c5deb41 100644 --- a/packages/dnb-eufemia/src/extensions/payment-card/PaymentCard.d.ts +++ b/packages/dnb-eufemia/src/extensions/payment-card/PaymentCard.d.ts @@ -7,23 +7,38 @@ export type PaymentCardVariant = 'normal' | 'compact'; export type PaymentCardDigits = string | number; export enum CardType { Visa, // eslint-disable-line - None, // eslint-disable-line - Left, // eslint-disable-line - Right // eslint-disable-line + Mastercard, // eslint-disable-line + None // eslint-disable-line } + export enum ProductType { - BankAxept, // eslint-disable-line Saga, // eslint-disable-line + Pluss, // eslint-disable-line + Intro, // eslint-disable-line + Business, // eslint-disable-line + Bedrift, // eslint-disable-line PrivateBanking, // eslint-disable-line None // eslint-disable-line } +export enum BankAxept { + White, // eslint-disable-line + Black, // eslint-disable-line + Gold, // eslint-disable-line + Black20, // eslint-disable-line + Gray // eslint-disable-line +} + +export enum BankAxeptType { + BankAxept, // eslint-disable-line + None // eslint-disable-line +} + export enum Designs { defaultDesign, // eslint-disable-line - white, // eslint-disable-line + young, // eslint-disable-line myFirst, // eslint-disable-line youth, // eslint-disable-line - silver, // eslint-disable-line pluss, // eslint-disable-line gold, // eslint-disable-line saga, // eslint-disable-line @@ -41,6 +56,7 @@ export interface PaymentCardRawData { cardDesign: Designs; cardType: CardType; productType: ProductType; + bankAxept: BankAxeptType; } export type PaymentCardChildren = | string diff --git a/packages/dnb-eufemia/src/extensions/payment-card/PaymentCard.js b/packages/dnb-eufemia/src/extensions/payment-card/PaymentCard.js index 5e360e75d2b..5cbde675742 100644 --- a/packages/dnb-eufemia/src/extensions/payment-card/PaymentCard.js +++ b/packages/dnb-eufemia/src/extensions/payment-card/PaymentCard.js @@ -23,12 +23,18 @@ import { } from '../../components/skeleton/SkeletonHelper' import P from '../../elements/P' -import { ProductType, CardType } from './utils/Types' +import { ProductType, CardType, BankAxeptType } from './utils/Types' import Designs, { defaultDesign } from './utils/CardDesigns' import cardProducts from './utils/cardProducts' -import { ProductLogo, TypeLogo, BankLogo, StatusIcon } from './icons' +import { + ProductLogo, + TypeLogo, + BankLogo, + StatusIcon, + BankAxeptLogo, +} from './icons' -export { Designs, ProductType, CardType } +export { Designs, ProductType, CardType, BankAxeptType } const cardDataPropTypes = PropTypes.shape({ productCode: PropTypes.string.isRequired, @@ -37,6 +43,7 @@ const cardDataPropTypes = PropTypes.shape({ cardDesign: PropTypes.object.isRequired, cardType: PropTypes.object.isRequired, productType: PropTypes.object.isRequired, + bankAxept: PropTypes.object.isRequired, }) const translationDefaultPropsProps = { @@ -189,6 +196,7 @@ const defaultCard = (productCode) => ({ cardDesign: defaultDesign, cardType: CardType.None, productType: ProductType.None, + bankAxept: BankAxeptType.None, }) StatusOverlay.propTypes = { @@ -254,7 +262,7 @@ function CardText({ cardNumber, translations, skeleton }) { >

{translations.text_card_number}

@@ -291,6 +299,13 @@ function NormalCard({ 'dnb-payment-card__card', `dnb-payment-card__${data.cardDesign.cardStyle}` )} + {...(data.cardDesign?.backgroundImage + ? { + style: { + backgroundImage: `url(${data.cardDesign.backgroundImage})`, + }, + } + : {})} >
@@ -299,6 +314,10 @@ function NormalCard({ productType={data.productType} cardDesign={data.cardDesign} /> +
{ displayName: 'Custom card', // Only showed in compact variant cardDesign: Designs.gold, cardType: CardType.Visa, - productType: ProductType.BankAxept, + productType: ProductType.None, + bankAxept: BankAxeptType.BankAxept, } const Comp = mount( diff --git a/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-a-basic-card.snap.png b/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-a-basic-card.snap.png index 6d5929672a7..d3ed6372c33 100644 Binary files a/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-a-basic-card.snap.png and b/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-a-basic-card.snap.png differ diff --git a/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-a-card-with-status.snap.png b/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-a-card-with-status.snap.png index 33d29b3084a..a955bb4de43 100644 Binary files a/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-a-card-with-status.snap.png and b/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-a-card-with-status.snap.png differ diff --git a/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-a-compact-card-variant.snap.png b/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-a-compact-card-variant.snap.png index 54bbea99c3e..8402df78f9e 100644 Binary files a/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-a-compact-card-variant.snap.png and b/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-a-compact-card-variant.snap.png differ diff --git a/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-all-cards.snap.png b/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-all-cards.snap.png index 8d370328b52..af6ad59e0ed 100644 Binary files a/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-all-cards.snap.png and b/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__image_snapshots__/paymentcard-have-to-match-all-cards.snap.png differ diff --git a/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__snapshots__/PaymentCard.test.tsx.snap b/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__snapshots__/PaymentCard.test.tsx.snap index d80e660114a..caaa1b015f6 100644 --- a/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__snapshots__/PaymentCard.test.tsx.snap +++ b/packages/dnb-eufemia/src/extensions/payment-card/__tests__/__snapshots__/PaymentCard.test.tsx.snap @@ -33,6 +33,9 @@ exports[`PaymentCard have to match snapshot 1`] = ` cardStatus="active" data={ { + "bankAxept": { + "is": [Function], + }, "cardDesign": { "bankAxept": { "is": [Function], @@ -108,14 +111,10 @@ exports[`PaymentCard have to match snapshot 1`] = ` + - +

Kortnummer

@@ -350,62 +375,63 @@ exports[`PaymentCard scss have to match snapshot 1`] = ` * Utilities */ .dnb-payment-card { + --color-dark-cyan: #003b47; --dnb-payment-bg-default: linear-gradient( - 184.55deg, - var(--color-sea-green) 6.31%, + 187.2deg, + #008484 6.31%, var(--color-sea-green) 82.66% ); --dnb-payment-bg-pluss: linear-gradient( 187.2deg, - #14555a 6.31%, - rgb(0 52 62 / 40%) 82.66% + var(--color-dark-cyan) 6.31%, + var(--color-ocean-green) 82.66% ), - #14555a; + var(--color-emerald-green); --dnb-payment-bg-white: linear-gradient( 184.55deg, var(--color-black-background) 4.63%, var(--color-white) 92.04% ); - --dnb-payment-bg-silver: linear-gradient( - 184.55deg, - var(--color-black-20) 4.63%, - var(--color-black-8) 82.87% - ); --dnb-payment-bg-gold: linear-gradient( 184.55deg, #bfa970 4.63%, #d3bd83 84.57% ); --dnb-payment-bg-saga: linear-gradient( - 184.55deg, - #241e23 6.31%, - #251d23 85.2% + 187.2deg, + #1c1c1c 6.31%, + #000 82.66% ); - --dnb-payment-bg-business-no-visa: linear-gradient( - 184.55deg, - #50c9de 6.31%, - var(--color-sky-blue) 82.66% + --dnb-payment-bg-private: linear-gradient( + 187.2deg, + #1c1c1c 6.31%, + #000 82.66% ); + --dnb-payment-bg-business-no-visa: linear-gradient( + 187.2deg, + var(--color-dark-cyan) 6.31%, + var(--color-ocean-green) 82.66% + ), + var(--color-emerald-green); --dnb-payment-bg-business-with-visa: linear-gradient( - 184.55deg, - #2cc48e 6.31%, - var(--color-summer-green) 82.66% - ); + 187.2deg, + var(--color-dark-cyan) 6.31%, + var(--color-ocean-green) 82.66% + ), + var(--color-emerald-green); margin: 0; } .dnb-payment-card__card { position: relative; width: 85.6mm; height: 53.98mm; - padding: 6mm; + padding: 4mm; border-radius: 3.48mm; border: 1px solid; border-color: rgba(255, 255, 255, 0.1) transparent rgba(0, 0, 0, 0.2) transparent; color: var(--color-white); box-shadow: var(--shadow-default); - background: var(--color-sea-green); transition: all 225ms cubic-bezier(0, 0, 0.2, 1) 0ms; - /* White, Youth, MyFirst */ } .dnb-payment-card__card--design-default { background: var(--dnb-payment-bg-default); @@ -415,12 +441,13 @@ exports[`PaymentCard scss have to match snapshot 1`] = ` background: var(--dnb-payment-bg-pluss); color: var(--color-white); } -.dnb-payment-card__card--design-white { - background: var(--dnb-payment-bg-white); +.dnb-payment-card__card--design-ung { color: var(--color-black-80); } -.dnb-payment-card__card--design-silver { - background: var(--dnb-payment-bg-silver); +.dnb-payment-card__card--design-youth { + color: var(--color-black-80); +} +.dnb-payment-card__card--design-my-first { color: var(--color-black-80); } .dnb-payment-card__card--design-gold { @@ -432,7 +459,7 @@ exports[`PaymentCard scss have to match snapshot 1`] = ` color: var(--color-white); } .dnb-payment-card__card--design-private { - background: var(--color-black-80); + background: var(--dnb-payment-bg-private); color: var(--color-white); } .dnb-payment-card__card--design-black { @@ -454,7 +481,7 @@ exports[`PaymentCard scss have to match snapshot 1`] = ` left: 0; width: 100%; height: 100%; - background-image: radial-gradient(farthest-corner at 80% 30%, rgba(247, 246, 230, 0.1215686275) 0%, rgba(6, 6, 6, 0) 60%, rgba(6, 6, 6, 0) 99%); + background: radial-gradient(52.39% 52.39% at 50% 50%, rgba(247, 246, 230, 0.1215686275) 0%, rgba(6, 6, 6, 0) 100%); border-radius: inherit; } .dnb-payment-card__card__content { @@ -472,18 +499,18 @@ exports[`PaymentCard scss have to match snapshot 1`] = ` margin-bottom: 0 !important; } .dnb-payment-card__card__holder { + font-weight: var(--font-weight-medium); text-transform: uppercase; text-align: left; - opacity: 0.5; } .dnb-payment-card__card__holder.dnb-p { font-size: 0.625rem; } .dnb-payment-card__card__numbers { - font-size: var(--font-size-medium); + font-size: 1.5rem !important; + font-weight: var(--font-weight-medium); } .dnb-payment-card__card__credit-type { - height: 51px; position: absolute; bottom: 0; right: 0; @@ -494,6 +521,12 @@ exports[`PaymentCard scss have to match snapshot 1`] = ` left: 0; } .dnb-payment-card__card__product-type { + height: 38px; + position: absolute; + top: 0; + left: 70px; +} +.dnb-payment-card__card__bank-axept { height: 45px; position: absolute; top: 0; @@ -556,7 +589,8 @@ exports[`PaymentCard scss have to match snapshot 1`] = ` font-size: var(--font-size-basis); } .dnb-payment-card--compact .dnb-payment-card__card__credit-type { - top: 0; + top: 8px; + right: 4px; bottom: auto; } .dnb-payment-card--compact .dnb-payment-card__blocking__center { diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/BankAxept.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/BankAxept.d.ts deleted file mode 100644 index 076e176e882..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/BankAxept.d.ts +++ /dev/null @@ -1,12 +0,0 @@ -import * as React from 'react'; -export interface BankAxeptSVGProps extends React.HTMLProps { - /** - * function fill() { [native code] } - */ - fill?: string; - width?: string; - height?: string; - viewBox?: string; -} -declare const BankAxeptSVG: React.FC; -export default BankAxeptSVG; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/BankAxept.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/BankAxept.js deleted file mode 100644 index 5bcebf5609d..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/BankAxept.js +++ /dev/null @@ -1,28 +0,0 @@ -import React from 'react' -import PropTypes from 'prop-types' - -const BankAxeptSVG = (props) => ( - - BankAxept - - -) -BankAxeptSVG.propTypes = { - fill: PropTypes.string, - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string -} -BankAxeptSVG.defaultProps = { - fill: '#fff', - width: '72', - height: '35', - viewBox: '0 0 72 35' -} - -export default BankAxeptSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/BankAxept.tsx b/packages/dnb-eufemia/src/extensions/payment-card/icons/BankAxept.tsx new file mode 100644 index 00000000000..124eb95355d --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/BankAxept.tsx @@ -0,0 +1,20 @@ +import React from 'react' + +const BankAxeptSVG = (props: React.SVGProps) => ( + + BankAxept + + +) + +export default BankAxeptSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/Bedrift.tsx b/packages/dnb-eufemia/src/extensions/payment-card/icons/Bedrift.tsx new file mode 100644 index 00000000000..c4090604ffe --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/Bedrift.tsx @@ -0,0 +1,20 @@ +import React from 'react' + +const Bedrift = (props: React.SVGProps) => ( + + Bedrift + + +) + +export default Bedrift diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/Business.tsx b/packages/dnb-eufemia/src/extensions/payment-card/icons/Business.tsx new file mode 100644 index 00000000000..c8c7ca177a0 --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/Business.tsx @@ -0,0 +1,20 @@ +import React from 'react' + +const Business = (props: React.SVGProps) => ( + + Business + + +) + +export default Business diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/Clock.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/Clock.d.ts deleted file mode 100644 index e4ba7086241..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/Clock.d.ts +++ /dev/null @@ -1,9 +0,0 @@ -import * as React from 'react'; -export interface ClockSVGProps extends React.HTMLProps { - stroke?: string; - width?: string; - height?: string; - viewBox?: string; -} -declare const ClockSVG: React.FC; -export default ClockSVG; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/Clock.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/Clock.js deleted file mode 100644 index d1df41ea154..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/Clock.js +++ /dev/null @@ -1,28 +0,0 @@ -import React from 'react' -import PropTypes from 'prop-types' - -const ClockSVG = (props) => ( - - - -) -ClockSVG.propTypes = { - stroke: PropTypes.string, - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string -} -ClockSVG.defaultProps = { - stroke: '#FBF6EC', - width: '24', - height: '24', - viewBox: '0 0 24 24' -} - -export default ClockSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/Clock.tsx b/packages/dnb-eufemia/src/extensions/payment-card/icons/Clock.tsx new file mode 100644 index 00000000000..de4cfd73812 --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/Clock.tsx @@ -0,0 +1,22 @@ +import React from 'react' + +const ClockSVG = (props: React.SVGProps) => ( + + + +) + +export default ClockSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/DNB.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/DNB.d.ts deleted file mode 100644 index 7c5c2876b13..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/DNB.d.ts +++ /dev/null @@ -1,12 +0,0 @@ -import * as React from 'react'; -export interface DNBLogoSVGProps extends React.HTMLProps { - /** - * function fill() { [native code] } - */ - fill?: string; - width?: string; - height?: string; - viewBox?: string; -} -declare const DNBLogoSVG: React.FC; -export default DNBLogoSVG; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/DNB.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/DNB.tsx similarity index 84% rename from packages/dnb-eufemia/src/extensions/payment-card/icons/DNB.js rename to packages/dnb-eufemia/src/extensions/payment-card/icons/DNB.tsx index 6560d918168..08102001d8b 100644 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/DNB.js +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/DNB.tsx @@ -1,8 +1,14 @@ import React from 'react' -import PropTypes from 'prop-types' -const DNBLogoSVG = (props) => ( - +const DNBLogoSVG = (props: React.SVGProps) => ( + DNB logo ( /> ) -DNBLogoSVG.propTypes = { - fill: PropTypes.string, - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string -} -DNBLogoSVG.defaultProps = { - fill: '#14555A', - width: '56', - height: '38', - viewBox: '0 0 56 38' -} export default DNBLogoSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/DNBMetallic.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/DNBMetallic.d.ts deleted file mode 100644 index f84c9c73dc6..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/DNBMetallic.d.ts +++ /dev/null @@ -1,13 +0,0 @@ -import * as React from 'react'; -export interface DNBMetallicLogoSVGProps - extends React.HTMLProps { - /** - * function fill() { [native code] } - */ - fill?: string; - width?: string; - height?: string; - viewBox?: string; -} -declare const DNBMetallicLogoSVG: React.FC; -export default DNBMetallicLogoSVG; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/DNBMetallic.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/DNBMetallic.js deleted file mode 100644 index 727522e4d5e..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/DNBMetallic.js +++ /dev/null @@ -1,47 +0,0 @@ -import React from 'react' -import PropTypes from 'prop-types' - -const DNBMetallicLogoSVG = (props) => ( - - DNB logo - - - - - - - - - - - - - - -) -DNBMetallicLogoSVG.propTypes = { - fill: PropTypes.string, - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string, -} -DNBMetallicLogoSVG.defaultProps = { - fill: 'none', - width: '56', - height: '38', - viewBox: '0 0 56 38', -} - -export default DNBMetallicLogoSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/Intro.tsx b/packages/dnb-eufemia/src/extensions/payment-card/icons/Intro.tsx new file mode 100644 index 00000000000..bd805b11f54 --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/Intro.tsx @@ -0,0 +1,20 @@ +import React from 'react' + +const Intro = (props: React.SVGProps) => ( + + Intro + + +) + +export default Intro diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardDark.tsx b/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardDark.tsx new file mode 100644 index 00000000000..e0200988324 --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardDark.tsx @@ -0,0 +1,25 @@ +import React from 'react' + +const MastercardDarkSVG = (props: React.SVGProps) => ( + + Mastercard + + + + +) + +export default MastercardDarkSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardDefault.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardDefault.d.ts deleted file mode 100644 index 8d36eab5f36..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardDefault.d.ts +++ /dev/null @@ -1,9 +0,0 @@ -import * as React from 'react'; -export interface MastercardSVGProps extends React.HTMLProps { - textFill?: string; - width?: string; - height?: string; - viewBox?: string; -} -declare const MastercardSVG: React.FC; -export default MastercardSVG; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardDefault.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardDefault.js deleted file mode 100644 index cfdea6dfc5c..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardDefault.js +++ /dev/null @@ -1,46 +0,0 @@ -import React from 'react' -import PropTypes from 'prop-types' - -const MastercardSVG = ({ textFill, ...props }) => ( - - Mastercard - - - - - - -) -MastercardSVG.propTypes = { - textFill: PropTypes.string, - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string -} -MastercardSVG.defaultProps = { - textFill: '#333333', - width: '80', - height: '54', - viewBox: '0 0 80 54' -} - -export default MastercardSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardDefault.tsx b/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardDefault.tsx new file mode 100644 index 00000000000..214da1ac6ee --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardDefault.tsx @@ -0,0 +1,25 @@ +import React from 'react' + +const MastercardSVG = (props: React.SVGProps) => ( + + Mastercard + + + + +) + +export default MastercardSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardMetallic.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardMetallic.d.ts deleted file mode 100644 index 2a9b193e3c6..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardMetallic.d.ts +++ /dev/null @@ -1,8 +0,0 @@ -import * as React from 'react'; -export interface MastercardSVGProps extends React.HTMLProps { - width?: string; - height?: string; - viewBox?: string; -} -declare const MastercardSVG: React.FC; -export default MastercardSVG; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardMetallic.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardMetallic.js deleted file mode 100644 index f1c718c6309..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardMetallic.js +++ /dev/null @@ -1,81 +0,0 @@ -import React from 'react' -import PropTypes from 'prop-types' - -const MastercardSVG = (props) => ( - - Mastercard - - - - - - - - - - - - - - - - - - - - - - - - -) -MastercardSVG.propTypes = { - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string -} -MastercardSVG.defaultProps = { - width: '80', - height: '54', - viewBox: '0 0 80 54' -} -export default MastercardSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardMetallicBlack.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardMetallicBlack.d.ts deleted file mode 100644 index d152aabd7a2..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardMetallicBlack.d.ts +++ /dev/null @@ -1,8 +0,0 @@ -import * as React from 'react'; -export interface SVGProps extends React.HTMLProps { - width?: string; - height?: string; - viewBox?: string; -} -declare const SVG: React.FC; -export default SVG; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardMetallicBlack.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardMetallicBlack.js deleted file mode 100644 index 4eb698d8fe5..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/MastercardMetallicBlack.js +++ /dev/null @@ -1,244 +0,0 @@ -import React from 'react' -import PropTypes from 'prop-types' - -const SVG = (props) => ( - - Mastercard - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -) -SVG.propTypes = { - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string -} -SVG.defaultProps = { - width: '74', - height: '49', - viewBox: '0 0 74 49' -} - -export default SVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/PB.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/PB.d.ts deleted file mode 100644 index b3720718a55..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/PB.d.ts +++ /dev/null @@ -1,12 +0,0 @@ -import * as React from 'react'; -export interface PBSVGProps extends React.HTMLProps { - /** - * function fill() { [native code] } - */ - fill?: string; - width?: string; - height?: string; - viewBox?: string; -} -declare const PBSVG: React.FC; -export default PBSVG; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/PB.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/PB.js deleted file mode 100644 index 3bf9887cc1d..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/PB.js +++ /dev/null @@ -1,28 +0,0 @@ -import React from 'react' -import PropTypes from 'prop-types' - -const PBSVG = (props) => ( - - PB - - -) -PBSVG.propTypes = { - fill: PropTypes.string, - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string -} -PBSVG.defaultProps = { - fill: '#B2B4B3', - width: '75', - height: '35', - viewBox: '0 0 75 35' -} - -export default PBSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/PB.tsx b/packages/dnb-eufemia/src/extensions/payment-card/icons/PB.tsx new file mode 100644 index 00000000000..4924bb39bf6 --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/PB.tsx @@ -0,0 +1,20 @@ +import React from 'react' + +const PBSVG = (props: React.SVGProps) => ( + + PrivateBanking + + +) + +export default PBSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/PBPlatinum.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/PBPlatinum.d.ts deleted file mode 100644 index 5cec117d7fb..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/PBPlatinum.d.ts +++ /dev/null @@ -1,8 +0,0 @@ -import * as React from 'react'; -export interface PBPlatinumSVGProps extends React.HTMLProps { - width?: string; - height?: string; - viewBox?: string; -} -declare const PBPlatinumSVG: React.FC; -export default PBPlatinumSVG; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/PBPlatinum.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/PBPlatinum.js deleted file mode 100644 index 0801154ff2d..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/PBPlatinum.js +++ /dev/null @@ -1,74 +0,0 @@ -import React from 'react' -import PropTypes from 'prop-types' - -const PBPlatinumSVG = (props) => ( - - PBPlatinum - - - - - - - - - - - - - - -) -PBPlatinumSVG.propTypes = { - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string -} -PBPlatinumSVG.defaultProps = { - width: '72', - height: '35', - viewBox: '0 0 75 35' -} - -export default PBPlatinumSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/Padlock.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/Padlock.d.ts deleted file mode 100644 index 03f2a691e2c..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/Padlock.d.ts +++ /dev/null @@ -1,9 +0,0 @@ -import * as React from 'react'; -export interface SVGProps extends React.HTMLProps { - stroke?: string; - width?: string; - height?: string; - viewBox?: string; -} -declare const SVG: React.FC; -export default SVG; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/Padlock.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/Padlock.tsx similarity index 57% rename from packages/dnb-eufemia/src/extensions/payment-card/icons/Padlock.js rename to packages/dnb-eufemia/src/extensions/payment-card/icons/Padlock.tsx index 61469fc3692..1fc07609ae7 100644 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/Padlock.js +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/Padlock.tsx @@ -1,28 +1,23 @@ import React from 'react' -import PropTypes from 'prop-types' -const SVG = (props) => ( - +const Padlock = (props: React.SVGProps) => ( + Hengelås ) -SVG.propTypes = { - stroke: PropTypes.string, - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string -} -SVG.defaultProps = { - stroke: '#FBF6EC', - width: '24', - height: '24', - viewBox: '0 0 24 24' -} -export default SVG + +export default Padlock diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/Pluss.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/Pluss.d.ts deleted file mode 100644 index 9e7590cc05f..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/Pluss.d.ts +++ /dev/null @@ -1,12 +0,0 @@ -import * as React from 'react'; -export interface PlussProps extends React.HTMLProps { - /** - * function fill() { [native code] } - */ - fill?: string; - width?: string; - height?: string; - viewBox?: string; -} -declare const Pluss: React.FC; -export default Pluss; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/Pluss.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/Pluss.js deleted file mode 100644 index 76b1a0d1bb2..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/Pluss.js +++ /dev/null @@ -1,41 +0,0 @@ -import React from 'react' -import PropTypes from 'prop-types' - -const Pluss = (props) => ( - - - - - - - -) -Pluss.propTypes = { - fill: PropTypes.string, - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string -} -Pluss.defaultProps = { - fill: '#A5E1D2', - width: '75', - height: '35', - viewBox: '0 0 75 35' -} - -export default Pluss diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/Pluss.tsx b/packages/dnb-eufemia/src/extensions/payment-card/icons/Pluss.tsx new file mode 100644 index 00000000000..8d3f40e6317 --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/Pluss.tsx @@ -0,0 +1,20 @@ +import React from 'react' + +const Pluss = (props: React.SVGProps) => ( + + Pluss + + +) + +export default Pluss diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaGold.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaGold.d.ts deleted file mode 100644 index f6281dca5f3..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaGold.d.ts +++ /dev/null @@ -1,8 +0,0 @@ -import * as React from 'react'; -export interface SagaGoldSVGProps extends React.HTMLProps { - width?: string; - height?: string; - viewBox?: string; -} -declare const SagaGoldSVG: React.FC; -export default SagaGoldSVG; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaGold.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaGold.js deleted file mode 100644 index b4cb08aabef..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaGold.js +++ /dev/null @@ -1,32 +0,0 @@ -import React from 'react' -import PropTypes from 'prop-types' - -const SagaGoldSVG = (props) => ( - - SagaGold - - - -) -SagaGoldSVG.propTypes = { - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string -} -SagaGoldSVG.defaultProps = { - width: '75', - height: '35', - viewBox: '0 0 75 35' -} - -export default SagaGoldSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaGold.tsx b/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaGold.tsx new file mode 100644 index 00000000000..309e790e6f2 --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaGold.tsx @@ -0,0 +1,20 @@ +import React from 'react' + +const SagaGoldSVG = (props: React.SVGProps) => ( + + Saga Gold + + +) + +export default SagaGoldSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaPlatinum.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaPlatinum.d.ts deleted file mode 100644 index 60c8b2ca6dd..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaPlatinum.d.ts +++ /dev/null @@ -1,9 +0,0 @@ -import * as React from 'react'; -export interface SagaPlatinumSVGProps - extends React.HTMLProps { - width?: string; - height?: string; - viewBox?: string; -} -declare const SagaPlatinumSVG: React.FC; -export default SagaPlatinumSVG; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaPlatinum.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaPlatinum.js deleted file mode 100644 index cf418a18efb..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaPlatinum.js +++ /dev/null @@ -1,58 +0,0 @@ -import React from 'react' -import PropTypes from 'prop-types' - -const SagaPlatinumSVG = (props) => ( - - SagaPlatinum - - - - - - - - - - -) -SagaPlatinumSVG.propTypes = { - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string -} -SagaPlatinumSVG.defaultProps = { - width: '73', - height: '35', - viewBox: '0 0 75 35' -} - -export default SagaPlatinumSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaPlatinum.tsx b/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaPlatinum.tsx new file mode 100644 index 00000000000..5690c345d44 --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaPlatinum.tsx @@ -0,0 +1,20 @@ +import React from 'react' + +const SagaPlatinumSVG = (props: React.SVGProps) => ( + + Saga Platinum + + +) + +export default SagaPlatinumSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaVisaPlatinum.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaVisaPlatinum.d.ts deleted file mode 100644 index 6ed64ee1110..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaVisaPlatinum.d.ts +++ /dev/null @@ -1,9 +0,0 @@ -import * as React from 'react'; -export interface SagaVisaPlatinumSVGProps - extends React.HTMLProps { - width?: string; - height?: string; - viewBox?: string; -} -declare const SagaVisaPlatinumSVG: React.FC; -export default SagaVisaPlatinumSVG; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaVisaPlatinum.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaVisaPlatinum.js deleted file mode 100644 index a9ceb32a669..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/SagaVisaPlatinum.js +++ /dev/null @@ -1,73 +0,0 @@ -import React from 'react' -import PropTypes from 'prop-types' - -const SagaVisaPlatinumSVG = (props) => ( - - SagaVisaPlatinum - - - - - - - - - - - - - - -) -SagaVisaPlatinumSVG.propTypes = { - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string -} -SagaVisaPlatinumSVG.defaultProps = { - width: '75', - height: '35', - viewBox: '0 0 75 35' -} -export default SagaVisaPlatinumSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaDefault.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaDefault.d.ts deleted file mode 100644 index 987cb1c1e2a..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaDefault.d.ts +++ /dev/null @@ -1,12 +0,0 @@ -import * as React from 'react'; -export interface VisaSVGProps extends React.HTMLProps { - /** - * function fill() { [native code] } - */ - fill?: string; - width?: string; - height?: string; - viewBox?: string; -} -declare const VisaSVG: React.FC; -export default VisaSVG; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaDefault.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaDefault.js deleted file mode 100644 index 646a2130a0f..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaDefault.js +++ /dev/null @@ -1,30 +0,0 @@ -import React from 'react' -import PropTypes from 'prop-types' - -const VisaSVG = (props) => ( - - Visa - - - -) -VisaSVG.propTypes = { - fill: PropTypes.string, - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string -} -VisaSVG.defaultProps = { - fill: '#ffffff', - width: '80', - height: '54', - viewBox: '0 0 80 54' -} - -export default VisaSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaDefault.tsx b/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaDefault.tsx new file mode 100644 index 00000000000..7d249731ebc --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaDefault.tsx @@ -0,0 +1,20 @@ +import React from 'react' + +const VisaDefaultSVG = (props: React.SVGProps) => ( + + Visa + + +) + +export default VisaDefaultSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaMetallic.d.ts b/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaMetallic.d.ts deleted file mode 100644 index f02ebe33d2a..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaMetallic.d.ts +++ /dev/null @@ -1,9 +0,0 @@ -import * as React from 'react'; -export interface VisaMetallicSVGProps - extends React.HTMLProps { - width?: string; - height?: string; - viewBox?: string; -} -declare const VisaMetallicSVG: React.FC; -export default VisaMetallicSVG; diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaMetallic.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaMetallic.js deleted file mode 100644 index 1970960bf40..00000000000 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaMetallic.js +++ /dev/null @@ -1,98 +0,0 @@ -import React from 'react' -import PropTypes from 'prop-types' - -const VisaMetallicSVG = (props) => ( - - Visa Metallic - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -) -VisaMetallicSVG.propTypes = { - width: PropTypes.string, - height: PropTypes.string, - viewBox: PropTypes.string, -} -VisaMetallicSVG.defaultProps = { - width: '80', - height: '54', - viewBox: '0 0 80 54', -} - -export default VisaMetallicSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaPlatinum.tsx b/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaPlatinum.tsx new file mode 100644 index 00000000000..9b9678f8a56 --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/VisaPlatinum.tsx @@ -0,0 +1,20 @@ +import React from 'react' + +const VisaPlatinumSVG = (props: React.SVGProps) => ( + + Visa Platinum + + +) + +export default VisaPlatinumSVG diff --git a/packages/dnb-eufemia/src/extensions/payment-card/icons/index.js b/packages/dnb-eufemia/src/extensions/payment-card/icons/index.js index 3c7783f5390..82237a4af86 100644 --- a/packages/dnb-eufemia/src/extensions/payment-card/icons/index.js +++ b/packages/dnb-eufemia/src/extensions/payment-card/icons/index.js @@ -2,20 +2,19 @@ import React from 'react' import BankAxept from './BankAxept' import DNB from './DNB' -import DNBMetallic from './DNBMetallic' import Expired from './Clock' import Blocked from './Padlock' import MastercardDefault from './MastercardDefault' -import MastercardMetallic from './MastercardMetallic' -import MastercardMetallicBlack from './MastercardMetallicBlack' +import MastercardDark from './MastercardDark' import Pluss from './Pluss' +import Intro from './Intro' +import Business from './Business' +import Bedrift from './Bedrift' import PB from './PB' -import PBPlatinum from './PBPlatinum' import SagaGold from './SagaGold' import SagaPlatinum from './SagaPlatinum' -import SagaVisaPlatinum from './SagaVisaPlatinum' import VisaDefault from './VisaDefault' -import VisaMetallic from './VisaMetallic' +import VisaPlatinum from './VisaPlatinum' const BankLogo = ({ logoType, height }) => logoType.cata({ @@ -26,40 +25,45 @@ const BankLogo = ({ logoType, height }) => className="dnb-payment-card__card__bank-logo" /> ), - Metallic: () => ( - - ), }) const ProductLogo = ({ productType, cardDesign }) => { const id = 'dnb-payment-card__card__product-type' return productType.cata({ - BankAxept: () => - cardDesign.bankAxept.cata({ - White: () => , - Black: () => , - }), Saga: () => cardDesign.saga.cata({ Gold: () => , Platinum: () => , - VisaPlatinum: () => , None: () => null, }), - Pluss: () => , + Pluss: () => , + Intro: () => , + Business: () => , + Bedrift: () => , PrivateBanking: () => cardDesign.privateBanking.cata({ Default: () => , - Platinum: () => , None: () => null, }), None: () => null, }) } +const BankAxeptLogo = ({ bankAxept, cardDesign }) => { + const id = 'dnb-payment-card__card__bank-axept' + return bankAxept.cata({ + BankAxept: () => + cardDesign.bankAxept.cata({ + White: () => , + Black20: () => , + Gray: () => , + Black: () => , + Gold: () => , + }), + None: () => null, + }) +} + const StatusIcon = ({ status }) => { switch (status) { case 'expired': @@ -80,19 +84,15 @@ const TypeLogo = ({ cardType, cardDesign }) => { Visa: () => cardDesign.visa.cata({ Colored: (color) => , - Metallic: () => , + Platinum: () => , }), Mastercard: () => cardDesign.mastercard.cata({ Default: () => , - DefaultWhite: () => ( - - ), - Metallic: () => , - BlackMetallic: () => , + Dark: () => , }), None: () => null, }) } -export { BankLogo, ProductLogo, StatusIcon, TypeLogo } +export { BankLogo, ProductLogo, StatusIcon, TypeLogo, BankAxeptLogo } diff --git a/packages/dnb-eufemia/src/extensions/payment-card/stories/PaymentCard.stories.tsx b/packages/dnb-eufemia/src/extensions/payment-card/stories/PaymentCard.stories.tsx index c7a4e614f93..4ae37d2c06f 100644 --- a/packages/dnb-eufemia/src/extensions/payment-card/stories/PaymentCard.stories.tsx +++ b/packages/dnb-eufemia/src/extensions/payment-card/stories/PaymentCard.stories.tsx @@ -12,6 +12,11 @@ import { H3 } from '../../..' import '../style' import '../style/themes/ui' import PaymentCard, { getCardData } from '../../../extensions/payment-card' +import cardData from '../utils/cardProducts' +import { Designs } from '../PaymentCard' +import { CardType } from '../PaymentCard' +import { ProductType } from '../PaymentCard' +import { BankAxeptType } from '../PaymentCard' export default { title: 'Eufemia/Extensions/PaymentCard', @@ -21,6 +26,16 @@ const CustomWrapper = styled(Wrapper)` /* empty */ ` +const customData = { + productCode: 'UNDEFINED', + productName: 'DNB Custom Card', + displayName: 'Custom card', // Only showed in compact variant + cardDesign: Designs.gold, + cardType: CardType.Visa, + productType: ProductType.Business, + bankAxept: BankAxeptType.BankAxept, +} + export const PaymentCards = () => ( @@ -40,35 +55,43 @@ export const PaymentCards = () => ( /> - {demoCards.map((product_code) => { + + + + {cards.map((product_code) => { const cardData = getCardData(product_code) return (
-

{cardData.cardDesign.name}

- +

+ {cardData.cardDesign.name}({product_code}) +

+
+ + {/* */} +
) })} ) - -const demoCards = [ - 'VE1', - 'VL2', - 'VX1', - 'VX3', - 'VL1', - '096', - 'VG1', - 'VP2', - 'VP3', - 'P101', - 'BK1', - 'VB2', -] +const cards = cardData.map((card) => card.productCode) diff --git a/packages/dnb-eufemia/src/extensions/payment-card/style/dnb-payment-card.scss b/packages/dnb-eufemia/src/extensions/payment-card/style/dnb-payment-card.scss index b67bd7c3333..ddbb37e2aa4 100644 --- a/packages/dnb-eufemia/src/extensions/payment-card/style/dnb-payment-card.scss +++ b/packages/dnb-eufemia/src/extensions/payment-card/style/dnb-payment-card.scss @@ -6,47 +6,50 @@ @import '../../../style/core/utilities.scss'; .dnb-payment-card { + --color-dark-cyan: #003b47; --dnb-payment-bg-default: linear-gradient( - 184.55deg, - var(--color-sea-green) 6.31%, + 187.2deg, + #008484 6.31%, var(--color-sea-green) 82.66% ); --dnb-payment-bg-pluss: linear-gradient( 187.2deg, - #14555a 6.31%, - rgb(0 52 62 / 40%) 82.66% + var(--color-dark-cyan) 6.31%, + var(--color-ocean-green) 82.66% ), - #14555a; + var(--color-emerald-green); --dnb-payment-bg-white: linear-gradient( 184.55deg, var(--color-black-background) 4.63%, var(--color-white) 92.04% ); - --dnb-payment-bg-silver: linear-gradient( - 184.55deg, - var(--color-black-20) 4.63%, - var(--color-black-8) 82.87% - ); --dnb-payment-bg-gold: linear-gradient( 184.55deg, #bfa970 4.63%, #d3bd83 84.57% ); --dnb-payment-bg-saga: linear-gradient( - 184.55deg, - #241e23 6.31%, - #251d23 85.2% + 187.2deg, + #1c1c1c 6.31%, + #000 82.66% ); - --dnb-payment-bg-business-no-visa: linear-gradient( - 184.55deg, - #50c9de 6.31%, - var(--color-sky-blue) 82.66% + --dnb-payment-bg-private: linear-gradient( + 187.2deg, + #1c1c1c 6.31%, + #000 82.66% ); + --dnb-payment-bg-business-no-visa: linear-gradient( + 187.2deg, + var(--color-dark-cyan) 6.31%, + var(--color-ocean-green) 82.66% + ), + var(--color-emerald-green); --dnb-payment-bg-business-with-visa: linear-gradient( - 184.55deg, - #2cc48e 6.31%, - var(--color-summer-green) 82.66% - ); + 187.2deg, + var(--color-dark-cyan) 6.31%, + var(--color-ocean-green) 82.66% + ), + var(--color-emerald-green); margin: 0; @@ -54,7 +57,7 @@ position: relative; width: 85.6mm; height: 53.98mm; - padding: 6mm; + padding: 4mm; border-radius: 3.48mm; @@ -64,7 +67,6 @@ color: var(--color-white); box-shadow: var(--shadow-default); - background: var(--color-sea-green); transition: all 225ms cubic-bezier(0, 0, 0.2, 1) 0ms; @@ -78,14 +80,15 @@ color: var(--color-white); } - /* White, Youth, MyFirst */ - &--design-white { - background: var(--dnb-payment-bg-white); + &--design-ung { + color: var(--color-black-80); + } + + &--design-youth { color: var(--color-black-80); } - &--design-silver { - background: var(--dnb-payment-bg-silver); + &--design-my-first { color: var(--color-black-80); } @@ -100,7 +103,7 @@ } &--design-private { - background: var(--color-black-80); + background: var(--dnb-payment-bg-private); color: var(--color-white); } @@ -128,11 +131,10 @@ width: 100%; height: 100%; - background-image: radial-gradient( - farthest-corner at 80% 30%, + background: radial-gradient( + 52.39% 52.39% at 50% 50%, #f7f6e61f 0%, - #06060600 60%, - #06060600 99% + #06060600 100% ); border-radius: inherit; } @@ -156,9 +158,10 @@ } &__holder { + font-weight: var(--font-weight-medium); text-transform: uppercase; text-align: left; - opacity: 0.5; + // opacity: 0.5; &.dnb-p { font-size: 0.625rem; @@ -166,11 +169,11 @@ } &__numbers { - font-size: var(--font-size-medium); + font-size: 1.5rem !important; + font-weight: var(--font-weight-medium); } &__credit-type { - height: 51px; position: absolute; bottom: 0; right: 0; @@ -183,6 +186,13 @@ } &__product-type { + height: 38px; + position: absolute; + top: 0; + left: 70px; + } + + &__bank-axept { height: 45px; position: absolute; top: 0; @@ -231,13 +241,6 @@ opacity: 1; } - // Not in use yet - // &--small { - // width: calc(85.6mm * 0.75); - // height: calc(53.98mm * 0.75); - // border-radius: calc(3.48mm * 0.75); - // } - &--compact &__card { padding: 0; height: 32.8mm; @@ -273,7 +276,8 @@ } &__credit-type { - top: 0; + top: 8px; + right: 4px; bottom: auto; } } diff --git a/packages/dnb-eufemia/src/extensions/payment-card/utils/CardDesigns.js b/packages/dnb-eufemia/src/extensions/payment-card/utils/CardDesigns.js index a75c9d548ea..0abefea4e82 100644 --- a/packages/dnb-eufemia/src/extensions/payment-card/utils/CardDesigns.js +++ b/packages/dnb-eufemia/src/extensions/payment-card/utils/CardDesigns.js @@ -1,12 +1,13 @@ import properties from '../../../style/themes/theme-ui/properties' import { DNB, Saga, PB, Mastercard, BankAxept, Visa } from './Types' +import { myFirstImg, youthImg, ungImg } from './backgrounds' const defaultDesign = { name: 'Default', cardStyle: 'card--design-default', bankLogo: DNB.Colored(properties['--color-white']), visa: Visa.Colored(properties['--color-white']), - mastercard: Mastercard.DefaultWhite, + mastercard: Mastercard.Default, bankAxept: BankAxept.White, saga: Saga.None, privateBanking: PB.None, @@ -15,56 +16,48 @@ const defaultDesign = { const pluss = { name: 'Pluss', cardStyle: 'card--design-pluss', - bankLogo: DNB.Colored(properties['--color-mint-green']), + bankLogo: DNB.Colored(properties['--color-white']), visa: Visa.Colored(properties['--color-white']), - mastercard: Mastercard.DefaultWhite, + mastercard: Mastercard.Default, bankAxept: BankAxept.White, saga: Saga.None, privateBanking: PB.None, } -const white = { - name: 'White', - cardStyle: 'card--design-white', - bankLogo: DNB.Colored(properties['--color-black-55']), - visa: Visa.Colored(properties['--color-black-55']), +const young = { + name: 'Ung', + cardStyle: 'card--design-ung', + bankLogo: DNB.Colored(properties['--color-sea-green']), + visa: Visa.Colored(properties['--color-black-80']), mastercard: Mastercard.Default, bankAxept: BankAxept.Black, saga: Saga.None, privateBanking: PB.None, + backgroundImage: ungImg, } const myFirst = { name: 'My first', - cardStyle: 'card--design-white', - bankLogo: DNB.Colored(properties['--color-emerald-green']), - visa: Visa.Colored(properties['--color-black-55']), + cardStyle: 'card--design-my-first', + bankLogo: DNB.Colored(properties['--color-ocean-green']), + visa: Visa.Colored(properties['--color-black-80']), mastercard: Mastercard.Default, bankAxept: BankAxept.Black, saga: Saga.None, privateBanking: PB.None, + backgroundImage: myFirstImg, } const youth = { name: 'Youth', - cardStyle: 'card--design-white', - bankLogo: DNB.Colored(properties['--color-summer-green']), - visa: Visa.Colored(properties['--color-black-55']), - mastercard: Mastercard.Default, - bankAxept: BankAxept.Black, - saga: Saga.None, - privateBanking: PB.None, -} - -const silver = { - name: 'Silver', - cardStyle: 'card--design-silver', - bankLogo: DNB.Colored(properties['--color-black-55']), - visa: Visa.Colored(properties['--color-black-55']), + cardStyle: 'card--design-youth', + bankLogo: DNB.Colored(properties['--color-sea-green']), + visa: Visa.Colored(properties['--color-black-80']), mastercard: Mastercard.Default, bankAxept: BankAxept.Black, saga: Saga.None, privateBanking: PB.None, + backgroundImage: youthImg, } const gold = { @@ -72,7 +65,7 @@ const gold = { cardStyle: 'card--design-gold', bankLogo: DNB.Colored(properties['--color-white']), visa: Visa.Colored(properties['--color-white']), - mastercard: Mastercard.DefaultWhite, + mastercard: Mastercard.Default, bankAxept: BankAxept.White, saga: Saga.None, privateBanking: PB.None, @@ -81,10 +74,10 @@ const gold = { const saga = { name: 'Saga', cardStyle: 'card--design-saga', - bankLogo: DNB.Colored('#CFAD88'), - visa: Visa.Colored('#CFAD8899'), - mastercard: Mastercard.DefaultWhite, - bankAxept: BankAxept.White, + bankLogo: DNB.Colored('#BFA970'), + visa: Visa.Colored('#BFA970'), + mastercard: Mastercard.Default, + bankAxept: BankAxept.Gold, saga: Saga.Gold, privateBanking: PB.None, } @@ -92,10 +85,10 @@ const saga = { const sagaPlatinum = { name: 'Saga platinum', cardStyle: 'card--design-saga', - bankLogo: DNB.Colored('#8C9091'), - visa: Visa.Colored('#8C909199'), - mastercard: Mastercard.DefaultWhite, - bankAxept: BankAxept.White, + bankLogo: DNB.Colored('#b2b4b3'), + visa: Visa.Colored('#cccccc'), + mastercard: Mastercard.Dark, + bankAxept: BankAxept.Black20, saga: Saga.Platinum, privateBanking: PB.None, } @@ -103,10 +96,10 @@ const sagaPlatinum = { const privateBanking = { name: 'Private Banking', cardStyle: 'card--design-private', - bankLogo: DNB.Metallic, - visa: Visa.Metallic, - mastercard: Mastercard.Metallic, - bankAxept: BankAxept.White, + bankLogo: DNB.Colored('#b2b4b3'), + visa: Visa.Platinum, + mastercard: Mastercard.Dark, + bankAxept: BankAxept.Gray, saga: Saga.None, privateBanking: PB.Default, } @@ -115,8 +108,8 @@ const mcBlack = { name: 'Mastercard Black', cardStyle: 'card--design-black', bankLogo: DNB.Colored(properties['--color-black-80']), - visa: Visa.Metallic, - mastercard: Mastercard.BlackMetallic, + visa: Visa.Colored('#b2b4b3'), + mastercard: Mastercard.Dark, bankAxept: BankAxept.White, saga: Saga.None, privateBanking: PB.None, @@ -125,9 +118,9 @@ const mcBlack = { const businessNoVisa = { name: 'Bedriftskort BankAxept', cardStyle: 'card--design-business-no-visa', - bankLogo: DNB.Colored(properties['--color-white']), + bankLogo: DNB.Colored(properties['--color-mint-green']), visa: Visa.Colored(properties['--color-white']), - mastercard: Mastercard.DefaultWhite, + mastercard: Mastercard.Default, bankAxept: BankAxept.White, saga: Saga.None, privateBanking: PB.None, @@ -136,9 +129,9 @@ const businessNoVisa = { const businessWithVisa = { name: 'Bedriftskort Visa', cardStyle: 'card--design-business-with-visa', - bankLogo: DNB.Colored(properties['--color-white']), + bankLogo: DNB.Colored(properties['--color-mint-green']), visa: Visa.Colored(properties['--color-white']), - mastercard: Mastercard.DefaultWhite, + mastercard: Mastercard.Default, bankAxept: BankAxept.White, saga: Saga.None, privateBanking: PB.None, @@ -146,10 +139,9 @@ const businessWithVisa = { const Designs = { defaultDesign, - white, + young, myFirst, youth, - silver, pluss, gold, saga, @@ -164,10 +156,9 @@ export default Designs export { defaultDesign, pluss, - white, + young, myFirst, youth, - silver, gold, saga, sagaPlatinum, diff --git a/packages/dnb-eufemia/src/extensions/payment-card/utils/Types.js b/packages/dnb-eufemia/src/extensions/payment-card/utils/Types.js index a7770d09874..21aea20f9d0 100644 --- a/packages/dnb-eufemia/src/extensions/payment-card/utils/Types.js +++ b/packages/dnb-eufemia/src/extensions/payment-card/utils/Types.js @@ -4,19 +4,16 @@ const daggy = createDaggy() const DNB = daggy.taggedSum('DNB', { Colored: ['color'], - Metallic: [], }) const Visa = daggy.taggedSum('Visa', { Colored: ['color'], - Metallic: [], + Platinum: [], }) const Mastercard = daggy.taggedSum('Mastercard', { Default: [], - DefaultWhite: [], - Metallic: [], - BlackMetallic: [], + Dark: [], }) const CardType = daggy.taggedSum('CardType', { @@ -28,35 +25,37 @@ const CardType = daggy.taggedSum('CardType', { const BankAxept = daggy.taggedSum('BankAxept', { White: [], Black: [], + Gold: [], + Black20: [], + Gray: [], }) const Saga = daggy.taggedSum('Saga', { Gold: [], Platinum: [], - VisaPlatinum: [], None: [], }) // PrivateBanking const PB = daggy.taggedSum('PB', { Default: [], - Platinum: [], None: [], }) const ProductType = daggy.taggedSum('ProductType', { - BankAxept: [], Saga: [], Pluss: [], + Intro: [], + Bedrift: [], + Business: [], PrivateBanking: [], None: [], }) -// const Status = daggy.taggedSum('Status', { -// Expired: [], -// Blocked: [], -// Active: [] -// }) +const BankAxeptType = daggy.taggedSum('BankAxeptType', { + BankAxept: [], + None: [], +}) export { DNB, @@ -66,8 +65,8 @@ export { ProductType, CardType, BankAxept, + BankAxeptType, Visa, - // Status } const Types = { @@ -78,8 +77,8 @@ const Types = { ProductType, CardType, BankAxept, + BankAxeptType, Visa, - // Status } export default Types diff --git a/packages/dnb-eufemia/src/extensions/payment-card/utils/backgrounds/index.ts b/packages/dnb-eufemia/src/extensions/payment-card/utils/backgrounds/index.ts new file mode 100644 index 00000000000..d8254788ff7 --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/utils/backgrounds/index.ts @@ -0,0 +1,5 @@ +import myFirstImg from './my-first' +import ungImg from './ung' +import youthImg from './youth' + +export { myFirstImg, ungImg, youthImg } diff --git a/packages/dnb-eufemia/src/extensions/payment-card/utils/backgrounds/my-first.ts b/packages/dnb-eufemia/src/extensions/payment-card/utils/backgrounds/my-first.ts new file mode 100644 index 00000000000..49b403a30c8 --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/utils/backgrounds/my-first.ts @@ -0,0 +1,4 @@ +const base64EncodedImage = + '' + +export default base64EncodedImage diff --git a/packages/dnb-eufemia/src/extensions/payment-card/utils/backgrounds/ung.ts b/packages/dnb-eufemia/src/extensions/payment-card/utils/backgrounds/ung.ts new file mode 100644 index 00000000000..5f39d2379db --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/utils/backgrounds/ung.ts @@ -0,0 +1,4 @@ +const base64EncodedImage = + ""; + +export default base64EncodedImage diff --git a/packages/dnb-eufemia/src/extensions/payment-card/utils/backgrounds/youth.ts b/packages/dnb-eufemia/src/extensions/payment-card/utils/backgrounds/youth.ts new file mode 100644 index 00000000000..5cdcd98422b --- /dev/null +++ b/packages/dnb-eufemia/src/extensions/payment-card/utils/backgrounds/youth.ts @@ -0,0 +1,4 @@ +const base64EncodedImage = + ""; + +export default base64EncodedImage diff --git a/packages/dnb-eufemia/src/extensions/payment-card/utils/cardProducts.js b/packages/dnb-eufemia/src/extensions/payment-card/utils/cardProducts.js index 6f981dd3287..06faac51a3d 100644 --- a/packages/dnb-eufemia/src/extensions/payment-card/utils/cardProducts.js +++ b/packages/dnb-eufemia/src/extensions/payment-card/utils/cardProducts.js @@ -1,10 +1,9 @@ import { defaultDesign, pluss, - white, + young, myFirst, youth, - silver, gold, saga, sagaPlatinum, @@ -14,7 +13,7 @@ import { businessWithVisa, } from './CardDesigns' -import { CardType, ProductType } from './Types' +import { CardType, ProductType, BankAxeptType } from './Types' const cardData = [ { @@ -23,7 +22,8 @@ const cardData = [ displayName: 'DNB Kortet', cardDesign: defaultDesign, cardType: CardType.None, - productType: ProductType.BankAxept, + productType: ProductType.None, + bankAxept: BankAxeptType.BankAxept, }, { productCode: 'NK4', @@ -31,7 +31,8 @@ const cardData = [ displayName: 'DNB Kortet', cardDesign: defaultDesign, cardType: CardType.None, - productType: ProductType.BankAxept, + productType: ProductType.None, + bankAxept: BankAxeptType.BankAxept, }, { productCode: 'NK5', @@ -39,7 +40,8 @@ const cardData = [ displayName: 'DNB Kortet', cardDesign: defaultDesign, cardType: CardType.None, - productType: ProductType.BankAxept, + productType: ProductType.None, + bankAxept: BankAxeptType.BankAxept, }, { productCode: 'VE1', @@ -48,6 +50,7 @@ const cardData = [ cardDesign: defaultDesign, cardType: CardType.Visa, productType: ProductType.None, + bankAxept: BankAxeptType.None, }, { productCode: 'VE2', @@ -56,6 +59,7 @@ const cardData = [ cardDesign: defaultDesign, cardType: CardType.Visa, productType: ProductType.None, + bankAxept: BankAxeptType.None, }, { productCode: 'VG1', @@ -64,6 +68,7 @@ const cardData = [ cardDesign: saga, cardType: CardType.Visa, productType: ProductType.Saga, + bankAxept: BankAxeptType.BankAxept, }, { productCode: 'VG4', @@ -72,6 +77,16 @@ const cardData = [ cardDesign: saga, cardType: CardType.Visa, productType: ProductType.Saga, + bankAxept: BankAxeptType.BankAxept, + }, + { + productCode: '053', + productName: 'SAGA Gull Mastercard', + displayName: 'SAGA Gull', + cardDesign: saga, + cardType: CardType.Mastercard, + productType: ProductType.Saga, + bankAxept: BankAxeptType.None, }, { productCode: 'VK2', @@ -80,6 +95,7 @@ const cardData = [ cardDesign: defaultDesign, productType: ProductType.None, cardType: CardType.Visa, + bankAxept: BankAxeptType.None, }, { productCode: 'VK4', @@ -88,6 +104,16 @@ const cardData = [ cardDesign: defaultDesign, productType: ProductType.None, cardType: CardType.Visa, + bankAxept: BankAxeptType.None, + }, + { + productCode: '084', + productName: 'Pluss Mastercard(leve)', + displayName: 'Pluss Mastercard', + cardDesign: pluss, + productType: ProductType.Pluss, + cardType: CardType.Mastercard, + bankAxept: BankAxeptType.None, }, { productCode: 'VL1', @@ -96,14 +122,16 @@ const cardData = [ cardDesign: pluss, productType: ProductType.Pluss, cardType: CardType.Visa, + bankAxept: BankAxeptType.BankAxept, }, { productCode: 'VL2', productName: 'Hvitt Visa', displayName: 'Hvitt kort', - cardDesign: white, + cardDesign: young, productType: ProductType.None, cardType: CardType.Visa, + bankAxept: BankAxeptType.BankAxept, }, { productCode: 'VL3', @@ -112,22 +140,34 @@ const cardData = [ cardDesign: pluss, productType: ProductType.Pluss, cardType: CardType.Visa, + bankAxept: BankAxeptType.None, }, { productCode: 'VL4', productName: 'DNB Visa u/leg', displayName: 'DNB Visa', - cardDesign: silver, + cardDesign: defaultDesign, productType: ProductType.None, cardType: CardType.Visa, + bankAxept: BankAxeptType.BankAxept, }, { productCode: 'VL6', productName: 'Hvitt Visa u/leg', displayName: 'Hvitt kort', - cardDesign: white, + cardDesign: young, productType: ProductType.None, cardType: CardType.Visa, + bankAxept: BankAxeptType.BankAxept, + }, + { + productCode: '085', + productName: 'Ung Mastercard(student)', + displayName: 'Ung Mastercard', + cardDesign: young, + productType: ProductType.None, + cardType: CardType.Mastercard, + bankAxept: BankAxeptType.None, }, { productCode: 'VO1', @@ -136,6 +176,7 @@ const cardData = [ cardDesign: defaultDesign, cardType: CardType.Visa, productType: ProductType.None, + bankAxept: BankAxeptType.BankAxept, }, { productCode: 'VP2', @@ -144,6 +185,7 @@ const cardData = [ cardDesign: sagaPlatinum, productType: ProductType.Saga, cardType: CardType.Visa, + bankAxept: BankAxeptType.None, }, { productCode: 'VP3', @@ -152,6 +194,7 @@ const cardData = [ cardDesign: privateBanking, productType: ProductType.PrivateBanking, cardType: CardType.Visa, + bankAxept: BankAxeptType.None, }, { productCode: 'VP4', @@ -160,6 +203,16 @@ const cardData = [ cardDesign: sagaPlatinum, productType: ProductType.Saga, cardType: CardType.Visa, + bankAxept: BankAxeptType.BankAxept, + }, + { + productCode: '069', + productName: 'SAGA Platinum Mastercard', + displayName: 'SAGA Platinum', + cardDesign: sagaPlatinum, + productType: ProductType.Saga, + cardType: CardType.Mastercard, + bankAxept: BankAxeptType.None, }, { productCode: 'VP5', @@ -168,25 +221,17 @@ const cardData = [ cardDesign: privateBanking, productType: ProductType.PrivateBanking, cardType: CardType.Visa, + bankAxept: BankAxeptType.BankAxept, + }, + { + productCode: '080', + productName: 'Private Banking Mastercard', + displayName: 'Private Banking', + cardDesign: privateBanking, + productType: ProductType.PrivateBanking, + cardType: CardType.Mastercard, + bankAxept: BankAxeptType.None, }, - // { - // productCode: 'VU3', - // productName: 'Intro Electron', - // displayName: 'Intro Electron', - // cardDesign: defaultDesign, - // - // productLogo: "", - // cardType: CardType.Visa, - // }, - // { - // productCode: 'VU6', - // productName: 'Leve Ung', - // displayName: 'Leve Ung', - // cardDesign: defaultDesign, - // - // productLogo: "", - // type: "", - // }, { productCode: 'VX1', productName: 'Mitt første kort', @@ -194,30 +239,34 @@ const cardData = [ cardDesign: myFirst, productType: ProductType.None, cardType: CardType.Visa, + bankAxept: BankAxeptType.None, }, { productCode: 'VX3', productName: 'Ungdomskortet', displayName: 'Ungdomskort', cardDesign: youth, - productType: ProductType.BankAxept, + productType: ProductType.None, cardType: CardType.Visa, + bankAxept: BankAxeptType.BankAxept, }, { productCode: 'VX4', productName: 'Mitt første kort u/leg', displayName: 'Mitt første kort', cardDesign: myFirst, - productType: ProductType.None, + productType: ProductType.Intro, cardType: CardType.Visa, + bankAxept: BankAxeptType.BankAxept, }, { productCode: 'VX5', productName: 'Ungdomskortet u/leg', displayName: 'Ungdomskort', cardDesign: youth, - productType: ProductType.BankAxept, + productType: ProductType.Intro, cardType: CardType.Visa, + bankAxept: BankAxeptType.BankAxept, }, { productCode: '096', @@ -226,14 +275,16 @@ const cardData = [ cardDesign: gold, productType: ProductType.None, cardType: CardType.Mastercard, + bankAxept: BankAxeptType.None, }, { productCode: '044', productName: 'Hvitt Mastercard', displayName: 'Student', - cardDesign: white, + cardDesign: young, productType: ProductType.None, cardType: CardType.Mastercard, + bankAxept: BankAxeptType.None, }, { productCode: '043', @@ -242,6 +293,7 @@ const cardData = [ cardDesign: pluss, productType: ProductType.Pluss, cardType: CardType.Mastercard, + bankAxept: BankAxeptType.None, }, { productCode: '098', @@ -250,6 +302,7 @@ const cardData = [ cardDesign: saga, productType: ProductType.Saga, cardType: CardType.Mastercard, + bankAxept: BankAxeptType.None, }, { productCode: '074', @@ -258,6 +311,7 @@ const cardData = [ cardDesign: sagaPlatinum, productType: ProductType.Saga, cardType: CardType.Mastercard, + bankAxept: BankAxeptType.None, }, { productCode: '062', @@ -266,22 +320,25 @@ const cardData = [ cardDesign: privateBanking, productType: ProductType.PrivateBanking, cardType: CardType.Mastercard, + bankAxept: BankAxeptType.None, }, { productCode: 'BK1', productName: 'Bedriftskort (småkjøpskort)', displayName: 'Bedriftskort (småkjøpskort)', cardDesign: businessNoVisa, - productType: ProductType.BankAxept, + productType: ProductType.Bedrift, cardType: CardType.None, + bankAxept: BankAxeptType.BankAxept, }, { productCode: 'BP1', productName: 'Bedriftskort (småkjøpskort)', displayName: 'Bedriftskort (småkjøpskort)', cardDesign: businessNoVisa, - productType: ProductType.BankAxept, + productType: ProductType.Bedrift, cardType: CardType.None, + bankAxept: BankAxeptType.BankAxept, }, { productCode: 'VB1', @@ -290,14 +347,25 @@ const cardData = [ cardDesign: businessWithVisa, productType: ProductType.None, cardType: CardType.Visa, + bankAxept: BankAxeptType.BankAxept, }, { productCode: 'VB2', + productName: 'Visa Business', + displayName: 'Visa Business', + cardDesign: businessWithVisa, + productType: ProductType.None, + cardType: CardType.Visa, + bankAxept: BankAxeptType.BankAxept, + }, + { + productCode: 'VB5', productName: 'Bedriftskort med Visa', displayName: 'Bedriftskort med Visa', cardDesign: businessWithVisa, - productType: ProductType.None, + productType: ProductType.Business, cardType: CardType.Visa, + bankAxept: BankAxeptType.None, }, { productCode: 'P101', @@ -306,6 +374,7 @@ const cardData = [ cardDesign: mcBlack, productType: ProductType.None, cardType: CardType.Mastercard, + bankAxept: BankAxeptType.None, }, ]