react-phone-number-input
Version:
Telephone number input React component
71 lines (57 loc) • 2.44 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.createCountryIconComponent = createCountryIconComponent;
exports["default"] = void 0;
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _InternationalIcon = _interopRequireDefault(require("./InternationalIcon"));
var _Flag = _interopRequireDefault(require("./Flag"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
function createCountryIconComponent(_ref) {
var flags = _ref.flags,
flagUrl = _ref.flagUrl,
FlagComponent = _ref.flagComponent,
InternationalIcon = _ref.internationalIcon;
function CountryIcon(_ref2) {
var country = _ref2.country,
label = _ref2.label,
aspectRatio = _ref2.aspectRatio;
// `aspectRatio` is currently a hack for the default "International" icon
// to render it as a square when Unicode flag icons are used.
// So `aspectRatio` property is only used with the default "International" icon.
var _aspectRatio = InternationalIcon === _InternationalIcon["default"] ? aspectRatio : undefined;
return _react["default"].createElement("div", {
className: (0, _classnames["default"])('PhoneInputCountryIcon', {
'PhoneInputCountryIcon--square': _aspectRatio === 1,
'PhoneInputCountryIcon--border': country
})
}, country ? _react["default"].createElement(FlagComponent, {
country: country,
countryName: label,
flags: flags,
flagUrl: flagUrl,
className: "PhoneInputCountryIconImg"
}) : _react["default"].createElement(InternationalIcon, {
title: label,
aspectRatio: _aspectRatio,
className: "PhoneInputCountryIconImg"
}));
}
CountryIcon.propTypes = {
country: _propTypes["default"].string,
label: _propTypes["default"].string.isRequired,
aspectRatio: _propTypes["default"].number
};
return CountryIcon;
}
var _default = createCountryIconComponent({
// Must be equal to `defaultProps.flagUrl` in `./PhoneInputWithCountry.js`.
flagUrl: 'https://purecatamphetamine.github.io/country-flag-icons/3x2/{XX}.svg',
flagComponent: _Flag["default"],
internationalIcon: _InternationalIcon["default"]
});
exports["default"] = _default;
//# sourceMappingURL=CountryIcon.js.map