UNPKG

houser-js-utils

Version:

A comprehensive collection of TypeScript utility functions for common development tasks including array manipulation, string processing, date handling, random number generation, validation, and much more.

166 lines (165 loc) 4.71 kB
/** * @module FileUtils * @description A collection of utility functions for file operations, validation, and manipulation. * @example * ```typescript * import { FileUtils } from 'houser-js-utils'; * * // Get file extension * const ext = FileUtils.getFileExtension('document.pdf'); // 'pdf' * * // Validate file type * const isImage = FileUtils.isImageFile(file); * * // Format file size * const size = FileUtils.formatFileSize(file.size); * ``` */ declare global { interface Navigator { msSaveOrOpenBlob?: (blob: Blob, filename: string) => void; } } /** * Basic file types supported by the utility functions. */ type FileType = "image" | "video" | "audio" | "document"; /** * Interface representing file data with optional media ID and metadata. */ export interface FileData { /** Optional media identifier */ mediaId?: string; /** File name */ name: string; /** File MIME type */ type: string; /** Optional file metadata */ data?: { /** Optional media identifier */ mediaId?: string; /** File name */ name: string; }; } /** * Utility object containing file handling functions. */ export declare const FileUtils: { /** * Converts bytes to a human-readable size string. * * @param bytes - Number of bytes to convert * @returns Formatted size string (e.g., "1.5 MB") * * @example * ```typescript * const size = FileUtils.bytesToSize(1500000); // "1.5 MB" * ``` */ bytesToSize(bytes: number): string; /** * Downloads a blob as a file. * Supports both modern browsers and IE. * * @param blob - Blob to download * @param filename - Name of the file to save as * * @example * ```typescript * const blob = new Blob(['Hello World'], { type: 'text/plain' }); * FileUtils.downloadBlob(blob, 'hello.txt'); * ``` */ downloadBlob(blob: Blob, filename: string): void; /** * Extracts base64 data from a local URL. * * @param url - URL containing base64 data * @returns Base64 string or original URL if no base64 data found * * @example * ```typescript * const base64 = FileUtils.extractBase64FromLocalUrl('...'); * ``` */ extractBase64FromLocalUrl(url: string): string; /** * Checks if a file is already attached to a list of files. * * @param file - File to check * @param files - List of files to check against * @returns The matching file if found, undefined otherwise * * @example * ```typescript * const isDuplicate = FileUtils.fileIsAlreadyAttached(newFile, existingFiles); * ``` */ fileIsAlreadyAttached(file: FileData, files: FileData[]): FileData | undefined; /** * Gets the basic file type (image, video, audio, or document). * * @param file - File to check * @returns Basic file type * * @example * ```typescript * const type = FileUtils.getBasicFileType(imageFile); // "image" * ``` */ getBasicFileType(file: File): FileType; /** * Gets a base64 preview of an image file. * * @param file - Image file to preview * @returns Promise resolving to base64 string of the image * @throws Error if file is not an image or fails to load * * @example * ```typescript * const preview = await FileUtils.getImagePreview(imageFile); * ``` */ getImagePreview(file: File): Promise<string>; /** * Gets a local URL for a file. * * @param file - File to get URL for * @param callback - Callback function to receive the URL * * @example * ```typescript * FileUtils.getLocalUrl(file, (url) => { * console.log('File URL:', url); * }); * ``` */ getLocalUrl(file: File, callback: (url: string) => void): void; /** * Checks if a value is a valid file extension. * * @param extension - File extension to validate * @returns True if valid, false otherwise * * @example * ```typescript * const isValid = FileUtils.isFileExtension('jpg'); // true * ``` */ isFileExtension(extension: string): boolean; /** * Converts a size with units to bytes. * * @param size - Size to convert * @param units - Units of the size (B, KB, MB, GB, TB) * @returns Size in bytes * * @example * ```typescript * const bytes = FileUtils.sizeToBytes(1.5, 'MB'); // 1572864 * ``` */ sizeToBytes(size: string | number, units: string): number; }; export {};