106 lines
3.7 KiB
JavaScript
106 lines
3.7 KiB
JavaScript
import { LocalizeMixin } from '@lion/localize';
|
|
import { LionInput } from '@lion/input';
|
|
import { FieldCustomMixin } from '@lion/field';
|
|
import { formatIBAN } from './formatters.js';
|
|
import { parseIBAN } from './parsers.js';
|
|
import { isIBANValidator } from './validators.js';
|
|
|
|
/**
|
|
* `LionInputIban` is a class for an IBAN custom form element (`<lion-input-iban>`).
|
|
*
|
|
* @extends {LionInput}
|
|
*/
|
|
export class LionInputIban extends FieldCustomMixin(LocalizeMixin(LionInput)) {
|
|
static get localizeNamespaces() {
|
|
return [
|
|
{
|
|
/* FIXME: This awful switch statement is used to make sure it works with polymer build.. */
|
|
'lion-input-iban': locale => {
|
|
switch (locale) {
|
|
case 'bg-BG':
|
|
return import('../translations/bg-BG.js');
|
|
case 'bg':
|
|
return import('../translations/bg.js');
|
|
case 'cs-CZ':
|
|
return import('../translations/cs-CZ.js');
|
|
case 'cs':
|
|
return import('../translations/cs.js');
|
|
case 'de-DE':
|
|
return import('../translations/de-DE.js');
|
|
case 'de':
|
|
return import('../translations/de.js');
|
|
case 'en-AU':
|
|
return import('../translations/en-AU.js');
|
|
case 'en-GB':
|
|
return import('../translations/en-GB.js');
|
|
case 'en-US':
|
|
return import('../translations/en-US.js');
|
|
case 'en-PH':
|
|
case 'en':
|
|
return import('../translations/en.js');
|
|
case 'es-ES':
|
|
return import('../translations/es-ES.js');
|
|
case 'es':
|
|
return import('../translations/es.js');
|
|
case 'fr-FR':
|
|
return import('../translations/fr-FR.js');
|
|
case 'fr-BE':
|
|
return import('../translations/fr-BE.js');
|
|
case 'fr':
|
|
return import('../translations/fr.js');
|
|
case 'hu-HU':
|
|
return import('../translations/hu-HU.js');
|
|
case 'hu':
|
|
return import('../translations/hu.js');
|
|
case 'it-IT':
|
|
return import('../translations/it-IT.js');
|
|
case 'it':
|
|
return import('../translations/it.js');
|
|
case 'nl-BE':
|
|
return import('../translations/nl-BE.js');
|
|
case 'nl-NL':
|
|
return import('../translations/nl-NL.js');
|
|
case 'nl':
|
|
return import('../translations/nl.js');
|
|
case 'pl-PL':
|
|
return import('../translations/pl-PL.js');
|
|
case 'pl':
|
|
return import('../translations/pl.js');
|
|
case 'ro-RO':
|
|
return import('../translations/ro-RO.js');
|
|
case 'ro':
|
|
return import('../translations/ro.js');
|
|
case 'ru-RU':
|
|
return import('../translations/ru-RU.js');
|
|
case 'ru':
|
|
return import('../translations/ru.js');
|
|
case 'sk-SK':
|
|
return import('../translations/sk-SK.js');
|
|
case 'sk':
|
|
return import('../translations/sk.js');
|
|
case 'uk-UA':
|
|
return import('../translations/uk-UA.js');
|
|
case 'uk':
|
|
return import('../translations/uk.js');
|
|
default:
|
|
return import(`../translations/${locale}.js`);
|
|
}
|
|
},
|
|
},
|
|
...super.localizeNamespaces,
|
|
];
|
|
}
|
|
|
|
constructor() {
|
|
super();
|
|
this.formatter = formatIBAN;
|
|
this.parser = parseIBAN;
|
|
}
|
|
|
|
getValidatorsForType(type) {
|
|
if (type === 'error') {
|
|
return [isIBANValidator()].concat(super.getValidatorsForType(type) || []);
|
|
}
|
|
return super.getValidatorsForType(type);
|
|
}
|
|
}
|