
- Complete NestJS TypeScript implementation with WebSocket support - Direct messaging (DM) and group chat functionality - End-to-end encryption with AES encryption and key pairs - Media file support (images, videos, audio, documents) up to 100MB - Push notifications with Firebase Cloud Messaging integration - Mention alerts and real-time typing indicators - User authentication with JWT and Passport - SQLite database with TypeORM entities and relationships - Comprehensive API documentation with Swagger/OpenAPI - File upload handling with secure access control - Online/offline status tracking and presence management - Message editing, deletion, and reply functionality - Notification management with automatic cleanup - Health check endpoint for monitoring - CORS configuration for cross-origin requests - Environment-based configuration management - Structured for Flutter SDK integration Features implemented: ✅ Real-time messaging with Socket.IO ✅ User registration and authentication ✅ Direct messages and group chats ✅ Media file uploads and management ✅ End-to-end encryption ✅ Push notifications ✅ Mention alerts ✅ Typing indicators ✅ Message read receipts ✅ Online status tracking ✅ File access control ✅ Comprehensive API documentation Ready for Flutter SDK development and production deployment.
106 lines
2.1 KiB
JavaScript
106 lines
2.1 KiB
JavaScript
import _formatNumber from '../format.js'
|
|
import parse from '../parse.js'
|
|
import isObject from '../helpers/isObject.js'
|
|
|
|
export default function formatNumber() {
|
|
const {
|
|
input,
|
|
format,
|
|
options,
|
|
metadata
|
|
} = normalizeArguments(arguments)
|
|
|
|
return _formatNumber(input, format, options, metadata)
|
|
}
|
|
|
|
// Sort out arguments
|
|
function normalizeArguments(args)
|
|
{
|
|
const [arg_1, arg_2, arg_3, arg_4, arg_5] = Array.prototype.slice.call(args)
|
|
|
|
let input
|
|
let format
|
|
let options
|
|
let metadata
|
|
|
|
// Sort out arguments.
|
|
|
|
// If the phone number is passed as a string.
|
|
// `format('8005553535', ...)`.
|
|
if (typeof arg_1 === 'string')
|
|
{
|
|
// If country code is supplied.
|
|
// `format('8005553535', 'RU', 'NATIONAL', [options], metadata)`.
|
|
if (typeof arg_3 === 'string')
|
|
{
|
|
format = arg_3
|
|
|
|
if (arg_5)
|
|
{
|
|
options = arg_4
|
|
metadata = arg_5
|
|
}
|
|
else
|
|
{
|
|
metadata = arg_4
|
|
}
|
|
|
|
input = parse(arg_1, { defaultCountry: arg_2, extended: true }, metadata)
|
|
}
|
|
// Just an international phone number is supplied
|
|
// `format('+78005553535', 'NATIONAL', [options], metadata)`.
|
|
else
|
|
{
|
|
if (typeof arg_2 !== 'string')
|
|
{
|
|
throw new Error('`format` argument not passed to `formatNumber(number, format)`')
|
|
}
|
|
|
|
format = arg_2
|
|
|
|
if (arg_4)
|
|
{
|
|
options = arg_3
|
|
metadata = arg_4
|
|
}
|
|
else
|
|
{
|
|
metadata = arg_3
|
|
}
|
|
|
|
input = parse(arg_1, { extended: true }, metadata)
|
|
}
|
|
}
|
|
// If the phone number is passed as a parsed number object.
|
|
// `format({ phone: '8005553535', country: 'RU' }, 'NATIONAL', [options], metadata)`.
|
|
else if (isObject(arg_1))
|
|
{
|
|
input = arg_1
|
|
format = arg_2
|
|
|
|
if (arg_4)
|
|
{
|
|
options = arg_3
|
|
metadata = arg_4
|
|
}
|
|
else
|
|
{
|
|
metadata = arg_3
|
|
}
|
|
}
|
|
else throw new TypeError('A phone number must either be a string or an object of shape { phone, [country] }.')
|
|
|
|
// Legacy lowercase formats.
|
|
if (format === 'International') {
|
|
format = 'INTERNATIONAL'
|
|
} else if (format === 'National') {
|
|
format = 'NATIONAL'
|
|
}
|
|
|
|
return {
|
|
input,
|
|
format,
|
|
options,
|
|
metadata
|
|
}
|
|
} |