Skip to content

Commit

Permalink
X2-7706 feat(helpers): adds formatPhoneNumber helper function
Browse files Browse the repository at this point in the history
  • Loading branch information
kirtesh-xola committed Nov 8, 2023
1 parent 5a0e0cc commit 0b88646
Show file tree
Hide file tree
Showing 3 changed files with 58 additions and 39 deletions.
51 changes: 12 additions & 39 deletions src/components/Utilities/Phone.jsx
Original file line number Diff line number Diff line change
@@ -1,48 +1,21 @@
import React from "react";
import phoneLib from "google-libphonenumber";
import PropTypes from "prop-types";
import clsx from "clsx";

const PNF = phoneLib.PhoneNumberFormat;
const phoneUtil = phoneLib.PhoneNumberUtil.getInstance();
import PropTypes from "prop-types";
import React from "react";
import { formatPhoneNumber, getRegionCode } from "../../helpers/phone";

export const Phone = ({ countryCode = "US", className, children }) => {
const number = children;

try {
let phoneObject = phoneUtil.parseAndKeepRawInput(number, countryCode);

const regionCode = phoneUtil.getRegionCodeForNumber(phoneObject);
if (regionCode && regionCode !== countryCode) {
// If the region code is different than what was passed in, reparse according to that format
phoneObject = phoneUtil.parseAndKeepRawInput(number, regionCode);
}

// Parse number for display in the region's format
let formattedNumber;
if (regionCode) {
const format = regionCode === countryCode ? PNF.NATIONAL : PNF.INTERNATIONAL;
formattedNumber = phoneUtil.format(phoneObject, format);
} else {
// If we didn't detect a region, don't guess and return the original thing
formattedNumber = number;
}

return (
<span
className={clsx("ui-phone", className)}
data-region-code={regionCode || "N/A"}
data-country-code={countryCode}
title={number}
>
{formattedNumber}
</span>
);
} catch {}
const formattedNumber = formatPhoneNumber(number, countryCode);
const regionCode = getRegionCode(number, countryCode);

return (
<span className={clsx("ui-phone", className)} data-country-code={countryCode}>
{number}
<span
className={clsx("ui-phone", className)}
data-region-code={regionCode || "N/A"}
data-country-code={countryCode}
title={number}
>
{formattedNumber}
</span>
);
};
Expand Down
45 changes: 45 additions & 0 deletions src/helpers/phone.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
import phoneLib from "google-libphonenumber";

const PNF = phoneLib.PhoneNumberFormat;
const phoneUtil = phoneLib.PhoneNumberUtil.getInstance();

export const getRegionCode = (number, countryCode = "US") => {
let phoneObject = phoneUtil.parseAndKeepRawInput(number, countryCode);

return phoneUtil.getRegionCodeForNumber(phoneObject);
};

/**
* Formats the Phone Number for provided country code
*
* @param number {string}
* @param countryCode {string}
*
* @return {string}
*/
export const formatPhoneNumber = (number, countryCode = "US") => {
try {
let phoneObject = phoneUtil.parseAndKeepRawInput(number, countryCode);

const regionCode = phoneUtil.getRegionCodeForNumber(phoneObject);
if (regionCode && regionCode !== countryCode) {
// If the region code is different than what was passed in, reparse according to that format
phoneObject = phoneUtil.parseAndKeepRawInput(number, regionCode);
}

// Parse number for display in the region's format
let formattedNumber;

if (regionCode) {
const format = regionCode === countryCode ? PNF.NATIONAL : PNF.INTERNATIONAL;
formattedNumber = phoneUtil.format(phoneObject, format);
} else {
// If we didn't detect a region, don't guess and return the original thing
formattedNumber = number;
}

return formattedNumber;
} catch {
return number;
}
};
1 change: 1 addition & 0 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ export { XolaLogoSimple } from "./images/XolaLogoSimple";
export { almostZero, numberFormat, roundNumber } from "./helpers/numbers";
export { getSymbol, isZeroDecimal } from "./helpers/currency";
export { formatDate, formatTime, dateFromObjectId } from "./helpers/date";
export { formatPhoneNumber } from "./helpers/phone";
export { isOSX } from "./helpers/browser";
export { flash } from "./helpers/flash";

Expand Down

0 comments on commit 0b88646

Please sign in to comment.