@qodalis/cli-core
Version:
Core Angular CLI for @qodalis extensions.
77 lines • 11.6 kB
JavaScript
import { CliBackgroundColor, CliForegroundColor } from '../models';
import { delay } from './delay';
import { ObjectDescriber } from './object-describer';
export const getParameterValue = (p, args) => {
return (args[p.name] ??
(p.aliases?.find((alias) => args[alias]) &&
args[p.aliases.find((alias) => args[alias])]));
};
export const formatJson = (json) => {
const identedJson = JSON.stringify(json, null, 2);
return colorizeJson(identedJson.split('\n').join('\r\n'));
};
export const colorizeJson = (jsonString) => {
return jsonString
.replace(/"([^"]+)":/g, '\x1b[33m"$1":\x1b[0m') // Keys (yellow)
.replace(/: "([^"]*)"/g, ': \x1b[32m"$1"\x1b[0m') // Strings (green)
.replace(/: (\d+)/g, ': \x1b[34m$1\x1b[0m') // Numbers (blue)
.replace(/: (true|false)/g, ': \x1b[35m$1\x1b[0m') // Booleans (magenta)
.replace(/: (null)/g, ': \x1b[36m$1\x1b[0m'); // Null (cyan)
};
export const toQueryString = (params) => {
const searchParams = new URLSearchParams();
for (const key in params) {
if (params.hasOwnProperty(key)) {
const value = params[key];
// Handle array and non-primitive values
if (Array.isArray(value)) {
value.forEach((v) => searchParams.append(key, v.toString()));
}
else if (value !== null && value !== undefined) {
searchParams.append(key, value.toString());
}
}
}
return searchParams.toString();
};
export const highlightTextWithBg = (text, pattern, bgColor = CliBackgroundColor.Yellow) => {
// Replace matches with background-colored text
return text.replace(pattern, (match) => `${bgColor}${match}${CliForegroundColor.Reset}`);
};
export const getRightOfWord = (command, word) => {
// Find the position of the word in the command
const index = command.indexOf(word);
// If the word is found, extract the substring to the right
if (index !== -1) {
return command.slice(index + word.length).trim();
}
// If the word is not found, return null
return undefined;
};
export const colorFirstWord = (text, colorFunction) => {
if (!text)
return text;
// Match leading spaces and first word separately
const match = text.match(/^(\s*)(\S+)(.*)$/);
if (!match)
return text; // If no match, return original text
const [, leadingSpaces, firstWord, restOfText] = match;
// Apply color only to the first word
const firstWordColored = colorFunction(firstWord);
// Reconstruct string: Keep spaces, color first word, and append rest
return `${leadingSpaces}${firstWordColored}${restOfText}`;
};
export * from './object-describer';
export * from './delay';
export const utils = {
getParameterValue,
formatJson,
colorizeJson,
toQueryString,
highlightTextWithBg,
getRightOfWord,
colorFirstWord,
ObjectDescriber,
delay,
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../projects/core/src/lib/utils/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { ICliCommandParameterDescriptor } from '../interfaces';\nimport { CliBackgroundColor, CliForegroundColor } from '../models';\nimport { delay } from './delay';\nimport { ObjectDescriber } from './object-describer';\n\nexport const getParameterValue = (\n    p: ICliCommandParameterDescriptor,\n    args: Record<string, any>,\n): any | undefined => {\n    return (\n        args[p.name] ??\n        (p.aliases?.find((alias) => args[alias]) &&\n            args[p.aliases!.find((alias) => args[alias])!])\n    );\n};\n\nexport const formatJson = (json: any): string => {\n    const identedJson = JSON.stringify(json, null, 2);\n\n    return colorizeJson(identedJson.split('\\n').join('\\r\\n'));\n};\n\nexport const colorizeJson = (jsonString: any): string => {\n    return jsonString\n        .replace(/\"([^\"]+)\":/g, '\\x1b[33m\"$1\":\\x1b[0m') // Keys (yellow)\n        .replace(/: \"([^\"]*)\"/g, ': \\x1b[32m\"$1\"\\x1b[0m') // Strings (green)\n        .replace(/: (\\d+)/g, ': \\x1b[34m$1\\x1b[0m') // Numbers (blue)\n        .replace(/: (true|false)/g, ': \\x1b[35m$1\\x1b[0m') // Booleans (magenta)\n        .replace(/: (null)/g, ': \\x1b[36m$1\\x1b[0m'); // Null (cyan)\n};\n\nexport const toQueryString = (params: Record<string, any>): string => {\n    const searchParams = new URLSearchParams();\n\n    for (const key in params) {\n        if (params.hasOwnProperty(key)) {\n            const value = params[key];\n            // Handle array and non-primitive values\n            if (Array.isArray(value)) {\n                value.forEach((v) => searchParams.append(key, v.toString()));\n            } else if (value !== null && value !== undefined) {\n                searchParams.append(key, value.toString());\n            }\n        }\n    }\n\n    return searchParams.toString();\n};\n\nexport const highlightTextWithBg = (\n    text: string,\n    pattern: RegExp,\n    bgColor: CliBackgroundColor = CliBackgroundColor.Yellow,\n): string => {\n    // Replace matches with background-colored text\n    return text.replace(\n        pattern,\n        (match) => `${bgColor}${match}${CliForegroundColor.Reset}`,\n    );\n};\n\nexport const getRightOfWord = (\n    command: string,\n    word: string,\n): string | undefined => {\n    // Find the position of the word in the command\n    const index = command.indexOf(word);\n\n    // If the word is found, extract the substring to the right\n    if (index !== -1) {\n        return command.slice(index + word.length).trim();\n    }\n\n    // If the word is not found, return null\n    return undefined;\n};\n\nexport const colorFirstWord = (\n    text: string,\n    colorFunction: (word: string) => string,\n) => {\n    if (!text) return text;\n\n    // Match leading spaces and first word separately\n    const match = text.match(/^(\\s*)(\\S+)(.*)$/);\n\n    if (!match) return text; // If no match, return original text\n\n    const [, leadingSpaces, firstWord, restOfText] = match;\n\n    // Apply color only to the first word\n    const firstWordColored = colorFunction(firstWord);\n\n    // Reconstruct string: Keep spaces, color first word, and append rest\n    return `${leadingSpaces}${firstWordColored}${restOfText}`;\n};\n\nexport * from './object-describer';\n\nexport * from './delay';\n\nexport const utils = {\n    getParameterValue,\n    formatJson,\n    colorizeJson,\n    toQueryString,\n    highlightTextWithBg,\n    getRightOfWord,\n    colorFirstWord,\n    ObjectDescriber,\n    delay,\n};\n"]}