@taiga-ui/addon-commerce 3.25.0-dev.main-569524c → 3.25.0-dev.main-165117e
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/taiga-ui-addon-commerce-components-input-card-grouped.umd.js +9 -82
- package/bundles/taiga-ui-addon-commerce-components-input-card-grouped.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-commerce-components-input-card.umd.js +136 -71
- package/bundles/taiga-ui-addon-commerce-components-input-card.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-commerce-utils.umd.js +1 -1
- package/bundles/taiga-ui-addon-commerce-utils.umd.js.map +1 -1
- package/components/input-card/abstract-input-card.d.ts +24 -0
- package/components/input-card/index.d.ts +2 -0
- package/components/input-card/input-card.component.d.ts +9 -16
- package/components/input-card/input-card.providers.d.ts +13 -0
- package/components/input-card-grouped/input-card-grouped.component.d.ts +4 -13
- package/components/input-card-grouped/input-card-grouped.providers.d.ts +4 -7
- package/esm2015/components/input-card/abstract-input-card.js +65 -0
- package/esm2015/components/input-card/index.js +3 -1
- package/esm2015/components/input-card/input-card.component.js +26 -50
- package/esm2015/components/input-card/input-card.providers.js +20 -0
- package/esm2015/components/input-card-grouped/input-card-grouped.component.js +7 -46
- package/esm2015/components/input-card-grouped/input-card-grouped.providers.js +3 -16
- package/esm2015/utils/get-payment-system.js +2 -2
- package/fesm2015/taiga-ui-addon-commerce-components-input-card-grouped.js +8 -60
- package/fesm2015/taiga-ui-addon-commerce-components-input-card-grouped.js.map +1 -1
- package/fesm2015/taiga-ui-addon-commerce-components-input-card.js +104 -52
- package/fesm2015/taiga-ui-addon-commerce-components-input-card.js.map +1 -1
- package/fesm2015/taiga-ui-addon-commerce-utils.js +1 -1
- package/fesm2015/taiga-ui-addon-commerce-utils.js.map +1 -1
- package/package.json +1 -1
- package/utils/get-payment-system.d.ts +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"taiga-ui-addon-commerce-utils.umd.js","sources":["../../../projects/addon-commerce/utils/create-auto-corrected-expire-pipe.ts","../../../projects/addon-commerce/utils/get-currency-symbol.ts","../../../projects/addon-commerce/utils/format-currency.ts","../../../projects/addon-commerce/utils/get-currency-by-code.ts","../../../projects/addon-commerce/utils/get-payment-system.ts","../../../projects/addon-commerce/utils/is-card-length-valid.ts","../../../projects/addon-commerce/utils/is-card-number-valid.ts","../../../projects/addon-commerce/utils/is-expire-valid.ts","../../../projects/addon-commerce/utils/taiga-ui-addon-commerce-utils.ts"],"sourcesContent":["import {TUI_NON_DIGIT_REGEXP, TuiTextMaskPipeHandler} from '@taiga-ui/core';\n\nconst TUI_EXP_YEAR_MONTH = /^\\d{2}[/|.]\\d{4}$/;\nconst TUI_EXP_SAFARI = /^\\d{1,4}.\\d{1,2}.\\d{1,4}$/;\n\n/**\n * Correct expiration date text allowing only valid months\n * @internal\n *\n * @returns MM/YY\n */\nexport function tuiCreateAutoCorrectedExpirePipe(): TuiTextMaskPipeHandler {\n return (conformedValue, {rawValue}) => {\n // Autofilled with MM/YYYY format\n if (TUI_EXP_YEAR_MONTH.test(rawValue)) {\n conformedValue = `${rawValue.slice(0, 2)}/${rawValue.slice(5)}`;\n }\n\n // Autofilled with Safari crazy format\n if (\n rawValue.length > 7 &&\n rawValue.length < 11 &&\n TUI_EXP_SAFARI.test(rawValue)\n ) {\n const array = rawValue.split(TUI_NON_DIGIT_REGEXP);\n\n // TODO: investigate why the month is sometimes more than 2-length in safari\n const month = array[1].slice(2);\n const year = array.find(({length}) => length === 4);\n\n conformedValue = `${`0`.repeat(2 - month.length)}${month}/${\n year ? year.slice(2) : ``\n }`;\n }\n\n const indexesOfPipedChars: number[] = [];\n const conformedValueArr = conformedValue.split(``);\n\n if (parseInt(conformedValueArr[0], 10) > 1) {\n conformedValueArr[2] = `/`;\n conformedValueArr[1] = conformedValueArr[0];\n conformedValueArr[0] = `0`;\n indexesOfPipedChars.push(0);\n }\n\n return {\n value: conformedValueArr.join(``),\n indexesOfPipedChars,\n };\n };\n}\n","import {TuiCurrency, TuiCurrencyCode} from '@taiga-ui/addon-commerce/enums';\nimport {TuiCurrencyVariants} from '@taiga-ui/addon-commerce/types';\n\n// eslint-disable-next-line complexity\nexport function tuiGetCurrencySymbol(currency: TuiCurrencyVariants): string | null {\n switch (currency) {\n case TuiCurrency.Ruble:\n case TuiCurrencyCode.Ruble:\n return `₽`;\n case TuiCurrency.Dollar:\n case TuiCurrencyCode.Dollar:\n case TuiCurrency.MexicanPeso:\n case TuiCurrencyCode.MexicanPeso:\n return `$`;\n case TuiCurrency.SingaporeDollar:\n case TuiCurrencyCode.SingaporeDollar:\n return `S$`;\n case TuiCurrency.AustralianDollar:\n case TuiCurrencyCode.AustralianDollar:\n return `A$`;\n case TuiCurrency.HongKongDollar:\n case TuiCurrencyCode.HongKongDollar:\n return `HK$`;\n case TuiCurrency.CanadianDollar:\n case TuiCurrencyCode.CanadianDollar:\n return `C$`;\n case TuiCurrency.Euro:\n case TuiCurrencyCode.Euro:\n return `€`;\n case TuiCurrency.Pound:\n case TuiCurrencyCode.Pound:\n return `£`;\n case TuiCurrency.Baht:\n case TuiCurrencyCode.Baht:\n return `฿`;\n case TuiCurrency.TurkishLira:\n case TuiCurrencyCode.TurkishLira:\n return `₺`;\n case TuiCurrency.YuanRenminbi:\n case TuiCurrencyCode.YuanRenminbi:\n return `CN¥`;\n case TuiCurrency.Yen:\n case TuiCurrencyCode.Yen:\n return `¥`;\n case TuiCurrency.IsraeliShekel:\n case TuiCurrencyCode.IsraeliShekel:\n return `₪`;\n case TuiCurrency.IndianRupee:\n case TuiCurrencyCode.IndianRupee:\n return `₹`;\n case TuiCurrency.SwissFranc:\n case TuiCurrencyCode.SwissFranc:\n return `₣`;\n case TuiCurrency.ArmenianDram:\n case TuiCurrencyCode.ArmenianDram:\n return `֏`;\n case TuiCurrency.Won:\n case TuiCurrencyCode.Won:\n return `₩`;\n case TuiCurrency.Tenge:\n case TuiCurrencyCode.Tenge:\n return `₸`;\n case TuiCurrency.Hryvnia:\n case TuiCurrencyCode.Hryvnia:\n return `₴`;\n case TuiCurrency.UzbekSum:\n case TuiCurrencyCode.UzbekSum:\n return `So'm`;\n case TuiCurrency.KyrgyzstanSom:\n case TuiCurrencyCode.KyrgyzstanSom:\n return `c`;\n case TuiCurrency.Dirham:\n case TuiCurrencyCode.Dirham:\n return `Dh`;\n default:\n return null;\n }\n}\n","import {TuiCurrencyVariants} from '@taiga-ui/addon-commerce/types';\nimport {tuiIsString} from '@taiga-ui/cdk';\n\nimport {tuiGetCurrencySymbol} from './get-currency-symbol';\n\nexport function tuiFormatCurrency(currency: TuiCurrencyVariants): string {\n const stringifiedCurrency = stringifyCurrency(currency);\n\n return tuiGetCurrencySymbol(stringifiedCurrency) || stringifiedCurrency;\n}\n\nfunction stringifyCurrency(currency: TuiCurrencyVariants): string {\n return currency === null || tuiIsString(currency)\n ? currency || ``\n : String(currency).padStart(3, `0`);\n}\n","// cspell:disable\nimport {TuiCurrency, TuiCurrencyCode} from '@taiga-ui/addon-commerce/enums';\n\nexport const TUI_CURRENCY_DICTIONARY: Record<TuiCurrencyCode, TuiCurrency> = {\n [TuiCurrencyCode.Ruble]: TuiCurrency.Ruble,\n [TuiCurrencyCode.Dollar]: TuiCurrency.Dollar,\n [TuiCurrencyCode.MexicanPeso]: TuiCurrency.MexicanPeso,\n [TuiCurrencyCode.SingaporeDollar]: TuiCurrency.SingaporeDollar,\n [TuiCurrencyCode.SingaporeDollar]: TuiCurrency.SingaporeDollar,\n [TuiCurrencyCode.AustralianDollar]: TuiCurrency.AustralianDollar,\n [TuiCurrencyCode.HongKongDollar]: TuiCurrency.HongKongDollar,\n [TuiCurrencyCode.CanadianDollar]: TuiCurrency.CanadianDollar,\n [TuiCurrencyCode.Euro]: TuiCurrency.Euro,\n [TuiCurrencyCode.Pound]: TuiCurrency.Pound,\n [TuiCurrencyCode.Baht]: TuiCurrency.Baht,\n [TuiCurrencyCode.TurkishLira]: TuiCurrency.TurkishLira,\n [TuiCurrencyCode.YuanRenminbi]: TuiCurrency.YuanRenminbi,\n [TuiCurrencyCode.Yen]: TuiCurrency.Yen,\n [TuiCurrencyCode.IsraeliShekel]: TuiCurrency.IsraeliShekel,\n [TuiCurrencyCode.IsraeliShekel]: TuiCurrency.IsraeliShekel,\n [TuiCurrencyCode.IndianRupee]: TuiCurrency.IndianRupee,\n [TuiCurrencyCode.SwissFranc]: TuiCurrency.SwissFranc,\n [TuiCurrencyCode.ArmenianDram]: TuiCurrency.ArmenianDram,\n [TuiCurrencyCode.Won]: TuiCurrency.Won,\n [TuiCurrencyCode.Tenge]: TuiCurrency.Tenge,\n [TuiCurrencyCode.Hryvnia]: TuiCurrency.Hryvnia,\n [TuiCurrencyCode.UzbekSum]: TuiCurrency.UzbekSum,\n [TuiCurrencyCode.KyrgyzstanSom]: TuiCurrency.KyrgyzstanSom,\n [TuiCurrencyCode.Dirham]: TuiCurrency.Dirham,\n};\n\nexport function tuiGetCurrencyByCode(currency: TuiCurrencyCode): TuiCurrency | null {\n return TUI_CURRENCY_DICTIONARY[currency] ?? null;\n}\n","import {TuiPaymentSystem} from '@taiga-ui/addon-commerce/types';\n\nexport function tuiGetPaymentSystem(cardNumber: string): TuiPaymentSystem | null {\n if (cardNumber === ``) {\n return null;\n }\n\n const one = Number.parseInt(cardNumber[0], 10);\n const two = Number.parseInt(cardNumber.slice(0, 2), 10);\n const three = Number.parseInt(cardNumber.slice(0, 3), 10);\n const four = Number.parseInt(cardNumber.slice(0, 4), 10);\n\n if (tuiIsMaestro(three, two, one)) {\n return `maestro`;\n }\n\n if (tuiIsMastercard(four, two, one)) {\n return `mastercard`;\n }\n\n if (tuiIsMir(four)) {\n return `mir`;\n }\n\n if (tuiIsElectron(four)) {\n return `electron`;\n }\n\n if (tuiIsVisa(one)) {\n return `visa`;\n }\n\n return null;\n}\n\nexport function tuiIsMaestro(three: number, two: number, one: number): boolean {\n if (one === 6) {\n return true;\n }\n\n if (two === 50 || (two > 55 && two < 59)) {\n return true;\n }\n\n if (three < 500) {\n return false;\n }\n\n return three < 510;\n}\n\nexport function tuiIsMastercard(four: number, two: number, one: number): boolean {\n if (one === 5) {\n return true;\n }\n\n if (two < 10) {\n return false;\n }\n\n if (two > 50 && two < 56) {\n return true;\n }\n\n if (four < 1000) {\n return false;\n }\n\n return four > 2220 && four < 2721;\n}\n\nexport function tuiIsMir(four: number): boolean {\n return four > 2199 && four < 2205;\n}\n\nexport function tuiIsElectron(four: number): boolean {\n switch (four) {\n case 4026:\n case 4175:\n case 4405:\n case 4508:\n case 4844:\n case 4913:\n case 4917:\n return true;\n default:\n return false;\n }\n}\n\nexport function tuiIsVisa(one: number): boolean {\n return one === 4;\n}\n","import {tuiGetPaymentSystem} from './get-payment-system';\n\n/**\n * Validates card number length using payment system dictionary\n */\nexport function tuiIsCardLengthValid(cardNumber: string): boolean {\n const {length} = cardNumber;\n const paymentSystem = tuiGetPaymentSystem(cardNumber);\n\n switch (paymentSystem) {\n case `electron`:\n return length === 16;\n case `maestro`:\n return length > 11 && length < 20;\n case `mastercard`:\n case `mir`:\n return length > 15 && length < 20;\n case `visa`:\n return length > 12 && length < 20;\n default:\n return length > 8 && length < 20;\n }\n}\n","import {TUI_NON_DIGITS_REGEXP} from '@taiga-ui/core';\n\n/**\n * Validates card number using Luhn algorithm\n */\nexport function tuiIsCardNumberValid(value: number | string): boolean {\n const cardNumber = String(value).replace(TUI_NON_DIGITS_REGEXP, ``);\n\n const {length} = cardNumber;\n const arr = cardNumber.split(``).map((char, index) => {\n const digit = parseInt(char, 10);\n\n if ((index + length) % 2 === 0) {\n const digitX2 = digit * 2;\n\n return digitX2 > 9 ? digitX2 - 9 : digitX2;\n }\n\n return digit;\n });\n\n return !(arr.reduce((a, b) => a + b, 0) % 10);\n}\n","export function tuiIsExpireValid(expire: string): boolean {\n const today = new Date();\n const currentMonth = today.getMonth();\n const currentYear = today.getFullYear() - 2000;\n // eslint-disable-next-line radix\n const month = parseInt(expire.slice(0, 2), 0);\n // eslint-disable-next-line radix\n const year = parseInt(expire.slice(-2), 0);\n\n return year > currentYear || (year === currentYear && month >= currentMonth);\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["TUI_NON_DIGIT_REGEXP","tuiIsString","TUI_NON_DIGITS_REGEXP"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"taiga-ui-addon-commerce-utils.umd.js","sources":["../../../projects/addon-commerce/utils/create-auto-corrected-expire-pipe.ts","../../../projects/addon-commerce/utils/get-currency-symbol.ts","../../../projects/addon-commerce/utils/format-currency.ts","../../../projects/addon-commerce/utils/get-currency-by-code.ts","../../../projects/addon-commerce/utils/get-payment-system.ts","../../../projects/addon-commerce/utils/is-card-length-valid.ts","../../../projects/addon-commerce/utils/is-card-number-valid.ts","../../../projects/addon-commerce/utils/is-expire-valid.ts","../../../projects/addon-commerce/utils/taiga-ui-addon-commerce-utils.ts"],"sourcesContent":["import {TUI_NON_DIGIT_REGEXP, TuiTextMaskPipeHandler} from '@taiga-ui/core';\n\nconst TUI_EXP_YEAR_MONTH = /^\\d{2}[/|.]\\d{4}$/;\nconst TUI_EXP_SAFARI = /^\\d{1,4}.\\d{1,2}.\\d{1,4}$/;\n\n/**\n * Correct expiration date text allowing only valid months\n * @internal\n *\n * @returns MM/YY\n */\nexport function tuiCreateAutoCorrectedExpirePipe(): TuiTextMaskPipeHandler {\n return (conformedValue, {rawValue}) => {\n // Autofilled with MM/YYYY format\n if (TUI_EXP_YEAR_MONTH.test(rawValue)) {\n conformedValue = `${rawValue.slice(0, 2)}/${rawValue.slice(5)}`;\n }\n\n // Autofilled with Safari crazy format\n if (\n rawValue.length > 7 &&\n rawValue.length < 11 &&\n TUI_EXP_SAFARI.test(rawValue)\n ) {\n const array = rawValue.split(TUI_NON_DIGIT_REGEXP);\n\n // TODO: investigate why the month is sometimes more than 2-length in safari\n const month = array[1].slice(2);\n const year = array.find(({length}) => length === 4);\n\n conformedValue = `${`0`.repeat(2 - month.length)}${month}/${\n year ? year.slice(2) : ``\n }`;\n }\n\n const indexesOfPipedChars: number[] = [];\n const conformedValueArr = conformedValue.split(``);\n\n if (parseInt(conformedValueArr[0], 10) > 1) {\n conformedValueArr[2] = `/`;\n conformedValueArr[1] = conformedValueArr[0];\n conformedValueArr[0] = `0`;\n indexesOfPipedChars.push(0);\n }\n\n return {\n value: conformedValueArr.join(``),\n indexesOfPipedChars,\n };\n };\n}\n","import {TuiCurrency, TuiCurrencyCode} from '@taiga-ui/addon-commerce/enums';\nimport {TuiCurrencyVariants} from '@taiga-ui/addon-commerce/types';\n\n// eslint-disable-next-line complexity\nexport function tuiGetCurrencySymbol(currency: TuiCurrencyVariants): string | null {\n switch (currency) {\n case TuiCurrency.Ruble:\n case TuiCurrencyCode.Ruble:\n return `₽`;\n case TuiCurrency.Dollar:\n case TuiCurrencyCode.Dollar:\n case TuiCurrency.MexicanPeso:\n case TuiCurrencyCode.MexicanPeso:\n return `$`;\n case TuiCurrency.SingaporeDollar:\n case TuiCurrencyCode.SingaporeDollar:\n return `S$`;\n case TuiCurrency.AustralianDollar:\n case TuiCurrencyCode.AustralianDollar:\n return `A$`;\n case TuiCurrency.HongKongDollar:\n case TuiCurrencyCode.HongKongDollar:\n return `HK$`;\n case TuiCurrency.CanadianDollar:\n case TuiCurrencyCode.CanadianDollar:\n return `C$`;\n case TuiCurrency.Euro:\n case TuiCurrencyCode.Euro:\n return `€`;\n case TuiCurrency.Pound:\n case TuiCurrencyCode.Pound:\n return `£`;\n case TuiCurrency.Baht:\n case TuiCurrencyCode.Baht:\n return `฿`;\n case TuiCurrency.TurkishLira:\n case TuiCurrencyCode.TurkishLira:\n return `₺`;\n case TuiCurrency.YuanRenminbi:\n case TuiCurrencyCode.YuanRenminbi:\n return `CN¥`;\n case TuiCurrency.Yen:\n case TuiCurrencyCode.Yen:\n return `¥`;\n case TuiCurrency.IsraeliShekel:\n case TuiCurrencyCode.IsraeliShekel:\n return `₪`;\n case TuiCurrency.IndianRupee:\n case TuiCurrencyCode.IndianRupee:\n return `₹`;\n case TuiCurrency.SwissFranc:\n case TuiCurrencyCode.SwissFranc:\n return `₣`;\n case TuiCurrency.ArmenianDram:\n case TuiCurrencyCode.ArmenianDram:\n return `֏`;\n case TuiCurrency.Won:\n case TuiCurrencyCode.Won:\n return `₩`;\n case TuiCurrency.Tenge:\n case TuiCurrencyCode.Tenge:\n return `₸`;\n case TuiCurrency.Hryvnia:\n case TuiCurrencyCode.Hryvnia:\n return `₴`;\n case TuiCurrency.UzbekSum:\n case TuiCurrencyCode.UzbekSum:\n return `So'm`;\n case TuiCurrency.KyrgyzstanSom:\n case TuiCurrencyCode.KyrgyzstanSom:\n return `c`;\n case TuiCurrency.Dirham:\n case TuiCurrencyCode.Dirham:\n return `Dh`;\n default:\n return null;\n }\n}\n","import {TuiCurrencyVariants} from '@taiga-ui/addon-commerce/types';\nimport {tuiIsString} from '@taiga-ui/cdk';\n\nimport {tuiGetCurrencySymbol} from './get-currency-symbol';\n\nexport function tuiFormatCurrency(currency: TuiCurrencyVariants): string {\n const stringifiedCurrency = stringifyCurrency(currency);\n\n return tuiGetCurrencySymbol(stringifiedCurrency) || stringifiedCurrency;\n}\n\nfunction stringifyCurrency(currency: TuiCurrencyVariants): string {\n return currency === null || tuiIsString(currency)\n ? currency || ``\n : String(currency).padStart(3, `0`);\n}\n","// cspell:disable\nimport {TuiCurrency, TuiCurrencyCode} from '@taiga-ui/addon-commerce/enums';\n\nexport const TUI_CURRENCY_DICTIONARY: Record<TuiCurrencyCode, TuiCurrency> = {\n [TuiCurrencyCode.Ruble]: TuiCurrency.Ruble,\n [TuiCurrencyCode.Dollar]: TuiCurrency.Dollar,\n [TuiCurrencyCode.MexicanPeso]: TuiCurrency.MexicanPeso,\n [TuiCurrencyCode.SingaporeDollar]: TuiCurrency.SingaporeDollar,\n [TuiCurrencyCode.SingaporeDollar]: TuiCurrency.SingaporeDollar,\n [TuiCurrencyCode.AustralianDollar]: TuiCurrency.AustralianDollar,\n [TuiCurrencyCode.HongKongDollar]: TuiCurrency.HongKongDollar,\n [TuiCurrencyCode.CanadianDollar]: TuiCurrency.CanadianDollar,\n [TuiCurrencyCode.Euro]: TuiCurrency.Euro,\n [TuiCurrencyCode.Pound]: TuiCurrency.Pound,\n [TuiCurrencyCode.Baht]: TuiCurrency.Baht,\n [TuiCurrencyCode.TurkishLira]: TuiCurrency.TurkishLira,\n [TuiCurrencyCode.YuanRenminbi]: TuiCurrency.YuanRenminbi,\n [TuiCurrencyCode.Yen]: TuiCurrency.Yen,\n [TuiCurrencyCode.IsraeliShekel]: TuiCurrency.IsraeliShekel,\n [TuiCurrencyCode.IsraeliShekel]: TuiCurrency.IsraeliShekel,\n [TuiCurrencyCode.IndianRupee]: TuiCurrency.IndianRupee,\n [TuiCurrencyCode.SwissFranc]: TuiCurrency.SwissFranc,\n [TuiCurrencyCode.ArmenianDram]: TuiCurrency.ArmenianDram,\n [TuiCurrencyCode.Won]: TuiCurrency.Won,\n [TuiCurrencyCode.Tenge]: TuiCurrency.Tenge,\n [TuiCurrencyCode.Hryvnia]: TuiCurrency.Hryvnia,\n [TuiCurrencyCode.UzbekSum]: TuiCurrency.UzbekSum,\n [TuiCurrencyCode.KyrgyzstanSom]: TuiCurrency.KyrgyzstanSom,\n [TuiCurrencyCode.Dirham]: TuiCurrency.Dirham,\n};\n\nexport function tuiGetCurrencyByCode(currency: TuiCurrencyCode): TuiCurrency | null {\n return TUI_CURRENCY_DICTIONARY[currency] ?? null;\n}\n","import {TuiPaymentSystem} from '@taiga-ui/addon-commerce/types';\n\nexport function tuiGetPaymentSystem(cardNumber?: string | null): TuiPaymentSystem | null {\n if (!cardNumber) {\n return null;\n }\n\n const one = Number.parseInt(cardNumber[0], 10);\n const two = Number.parseInt(cardNumber.slice(0, 2), 10);\n const three = Number.parseInt(cardNumber.slice(0, 3), 10);\n const four = Number.parseInt(cardNumber.slice(0, 4), 10);\n\n if (tuiIsMaestro(three, two, one)) {\n return `maestro`;\n }\n\n if (tuiIsMastercard(four, two, one)) {\n return `mastercard`;\n }\n\n if (tuiIsMir(four)) {\n return `mir`;\n }\n\n if (tuiIsElectron(four)) {\n return `electron`;\n }\n\n if (tuiIsVisa(one)) {\n return `visa`;\n }\n\n return null;\n}\n\nexport function tuiIsMaestro(three: number, two: number, one: number): boolean {\n if (one === 6) {\n return true;\n }\n\n if (two === 50 || (two > 55 && two < 59)) {\n return true;\n }\n\n if (three < 500) {\n return false;\n }\n\n return three < 510;\n}\n\nexport function tuiIsMastercard(four: number, two: number, one: number): boolean {\n if (one === 5) {\n return true;\n }\n\n if (two < 10) {\n return false;\n }\n\n if (two > 50 && two < 56) {\n return true;\n }\n\n if (four < 1000) {\n return false;\n }\n\n return four > 2220 && four < 2721;\n}\n\nexport function tuiIsMir(four: number): boolean {\n return four > 2199 && four < 2205;\n}\n\nexport function tuiIsElectron(four: number): boolean {\n switch (four) {\n case 4026:\n case 4175:\n case 4405:\n case 4508:\n case 4844:\n case 4913:\n case 4917:\n return true;\n default:\n return false;\n }\n}\n\nexport function tuiIsVisa(one: number): boolean {\n return one === 4;\n}\n","import {tuiGetPaymentSystem} from './get-payment-system';\n\n/**\n * Validates card number length using payment system dictionary\n */\nexport function tuiIsCardLengthValid(cardNumber: string): boolean {\n const {length} = cardNumber;\n const paymentSystem = tuiGetPaymentSystem(cardNumber);\n\n switch (paymentSystem) {\n case `electron`:\n return length === 16;\n case `maestro`:\n return length > 11 && length < 20;\n case `mastercard`:\n case `mir`:\n return length > 15 && length < 20;\n case `visa`:\n return length > 12 && length < 20;\n default:\n return length > 8 && length < 20;\n }\n}\n","import {TUI_NON_DIGITS_REGEXP} from '@taiga-ui/core';\n\n/**\n * Validates card number using Luhn algorithm\n */\nexport function tuiIsCardNumberValid(value: number | string): boolean {\n const cardNumber = String(value).replace(TUI_NON_DIGITS_REGEXP, ``);\n\n const {length} = cardNumber;\n const arr = cardNumber.split(``).map((char, index) => {\n const digit = parseInt(char, 10);\n\n if ((index + length) % 2 === 0) {\n const digitX2 = digit * 2;\n\n return digitX2 > 9 ? digitX2 - 9 : digitX2;\n }\n\n return digit;\n });\n\n return !(arr.reduce((a, b) => a + b, 0) % 10);\n}\n","export function tuiIsExpireValid(expire: string): boolean {\n const today = new Date();\n const currentMonth = today.getMonth();\n const currentYear = today.getFullYear() - 2000;\n // eslint-disable-next-line radix\n const month = parseInt(expire.slice(0, 2), 0);\n // eslint-disable-next-line radix\n const year = parseInt(expire.slice(-2), 0);\n\n return year > currentYear || (year === currentYear && month >= currentMonth);\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["TUI_NON_DIGIT_REGEXP","tuiIsString","TUI_NON_DIGITS_REGEXP"],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { ChangeDetectorRef, EventEmitter } from '@angular/core';
|
|
2
|
+
import { NgControl } from '@angular/forms';
|
|
3
|
+
import { TuiPaymentSystem } from '@taiga-ui/addon-commerce/types';
|
|
4
|
+
import { AbstractTuiNullableControl, TuiAutofillFieldName, TuiFocusableElementAccessor, TuiNativeFocusableElement } from '@taiga-ui/cdk';
|
|
5
|
+
import { PolymorpheusContent } from '@tinkoff/ng-polymorpheus';
|
|
6
|
+
import { TuiInputCardOptions } from './input-card.providers';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export declare abstract class AbstractTuiInputCard<T, Options extends TuiInputCardOptions = TuiInputCardOptions> extends AbstractTuiNullableControl<T> implements TuiFocusableElementAccessor {
|
|
9
|
+
protected readonly options: Options;
|
|
10
|
+
cardSrc: PolymorpheusContent;
|
|
11
|
+
autocompleteEnabled: boolean;
|
|
12
|
+
readonly binChange: EventEmitter<string | null>;
|
|
13
|
+
constructor(control: NgControl | null, cdr: ChangeDetectorRef, options: Options);
|
|
14
|
+
abstract get card(): string;
|
|
15
|
+
abstract get nativeFocusableElement(): TuiNativeFocusableElement | null;
|
|
16
|
+
get defaultIcon(): string | null;
|
|
17
|
+
get paymentSystem(): TuiPaymentSystem | null;
|
|
18
|
+
get icon(): PolymorpheusContent;
|
|
19
|
+
get autocompleteCard(): TuiAutofillFieldName;
|
|
20
|
+
get bin(): string | null;
|
|
21
|
+
protected getPaymentSystem(cardNumber?: string | null): TuiPaymentSystem | null;
|
|
22
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AbstractTuiInputCard<any, any>, never>;
|
|
23
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<AbstractTuiInputCard<any, any>, never, never, { "cardSrc": "cardSrc"; "autocompleteEnabled": "autocompleteEnabled"; }, { "binChange": "binChange"; }, never>;
|
|
24
|
+
}
|
|
@@ -1,29 +1,22 @@
|
|
|
1
|
-
import { ChangeDetectorRef
|
|
1
|
+
import { ChangeDetectorRef } from '@angular/core';
|
|
2
2
|
import { NgControl } from '@angular/forms';
|
|
3
|
-
import { TuiPaymentSystem } from '@taiga-ui/addon-commerce/types';
|
|
4
|
-
import { AbstractTuiControl, TuiAutofillFieldName, TuiFocusableElementAccessor } from '@taiga-ui/cdk';
|
|
5
3
|
import { TuiTextMaskOptions } from '@taiga-ui/core';
|
|
6
|
-
import {
|
|
4
|
+
import { AbstractTuiInputCard } from './abstract-input-card';
|
|
5
|
+
import { TuiInputCardOptions } from './input-card.providers';
|
|
7
6
|
import * as i0 from "@angular/core";
|
|
8
|
-
export declare class TuiInputCardComponent extends
|
|
7
|
+
export declare class TuiInputCardComponent extends AbstractTuiInputCard<string> {
|
|
9
8
|
private readonly input?;
|
|
10
|
-
cardSrc: PolymorpheusContent;
|
|
11
|
-
autocompleteEnabled: boolean;
|
|
12
|
-
readonly binChange: EventEmitter<string | null>;
|
|
13
9
|
readonly textMaskOptions: TuiTextMaskOptions;
|
|
14
|
-
constructor(control: NgControl | null, cdr: ChangeDetectorRef);
|
|
15
|
-
|
|
10
|
+
constructor(control: NgControl | null, cdr: ChangeDetectorRef, options: TuiInputCardOptions);
|
|
11
|
+
get card(): string;
|
|
16
12
|
get nativeFocusableElement(): HTMLInputElement | null;
|
|
17
13
|
get focused(): boolean;
|
|
18
|
-
get icon(): PolymorpheusContent;
|
|
19
|
-
get autocomplete(): TuiAutofillFieldName;
|
|
20
|
-
get paymentSystem(): TuiPaymentSystem | null;
|
|
21
|
-
get bin(): string | null;
|
|
22
14
|
get formattedCard(): string;
|
|
23
15
|
onValueChange(value: string): void;
|
|
24
16
|
onFocused(focused: boolean): void;
|
|
25
17
|
writeValue(value: string | null): void;
|
|
26
18
|
protected getFallbackValue(): string;
|
|
27
|
-
|
|
28
|
-
static
|
|
19
|
+
private getFormattedCard;
|
|
20
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiInputCardComponent, [{ optional: true; self: true; }, null, null]>;
|
|
21
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TuiInputCardComponent, "tui-input-card", never, {}, {}, never, ["*", "input"]>;
|
|
29
22
|
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { InjectionToken, ValueProvider } from '@angular/core';
|
|
2
|
+
import { TuiPaymentSystem } from '@taiga-ui/addon-commerce/types';
|
|
3
|
+
import { TuiHandler } from '@taiga-ui/cdk';
|
|
4
|
+
import { PolymorpheusContent } from '@tinkoff/ng-polymorpheus';
|
|
5
|
+
export interface TuiInputCardOptions {
|
|
6
|
+
cardSrc: PolymorpheusContent;
|
|
7
|
+
readonly autocompleteEnabled: boolean;
|
|
8
|
+
readonly icons: Record<TuiPaymentSystem, string>;
|
|
9
|
+
readonly paymentSystemHandler: TuiHandler<string | null | undefined, TuiPaymentSystem | null>;
|
|
10
|
+
}
|
|
11
|
+
export declare const TUI_INPUT_CARD_DEFAULT_OPTIONS: TuiInputCardOptions;
|
|
12
|
+
export declare const TUI_INPUT_CARD_OPTIONS: InjectionToken<TuiInputCardOptions>;
|
|
13
|
+
export declare const tuiInputCardOptionsProvider: (options: Partial<TuiInputCardOptions>) => ValueProvider;
|
|
@@ -1,19 +1,19 @@
|
|
|
1
1
|
import { ChangeDetectorRef, ElementRef, EventEmitter } from '@angular/core';
|
|
2
2
|
import { NgControl } from '@angular/forms';
|
|
3
|
+
import { AbstractTuiInputCard } from '@taiga-ui/addon-commerce/components/input-card';
|
|
3
4
|
import { TuiCard } from '@taiga-ui/addon-commerce/interfaces';
|
|
4
5
|
import { TuiCodeCVCLength } from '@taiga-ui/addon-commerce/types';
|
|
5
|
-
import {
|
|
6
|
+
import { TuiAutofillFieldName, TuiFocusableElementAccessor } from '@taiga-ui/cdk';
|
|
6
7
|
import { TuiBrightness, TuiDataListComponent, TuiDataListHost, TuiTextfieldController, TuiTextMaskOptions } from '@taiga-ui/core';
|
|
7
8
|
import { PolymorpheusContent } from '@tinkoff/ng-polymorpheus';
|
|
8
9
|
import { Observable } from 'rxjs';
|
|
9
10
|
import { TuiCardGroupedTexts, TuiInputCardGroupedOptions } from './input-card-grouped.providers';
|
|
10
11
|
import * as i0 from "@angular/core";
|
|
11
|
-
export declare class TuiInputCardGroupedComponent extends
|
|
12
|
+
export declare class TuiInputCardGroupedComponent extends AbstractTuiInputCard<TuiCard, TuiInputCardGroupedOptions> implements TuiFocusableElementAccessor, TuiDataListHost<Partial<TuiCard>> {
|
|
12
13
|
private readonly el;
|
|
13
14
|
readonly mode$: Observable<TuiBrightness | null>;
|
|
14
15
|
readonly cardGroupedTexts$: Observable<TuiCardGroupedTexts>;
|
|
15
16
|
readonly controller: TuiTextfieldController;
|
|
16
|
-
private readonly options;
|
|
17
17
|
private readonly inputCard?;
|
|
18
18
|
private readonly cardNumberAutofocusRef?;
|
|
19
19
|
private readonly inputExpire?;
|
|
@@ -21,13 +21,10 @@ export declare class TuiInputCardGroupedComponent extends AbstractTuiNullableCon
|
|
|
21
21
|
private readonly inputCVC?;
|
|
22
22
|
private readonly cvcCardAutofocusRef?;
|
|
23
23
|
private expireInert;
|
|
24
|
-
autocompleteEnabled: boolean;
|
|
25
|
-
cardSrc: PolymorpheusContent;
|
|
26
24
|
exampleText: string;
|
|
27
25
|
cardValidator: import("@taiga-ui/cdk").TuiBooleanHandler<string>;
|
|
28
26
|
set codeLength(length: TuiCodeCVCLength);
|
|
29
27
|
readonly autofilledChange: EventEmitter<boolean>;
|
|
30
|
-
readonly binChange: EventEmitter<string | null>;
|
|
31
28
|
readonly dropdown: PolymorpheusContent;
|
|
32
29
|
readonly datalist?: TuiDataListComponent<TuiCard>;
|
|
33
30
|
exampleTextCVC: string;
|
|
@@ -44,16 +41,12 @@ export declare class TuiInputCardGroupedComponent extends AbstractTuiNullableCon
|
|
|
44
41
|
get cvc(): string;
|
|
45
42
|
get hasCleaner(): boolean;
|
|
46
43
|
get hasDropdown(): boolean;
|
|
47
|
-
get defaultIcon(): string | null;
|
|
48
|
-
get icon(): PolymorpheusContent;
|
|
49
|
-
get bin(): string | null;
|
|
50
44
|
get placeholderRaised(): boolean;
|
|
51
45
|
get hasCardNumber(): boolean;
|
|
52
46
|
get idCard(): string;
|
|
53
47
|
get idExpire(): string;
|
|
54
48
|
get idCVC(): string;
|
|
55
49
|
get isCardCollapsed(): boolean;
|
|
56
|
-
get autocompleteCard(): TuiAutofillFieldName;
|
|
57
50
|
get autocompleteExpire(): TuiAutofillFieldName;
|
|
58
51
|
get autocompleteCVC(): TuiAutofillFieldName;
|
|
59
52
|
get tailLength(): number;
|
|
@@ -82,13 +75,11 @@ export declare class TuiInputCardGroupedComponent extends AbstractTuiNullableCon
|
|
|
82
75
|
focusExpire(): void;
|
|
83
76
|
focusCVC(): void;
|
|
84
77
|
private get cardFocused();
|
|
85
|
-
private get paymentSystem();
|
|
86
78
|
private get hasExtraSpace();
|
|
87
|
-
private getPaymentSystem;
|
|
88
79
|
private isFocusable;
|
|
89
80
|
private updateBin;
|
|
90
81
|
private updateProperty;
|
|
91
82
|
private focusInput;
|
|
92
83
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiInputCardGroupedComponent, [{ optional: true; self: true; }, null, null, null, null, null, null]>;
|
|
93
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TuiInputCardGroupedComponent, "tui-input-card-grouped", never, { "
|
|
84
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TuiInputCardGroupedComponent, "tui-input-card-grouped", never, { "exampleText": "exampleText"; "cardValidator": "cardValidator"; "codeLength": "codeLength"; }, { "autofilledChange": "autofilledChange"; }, ["dropdown", "datalist"], never>;
|
|
94
85
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { InjectionToken, ValueProvider } from '@angular/core';
|
|
2
|
-
import {
|
|
3
|
-
import { TuiBooleanHandler
|
|
2
|
+
import { TuiInputCardOptions } from '@taiga-ui/addon-commerce/components/input-card';
|
|
3
|
+
import { TuiBooleanHandler } from '@taiga-ui/cdk';
|
|
4
4
|
import { Observable } from 'rxjs';
|
|
5
5
|
export interface TuiCardGroupedTexts {
|
|
6
6
|
readonly cardNumberText: string;
|
|
@@ -11,13 +11,10 @@ export interface TuiCardGroupedTexts {
|
|
|
11
11
|
* InputCardGrouped texts
|
|
12
12
|
*/
|
|
13
13
|
export declare const TUI_INPUT_CARD_GROUPED_TEXTS: InjectionToken<Observable<TuiCardGroupedTexts>>;
|
|
14
|
-
export interface TuiInputCardGroupedOptions {
|
|
14
|
+
export interface TuiInputCardGroupedOptions extends TuiInputCardOptions {
|
|
15
|
+
readonly cardValidator: TuiBooleanHandler<string>;
|
|
15
16
|
readonly exampleText: string;
|
|
16
17
|
readonly exampleTextCVC: string;
|
|
17
|
-
readonly autocompleteEnabled: boolean;
|
|
18
|
-
readonly icons: Record<TuiPaymentSystem, string>;
|
|
19
|
-
readonly cardValidator: TuiBooleanHandler<string>;
|
|
20
|
-
readonly paymentSystemHandler: TuiHandler<string, TuiPaymentSystem | null>;
|
|
21
18
|
}
|
|
22
19
|
export declare const TUI_INPUT_CARD_GROUPED_DEFAULT_OPTIONS: TuiInputCardGroupedOptions;
|
|
23
20
|
export declare const TUI_INPUT_CARD_GROUPED_OPTIONS: InjectionToken<TuiInputCardGroupedOptions>;
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { ChangeDetectorRef, Directive, EventEmitter, Inject, Input, Optional, Output, Self, } from '@angular/core';
|
|
3
|
+
import { NgControl } from '@angular/forms';
|
|
4
|
+
import { AbstractTuiNullableControl, tuiDefaultProp, tuiPure, } from '@taiga-ui/cdk';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/forms";
|
|
7
|
+
export class AbstractTuiInputCard extends AbstractTuiNullableControl {
|
|
8
|
+
constructor(control, cdr, options) {
|
|
9
|
+
super(control, cdr);
|
|
10
|
+
this.options = options;
|
|
11
|
+
this.cardSrc = ``;
|
|
12
|
+
this.autocompleteEnabled = this.options.autocompleteEnabled;
|
|
13
|
+
this.binChange = new EventEmitter();
|
|
14
|
+
}
|
|
15
|
+
get defaultIcon() {
|
|
16
|
+
const paymentSystem = this.getPaymentSystem(this.card);
|
|
17
|
+
return paymentSystem && this.options.icons[paymentSystem];
|
|
18
|
+
}
|
|
19
|
+
get paymentSystem() {
|
|
20
|
+
return this.getPaymentSystem(this.card);
|
|
21
|
+
}
|
|
22
|
+
get icon() {
|
|
23
|
+
return this.cardSrc || this.defaultIcon;
|
|
24
|
+
}
|
|
25
|
+
get autocompleteCard() {
|
|
26
|
+
return this.autocompleteEnabled ? `cc-number` : `off`;
|
|
27
|
+
}
|
|
28
|
+
get bin() {
|
|
29
|
+
return this.card.length < 6 ? null : this.card.slice(0, 6);
|
|
30
|
+
}
|
|
31
|
+
getPaymentSystem(cardNumber) {
|
|
32
|
+
return this.options.paymentSystemHandler(cardNumber);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
AbstractTuiInputCard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: AbstractTuiInputCard, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
|
|
36
|
+
AbstractTuiInputCard.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: AbstractTuiInputCard, inputs: { cardSrc: "cardSrc", autocompleteEnabled: "autocompleteEnabled" }, outputs: { binChange: "binChange" }, usesInheritance: true, ngImport: i0 });
|
|
37
|
+
__decorate([
|
|
38
|
+
tuiDefaultProp()
|
|
39
|
+
], AbstractTuiInputCard.prototype, "cardSrc", void 0);
|
|
40
|
+
__decorate([
|
|
41
|
+
tuiDefaultProp()
|
|
42
|
+
], AbstractTuiInputCard.prototype, "autocompleteEnabled", void 0);
|
|
43
|
+
__decorate([
|
|
44
|
+
tuiPure
|
|
45
|
+
], AbstractTuiInputCard.prototype, "getPaymentSystem", null);
|
|
46
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: AbstractTuiInputCard, decorators: [{
|
|
47
|
+
type: Directive
|
|
48
|
+
}], ctorParameters: function () { return [{ type: i1.NgControl, decorators: [{
|
|
49
|
+
type: Optional
|
|
50
|
+
}, {
|
|
51
|
+
type: Self
|
|
52
|
+
}, {
|
|
53
|
+
type: Inject,
|
|
54
|
+
args: [NgControl]
|
|
55
|
+
}] }, { type: i0.ChangeDetectorRef, decorators: [{
|
|
56
|
+
type: Inject,
|
|
57
|
+
args: [ChangeDetectorRef]
|
|
58
|
+
}] }, { type: undefined }]; }, propDecorators: { cardSrc: [{
|
|
59
|
+
type: Input
|
|
60
|
+
}], autocompleteEnabled: [{
|
|
61
|
+
type: Input
|
|
62
|
+
}], binChange: [{
|
|
63
|
+
type: Output
|
|
64
|
+
}], getPaymentSystem: [] } });
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QtaW5wdXQtY2FyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWNvbW1lcmNlL2NvbXBvbmVudHMvaW5wdXQtY2FyZC9hYnN0cmFjdC1pbnB1dC1jYXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQ0gsaUJBQWlCLEVBQ2pCLFNBQVMsRUFDVCxZQUFZLEVBQ1osTUFBTSxFQUNOLEtBQUssRUFDTCxRQUFRLEVBQ1IsTUFBTSxFQUNOLElBQUksR0FDUCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFFekMsT0FBTyxFQUNILDBCQUEwQixFQUUxQixjQUFjLEVBR2QsT0FBTyxHQUNWLE1BQU0sZUFBZSxDQUFDOzs7QUFNdkIsTUFBTSxPQUFnQixvQkFJbEIsU0FBUSwwQkFBNkI7SUFjckMsWUFJSSxPQUF5QixFQUNFLEdBQXNCLEVBQzlCLE9BQWdCO1FBRW5DLEtBQUssQ0FBQyxPQUFPLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFGRCxZQUFPLEdBQVAsT0FBTyxDQUFTO1FBZnZDLFlBQU8sR0FBd0IsRUFBRSxDQUFDO1FBSWxDLHdCQUFtQixHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsbUJBQW1CLENBQUM7UUFHOUMsY0FBUyxHQUFHLElBQUksWUFBWSxFQUFpQixDQUFDO0lBV3ZELENBQUM7SUFNRCxJQUFJLFdBQVc7UUFDWCxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRXZELE9BQU8sYUFBYSxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFRCxJQUFJLGFBQWE7UUFDYixPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDNUMsQ0FBQztJQUVELElBQUksSUFBSTtRQUNKLE9BQU8sSUFBSSxDQUFDLE9BQU8sSUFBSSxJQUFJLENBQUMsV0FBVyxDQUFDO0lBQzVDLENBQUM7SUFFRCxJQUFJLGdCQUFnQjtRQUNoQixPQUFPLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7SUFDMUQsQ0FBQztJQUVELElBQUksR0FBRztRQUNILE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBR1MsZ0JBQWdCLENBQUMsVUFBMEI7UUFDakQsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLG9CQUFvQixDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ3pELENBQUM7O2tIQTFEaUIsb0JBQW9CO3NHQUFwQixvQkFBb0I7QUFTdEM7SUFEQyxjQUFjLEVBQUU7cURBQ2lCO0FBSWxDO0lBREMsY0FBYyxFQUFFO2lFQUNzQztBQTJDdkQ7SUFEQyxPQUFPOzREQUdQOzRGQTFEaUIsb0JBQW9CO2tCQUR6QyxTQUFTOzswQkFvQkQsUUFBUTs7MEJBQ1IsSUFBSTs7MEJBQ0osTUFBTTsyQkFBQyxTQUFTOzswQkFFaEIsTUFBTTsyQkFBQyxpQkFBaUI7aUVBZDdCLE9BQU87c0JBRk4sS0FBSztnQkFNTixtQkFBbUI7c0JBRmxCLEtBQUs7Z0JBS0csU0FBUztzQkFEakIsTUFBTTtnQkF5Q0csZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgICBEaXJlY3RpdmUsXG4gICAgRXZlbnRFbWl0dGVyLFxuICAgIEluamVjdCxcbiAgICBJbnB1dCxcbiAgICBPcHRpb25hbCxcbiAgICBPdXRwdXQsXG4gICAgU2VsZixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge05nQ29udHJvbH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHtUdWlQYXltZW50U3lzdGVtfSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tY29tbWVyY2UvdHlwZXMnO1xuaW1wb3J0IHtcbiAgICBBYnN0cmFjdFR1aU51bGxhYmxlQ29udHJvbCxcbiAgICBUdWlBdXRvZmlsbEZpZWxkTmFtZSxcbiAgICB0dWlEZWZhdWx0UHJvcCxcbiAgICBUdWlGb2N1c2FibGVFbGVtZW50QWNjZXNzb3IsXG4gICAgVHVpTmF0aXZlRm9jdXNhYmxlRWxlbWVudCxcbiAgICB0dWlQdXJlLFxufSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7UG9seW1vcnBoZXVzQ29udGVudH0gZnJvbSAnQHRpbmtvZmYvbmctcG9seW1vcnBoZXVzJztcblxuaW1wb3J0IHtUdWlJbnB1dENhcmRPcHRpb25zfSBmcm9tICcuL2lucHV0LWNhcmQucHJvdmlkZXJzJztcblxuQERpcmVjdGl2ZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQWJzdHJhY3RUdWlJbnB1dENhcmQ8XG4gICAgICAgIFQsXG4gICAgICAgIE9wdGlvbnMgZXh0ZW5kcyBUdWlJbnB1dENhcmRPcHRpb25zID0gVHVpSW5wdXRDYXJkT3B0aW9ucyxcbiAgICA+XG4gICAgZXh0ZW5kcyBBYnN0cmFjdFR1aU51bGxhYmxlQ29udHJvbDxUPlxuICAgIGltcGxlbWVudHMgVHVpRm9jdXNhYmxlRWxlbWVudEFjY2Vzc29yXG57XG4gICAgQElucHV0KClcbiAgICBAdHVpRGVmYXVsdFByb3AoKVxuICAgIGNhcmRTcmM6IFBvbHltb3JwaGV1c0NvbnRlbnQgPSBgYDtcblxuICAgIEBJbnB1dCgpXG4gICAgQHR1aURlZmF1bHRQcm9wKClcbiAgICBhdXRvY29tcGxldGVFbmFibGVkID0gdGhpcy5vcHRpb25zLmF1dG9jb21wbGV0ZUVuYWJsZWQ7XG5cbiAgICBAT3V0cHV0KClcbiAgICByZWFkb25seSBiaW5DaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZyB8IG51bGw+KCk7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgQE9wdGlvbmFsKClcbiAgICAgICAgQFNlbGYoKVxuICAgICAgICBASW5qZWN0KE5nQ29udHJvbClcbiAgICAgICAgY29udHJvbDogTmdDb250cm9sIHwgbnVsbCxcbiAgICAgICAgQEluamVjdChDaGFuZ2VEZXRlY3RvclJlZikgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZixcbiAgICAgICAgcHJvdGVjdGVkIHJlYWRvbmx5IG9wdGlvbnM6IE9wdGlvbnMsXG4gICAgKSB7XG4gICAgICAgIHN1cGVyKGNvbnRyb2wsIGNkcik7XG4gICAgfVxuXG4gICAgYWJzdHJhY3QgZ2V0IGNhcmQoKTogc3RyaW5nO1xuXG4gICAgYWJzdHJhY3QgZ2V0IG5hdGl2ZUZvY3VzYWJsZUVsZW1lbnQoKTogVHVpTmF0aXZlRm9jdXNhYmxlRWxlbWVudCB8IG51bGw7XG5cbiAgICBnZXQgZGVmYXVsdEljb24oKTogc3RyaW5nIHwgbnVsbCB7XG4gICAgICAgIGNvbnN0IHBheW1lbnRTeXN0ZW0gPSB0aGlzLmdldFBheW1lbnRTeXN0ZW0odGhpcy5jYXJkKTtcblxuICAgICAgICByZXR1cm4gcGF5bWVudFN5c3RlbSAmJiB0aGlzLm9wdGlvbnMuaWNvbnNbcGF5bWVudFN5c3RlbV07XG4gICAgfVxuXG4gICAgZ2V0IHBheW1lbnRTeXN0ZW0oKTogVHVpUGF5bWVudFN5c3RlbSB8IG51bGwge1xuICAgICAgICByZXR1cm4gdGhpcy5nZXRQYXltZW50U3lzdGVtKHRoaXMuY2FyZCk7XG4gICAgfVxuXG4gICAgZ2V0IGljb24oKTogUG9seW1vcnBoZXVzQ29udGVudCB7XG4gICAgICAgIHJldHVybiB0aGlzLmNhcmRTcmMgfHwgdGhpcy5kZWZhdWx0SWNvbjtcbiAgICB9XG5cbiAgICBnZXQgYXV0b2NvbXBsZXRlQ2FyZCgpOiBUdWlBdXRvZmlsbEZpZWxkTmFtZSB7XG4gICAgICAgIHJldHVybiB0aGlzLmF1dG9jb21wbGV0ZUVuYWJsZWQgPyBgY2MtbnVtYmVyYCA6IGBvZmZgO1xuICAgIH1cblxuICAgIGdldCBiaW4oKTogc3RyaW5nIHwgbnVsbCB7XG4gICAgICAgIHJldHVybiB0aGlzLmNhcmQubGVuZ3RoIDwgNiA/IG51bGwgOiB0aGlzLmNhcmQuc2xpY2UoMCwgNik7XG4gICAgfVxuXG4gICAgQHR1aVB1cmVcbiAgICBwcm90ZWN0ZWQgZ2V0UGF5bWVudFN5c3RlbShjYXJkTnVtYmVyPzogc3RyaW5nIHwgbnVsbCk6IFR1aVBheW1lbnRTeXN0ZW0gfCBudWxsIHtcbiAgICAgICAgcmV0dXJuIHRoaXMub3B0aW9ucy5wYXltZW50U3lzdGVtSGFuZGxlcihjYXJkTnVtYmVyKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
+
export * from './abstract-input-card';
|
|
1
2
|
export * from './input-card.component';
|
|
2
3
|
export * from './input-card.directive';
|
|
3
4
|
export * from './input-card.module';
|
|
4
|
-
|
|
5
|
+
export * from './input-card.providers';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1jb21tZXJjZS9jb21wb25lbnRzL2lucHV0LWNhcmQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLHdCQUF3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hYnN0cmFjdC1pbnB1dC1jYXJkJztcbmV4cG9ydCAqIGZyb20gJy4vaW5wdXQtY2FyZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1jYXJkLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2lucHV0LWNhcmQubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vaW5wdXQtY2FyZC5wcm92aWRlcnMnO1xuIl19
|
|
@@ -1,36 +1,27 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component,
|
|
2
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Optional, Self, ViewChild, } from '@angular/core';
|
|
3
3
|
import { NgControl } from '@angular/forms';
|
|
4
4
|
import { TUI_CARD_MASK } from '@taiga-ui/addon-commerce/constants';
|
|
5
|
-
import {
|
|
6
|
-
import { AbstractTuiControl, tuiAsControl, tuiAsFocusableItemAccessor, tuiDefaultProp, } from '@taiga-ui/cdk';
|
|
5
|
+
import { tuiAsControl, tuiAsFocusableItemAccessor, tuiPure } from '@taiga-ui/cdk';
|
|
7
6
|
import { TuiPrimitiveTextfieldComponent } from '@taiga-ui/core';
|
|
7
|
+
import { AbstractTuiInputCard } from './abstract-input-card';
|
|
8
|
+
import { TUI_INPUT_CARD_OPTIONS } from './input-card.providers';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
import * as i1 from "@taiga-ui/core";
|
|
10
11
|
import * as i2 from "@taiga-ui/kit";
|
|
11
12
|
import * as i3 from "@angular/forms";
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
electron: 'tuiIconElectron',
|
|
16
|
-
mastercard: 'tuiIconMastercard',
|
|
17
|
-
maestro: 'tuiIconMaestro',
|
|
18
|
-
};
|
|
19
|
-
export class TuiInputCardComponent extends AbstractTuiControl {
|
|
20
|
-
constructor(control, cdr) {
|
|
21
|
-
super(control, cdr);
|
|
22
|
-
this.cardSrc = '';
|
|
23
|
-
this.autocompleteEnabled = false;
|
|
24
|
-
this.binChange = new EventEmitter();
|
|
13
|
+
export class TuiInputCardComponent extends AbstractTuiInputCard {
|
|
14
|
+
constructor(control, cdr, options) {
|
|
15
|
+
super(control, cdr, options);
|
|
25
16
|
this.textMaskOptions = {
|
|
26
17
|
mask: TUI_CARD_MASK,
|
|
27
18
|
guide: false,
|
|
28
19
|
pipe: conformedValue => conformedValue.trim(),
|
|
29
20
|
};
|
|
30
21
|
}
|
|
31
|
-
get
|
|
32
|
-
|
|
33
|
-
return
|
|
22
|
+
get card() {
|
|
23
|
+
var _a;
|
|
24
|
+
return (_a = this.value) !== null && _a !== void 0 ? _a : '';
|
|
34
25
|
}
|
|
35
26
|
get nativeFocusableElement() {
|
|
36
27
|
return this.input ? this.input.nativeFocusableElement : null;
|
|
@@ -38,23 +29,8 @@ export class TuiInputCardComponent extends AbstractTuiControl {
|
|
|
38
29
|
get focused() {
|
|
39
30
|
return !!this.input && this.input.focused;
|
|
40
31
|
}
|
|
41
|
-
get icon() {
|
|
42
|
-
return this.cardSrc || this.defaultCardIcon;
|
|
43
|
-
}
|
|
44
|
-
get autocomplete() {
|
|
45
|
-
return this.autocompleteEnabled ? 'cc-number' : 'off';
|
|
46
|
-
}
|
|
47
|
-
get paymentSystem() {
|
|
48
|
-
return tuiGetPaymentSystem(this.value);
|
|
49
|
-
}
|
|
50
|
-
get bin() {
|
|
51
|
-
return this.value.length < 6 ? null : this.value.slice(0, 6);
|
|
52
|
-
}
|
|
53
32
|
get formattedCard() {
|
|
54
|
-
return this.
|
|
55
|
-
.split('')
|
|
56
|
-
.map((char, index) => (index && index % 4 === 0 ? ` ${char}` : char))
|
|
57
|
-
.join('');
|
|
33
|
+
return this.getFormattedCard(this.card);
|
|
58
34
|
}
|
|
59
35
|
onValueChange(value) {
|
|
60
36
|
const parsed = value.split(' ').join('');
|
|
@@ -79,18 +55,21 @@ export class TuiInputCardComponent extends AbstractTuiControl {
|
|
|
79
55
|
getFallbackValue() {
|
|
80
56
|
return '';
|
|
81
57
|
}
|
|
58
|
+
getFormattedCard(cardNumber) {
|
|
59
|
+
return cardNumber
|
|
60
|
+
.split('')
|
|
61
|
+
.map((char, index) => (index && index % 4 === 0 ? ` ${char}` : char))
|
|
62
|
+
.join('');
|
|
63
|
+
}
|
|
82
64
|
}
|
|
83
|
-
TuiInputCardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputCardComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
84
|
-
TuiInputCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiInputCardComponent, selector: "tui-input-card",
|
|
65
|
+
TuiInputCardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputCardComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }, { token: TUI_INPUT_CARD_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
|
|
66
|
+
TuiInputCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiInputCardComponent, selector: "tui-input-card", providers: [
|
|
85
67
|
tuiAsFocusableItemAccessor(TuiInputCardComponent),
|
|
86
68
|
tuiAsControl(TuiInputCardComponent),
|
|
87
69
|
], viewQueries: [{ propertyName: "input", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-primitive-textfield\n tuiValueAccessor\n class=\"t-input\"\n [tuiTextfieldCustomContent]=\"icon\"\n [readOnly]=\"readOnly\"\n [disabled]=\"disabled\"\n [focusable]=\"focusable\"\n [nativeId]=\"nativeId\"\n [invalid]=\"computedInvalid\"\n [pseudoHover]=\"pseudoHover\"\n [pseudoActive]=\"pseudoActive\"\n [pseudoFocus]=\"pseudoFocus\"\n [textMask]=\"textMaskOptions\"\n [value]=\"formattedCard\"\n (valueChange)=\"onValueChange($event)\"\n (focusedChange)=\"onFocused($event)\"\n>\n <ng-content></ng-content>\n <ng-content\n select=\"input\"\n ngProjectAs=\"input\"\n ></ng-content>\n</tui-primitive-textfield>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:left}.t-input{border-radius:inherit;text-align:inherit}\n"], components: [{ type: i1.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "filler", "iconCleaner", "readOnly", "invalid", "disabled", "prefix", "postfix", "value"], outputs: ["valueChange"] }], directives: [{ type: i1.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { type: i2.TuiValueAccessorDirective, selector: "[tuiValueAccessor]" }, { type: i1.TuiTextfieldCustomContentDirective, selector: "[tuiTextfieldCustomContent]", inputs: ["tuiTextfieldCustomContent"] }, { type: i2.MaskedInputDirective, selector: "[textMask]", inputs: ["textMask"], exportAs: ["textMask"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
88
70
|
__decorate([
|
|
89
|
-
|
|
90
|
-
], TuiInputCardComponent.prototype, "
|
|
91
|
-
__decorate([
|
|
92
|
-
tuiDefaultProp()
|
|
93
|
-
], TuiInputCardComponent.prototype, "autocompleteEnabled", void 0);
|
|
71
|
+
tuiPure
|
|
72
|
+
], TuiInputCardComponent.prototype, "getFormattedCard", null);
|
|
94
73
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputCardComponent, decorators: [{
|
|
95
74
|
type: Component,
|
|
96
75
|
args: [{
|
|
@@ -113,14 +92,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
113
92
|
}] }, { type: i0.ChangeDetectorRef, decorators: [{
|
|
114
93
|
type: Inject,
|
|
115
94
|
args: [ChangeDetectorRef]
|
|
95
|
+
}] }, { type: undefined, decorators: [{
|
|
96
|
+
type: Inject,
|
|
97
|
+
args: [TUI_INPUT_CARD_OPTIONS]
|
|
116
98
|
}] }]; }, propDecorators: { input: [{
|
|
117
99
|
type: ViewChild,
|
|
118
100
|
args: [TuiPrimitiveTextfieldComponent]
|
|
119
|
-
}],
|
|
120
|
-
|
|
121
|
-
}], autocompleteEnabled: [{
|
|
122
|
-
type: Input
|
|
123
|
-
}], binChange: [{
|
|
124
|
-
type: Output
|
|
125
|
-
}] } });
|
|
126
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-card.component.js","sourceRoot":"","sources":["../../../../../projects/addon-commerce/components/input-card/input-card.component.ts","../../../../../projects/addon-commerce/components/input-card/input-card.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {TUI_CARD_MASK} from '@taiga-ui/addon-commerce/constants';\nimport {TuiPaymentSystem} from '@taiga-ui/addon-commerce/types';\nimport {tuiGetPaymentSystem} from '@taiga-ui/addon-commerce/utils';\nimport {\n    AbstractTuiControl,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    TuiAutofillFieldName,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n} from '@taiga-ui/cdk';\nimport {TuiPrimitiveTextfieldComponent, TuiTextMaskOptions} from '@taiga-ui/core';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\nconst icons: Record<TuiPaymentSystem, string> = {\n    mir: 'tuiIconMir',\n    visa: 'tuiIconVisa',\n    electron: 'tuiIconElectron',\n    mastercard: 'tuiIconMastercard',\n    maestro: 'tuiIconMaestro',\n};\n\n@Component({\n    selector: 'tui-input-card',\n    templateUrl: './input-card.template.html',\n    styleUrls: ['./input-card.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputCardComponent),\n        tuiAsControl(TuiInputCardComponent),\n    ],\n})\nexport class TuiInputCardComponent\n    extends AbstractTuiControl<string>\n    implements TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly input?: TuiPrimitiveTextfieldComponent;\n\n    @Input()\n    @tuiDefaultProp()\n    cardSrc: PolymorpheusContent = '';\n\n    @Input()\n    @tuiDefaultProp()\n    autocompleteEnabled = false;\n\n    @Output()\n    readonly binChange = new EventEmitter<string | null>();\n\n    readonly textMaskOptions: TuiTextMaskOptions = {\n        mask: TUI_CARD_MASK,\n        guide: false,\n        pipe: conformedValue => conformedValue.trim(),\n    };\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) cdr: ChangeDetectorRef,\n    ) {\n        super(control, cdr);\n    }\n\n    private get defaultCardIcon(): string | null {\n        const {paymentSystem} = this;\n\n        return paymentSystem ? icons[paymentSystem] : null;\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.input ? this.input.nativeFocusableElement : null;\n    }\n\n    get focused(): boolean {\n        return !!this.input && this.input.focused;\n    }\n\n    get icon(): PolymorpheusContent {\n        return this.cardSrc || this.defaultCardIcon;\n    }\n\n    get autocomplete(): TuiAutofillFieldName {\n        return this.autocompleteEnabled ? 'cc-number' : 'off';\n    }\n\n    get paymentSystem(): TuiPaymentSystem | null {\n        return tuiGetPaymentSystem(this.value);\n    }\n\n    get bin(): string | null {\n        return this.value.length < 6 ? null : this.value.slice(0, 6);\n    }\n\n    get formattedCard(): string {\n        return this.value\n            .split('')\n            .map((char, index) => (index && index % 4 === 0 ? ` ${char}` : char))\n            .join('');\n    }\n\n    onValueChange(value: string): void {\n        const parsed = value.split(' ').join('');\n        const currentBin = this.bin;\n\n        this.value = parsed;\n\n        const newBin = this.bin;\n\n        if (currentBin !== newBin) {\n            this.binChange.emit(newBin);\n        }\n    }\n\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    override writeValue(value: string | null): void {\n        const currentBin = this.bin;\n\n        super.writeValue(value);\n\n        const newBin = this.bin;\n\n        if (currentBin !== newBin) {\n            this.binChange.emit(newBin);\n        }\n    }\n\n    protected getFallbackValue(): string {\n        return '';\n    }\n}\n","<tui-primitive-textfield\n    tuiValueAccessor\n    class=\"t-input\"\n    [tuiTextfieldCustomContent]=\"icon\"\n    [readOnly]=\"readOnly\"\n    [disabled]=\"disabled\"\n    [focusable]=\"focusable\"\n    [nativeId]=\"nativeId\"\n    [invalid]=\"computedInvalid\"\n    [pseudoHover]=\"pseudoHover\"\n    [pseudoActive]=\"pseudoActive\"\n    [pseudoFocus]=\"pseudoFocus\"\n    [textMask]=\"textMaskOptions\"\n    [value]=\"formattedCard\"\n    (valueChange)=\"onValueChange($event)\"\n    (focusedChange)=\"onFocused($event)\"\n>\n    <ng-content></ng-content>\n    <ng-content\n        select=\"input\"\n        ngProjectAs=\"input\"\n    ></ng-content>\n</tui-primitive-textfield>\n"]}
|
|
101
|
+
}], getFormattedCard: [] } });
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-card.component.js","sourceRoot":"","sources":["../../../../../projects/addon-commerce/components/input-card/input-card.component.ts","../../../../../projects/addon-commerce/components/input-card/input-card.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Inject,\n    Optional,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {TUI_CARD_MASK} from '@taiga-ui/addon-commerce/constants';\nimport {tuiAsControl, tuiAsFocusableItemAccessor, tuiPure} from '@taiga-ui/cdk';\nimport {TuiPrimitiveTextfieldComponent, TuiTextMaskOptions} from '@taiga-ui/core';\n\nimport {AbstractTuiInputCard} from './abstract-input-card';\nimport {TUI_INPUT_CARD_OPTIONS, TuiInputCardOptions} from './input-card.providers';\n\n@Component({\n    selector: 'tui-input-card',\n    templateUrl: './input-card.template.html',\n    styleUrls: ['./input-card.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputCardComponent),\n        tuiAsControl(TuiInputCardComponent),\n    ],\n})\nexport class TuiInputCardComponent extends AbstractTuiInputCard<string> {\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly input?: TuiPrimitiveTextfieldComponent;\n\n    readonly textMaskOptions: TuiTextMaskOptions = {\n        mask: TUI_CARD_MASK,\n        guide: false,\n        pipe: conformedValue => conformedValue.trim(),\n    };\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) cdr: ChangeDetectorRef,\n        @Inject(TUI_INPUT_CARD_OPTIONS) options: TuiInputCardOptions,\n    ) {\n        super(control, cdr, options);\n    }\n\n    get card(): string {\n        return this.value ?? '';\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.input ? this.input.nativeFocusableElement : null;\n    }\n\n    get focused(): boolean {\n        return !!this.input && this.input.focused;\n    }\n\n    get formattedCard(): string {\n        return this.getFormattedCard(this.card);\n    }\n\n    onValueChange(value: string): void {\n        const parsed = value.split(' ').join('');\n        const currentBin = this.bin;\n\n        this.value = parsed;\n\n        const newBin = this.bin;\n\n        if (currentBin !== newBin) {\n            this.binChange.emit(newBin);\n        }\n    }\n\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    override writeValue(value: string | null): void {\n        const currentBin = this.bin;\n\n        super.writeValue(value);\n\n        const newBin = this.bin;\n\n        if (currentBin !== newBin) {\n            this.binChange.emit(newBin);\n        }\n    }\n\n    protected override getFallbackValue(): string {\n        return '';\n    }\n\n    @tuiPure\n    private getFormattedCard(cardNumber: string): string {\n        return cardNumber\n            .split('')\n            .map((char, index) => (index && index % 4 === 0 ? ` ${char}` : char))\n            .join('');\n    }\n}\n","<tui-primitive-textfield\n    tuiValueAccessor\n    class=\"t-input\"\n    [tuiTextfieldCustomContent]=\"icon\"\n    [readOnly]=\"readOnly\"\n    [disabled]=\"disabled\"\n    [focusable]=\"focusable\"\n    [nativeId]=\"nativeId\"\n    [invalid]=\"computedInvalid\"\n    [pseudoHover]=\"pseudoHover\"\n    [pseudoActive]=\"pseudoActive\"\n    [pseudoFocus]=\"pseudoFocus\"\n    [textMask]=\"textMaskOptions\"\n    [value]=\"formattedCard\"\n    (valueChange)=\"onValueChange($event)\"\n    (focusedChange)=\"onFocused($event)\"\n>\n    <ng-content></ng-content>\n    <ng-content\n        select=\"input\"\n        ngProjectAs=\"input\"\n    ></ng-content>\n</tui-primitive-textfield>\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
2
|
+
import { tuiGetPaymentSystem } from '@taiga-ui/addon-commerce/utils';
|
|
3
|
+
export const TUI_INPUT_CARD_DEFAULT_OPTIONS = {
|
|
4
|
+
icons: {
|
|
5
|
+
mir: `tuiIconMir`,
|
|
6
|
+
visa: `tuiIconVisa`,
|
|
7
|
+
electron: `tuiIconElectron`,
|
|
8
|
+
mastercard: `tuiIconMastercard`,
|
|
9
|
+
maestro: `tuiIconMaestro`,
|
|
10
|
+
},
|
|
11
|
+
cardSrc: ``,
|
|
12
|
+
paymentSystemHandler: tuiGetPaymentSystem,
|
|
13
|
+
autocompleteEnabled: false,
|
|
14
|
+
};
|
|
15
|
+
export const TUI_INPUT_CARD_OPTIONS = new InjectionToken(`[TUI_INPUT_CARD_OPTIONS]`, { factory: () => TUI_INPUT_CARD_DEFAULT_OPTIONS });
|
|
16
|
+
export const tuiInputCardOptionsProvider = (options) => ({
|
|
17
|
+
provide: TUI_INPUT_CARD_OPTIONS,
|
|
18
|
+
useValue: Object.assign(Object.assign({}, TUI_INPUT_CARD_DEFAULT_OPTIONS), options),
|
|
19
|
+
});
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtY2FyZC5wcm92aWRlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1jb21tZXJjZS9jb21wb25lbnRzL2lucHV0LWNhcmQvaW5wdXQtY2FyZC5wcm92aWRlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGNBQWMsRUFBZ0IsTUFBTSxlQUFlLENBQUM7QUFFNUQsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sZ0NBQWdDLENBQUM7QUFjbkUsTUFBTSxDQUFDLE1BQU0sOEJBQThCLEdBQXdCO0lBQy9ELEtBQUssRUFBRTtRQUNILEdBQUcsRUFBRSxZQUFZO1FBQ2pCLElBQUksRUFBRSxhQUFhO1FBQ25CLFFBQVEsRUFBRSxpQkFBaUI7UUFDM0IsVUFBVSxFQUFFLG1CQUFtQjtRQUMvQixPQUFPLEVBQUUsZ0JBQWdCO0tBQzVCO0lBQ0QsT0FBTyxFQUFFLEVBQUU7SUFDWCxvQkFBb0IsRUFBRSxtQkFBbUI7SUFDekMsbUJBQW1CLEVBQUUsS0FBSztDQUM3QixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsSUFBSSxjQUFjLENBQ3BELDBCQUEwQixFQUMxQixFQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyw4QkFBOEIsRUFBQyxDQUNsRCxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBRW5CLENBQUMsT0FBcUMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUM3RCxPQUFPLEVBQUUsc0JBQXNCO0lBQy9CLFFBQVEsa0NBQU0sOEJBQThCLEdBQUssT0FBTyxDQUFDO0NBQzVELENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0aW9uVG9rZW4sIFZhbHVlUHJvdmlkZXJ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtUdWlQYXltZW50U3lzdGVtfSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tY29tbWVyY2UvdHlwZXMnO1xuaW1wb3J0IHt0dWlHZXRQYXltZW50U3lzdGVtfSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tY29tbWVyY2UvdXRpbHMnO1xuaW1wb3J0IHtUdWlIYW5kbGVyfSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7UG9seW1vcnBoZXVzQ29udGVudH0gZnJvbSAnQHRpbmtvZmYvbmctcG9seW1vcnBoZXVzJztcblxuZXhwb3J0IGludGVyZmFjZSBUdWlJbnB1dENhcmRPcHRpb25zIHtcbiAgICBjYXJkU3JjOiBQb2x5bW9ycGhldXNDb250ZW50O1xuICAgIHJlYWRvbmx5IGF1dG9jb21wbGV0ZUVuYWJsZWQ6IGJvb2xlYW47XG4gICAgcmVhZG9ubHkgaWNvbnM6IFJlY29yZDxUdWlQYXltZW50U3lzdGVtLCBzdHJpbmc+O1xuICAgIHJlYWRvbmx5IHBheW1lbnRTeXN0ZW1IYW5kbGVyOiBUdWlIYW5kbGVyPFxuICAgICAgICBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkLFxuICAgICAgICBUdWlQYXltZW50U3lzdGVtIHwgbnVsbFxuICAgID47XG59XG5cbmV4cG9ydCBjb25zdCBUVUlfSU5QVVRfQ0FSRF9ERUZBVUxUX09QVElPTlM6IFR1aUlucHV0Q2FyZE9wdGlvbnMgPSB7XG4gICAgaWNvbnM6IHtcbiAgICAgICAgbWlyOiBgdHVpSWNvbk1pcmAsXG4gICAgICAgIHZpc2E6IGB0dWlJY29uVmlzYWAsXG4gICAgICAgIGVsZWN0cm9uOiBgdHVpSWNvbkVsZWN0cm9uYCxcbiAgICAgICAgbWFzdGVyY2FyZDogYHR1aUljb25NYXN0ZXJjYXJkYCxcbiAgICAgICAgbWFlc3RybzogYHR1aUljb25NYWVzdHJvYCxcbiAgICB9LFxuICAgIGNhcmRTcmM6IGBgLFxuICAgIHBheW1lbnRTeXN0ZW1IYW5kbGVyOiB0dWlHZXRQYXltZW50U3lzdGVtLFxuICAgIGF1dG9jb21wbGV0ZUVuYWJsZWQ6IGZhbHNlLFxufTtcblxuZXhwb3J0IGNvbnN0IFRVSV9JTlBVVF9DQVJEX09QVElPTlMgPSBuZXcgSW5qZWN0aW9uVG9rZW48VHVpSW5wdXRDYXJkT3B0aW9ucz4oXG4gICAgYFtUVUlfSU5QVVRfQ0FSRF9PUFRJT05TXWAsXG4gICAge2ZhY3Rvcnk6ICgpID0+IFRVSV9JTlBVVF9DQVJEX0RFRkFVTFRfT1BUSU9OU30sXG4pO1xuXG5leHBvcnQgY29uc3QgdHVpSW5wdXRDYXJkT3B0aW9uc1Byb3ZpZGVyOiAoXG4gICAgb3B0aW9uczogUGFydGlhbDxUdWlJbnB1dENhcmRPcHRpb25zPixcbikgPT4gVmFsdWVQcm92aWRlciA9IChvcHRpb25zOiBQYXJ0aWFsPFR1aUlucHV0Q2FyZE9wdGlvbnM+KSA9PiAoe1xuICAgIHByb3ZpZGU6IFRVSV9JTlBVVF9DQVJEX09QVElPTlMsXG4gICAgdXNlVmFsdWU6IHsuLi5UVUlfSU5QVVRfQ0FSRF9ERUZBVUxUX09QVElPTlMsIC4uLm9wdGlvbnN9LFxufSk7XG4iXX0=
|