rocketfellows/sk-vat-number-format-validators-config

v1.0.0 2023-04-29 15:43 UTC

This package is not auto-updated.

Last update: 2024-09-15 20:51:07 UTC


README

Code Coverage Badge

此包提供了斯洛伐克国家增值税号码格式验证器的预配置配置类。它是包 https://github.com/rocketfellows/specific-country-vat-number-format-validators-config 的扩展。

安装

composer require rocketfellows/sk-vat-number-format-validators-config

依赖项

参考文献

包组件列表

  • rocketfellows\SKVatNumberFormatValidatorsConfig\SKVatNumberFormatValidatorsConfig - 斯洛伐克国家增值税号码格式验证器的预配置配置类;

SKVatNumberFormatValidatorsConfig 描述

一个配置类,为斯洛伐克国家的增值税号码格式验证器提供匹配。

类接口

  • getCountry - 返回斯洛伐克 Country 实例;
  • getValidators - 返回验证器元组

初始化默认配置时,getValidators 函数返回一个包含单个验证器的元组 - SKVatFormatValidator 的实例。

$config = new SKVatNumberFormatValidatorsConfig();

$config->getCountry();      // returns Slovakia Country instance
$config->getValidators();   // returns CountryVatFormatValidators with one item - instance of SKVatFormatValidator

您可以通过类构造函数的第一个参数使用新的默认验证器初始化配置类对象来覆盖默认验证器。注意 - 验证器必须实现接口 CountryVatFormatValidatorInterface

$newDefaultValidator = new NewDefaultValidator();                       // instance of CountryVatFormatValidatorInterface
$config = new SKVatNumberFormatValidatorsConfig($newDefaultValidator);  // initialize with new default validator

$config->getValidators();   // returns CountryVatFormatValidators with one item - $newDefaultValidator

您可以通过第二个构造函数参数将其他验证器添加到默认验证器中。

注意 - 额外验证器参数必须是元组 CountryVatFormatValidators 的实例。并且每个额外验证器都必须实现接口 CountryVatFormatValidatorInterface

$firstAdditionalValidator = new FirstAdditionalValidator();   // instance of CountryVatFormatValidatorInterface
$secondAdditionalValidator = new SecondAdditionalValidator(); // instance of CountryVatFormatValidatorInterface

$config = new SKVatNumberFormatValidatorsConfig(
    null,
    (
        new CountryVatFormatValidators(
            $firstAdditionalValidator,
            $secondAdditionalValidator
        )
    )
);

// returns CountryVatFormatValidators with three items:
// default preconfigured validator by default - instance of SKVatFormatValidator
// $firstAdditionalValidator - from additional tuple
// $secondAdditionalValidator - from additional tuple
$config->getValidators();

您还可以通过将默认验证器和额外验证器的元组传递给配置类构造函数来完全重建配置。

$defaultValidator = new DefaultValidator();                   // instance of CountryVatFormatValidatorInterface
$firstAdditionalValidator = new FirstAdditionalValidator();   // instance of CountryVatFormatValidatorInterface
$secondAdditionalValidator = new SecondAdditionalValidator(); // instance of CountryVatFormatValidatorInterface

$config = new SKVatNumberFormatValidatorsConfig(
    $defaultValidator,
    (
        new CountryVatFormatValidators(
            $firstAdditionalValidator,
            $secondAdditionalValidator
        )
    )
);

// returns CountryVatFormatValidators with three items:
// $defaultValidator from constructor first parameter
// $firstAdditionalValidator - from additional tuple
// $secondAdditionalValidator - from additional tuple
$config->getValidators();

更多用例示例可以在包的单元测试中找到。

贡献

欢迎提交拉取请求。如果有重大更改,请首先打开一个问题进行讨论。

请确保根据需要更新测试。