@intlayer/core 8.2.2 → 8.2.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/dist/cjs/deepTransformPlugins/getMissingLocalesContent.cjs +1 -1
  2. package/dist/cjs/deepTransformPlugins/getMissingLocalesContent.cjs.map +1 -1
  3. package/dist/cjs/dictionaryManipulator/mergeDictionaries.cjs +1 -1
  4. package/dist/cjs/dictionaryManipulator/mergeDictionaries.cjs.map +1 -1
  5. package/dist/cjs/interpreter/getIntlayer.cjs +1 -1
  6. package/dist/cjs/interpreter/getIntlayer.cjs.map +1 -1
  7. package/dist/cjs/localization/getBrowserLocale.cjs.map +1 -1
  8. package/dist/cjs/localization/getLocalizedUrl.cjs +1 -1
  9. package/dist/cjs/localization/getLocalizedUrl.cjs.map +1 -1
  10. package/dist/cjs/localization/localeDetector.cjs.map +1 -1
  11. package/dist/cjs/markdown/compiler.cjs +2 -2
  12. package/dist/cjs/markdown/compiler.cjs.map +1 -1
  13. package/dist/cjs/markdown/constants.cjs.map +1 -1
  14. package/dist/cjs/markdown/parser.cjs +1 -1
  15. package/dist/cjs/markdown/parser.cjs.map +1 -1
  16. package/dist/cjs/markdown/renderer.cjs +1 -1
  17. package/dist/cjs/markdown/renderer.cjs.map +1 -1
  18. package/dist/cjs/markdown/utils.cjs +5 -5
  19. package/dist/cjs/markdown/utils.cjs.map +1 -1
  20. package/dist/cjs/transpiler/file/file.cjs +1 -1
  21. package/dist/esm/deepTransformPlugins/getMissingLocalesContent.mjs +1 -1
  22. package/dist/esm/deepTransformPlugins/getMissingLocalesContent.mjs.map +1 -1
  23. package/dist/esm/dictionaryManipulator/mergeDictionaries.mjs +1 -1
  24. package/dist/esm/dictionaryManipulator/mergeDictionaries.mjs.map +1 -1
  25. package/dist/esm/interpreter/getIntlayer.mjs +1 -1
  26. package/dist/esm/interpreter/getIntlayer.mjs.map +1 -1
  27. package/dist/esm/localization/getBrowserLocale.mjs.map +1 -1
  28. package/dist/esm/localization/getLocalizedUrl.mjs +1 -1
  29. package/dist/esm/localization/getLocalizedUrl.mjs.map +1 -1
  30. package/dist/esm/localization/localeDetector.mjs.map +1 -1
  31. package/dist/esm/markdown/compiler.mjs +6 -6
  32. package/dist/esm/markdown/compiler.mjs.map +1 -1
  33. package/dist/esm/markdown/constants.mjs.map +1 -1
  34. package/dist/esm/markdown/parser.mjs +1 -1
  35. package/dist/esm/markdown/parser.mjs.map +1 -1
  36. package/dist/esm/markdown/renderer.mjs +1 -1
  37. package/dist/esm/markdown/renderer.mjs.map +1 -1
  38. package/dist/esm/markdown/utils.mjs +6 -6
  39. package/dist/esm/markdown/utils.mjs.map +1 -1
  40. package/dist/esm/transpiler/file/file.mjs +1 -1
  41. package/dist/esm/transpiler/file/fileBrowser.mjs +1 -1
  42. package/dist/esm/transpiler/file/fileBrowser.mjs.map +1 -1
  43. package/dist/types/deepTransformPlugins/getMissingLocalesContent.d.ts.map +1 -1
  44. package/dist/types/interpreter/getIntlayer.d.ts.map +1 -1
  45. package/dist/types/localization/getLocalizedUrl.d.ts +1 -1
  46. package/dist/types/localization/getLocalizedUrl.d.ts.map +1 -1
  47. package/package.json +8 -8
@@ -1 +1 @@
1
- {"version":3,"file":"utils.mjs","names":[],"sources":["../../../src/markdown/utils.ts"],"sourcesContent":["import {\n ATTRIBUTES_TO_SANITIZE,\n CAPTURE_LETTER_AFTER_HYPHEN,\n CR_NEWLINE_R,\n DURATION_DELAY_TRIGGER,\n FORMFEED_R,\n HTML_CUSTOM_ATTR_R,\n INTERPOLATION_R,\n TAB_R,\n TABLE_CENTER_ALIGN,\n TABLE_LEFT_ALIGN,\n TABLE_RIGHT_ALIGN,\n TABLE_TRIM_PIPES,\n UNESCAPE_R,\n} from './constants';\nimport type { NestedParser, ParserResult, ParseState, Rule } from './types';\n\n// ============================================================================\n// STRING UTILITIES\n// ============================================================================\n\n/**\n * Trim trailing whitespace from a string.\n */\nexport const trimEnd = (str: string): string => {\n let end = str.length;\n\n while (end > 0 && str[end - 1] <= ' ') end--;\n\n return str.slice(0, end);\n};\n\n/**\n * Check if string starts with prefix.\n */\nexport const startsWith = (str: string, prefix: string): boolean => {\n return str.startsWith(prefix);\n};\n\n/**\n * Remove symmetrical leading and trailing quotes.\n */\nexport const unquote = (str: string): string => {\n const first = str[0];\n\n if (\n (first === '\"' || first === \"'\") &&\n str.length >= 2 &&\n str[str.length - 1] === first\n ) {\n return str.slice(1, -1);\n }\n\n return str;\n};\n\n/**\n * Unescape backslash-escaped characters.\n */\nexport const unescapeString = (rawString: string): string =>\n rawString ? rawString.replace(UNESCAPE_R, '$1') : rawString;\n\n/**\n * Join class names, filtering out falsy values.\n */\nexport const cx = (...args: any[]): string => args.filter(Boolean).join(' ');\n\n/**\n * Get a nested property from an object using dot notation.\n */\nexport const get = (src: any, path: string, fb?: any): any => {\n let ptr = src;\n const frags = path.split('.');\n\n while (frags.length) {\n ptr = ptr[frags[0]];\n\n if (ptr === undefined) break;\n else frags.shift();\n }\n\n return ptr ?? fb;\n};\n\n// ============================================================================\n// SLUGIFY\n// ============================================================================\n\n/**\n * Convert a string to a URL-safe slug.\n * Based on https://stackoverflow.com/a/18123682/1141611\n */\nexport const slugify = (str: string): string =>\n str\n .replace(/[ÀÁÂÃÄÅàáâãä忯]/g, 'a')\n .replace(/[çÇ]/g, 'c')\n .replace(/[ðÐ]/g, 'd')\n .replace(/[ÈÉÊËéèêë]/g, 'e')\n .replace(/[ÏïÎîÍíÌì]/g, 'i')\n .replace(/[Ññ]/g, 'n')\n .replace(/[øØœŒÕõÔôÓóÒò]/g, 'o')\n .replace(/[ÜüÛûÚúÙù]/g, 'u')\n .replace(/[ŸÿÝý]/g, 'y')\n .replace(/[^a-z0-9- ]/gi, '')\n .replace(/ /gi, '-')\n .toLowerCase();\n\n// ============================================================================\n// SANITIZER\n// ============================================================================\n\nconst SANITIZE_R = /(javascript|vbscript|data(?!:image)):/i;\n\n/**\n * Sanitize URLs to prevent XSS attacks.\n * Returns null if the URL is unsafe.\n */\nexport const sanitizer = (input: string): string | null => {\n try {\n const decoded = decodeURIComponent(input).replace(/[^A-Za-z0-9/:]/g, '');\n\n if (SANITIZE_R.test(decoded)) {\n if (process.env.NODE_ENV !== 'production') {\n console.warn(\n 'Input contains an unsafe JavaScript/VBScript/data expression, it will not be rendered.',\n decoded\n );\n }\n\n return null;\n }\n } catch (_e) {\n if (process.env.NODE_ENV !== 'production') {\n console.warn(\n 'Input could not be decoded due to malformed syntax or characters, it will not be rendered.',\n input\n );\n }\n\n // decodeURIComponent sometimes throws a URIError\n return null;\n }\n\n return input;\n};\n\n// ============================================================================\n// WHITESPACE NORMALIZATION\n// ============================================================================\n\n/**\n * Normalize whitespace in source string.\n */\nexport const normalizeWhitespace = (source: string): string => {\n const start = performance.now();\n const result = source\n .replace(CR_NEWLINE_R, '\\n')\n .replace(FORMFEED_R, '')\n .replace(TAB_R, ' ');\n\n const duration = performance.now() - start;\n\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `normalizeWhitespace: ${duration.toFixed(3)}ms, source length: ${source.length}`\n );\n }\n\n return result;\n};\n\n/**\n * Safely remove a uniform leading indentation from lines, but do NOT touch\n * the content inside fenced code blocks (``` or ~~~).\n */\nexport const trimLeadingWhitespaceOutsideFences = (\n text: string,\n whitespace: string\n): string => {\n const start = performance.now();\n if (!whitespace) return text;\n\n const lines = text.split('\\n');\n let inFence = false;\n let fenceToken: string | null = null;\n\n const isFenceLine = (line: string): RegExpMatchArray | null =>\n line.match(/^\\s*(`{3,}|~{3,})/);\n\n const maybeToggleFence = (line: string): void => {\n const m = isFenceLine(line);\n\n if (!m) return;\n\n const token = m[1];\n\n if (!inFence) {\n inFence = true;\n fenceToken = token;\n } else if (fenceToken && line.includes(fenceToken)) {\n inFence = false;\n fenceToken = null;\n }\n };\n\n const out = lines.map((line) => {\n const fenceMatch = isFenceLine(line);\n if (fenceMatch) {\n const trimmedFenceLine = line.startsWith(whitespace)\n ? line.slice(whitespace.length)\n : line;\n maybeToggleFence(line);\n return trimmedFenceLine;\n }\n\n if (inFence) {\n return line;\n }\n\n return line.startsWith(whitespace) ? line.slice(whitespace.length) : line;\n });\n\n const result = out.join('\\n');\n\n const duration = performance.now() - start;\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `trimLeadingWhitespaceOutsideFences: ${duration.toFixed(3)}ms, text length: ${text.length}, lines count: ${lines.length}`\n );\n }\n\n return result;\n};\n\n/**\n * Normalize HTML attribute key to JSX prop name.\n */\nexport const normalizeAttributeKey = (key: string): string => {\n const hyphenIndex = key.indexOf('-');\n\n if (hyphenIndex !== -1 && key.match(HTML_CUSTOM_ATTR_R) === null) {\n key = key.replace(CAPTURE_LETTER_AFTER_HYPHEN, (_, letter) => {\n return letter.toUpperCase();\n });\n }\n\n return key;\n};\n\ntype StyleTuple = [key: string, value: string];\n\n/**\n * Parse a CSS style string into an array of [key, value] tuples.\n */\nexport const parseStyleAttribute = (styleString: string): StyleTuple[] => {\n const start = performance.now();\n const styles: StyleTuple[] = [];\n let buffer = '';\n let inUrl = false;\n let inQuotes = false;\n let quoteChar: '\"' | \"'\" | '' = '';\n\n if (!styleString) return styles;\n\n for (let i = 0; i < styleString.length; i++) {\n const char = styleString[i];\n\n if ((char === '\"' || char === \"'\") && !inUrl) {\n if (!inQuotes) {\n inQuotes = true;\n quoteChar = char;\n } else if (char === quoteChar) {\n inQuotes = false;\n quoteChar = '';\n }\n }\n\n if (char === '(' && buffer.endsWith('url')) {\n inUrl = true;\n } else if (char === ')' && inUrl) {\n inUrl = false;\n }\n\n if (char === ';' && !inQuotes && !inUrl) {\n const declaration = buffer.trim();\n\n if (declaration) {\n const colonIndex = declaration.indexOf(':');\n\n if (colonIndex > 0) {\n const key = declaration.slice(0, colonIndex).trim();\n const value = declaration.slice(colonIndex + 1).trim();\n styles.push([key, value]);\n }\n }\n buffer = '';\n } else {\n buffer += char;\n }\n }\n\n const declaration = buffer.trim();\n\n if (declaration) {\n const colonIndex = declaration.indexOf(':');\n if (colonIndex > 0) {\n const key = declaration.slice(0, colonIndex).trim();\n const value = declaration.slice(colonIndex + 1).trim();\n styles.push([key, value]);\n }\n }\n\n const duration = performance.now() - start;\n\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `parseStyleAttribute: ${duration.toFixed(3)}ms, styleString length: ${styleString.length}, styles count: ${styles.length}`\n );\n }\n\n return styles;\n};\n\n/**\n * Convert an attribute value to a Node prop value.\n */\nexport const attributeValueToNodePropValue = (\n tag: string,\n key: string,\n value: string,\n sanitizeUrlFn: (\n value: string,\n tag: string,\n attribute: string\n ) => string | null\n): any => {\n if (key === 'style') {\n return parseStyleAttribute(value).reduce(\n (styles, [styleKey, styleValue]) => {\n const camelCasedKey = styleKey.replace(/(-[a-z])/g, (substr) =>\n substr[1].toUpperCase()\n );\n\n (styles as Record<string, any>)[camelCasedKey] = sanitizeUrlFn(\n styleValue,\n tag,\n styleKey\n );\n\n return styles;\n },\n {} as Record<string, any>\n );\n } else if (ATTRIBUTES_TO_SANITIZE.indexOf(key) !== -1) {\n return sanitizeUrlFn(unescapeString(value), tag, key);\n } else if (value.match(INTERPOLATION_R)) {\n value = unescapeString(value.slice(1, value.length - 1));\n }\n\n if (value === 'true') {\n return true;\n } else if (value === 'false') {\n return false;\n }\n\n return value;\n};\n\n// ============================================================================\n// TABLE PARSING\n// ============================================================================\n\n/**\n * Parse table alignment from a separator row.\n */\nexport const parseTableAlignCapture = (\n alignCapture: string\n): 'left' | 'right' | 'center' => {\n if (TABLE_RIGHT_ALIGN.test(alignCapture)) {\n return 'right';\n } else if (TABLE_CENTER_ALIGN.test(alignCapture)) {\n return 'center';\n } else if (TABLE_LEFT_ALIGN.test(alignCapture)) {\n return 'left';\n }\n\n return 'left';\n};\n\n/**\n * Parse table alignment row.\n */\nexport const parseTableAlign = (\n source: string\n): ('left' | 'right' | 'center')[] => {\n const alignText = source.replace(TABLE_TRIM_PIPES, '').split('|');\n return alignText.map(parseTableAlignCapture);\n};\n\n/**\n * Parse a single table row.\n */\nexport const parseTableRow = (\n source: string,\n parse: NestedParser,\n state: ParseState,\n tableOutput: boolean\n): ParserResult[][] => {\n const start = performance.now();\n const prevInTable = state.inTable;\n\n state.inTable = true;\n\n const cells: ParserResult[][] = [[]];\n let acc = '';\n\n const flush = (): void => {\n if (!acc) return;\n\n const cell = cells[cells.length - 1];\n cell.push.apply(cell, parse(acc, state));\n acc = '';\n };\n\n source\n .trim()\n .split(/(`[^`]*`|\\\\\\||\\|)/)\n .filter(Boolean)\n .forEach((fragment, i, arr) => {\n if (fragment.trim() === '|') {\n flush();\n\n if (tableOutput) {\n if (i !== 0 && i !== arr.length - 1) {\n cells.push([]);\n }\n\n return;\n }\n }\n\n acc += fragment;\n });\n\n flush();\n\n state.inTable = prevInTable;\n\n const duration = performance.now() - start;\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `parseTableRow: ${duration.toFixed(3)}ms, source length: ${source.length}, cells count: ${cells.length}`\n );\n }\n\n return cells;\n};\n\n/**\n * Parse table cells (multiple rows).\n */\nexport const parseTableCells = (\n source: string,\n parse: NestedParser,\n state: ParseState\n): ParserResult[][][] => {\n const start = performance.now();\n const rowsText = source.trim().split('\\n');\n\n const result = rowsText.map((rowText) =>\n parseTableRow(rowText, parse, state, true)\n );\n\n const duration = performance.now() - start;\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `parseTableCells: ${duration.toFixed(3)}ms, source length: ${source.length}, rows count: ${rowsText.length}`\n );\n }\n\n return result;\n};\n\n// ============================================================================\n// PARSING HELPERS\n// ============================================================================\n\n/**\n * Check if a rule qualifies for the current source and state.\n */\nexport const qualifies = (\n source: string,\n state: ParseState,\n qualify: NonNullable<Rule<any>['_qualify']>\n): boolean => {\n if (Array.isArray(qualify)) {\n for (let i = 0; i < qualify.length; i++) {\n if (startsWith(source, qualify[i])) return true;\n }\n\n return false;\n }\n\n return (qualify as (source: string, state: ParseState) => boolean)(\n source,\n state\n );\n};\n\n/**\n * Marks a matcher function as eligible for being run inside an inline context.\n */\nexport const allowInline = <T extends (...args: any[]) => any>(\n fn: T\n): T & { inline: 1 } => {\n (fn as any).inline = 1;\n return fn as T & { inline: 1 };\n};\n\n/**\n * Creates a match function for an inline scoped element from a regex.\n */\nexport const inlineRegex = (regex: RegExp) =>\n allowInline((source: string, state: ParseState): RegExpMatchArray | null => {\n if (state.inline) {\n return regex.exec(source);\n } else {\n return null;\n }\n });\n\n/**\n * Creates a match function for inline elements except links.\n */\nexport const simpleInlineRegex = (regex: RegExp) =>\n allowInline((source: string, state: ParseState): RegExpMatchArray | null => {\n if (state.inline || state.simple) {\n return regex.exec(source);\n } else {\n return null;\n }\n });\n\n/**\n * Creates a match function for a block scoped element from a regex.\n */\nexport const blockRegex =\n (regex: RegExp) =>\n (source: string, state: ParseState): RegExpMatchArray | null => {\n if (state.inline || state.simple) {\n return null;\n } else {\n return regex.exec(source);\n }\n };\n\n/**\n * Creates a match function from a regex, ignoring block/inline scope.\n */\nexport const anyScopeRegex = (\n fn: RegExp | ((source: string, state: ParseState) => RegExpMatchArray | null)\n) =>\n allowInline((source: string, state: ParseState): RegExpMatchArray | null => {\n if (typeof fn === 'function') {\n return fn(source, state);\n }\n return fn.exec(source);\n });\n\n/**\n * Parse inline content (including links).\n */\nexport const parseInline = (\n parse: NestedParser,\n children: string,\n state: ParseState\n): ParserResult[] => {\n const start = performance.now();\n const isCurrentlyInline = state.inline ?? false;\n const isCurrentlySimple = state.simple ?? false;\n state.inline = true;\n state.simple = true;\n const result = parse(children, state);\n state.inline = isCurrentlyInline;\n state.simple = isCurrentlySimple;\n\n const duration = performance.now() - start;\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `parseInline: ${duration.toFixed(3)}ms, children length: ${children.length}, result count: ${result.length}`\n );\n }\n\n return result;\n};\n\n/**\n * Parse simple inline content (no links).\n */\nexport const parseSimpleInline = (\n parse: NestedParser,\n children: string,\n state: ParseState\n): ParserResult[] => {\n const start = performance.now();\n const isCurrentlyInline = state.inline ?? false;\n const isCurrentlySimple = state.simple ?? false;\n\n state.inline = false;\n state.simple = true;\n const result = parse(children, state);\n state.inline = isCurrentlyInline;\n state.simple = isCurrentlySimple;\n\n const duration = performance.now() - start;\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `parseSimpleInline: ${duration.toFixed(3)}ms, children length: ${children.length}, result count: ${result.length}`\n );\n }\n\n return result;\n};\n\n/**\n * Parse block content.\n */\nexport const parseBlock = (\n parse: NestedParser,\n children: string,\n state: ParseState = {}\n): ParserResult[] => {\n const start = performance.now();\n const isCurrentlyInline = state.inline || false;\n state.inline = false;\n const normalizedChildren = trimEnd(children);\n const needsTerminator = /\\n\\n$/.test(normalizedChildren) === false;\n const blockInput = needsTerminator\n ? normalizedChildren.endsWith('\\n')\n ? `${normalizedChildren}\\n`\n : `${normalizedChildren}\\n\\n`\n : normalizedChildren;\n\n const result = parse(blockInput, state);\n state.inline = isCurrentlyInline;\n\n const duration = performance.now() - start;\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `parseBlock: ${duration.toFixed(3)}ms, children length: ${children.length}, result count: ${result.length}`\n );\n }\n\n return result;\n};\n\n/**\n * Helper to parse capture group 2 as inline content.\n */\nexport const parseCaptureInline = (\n capture: RegExpMatchArray,\n parse: NestedParser,\n state: ParseState\n): { children: ParserResult[] } => {\n return {\n children: parseInline(parse, capture[2], state),\n };\n};\n\n/**\n * Helper that captures nothing (empty object).\n */\nexport const captureNothing = (): Record<string, never> => ({});\n\n/**\n * Helper that renders nothing (null).\n */\nexport const renderNothing = (): null => null;\n\n/**\n * Check if any regex in a list matches the input.\n */\nexport const some = (regexes: RegExp[], input: string): boolean => {\n for (let i = 0; i < regexes.length; i++) {\n if (regexes[i].test(input)) {\n return true;\n }\n }\n return false;\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"utils.mjs","names":[],"sources":["../../../src/markdown/utils.ts"],"sourcesContent":["import {\n ATTRIBUTES_TO_SANITIZE,\n CAPTURE_LETTER_AFTER_HYPHEN,\n CR_NEWLINE_R,\n DURATION_DELAY_TRIGGER,\n FORMFEED_R,\n HTML_CUSTOM_ATTR_R,\n INTERPOLATION_R,\n TAB_R,\n TABLE_CENTER_ALIGN,\n TABLE_LEFT_ALIGN,\n TABLE_RIGHT_ALIGN,\n TABLE_TRIM_PIPES,\n UNESCAPE_R,\n} from './constants';\nimport type { NestedParser, ParserResult, ParseState, Rule } from './types';\n\n// ============================================================================\n// STRING UTILITIES\n// ============================================================================\n\n/**\n * Trim trailing whitespace from a string.\n */\nexport const trimEnd = (str: string): string => {\n let end = str.length;\n\n while (end > 0 && str[end - 1] <= ' ') end--;\n\n return str.slice(0, end);\n};\n\n/**\n * Check if string starts with prefix.\n */\nexport const startsWith = (str: string, prefix: string): boolean => {\n return str.startsWith(prefix);\n};\n\n/**\n * Remove symmetrical leading and trailing quotes.\n */\nexport const unquote = (str: string): string => {\n const first = str[0];\n\n if (\n (first === '\"' || first === \"'\") &&\n str.length >= 2 &&\n str[str.length - 1] === first\n ) {\n return str.slice(1, -1);\n }\n\n return str;\n};\n\n/**\n * Unescape backslash-escaped characters.\n */\nexport const unescapeString = (rawString: string): string =>\n rawString ? rawString.replace(UNESCAPE_R, '$1') : rawString;\n\n/**\n * Join class names, filtering out falsy values.\n */\nexport const cx = (...args: any[]): string => args.filter(Boolean).join(' ');\n\n/**\n * Get a nested property from an object using dot notation.\n */\nexport const get = (src: any, path: string, fb?: any): any => {\n let ptr = src;\n const frags = path.split('.');\n\n while (frags.length) {\n ptr = ptr[frags[0]];\n\n if (ptr === undefined) break;\n else frags.shift();\n }\n\n return ptr ?? fb;\n};\n\n// ============================================================================\n// SLUGIFY\n// ============================================================================\n\n/**\n * Convert a string to a URL-safe slug.\n * Based on https://stackoverflow.com/a/18123682/1141611\n */\nexport const slugify = (str: string): string =>\n str\n .replace(/[ÀÁÂÃÄÅàáâãä忯]/g, 'a')\n .replace(/[çÇ]/g, 'c')\n .replace(/[ðÐ]/g, 'd')\n .replace(/[ÈÉÊËéèêë]/g, 'e')\n .replace(/[ÏïÎîÍíÌì]/g, 'i')\n .replace(/[Ññ]/g, 'n')\n .replace(/[øØœŒÕõÔôÓóÒò]/g, 'o')\n .replace(/[ÜüÛûÚúÙù]/g, 'u')\n .replace(/[ŸÿÝý]/g, 'y')\n .replace(/[^a-z0-9- ]/gi, '')\n .replace(/ /gi, '-')\n .toLowerCase();\n\n// ============================================================================\n// SANITIZER\n// ============================================================================\n\nconst SANITIZE_R = /(javascript|vbscript|data(?!:image)):/i;\n\n/**\n * Sanitize URLs to prevent XSS attacks.\n * Returns null if the URL is unsafe.\n */\nexport const sanitizer = (input: string): string | null => {\n try {\n const decoded = decodeURIComponent(input).replace(/[^A-Za-z0-9/:]/g, '');\n\n if (SANITIZE_R.test(decoded)) {\n if (process.env.NODE_ENV !== 'production') {\n console.warn(\n 'Input contains an unsafe JavaScript/VBScript/data expression, it will not be rendered.',\n decoded\n );\n }\n\n return null;\n }\n } catch (_e) {\n if (process.env.NODE_ENV !== 'production') {\n console.warn(\n 'Input could not be decoded due to malformed syntax or characters, it will not be rendered.',\n input\n );\n }\n\n // decodeURIComponent sometimes throws a URIError\n return null;\n }\n\n return input;\n};\n\n// ============================================================================\n// WHITESPACE NORMALIZATION\n// ============================================================================\n\n/**\n * Normalize whitespace in source string.\n */\nexport const normalizeWhitespace = (source: string): string => {\n const start = performance.now();\n const result = source\n .replace(CR_NEWLINE_R, '\\n')\n .replace(FORMFEED_R, '')\n .replace(TAB_R, ' ');\n\n const duration = performance.now() - start;\n\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `normalizeWhitespace: ${duration.toFixed(3)}ms, source length: ${source.length}`\n );\n }\n\n return result;\n};\n\n/**\n * Safely remove a uniform leading indentation from lines, but do NOT touch\n * the content inside fenced code blocks (``` or ~~~).\n */\nexport const trimLeadingWhitespaceOutsideFences = (\n text: string,\n whitespace: string\n): string => {\n const start = performance.now();\n if (!whitespace) return text;\n\n const lines = text.split('\\n');\n let inFence = false;\n let fenceToken: string | null = null;\n\n const isFenceLine = (line: string): RegExpMatchArray | null =>\n line.match(/^\\s*(`{3,}|~{3,})/);\n\n const maybeToggleFence = (line: string): void => {\n const m = isFenceLine(line);\n\n if (!m) return;\n\n const token = m[1];\n\n if (!inFence) {\n inFence = true;\n fenceToken = token;\n } else if (fenceToken && line.includes(fenceToken)) {\n inFence = false;\n fenceToken = null;\n }\n };\n\n const out = lines.map((line) => {\n const fenceMatch = isFenceLine(line);\n if (fenceMatch) {\n const trimmedFenceLine = line.startsWith(whitespace)\n ? line.slice(whitespace.length)\n : line;\n maybeToggleFence(line);\n return trimmedFenceLine;\n }\n\n if (inFence) {\n return line;\n }\n\n return line.startsWith(whitespace) ? line.slice(whitespace.length) : line;\n });\n\n const result = out.join('\\n');\n\n const duration = performance.now() - start;\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `trimLeadingWhitespaceOutsideFences: ${duration.toFixed(3)}ms, text length: ${text.length}, lines count: ${lines.length}`\n );\n }\n\n return result;\n};\n\n/**\n * Normalize HTML attribute key to JSX prop name.\n */\nexport const normalizeAttributeKey = (key: string): string => {\n const hyphenIndex = key.indexOf('-');\n\n if (hyphenIndex !== -1 && key.match(HTML_CUSTOM_ATTR_R) === null) {\n key = key.replace(CAPTURE_LETTER_AFTER_HYPHEN, (_, letter) => {\n return letter.toUpperCase();\n });\n }\n\n return key;\n};\n\ntype StyleTuple = [key: string, value: string];\n\n/**\n * Parse a CSS style string into an array of [key, value] tuples.\n */\nexport const parseStyleAttribute = (styleString: string): StyleTuple[] => {\n const start = performance.now();\n const styles: StyleTuple[] = [];\n let buffer = '';\n let inUrl = false;\n let inQuotes = false;\n let quoteChar: '\"' | \"'\" | '' = '';\n\n if (!styleString) return styles;\n\n for (let i = 0; i < styleString.length; i++) {\n const char = styleString[i];\n\n if ((char === '\"' || char === \"'\") && !inUrl) {\n if (!inQuotes) {\n inQuotes = true;\n quoteChar = char;\n } else if (char === quoteChar) {\n inQuotes = false;\n quoteChar = '';\n }\n }\n\n if (char === '(' && buffer.endsWith('url')) {\n inUrl = true;\n } else if (char === ')' && inUrl) {\n inUrl = false;\n }\n\n if (char === ';' && !inQuotes && !inUrl) {\n const declaration = buffer.trim();\n\n if (declaration) {\n const colonIndex = declaration.indexOf(':');\n\n if (colonIndex > 0) {\n const key = declaration.slice(0, colonIndex).trim();\n const value = declaration.slice(colonIndex + 1).trim();\n styles.push([key, value]);\n }\n }\n buffer = '';\n } else {\n buffer += char;\n }\n }\n\n const declaration = buffer.trim();\n\n if (declaration) {\n const colonIndex = declaration.indexOf(':');\n if (colonIndex > 0) {\n const key = declaration.slice(0, colonIndex).trim();\n const value = declaration.slice(colonIndex + 1).trim();\n styles.push([key, value]);\n }\n }\n\n const duration = performance.now() - start;\n\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `parseStyleAttribute: ${duration.toFixed(3)}ms, styleString length: ${styleString.length}, styles count: ${styles.length}`\n );\n }\n\n return styles;\n};\n\n/**\n * Convert an attribute value to a Node prop value.\n */\nexport const attributeValueToNodePropValue = (\n tag: string,\n key: string,\n value: string,\n sanitizeUrlFn: (\n value: string,\n tag: string,\n attribute: string\n ) => string | null\n): any => {\n if (key === 'style') {\n return parseStyleAttribute(value).reduce(\n (styles, [styleKey, styleValue]) => {\n const camelCasedKey = styleKey.replace(/(-[a-z])/g, (substr) =>\n substr[1].toUpperCase()\n );\n\n (styles as Record<string, any>)[camelCasedKey] = sanitizeUrlFn(\n styleValue,\n tag,\n styleKey\n );\n\n return styles;\n },\n {} as Record<string, any>\n );\n } else if (ATTRIBUTES_TO_SANITIZE.indexOf(key) !== -1) {\n return sanitizeUrlFn(unescapeString(value), tag, key);\n } else if (value.match(INTERPOLATION_R)) {\n value = unescapeString(value.slice(1, value.length - 1));\n }\n\n if (value === 'true') {\n return true;\n } else if (value === 'false') {\n return false;\n }\n\n return value;\n};\n\n// ============================================================================\n// TABLE PARSING\n// ============================================================================\n\n/**\n * Parse table alignment from a separator row.\n */\nexport const parseTableAlignCapture = (\n alignCapture: string\n): 'left' | 'right' | 'center' => {\n if (TABLE_RIGHT_ALIGN.test(alignCapture)) {\n return 'right';\n } else if (TABLE_CENTER_ALIGN.test(alignCapture)) {\n return 'center';\n } else if (TABLE_LEFT_ALIGN.test(alignCapture)) {\n return 'left';\n }\n\n return 'left';\n};\n\n/**\n * Parse table alignment row.\n */\nexport const parseTableAlign = (\n source: string\n): ('left' | 'right' | 'center')[] => {\n const alignText = source.replace(TABLE_TRIM_PIPES, '').split('|');\n return alignText.map(parseTableAlignCapture);\n};\n\n/**\n * Parse a single table row.\n */\nexport const parseTableRow = (\n source: string,\n parse: NestedParser,\n state: ParseState,\n tableOutput: boolean\n): ParserResult[][] => {\n const start = performance.now();\n const prevInTable = state.inTable;\n\n state.inTable = true;\n\n const cells: ParserResult[][] = [[]];\n let acc = '';\n\n const flush = (): void => {\n if (!acc) return;\n\n const cell = cells[cells.length - 1];\n cell.push.apply(cell, parse(acc, state));\n acc = '';\n };\n\n source\n .trim()\n .split(/(`[^`]*`|\\\\\\||\\|)/)\n .filter(Boolean)\n .forEach((fragment, i, arr) => {\n if (fragment.trim() === '|') {\n flush();\n\n if (tableOutput) {\n if (i !== 0 && i !== arr.length - 1) {\n cells.push([]);\n }\n\n return;\n }\n }\n\n acc += fragment;\n });\n\n flush();\n\n state.inTable = prevInTable;\n\n const duration = performance.now() - start;\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `parseTableRow: ${duration.toFixed(3)}ms, source length: ${source.length}, cells count: ${cells.length}`\n );\n }\n\n return cells;\n};\n\n/**\n * Parse table cells (multiple rows).\n */\nexport const parseTableCells = (\n source: string,\n parse: NestedParser,\n state: ParseState\n): ParserResult[][][] => {\n const start = performance.now();\n const rowsText = source.trim().split('\\n');\n\n const result = rowsText.map((rowText) =>\n parseTableRow(rowText, parse, state, true)\n );\n\n const duration = performance.now() - start;\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `parseTableCells: ${duration.toFixed(3)}ms, source length: ${source.length}, rows count: ${rowsText.length}`\n );\n }\n\n return result;\n};\n\n// ============================================================================\n// PARSING HELPERS\n// ============================================================================\n\n/**\n * Check if a rule qualifies for the current source and state.\n */\nexport const qualifies = (\n source: string,\n state: ParseState,\n qualify: NonNullable<Rule<any>['_qualify']>\n): boolean => {\n if (Array.isArray(qualify)) {\n for (let i = 0; i < qualify.length; i++) {\n if (startsWith(source, qualify[i])) return true;\n }\n\n return false;\n }\n\n return (qualify as (source: string, state: ParseState) => boolean)(\n source,\n state\n );\n};\n\n/**\n * Marks a matcher function as eligible for being run inside an inline context.\n */\nexport const allowInline = <T extends (...args: any[]) => any>(\n fn: T\n): T & { inline: 1 } => {\n (fn as any).inline = 1;\n return fn as T & { inline: 1 };\n};\n\n/**\n * Creates a match function for an inline scoped element from a regex.\n */\nexport const inlineRegex = (regex: RegExp) =>\n allowInline((source: string, state: ParseState): RegExpMatchArray | null => {\n if (state.inline) {\n return regex.exec(source);\n } else {\n return null;\n }\n });\n\n/**\n * Creates a match function for inline elements except links.\n */\nexport const simpleInlineRegex = (regex: RegExp) =>\n allowInline((source: string, state: ParseState): RegExpMatchArray | null => {\n if (state.inline || state.simple) {\n return regex.exec(source);\n } else {\n return null;\n }\n });\n\n/**\n * Creates a match function for a block scoped element from a regex.\n */\nexport const blockRegex =\n (regex: RegExp) =>\n (source: string, state: ParseState): RegExpMatchArray | null => {\n if (state.inline || state.simple) {\n return null;\n } else {\n return regex.exec(source);\n }\n };\n\n/**\n * Creates a match function from a regex, ignoring block/inline scope.\n */\nexport const anyScopeRegex = (\n fn: RegExp | ((source: string, state: ParseState) => RegExpMatchArray | null)\n) =>\n allowInline((source: string, state: ParseState): RegExpMatchArray | null => {\n if (typeof fn === 'function') {\n return fn(source, state);\n }\n return fn.exec(source);\n });\n\n/**\n * Parse inline content (including links).\n */\nexport const parseInline = (\n parse: NestedParser,\n children: string,\n state: ParseState\n): ParserResult[] => {\n const start = performance.now();\n const isCurrentlyInline = state.inline ?? false;\n const isCurrentlySimple = state.simple ?? false;\n state.inline = true;\n state.simple = true;\n const result = parse(children, state);\n state.inline = isCurrentlyInline;\n state.simple = isCurrentlySimple;\n\n const duration = performance.now() - start;\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `parseInline: ${duration.toFixed(3)}ms, children length: ${children.length}, result count: ${result.length}`\n );\n }\n\n return result;\n};\n\n/**\n * Parse simple inline content (no links).\n */\nexport const parseSimpleInline = (\n parse: NestedParser,\n children: string,\n state: ParseState\n): ParserResult[] => {\n const start = performance.now();\n const isCurrentlyInline = state.inline ?? false;\n const isCurrentlySimple = state.simple ?? false;\n\n state.inline = false;\n state.simple = true;\n const result = parse(children, state);\n state.inline = isCurrentlyInline;\n state.simple = isCurrentlySimple;\n\n const duration = performance.now() - start;\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `parseSimpleInline: ${duration.toFixed(3)}ms, children length: ${children.length}, result count: ${result.length}`\n );\n }\n\n return result;\n};\n\n/**\n * Parse block content.\n */\nexport const parseBlock = (\n parse: NestedParser,\n children: string,\n state: ParseState = {}\n): ParserResult[] => {\n const start = performance.now();\n const isCurrentlyInline = state.inline || false;\n state.inline = false;\n const normalizedChildren = trimEnd(children);\n const needsTerminator = /\\n\\n$/.test(normalizedChildren) === false;\n const blockInput = needsTerminator\n ? normalizedChildren.endsWith('\\n')\n ? `${normalizedChildren}\\n`\n : `${normalizedChildren}\\n\\n`\n : normalizedChildren;\n\n const result = parse(blockInput, state);\n state.inline = isCurrentlyInline;\n\n const duration = performance.now() - start;\n if (duration > DURATION_DELAY_TRIGGER) {\n console.log(\n `parseBlock: ${duration.toFixed(3)}ms, children length: ${children.length}, result count: ${result.length}`\n );\n }\n\n return result;\n};\n\n/**\n * Helper to parse capture group 2 as inline content.\n */\nexport const parseCaptureInline = (\n capture: RegExpMatchArray,\n parse: NestedParser,\n state: ParseState\n): { children: ParserResult[] } => {\n return {\n children: parseInline(parse, capture[2], state),\n };\n};\n\n/**\n * Helper that captures nothing (empty object).\n */\nexport const captureNothing = (): Record<string, never> => ({});\n\n/**\n * Helper that renders nothing (null).\n */\nexport const renderNothing = (): null => null;\n\n/**\n * Check if any regex in a list matches the input.\n */\nexport const some = (regexes: RegExp[], input: string): boolean => {\n for (let i = 0; i < regexes.length; i++) {\n if (regexes[i].test(input)) {\n return true;\n }\n }\n return false;\n};\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import{NodeType as e,formatNodeType as t}from"@intlayer/types";import{existsSync as n,readFileSync as r,statSync as i}from"node:fs";import{dirname as a,isAbsolute as o,relative as s,resolve as c}from"node:path";import{colorizePath as l,getAppLogger as u}from"@intlayer/config/logger";const d=(a,d,f)=>{let p=a.startsWith(`./`)||a.startsWith(`../`),m=u(),h;if(o(a)?(m(`Using absolute path for file is not recommended. Use relative paths instead. Path: ${a}, imported from: ${d}`,{level:`warn`}),h=a):h=c(p?d:f,a),n(h)&&i(h).isFile())try{let n=r(h,`utf8`);return t(e.File,a,{content:n,fixedPath:s(f,h)})}catch{m(`Unable to read path: ${l(s(f,h))}`,{level:`warn`})}else m(`File not found: ${l(s(f,h))}`,{level:`warn`});return t(e.File,a,{content:`-`})},f=e=>{let{INTLAYER_FILE_PATH:t,INTLAYER_BASE_DIR:n}=globalThis;return d(e,a(t),n)};export{f as file,d as fileContent};
1
+ import{NodeType as e,formatNodeType as t}from"@intlayer/types";import{colorizePath as n,getAppLogger as r}from"@intlayer/config/logger";import{existsSync as i,readFileSync as a,statSync as o}from"node:fs";import{dirname as s,isAbsolute as c,relative as l,resolve as u}from"node:path";const d=(s,d,f)=>{let p=s.startsWith(`./`)||s.startsWith(`../`),m=r(),h;if(c(s)?(m(`Using absolute path for file is not recommended. Use relative paths instead. Path: ${s}, imported from: ${d}`,{level:`warn`}),h=s):h=u(p?d:f,s),i(h)&&o(h).isFile())try{let n=a(h,`utf8`);return t(e.File,s,{content:n,fixedPath:l(f,h)})}catch{m(`Unable to read path: ${n(l(f,h))}`,{level:`warn`})}else m(`File not found: ${n(l(f,h))}`,{level:`warn`});return t(e.File,s,{content:`-`})},f=e=>{let{INTLAYER_FILE_PATH:t,INTLAYER_BASE_DIR:n}=globalThis;return d(e,s(t),n)};export{f as file,d as fileContent};
2
2
  //# sourceMappingURL=file.mjs.map
@@ -1,2 +1,2 @@
1
- import{NodeType as e,formatNodeType as t}from"@intlayer/types";const n=e=>{throw Error(`file is not available in browser`)};export{n as file};
1
+ import"@intlayer/types";const e=e=>{throw Error(`file is not available in browser`)};export{e as file};
2
2
  //# sourceMappingURL=fileBrowser.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"fileBrowser.mjs","names":[],"sources":["../../../../src/transpiler/file/fileBrowser.ts"],"sourcesContent":["import { formatNodeType, NodeType } from '@intlayer/types';\nimport type { FileContent } from './file';\n\n/**\n * Function intended to be used to build intlayer dictionaries.\n *\n * Allow identify the usage of an external resource.\n *\n * Usage:\n *\n * ```ts\n * file('/path/to/file.md') // absolute path\n *\n * // or\n *\n * file('path/to/file.md') // relative path\n * ```\n */\nexport const file = (path: string): FileContent => {\n throw new Error('file is not available in browser');\n\n return formatNodeType(NodeType.File, path, {\n content: '',\n fixedPath: '',\n });\n};\n"],"mappings":"+DAkBA,MAAa,EAAQ,GAA8B,CACjD,MAAU,MAAM,mCAAmC"}
1
+ {"version":3,"file":"fileBrowser.mjs","names":[],"sources":["../../../../src/transpiler/file/fileBrowser.ts"],"sourcesContent":["import { formatNodeType, NodeType } from '@intlayer/types';\nimport type { FileContent } from './file';\n\n/**\n * Function intended to be used to build intlayer dictionaries.\n *\n * Allow identify the usage of an external resource.\n *\n * Usage:\n *\n * ```ts\n * file('/path/to/file.md') // absolute path\n *\n * // or\n *\n * file('path/to/file.md') // relative path\n * ```\n */\nexport const file = (path: string): FileContent => {\n throw new Error('file is not available in browser');\n\n return formatNodeType(NodeType.File, path, {\n content: '',\n fixedPath: '',\n });\n};\n"],"mappings":"wBAkBA,MAAa,EAAQ,GAA8B,CACjD,MAAU,MAAM,mCAAmC"}
@@ -1 +1 @@
1
- {"version":3,"file":"getMissingLocalesContent.d.ts","names":[],"sources":["../../../src/deepTransformPlugins/getMissingLocalesContent.ts"],"mappings":";;;;;cAiDa,yBAAA,GACX,OAAA,EAAS,MAAA,IACT,eAAA,GAAkB,MAAA,EAAQ,MAAA,cACzB,OAAA;AAHH;;;;;;AAAA,cAsDa,wBAAA,aAAsC,WAAA,EACjD,IAAA,EAAM,CAAA,EACN,OAAA,EAAS,aAAA,IACT,SAAA,EAAW,SAAA,KACV,MAAA;AAAA,cAkBU,sCAAA,GACX,UAAA,EAAY,UAAA,EACZ,OAAA,GAAS,aAAA,OAA8D,MAAA"}
1
+ {"version":3,"file":"getMissingLocalesContent.d.ts","names":[],"sources":["../../../src/deepTransformPlugins/getMissingLocalesContent.ts"],"mappings":";;;;;cAoGa,yBAAA,GACX,OAAA,EAAS,MAAA,IACT,eAAA,GAAkB,MAAA,EAAQ,MAAA,cACzB,OAAA;AAHH;;;;;;AAAA,cA0Ga,wBAAA,aAAsC,WAAA,EACjD,IAAA,EAAM,CAAA,EACN,OAAA,EAAS,aAAA,IACT,SAAA,EAAW,SAAA,KACV,MAAA;AAAA,cAkBU,sCAAA,GACX,UAAA,EAAY,UAAA,EACZ,OAAA,GAAS,aAAA,OAA8D,MAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"getIntlayer.d.ts","names":[],"sources":["../../../src/interpreter/getIntlayer.ts"],"mappings":";;;;cAqDa,WAAA,aACD,cAAA,YACA,aAAA,GAAgB,eAAA,EAE1B,GAAA,EAAK,CAAA,EACL,MAAA,GAAS,CAAA,EACT,OAAA,GAAU,OAAA,OACT,oBAAA,CACD,yBAAA,CAA0B,CAAA,GAC1B,uBAAA,EACA,CAAA"}
1
+ {"version":3,"file":"getIntlayer.d.ts","names":[],"sources":["../../../src/interpreter/getIntlayer.ts"],"mappings":";;;;cAmDa,WAAA,aACD,cAAA,YACA,aAAA,GAAgB,eAAA,EAE1B,GAAA,EAAK,CAAA,EACL,MAAA,GAAS,CAAA,EACT,OAAA,GAAU,OAAA,OACT,oBAAA,CACD,yBAAA,CAA0B,CAAA,GAC1B,uBAAA,EACA,CAAA"}
@@ -37,7 +37,7 @@ import { LocalesValues, RoutingConfig } from "@intlayer/types";
37
37
  * @param options.mode - URL routing mode for locale handling. Defaults to configured mode.
38
38
  * @returns The localized URL for the current locale.
39
39
  */
40
- declare const getLocalizedUrl: (url: string, currentLocale: LocalesValues, options?: {
40
+ declare const getLocalizedUrl: (url: string, currentLocale?: LocalesValues, options?: {
41
41
  locales?: LocalesValues[];
42
42
  defaultLocale?: LocalesValues;
43
43
  mode?: RoutingConfig["mode"];
@@ -1 +1 @@
1
- {"version":3,"file":"getLocalizedUrl.d.ts","names":[],"sources":["../../../src/localization/getLocalizedUrl.ts"],"mappings":";;;;;AAgDA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cAAa,eAAA,GACX,GAAA,UACA,aAAA,EAAe,aAAA,EACf,OAAA;EACE,OAAA,GAAU,aAAA;EACV,aAAA,GAAgB,aAAA;EAChB,IAAA,GAAO,aAAA;EACP,OAAA,GAAU,aAAA;AAAA"}
1
+ {"version":3,"file":"getLocalizedUrl.d.ts","names":[],"sources":["../../../src/localization/getLocalizedUrl.ts"],"mappings":";;;;;AAgDA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cAAa,eAAA,GACX,GAAA,UACA,aAAA,GAAe,aAAA,EAEf,OAAA;EACE,OAAA,GAAU,aAAA;EACV,aAAA,GAAgB,aAAA;EAChB,IAAA,GAAO,aAAA;EACP,OAAA,GAAU,aAAA;AAAA"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@intlayer/core",
3
- "version": "8.2.2",
3
+ "version": "8.2.4",
4
4
  "private": false,
5
5
  "description": "Includes core Intlayer functions like translation, dictionary, and utility functions shared across multiple packages.",
6
6
  "keywords": [
@@ -168,20 +168,20 @@
168
168
  "typecheck": "tsc --noEmit --project tsconfig.types.json"
169
169
  },
170
170
  "dependencies": {
171
- "@intlayer/api": "8.2.2",
172
- "@intlayer/config": "8.2.2",
173
- "@intlayer/dictionaries-entry": "8.2.2",
174
- "@intlayer/types": "8.2.2",
175
- "@intlayer/unmerged-dictionaries-entry": "8.2.2",
171
+ "@intlayer/api": "8.2.3",
172
+ "@intlayer/config": "8.2.3",
173
+ "@intlayer/dictionaries-entry": "8.2.3",
174
+ "@intlayer/types": "8.2.3",
175
+ "@intlayer/unmerged-dictionaries-entry": "8.2.3",
176
176
  "defu": "6.1.4"
177
177
  },
178
178
  "devDependencies": {
179
- "@types/node": "25.3.3",
179
+ "@types/node": "25.3.5",
180
180
  "@utils/ts-config": "1.0.4",
181
181
  "@utils/ts-config-types": "1.0.4",
182
182
  "@utils/tsdown-config": "1.0.4",
183
183
  "rimraf": "6.1.3",
184
- "tsdown": "0.20.3",
184
+ "tsdown": "0.21.0",
185
185
  "typescript": "5.9.3",
186
186
  "vitest": "4.0.18"
187
187
  },