承接 erichowey/nanp-number-formatter 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

erichowey/nanp-number-formatter

最新稳定版本:2.0.0

Composer 安装命令:

composer require erichowey/nanp-number-formatter

包简介

Take a NANP phone number and return it in a variety of formats.

README 文档

README

This utility takes a NANP (North American Numbering Plan) phone number, parses it and returns the number in a variety of formats.

Install

You can install this package via composer

composer require erichowey/nanp-number-formatter

Supported Input Formats and Characters

  • 10 Digit 2125550123
  • 11 Digit 12125550123
  • E.164 +12125550123
  • Parenthesis (212) 555-0123
  • Dot 212.555.0123
  • Hyphen 212-555-0123
  • Space 212 555 0123
  • Letters 1800FLOWERS

etc...

Outputted Formats

  • E.164 +12125550123
  • Dot Format 212.555.0123
  • Hyphen Format 212-555-0123
  • National Format (212) 555-0123
  • National Format Plus One 1 (212) 555-0123
  • International Format +1 212 555 0123
  • 10 Digit 2125550123
  • 11 Digit 12325550123
  • URI tel:+12125550123
  • NPA 212
  • NXX 555
  • Line 0123

Example Usage

use Erichowey\NanpNumberFormatter\NanpNumberFormatter;
...
$number = NanpNumberFormatter::format("(212) 555-0123");

echo $number->e164; // +12125550123
echo $number->nationalFormat; // (212) 555-0123
echo $number->nationalFormatPlusOne; // 1 (212) 555-0123
echo $number->internationalFormat; // +1 212 555 0123
echo $number->dotFormat; // 212.555.0123
echo $number->hyphenFormat; // 212-555-0123
echo $number->tendigit; // 2125550123
echo $number->elevendigit; // 12125550123
echo $number->uri; // tel:+12125550123
echo $number->npa; // 212
echo $number->nxx; // 555
echo $number->line; // 0123
...

Wildcards

Historically, NANP telephone number wildcards have been represented with the following characters: X for 0-9, N for 2-9 and occasionally Y for 1-9 in dialplan matching. Since this tool accepts letter input, these wildcard characters cannot be used. To utilize wildcard characters, set the second parameter of the format() method to true. Use * to represent a wildcard character.

$number = NanpNumberFormatter::format("(212) 555-****", true);

Errors

If an invalid or non nanp number is attempted to be formatted, a NanpNumberFormatterException will be thrown. They can be handled with the typical try/catch pattern:

try {
    $number = NanpNumberFormatter::format("1234");
} catch (NanpNumberFormatterException $e) {
    echo $e->getMessage(); // 1234 is less than 10 characters
}

Contributing

Contributions are welcome. Criticism is even more welcome. You're welcome to submit a PR or open an issue. Please conform to PSR-12 standards and create tests for your PR.

Testing

Run

./vendor/bin/phpunit

统计信息

  • 总下载量: 3.79k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 2
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2020-06-03

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固