@json-to-office/shared-docx 0.6.0 → 0.8.0

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 (41) hide show
  1. package/dist/{chunk-6SLVQATI.js → chunk-3AJ5NHUF.js} +2 -2
  2. package/dist/{chunk-YQECZGRR.js → chunk-7PK36JXG.js} +2 -2
  3. package/dist/chunk-F5IGGVWN.js +1339 -0
  4. package/dist/chunk-F5IGGVWN.js.map +1 -0
  5. package/dist/{chunk-V4L4S6ZS.js → chunk-JYGWHRMY.js} +2 -2
  6. package/dist/{chunk-L5TZFC47.js → chunk-M4OD7UER.js} +4 -42
  7. package/dist/chunk-M4OD7UER.js.map +1 -0
  8. package/dist/{chunk-22VYYAC2.js → chunk-MQ7KNRW2.js} +6 -4
  9. package/dist/{chunk-22VYYAC2.js.map → chunk-MQ7KNRW2.js.map} +1 -1
  10. package/dist/{chunk-OE5JFL7S.js → chunk-QEDASPGD.js} +8 -6
  11. package/dist/{chunk-OE5JFL7S.js.map → chunk-QEDASPGD.js.map} +1 -1
  12. package/dist/{chunk-SK6LSPFN.js → chunk-RFNU2AYT.js} +2 -2
  13. package/dist/chunk-S5KMAUDZ.js +645 -0
  14. package/dist/chunk-S5KMAUDZ.js.map +1 -0
  15. package/dist/{chunk-ABVYMFDA.js → chunk-VQXTI6WF.js} +2 -2
  16. package/dist/index.d.ts +220 -1
  17. package/dist/index.js +16 -14
  18. package/dist/index.js.map +1 -1
  19. package/dist/schemas/api.js +4 -3
  20. package/dist/schemas/component-defaults.d.ts +448 -0
  21. package/dist/schemas/component-defaults.js +24 -0
  22. package/dist/schemas/component-defaults.js.map +1 -0
  23. package/dist/schemas/component-registry.js +2 -1
  24. package/dist/schemas/components.d.ts +436 -0
  25. package/dist/schemas/components.js +13 -11
  26. package/dist/schemas/document.js +5 -4
  27. package/dist/schemas/export.js +3 -2
  28. package/dist/schemas/generator.js +3 -2
  29. package/dist/schemas/theme.d.ts +4 -444
  30. package/dist/schemas/theme.js +12 -12
  31. package/dist/validation/unified/index.d.ts +223 -0
  32. package/dist/validation/unified/index.js +6 -5
  33. package/package.json +2 -2
  34. package/dist/chunk-L5TZFC47.js.map +0 -1
  35. package/dist/chunk-PN6JT3KF.js +0 -1926
  36. package/dist/chunk-PN6JT3KF.js.map +0 -1
  37. /package/dist/{chunk-6SLVQATI.js.map → chunk-3AJ5NHUF.js.map} +0 -0
  38. /package/dist/{chunk-YQECZGRR.js.map → chunk-7PK36JXG.js.map} +0 -0
  39. /package/dist/{chunk-V4L4S6ZS.js.map → chunk-JYGWHRMY.js.map} +0 -0
  40. /package/dist/{chunk-SK6LSPFN.js.map → chunk-RFNU2AYT.js.map} +0 -0
  41. /package/dist/{chunk-ABVYMFDA.js.map → chunk-VQXTI6WF.js.map} +0 -0
@@ -1,29 +1,31 @@
1
1
  import {
2
2
  ThemeConfigSchema
3
- } from "./chunk-L5TZFC47.js";
3
+ } from "./chunk-M4OD7UER.js";
4
4
  import {
5
5
  documentValidator,
6
6
  strictDocumentValidator,
7
7
  validateAgainstSchema,
8
8
  validateJson
9
- } from "./chunk-22VYYAC2.js";
9
+ } from "./chunk-MQ7KNRW2.js";
10
10
  import {
11
11
  ComponentDefinitionSchema
12
- } from "./chunk-YQECZGRR.js";
12
+ } from "./chunk-7PK36JXG.js";
13
13
  import {
14
14
  CustomComponentDefinitionSchema
15
15
  } from "./chunk-VP3X6DBP.js";
16
+ import {
17
+ ReportPropsSchema
18
+ } from "./chunk-S5KMAUDZ.js";
16
19
  import {
17
20
  ColumnsPropsSchema,
18
21
  HeadingPropsSchema,
19
22
  ImagePropsSchema,
20
23
  ListPropsSchema,
21
24
  ParagraphPropsSchema,
22
- ReportPropsSchema,
23
25
  SectionPropsSchema,
24
26
  StatisticPropsSchema,
25
27
  TablePropsSchema
26
- } from "./chunk-PN6JT3KF.js";
28
+ } from "./chunk-F5IGGVWN.js";
27
29
 
28
30
  // src/validation/unified/index.ts
29
31
  import {
@@ -414,4 +416,4 @@ export {
414
416
  createErrorConfig,
415
417
  formatErrorMessage
416
418
  };
417
- //# sourceMappingURL=chunk-OE5JFL7S.js.map
419
+ //# sourceMappingURL=chunk-QEDASPGD.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/validation/unified/index.ts","../src/validation/unified/error-formatter-config.ts","../src/validation/unified/theme-validator.ts","../src/validation/unified/component-validator.ts"],"sourcesContent":["/**\n * Unified validation facade\n * Simple, clean API for all validation needs\n */\n\n// Format-agnostic types re-exported from @json-to-office/shared\nexport type { ValidationError, ValidationResult } from '@json-to-office/shared';\n\n// Docx-specific extended types (local)\nexport type {\n ValidationOptions,\n JsonValidationResult,\n ThemeValidationResult,\n DocumentValidationResult,\n ComponentValidationResult,\n EnhancedValueError,\n} from './types';\n\n// Format-agnostic error utilities re-exported from @json-to-office/shared\nexport {\n transformValueError,\n transformValueErrors,\n calculatePosition,\n formatErrorSummary,\n groupErrorsByPath,\n createJsonParseError,\n} from '@json-to-office/shared';\n\n// Docx-specific error transformer (local, extends shared with docx-specific messages)\nexport {\n transformValueError as transformDocxValueError,\n transformValueErrors as transformDocxValueErrors,\n} from './error-transformer';\n\n// Export deep validation utilities (docx-specific)\nexport {\n deepValidateDocument,\n comprehensiveValidateDocument,\n} from './deep-validator';\n\n// Format-agnostic schema utilities re-exported from @json-to-office/shared\nexport {\n isUnionSchema,\n isObjectSchema,\n isLiteralSchema,\n getObjectSchemaPropertyNames,\n getLiteralValue,\n extractStandardComponentNames,\n clearComponentNamesCache,\n getSchemaMetadata,\n} from '@json-to-office/shared';\n\n// Format-agnostic error formatter config re-exported from @json-to-office/shared\nexport {\n type ErrorFormatterConfig,\n DEFAULT_ERROR_CONFIG,\n ERROR_EMOJIS,\n createErrorConfig,\n formatErrorMessage,\n} from '@json-to-office/shared';\n\n// Docx-specific error formatter extras (local)\nexport { ERROR_TEMPLATES, DOC_LINKS } from './error-formatter-config';\n\n// Export base validator utilities\nexport {\n validateAgainstSchema,\n validateJson,\n validateBatch,\n validateWithEnhancement,\n createValidator,\n createJsonValidator,\n isValidationSuccess,\n getValidationSummary,\n} from './base-validator';\n\n// Export document validation\nexport {\n validateDocument,\n validateJsonDocument,\n isValidDocument,\n createDocumentValidator,\n documentValidator,\n strictDocumentValidator,\n // Legacy compatibility\n validateJsonComponent,\n validateDocumentWithSchema,\n} from './document-validator';\n\n// Export theme validation\nexport {\n validateTheme,\n validateThemeJson,\n validateThemeWithEnhancement,\n isValidTheme,\n createThemeValidator,\n themeValidator,\n strictThemeValidator,\n getThemeName,\n isThemeConfig,\n} from './theme-validator';\n\n// Export component validation\nexport {\n validateComponent,\n validateComponentDefinition,\n validateCustomComponentProps,\n validateComponents,\n isStandardComponentName,\n createComponentValidator,\n componentValidator,\n strictComponentValidator,\n // Type guards\n isReportProps,\n isSectionProps,\n isHeadingProps,\n isParagraphProps,\n isColumnsProps,\n isImageProps,\n isStatisticProps,\n isTableProps,\n isListProps,\n isCustomComponentProps,\n // Types\n type StandardComponentName,\n} from './component-validator';\n\n// Import the validators we need\nimport {\n documentValidator,\n strictDocumentValidator,\n} from './document-validator';\nimport { themeValidator, strictThemeValidator } from './theme-validator';\nimport {\n componentValidator,\n strictComponentValidator,\n} from './component-validator';\n\n/**\n * Simple validation API\n * The main entry point for most validation needs\n */\nexport const validate = {\n // Document validation\n document: (data: unknown) => documentValidator.validate(data),\n jsonDocument: (jsonInput: string | object) =>\n documentValidator.validateJson(jsonInput),\n\n // Theme validation\n theme: (data: unknown) => themeValidator.validate(data),\n jsonTheme: (jsonInput: string | object) =>\n themeValidator.validateJson(jsonInput),\n\n // Component validation\n component: (name: string, props: unknown) =>\n componentValidator.validate(name, props),\n componentDefinition: (component: unknown) =>\n componentValidator.validateDefinition(component),\n\n // Batch operations\n components: (components: Array<{ name: string; props: unknown }>) =>\n components.map((c) => componentValidator.validate(c.name, c.props)),\n\n // Type checking (non-throwing)\n isDocument: (data: unknown) => {\n const result = documentValidator.validate(data);\n return result.valid;\n },\n isTheme: (data: unknown) => {\n const result = themeValidator.validate(data);\n return result.valid;\n },\n isComponent: (name: string, props: unknown) => {\n const result = componentValidator.validate(name, props);\n return result.valid;\n },\n};\n\n/**\n * Strict validation API\n * For cases where you want no cleaning or defaults\n */\nexport const validateStrict = {\n document: (data: unknown) => strictDocumentValidator.validate(data),\n jsonDocument: (jsonInput: string | object) =>\n strictDocumentValidator.validateJson(jsonInput),\n theme: (data: unknown) => strictThemeValidator.validate(data),\n jsonTheme: (jsonInput: string | object) =>\n strictThemeValidator.validateJson(jsonInput),\n component: (name: string, props: unknown) =>\n strictComponentValidator.validate(name, props),\n componentDefinition: (component: unknown) =>\n strictComponentValidator.validateDefinition(component),\n};\n","/**\n * Error Formatter Configuration\n * Configurable error message formatting options\n */\n\n/**\n * Error formatter configuration options\n */\nexport interface ErrorFormatterConfig {\n /**\n * Include emoji indicators in error messages\n * Default: true (false in CI environments)\n */\n includeEmojis?: boolean;\n\n /**\n * Verbosity level for error messages\n * - minimal: Just the error message\n * - normal: Error message with path\n * - detailed: Full error with suggestions and context\n * Default: 'normal'\n */\n verbosity?: 'minimal' | 'normal' | 'detailed';\n\n /**\n * Include suggestions for fixing errors\n * Default: true\n */\n includeSuggestions?: boolean;\n\n /**\n * Include stack trace or error path\n * Default: true\n */\n includePath?: boolean;\n\n /**\n * Maximum error message length (0 = unlimited)\n * Default: 0\n */\n maxMessageLength?: number;\n\n /**\n * Include links to documentation\n * Default: false\n */\n includeDocLinks?: boolean;\n\n /**\n * Terminal color support\n * Default: auto-detected\n */\n colorSupport?: boolean;\n}\n\n/**\n * Get default configuration\n * Evaluates environment variables at call time, not module load time\n */\nfunction getDefaultConfig(): Required<ErrorFormatterConfig> {\n return {\n includeEmojis: !isCI(),\n verbosity: 'normal',\n includeSuggestions: true,\n includePath: true,\n maxMessageLength: 0,\n includeDocLinks: false,\n colorSupport: hasColorSupport(),\n };\n}\n\n/**\n * Default configuration (for backward compatibility)\n */\nexport const DEFAULT_ERROR_CONFIG: Required<ErrorFormatterConfig> =\n getDefaultConfig();\n\n/**\n * Error message templates\n */\nexport const ERROR_TEMPLATES = {\n UNION_NO_MATCH: 'Value doesn\\'t match any of the expected formats',\n TYPE_MISMATCH: 'Expected {expected} but got {actual}',\n MISSING_REQUIRED: 'Missing required field \\'{field}\\'',\n UNKNOWN_PROPERTY: 'Unknown property \\'{property}\\'',\n INVALID_FORMAT: 'Invalid {type} format',\n PATTERN_MISMATCH: 'Value doesn\\'t match the required pattern',\n} as const;\n\n/**\n * Emoji indicators for different error types\n */\nexport const ERROR_EMOJIS = {\n ERROR: '❌',\n WARNING: '⚠️',\n INFO: 'ℹ️',\n SUGGESTION: '💡',\n FIX: '🔧',\n LINK: '🔗',\n} as const;\n\n/**\n * Documentation links for common errors\n */\nexport const DOC_LINKS = {\n MODULE_TYPES: 'https://docs.json-to-docx.com/modules',\n THEME_CONFIG: 'https://docs.json-to-docx.com/themes',\n VALIDATION: 'https://docs.json-to-docx.com/validation',\n} as const;\n\n/**\n * Detect if running in CI environment\n */\nfunction isCI(): boolean {\n // Check if we're in a Node environment\n if (typeof process === 'undefined' || !process.env) {\n return false;\n }\n\n return !!(\n process.env.CI ||\n process.env.CONTINUOUS_INTEGRATION ||\n process.env.GITHUB_ACTIONS ||\n process.env.GITLAB_CI ||\n process.env.CIRCLECI ||\n process.env.TRAVIS ||\n process.env.JENKINS_URL\n );\n}\n\n/**\n * Detect terminal color support\n */\nfunction hasColorSupport(): boolean {\n // Check if we're in a Node environment\n if (typeof process === 'undefined') {\n return false;\n }\n\n // Check for explicit NO_COLOR env var\n if (process.env?.NO_COLOR) {\n return false;\n }\n\n // Check for explicit FORCE_COLOR env var\n if (process.env?.FORCE_COLOR) {\n return true;\n }\n\n // Check if stdout is a TTY\n if (process.stdout?.isTTY) {\n return true;\n }\n\n // Default to no color in CI environments\n return !isCI();\n}\n\n/**\n * Create a configuration with defaults\n */\nexport function createErrorConfig(\n config?: ErrorFormatterConfig\n): Required<ErrorFormatterConfig> {\n // Get fresh defaults that evaluate environment at call time\n const defaults = getDefaultConfig();\n return {\n ...defaults,\n ...config,\n };\n}\n\n/**\n * Format an error message based on configuration\n */\nexport function formatErrorMessage(\n message: string,\n config: ErrorFormatterConfig = {}\n): string {\n const finalConfig = createErrorConfig(config);\n\n let formatted = message;\n\n // Remove emojis if not wanted\n if (!finalConfig.includeEmojis) {\n Object.values(ERROR_EMOJIS).forEach((emoji) => {\n formatted = formatted.replace(new RegExp(emoji, 'g'), '');\n });\n // Clean up extra spaces\n formatted = formatted.replace(/\\s+/g, ' ').trim();\n }\n\n // Truncate if needed\n if (\n finalConfig.maxMessageLength > 0 &&\n formatted.length > finalConfig.maxMessageLength\n ) {\n formatted =\n formatted.substring(0, finalConfig.maxMessageLength - 3) + '...';\n }\n\n return formatted;\n}\n","/**\n * Theme validation implementation\n * Single source of truth for all theme validation\n */\n\nimport type { Static } from '@sinclair/typebox';\nimport { ThemeConfigSchema } from '../../schemas/theme';\nimport type { ValidationOptions } from './types';\nimport { validateAgainstSchema, validateJson } from './base-validator';\n\n// Re-export ThemeValidationResult type\nexport type { ThemeValidationResult } from './types';\nimport type { ThemeValidationResult } from './types';\n\n/**\n * Validate a theme configuration object\n */\nexport function validateTheme(\n data: unknown,\n options?: ValidationOptions\n): ThemeValidationResult {\n // Handle string input (theme name)\n if (typeof data === 'string') {\n // This is just a theme name, not a theme config\n // It will be resolved later by the theme resolver\n return {\n valid: true,\n themeName: data,\n };\n }\n\n const result = validateAgainstSchema(ThemeConfigSchema, data, options);\n\n // Add theme-specific metadata\n const themeResult: ThemeValidationResult = {\n ...result,\n };\n\n // Extract theme name if present\n if (result.valid && result.data) {\n const theme = result.data as any;\n if (theme.name) {\n themeResult.themeName = theme.name;\n }\n }\n\n return themeResult;\n}\n\n/**\n * Validate a theme JSON string or object\n * This replaces all three validateThemeJson implementations\n */\nexport function validateThemeJson(\n jsonInput: string | object,\n options?: ValidationOptions\n): ThemeValidationResult {\n const result = validateJson(ThemeConfigSchema, jsonInput, options);\n\n // Add theme-specific metadata\n const themeResult: ThemeValidationResult = {\n ...result,\n };\n\n // Extract theme name if present\n if (result.valid && result.data) {\n const theme = result.data as any;\n\n // Inject default $schema if missing and it's an object\n if (typeof theme === 'object' && !theme.$schema) {\n theme.$schema = './json-schemas/theme.schema.json';\n }\n\n if (theme.name) {\n themeResult.themeName = theme.name;\n }\n }\n\n return themeResult;\n}\n\n/**\n * Validate theme with enhanced error messages\n */\nexport function validateThemeWithEnhancement(\n data: unknown,\n options?: ValidationOptions\n): ThemeValidationResult {\n const result = validateTheme(data, options);\n\n // Enhance errors with theme-specific suggestions\n if (!result.valid && result.errors) {\n result.errors = result.errors.map((error) => {\n // Add specific suggestions for common theme errors\n if (error.path.includes('colors') && !error.suggestion) {\n error.suggestion = 'Colors must be valid hex, rgb, or named colors';\n }\n if (error.path.includes('fonts') && !error.suggestion) {\n error.suggestion = 'Fonts must include size and family properties';\n }\n if (error.path.includes('headings') && !error.suggestion) {\n error.suggestion = 'Headings must be an array of 6 style definitions';\n }\n return error;\n });\n }\n\n return result;\n}\n\n/**\n * Type guard for valid theme result\n */\nexport function isValidTheme(\n result: ThemeValidationResult\n): result is ThemeValidationResult & {\n valid: true;\n data: Static<typeof ThemeConfigSchema>;\n} {\n return result.valid === true && result.data !== undefined;\n}\n\n/**\n * Create a theme validator with default options\n */\nexport function createThemeValidator(defaultOptions?: ValidationOptions) {\n return {\n validate: (data: unknown, options?: ValidationOptions) =>\n validateTheme(data, { ...defaultOptions, ...options }),\n validateJson: (jsonInput: string | object, options?: ValidationOptions) =>\n validateThemeJson(jsonInput, { ...defaultOptions, ...options }),\n validateWithEnhancement: (data: unknown, options?: ValidationOptions) =>\n validateThemeWithEnhancement(data, { ...defaultOptions, ...options }),\n };\n}\n\n// Export convenient validators with common configurations\nexport const themeValidator = createThemeValidator({\n clean: true,\n applyDefaults: true,\n});\n\nexport const strictThemeValidator = createThemeValidator({\n clean: false,\n applyDefaults: false,\n maxErrors: 10,\n});\n\n/**\n * Get theme name from data\n */\nexport function getThemeName(data: unknown): string | undefined {\n if (typeof data === 'string') {\n return data;\n }\n\n if (typeof data === 'object' && data !== null && 'name' in data) {\n const theme = data as any;\n if (typeof theme.name === 'string') {\n return theme.name;\n }\n }\n\n return undefined;\n}\n\n/**\n * Check if theme config is valid (basic check without full validation)\n */\nexport function isThemeConfig(data: unknown): boolean {\n if (!data || typeof data !== 'object') {\n return false;\n }\n\n const theme = data as any;\n return !!(theme.colors && theme.fonts);\n}\n","/**\n * Component validation implementation\n * Single source of truth for all component validation\n */\n\nimport { Value } from '@sinclair/typebox/value';\nimport type { Static, TSchema } from '@sinclair/typebox';\nimport { validateCustomComponentProps as sharedValidateCustomComponentProps } from '@json-to-office/shared/plugin';\nimport {\n ReportPropsSchema,\n SectionPropsSchema,\n HeadingPropsSchema,\n ParagraphPropsSchema,\n ColumnsPropsSchema,\n ImagePropsSchema,\n StatisticPropsSchema,\n TablePropsSchema,\n ListPropsSchema,\n ComponentDefinitionSchema,\n} from '../../schemas/components';\nimport { CustomComponentDefinitionSchema } from '../../schemas/custom-components';\nimport type { ComponentValidationResult, ValidationOptions } from './types';\nimport { validateAgainstSchema } from './base-validator';\n\n// Map of standard component names to their schemas\nconst COMPONENT_SCHEMA_MAP = {\n report: ReportPropsSchema,\n section: SectionPropsSchema,\n heading: HeadingPropsSchema,\n paragraph: ParagraphPropsSchema,\n columns: ColumnsPropsSchema,\n image: ImagePropsSchema,\n statistic: StatisticPropsSchema,\n table: TablePropsSchema,\n list: ListPropsSchema,\n custom: CustomComponentDefinitionSchema,\n} as const;\n\nexport type StandardComponentName = keyof typeof COMPONENT_SCHEMA_MAP;\n\n/**\n * Validate a component configuration by type\n */\nexport function validateComponent<T extends StandardComponentName>(\n name: T,\n props: unknown,\n options?: ValidationOptions\n): ComponentValidationResult<any> {\n const schema = COMPONENT_SCHEMA_MAP[name];\n\n if (!schema) {\n // Unknown component type, try custom component schema\n const customResult = validateAgainstSchema(\n CustomComponentDefinitionSchema,\n props,\n options\n );\n\n return {\n ...customResult,\n success: customResult.valid, // Add success for backward compatibility\n componentName: name,\n isCustomComponent: true,\n };\n }\n\n const result = validateAgainstSchema(schema, props, options);\n\n return {\n ...result,\n success: result.valid, // Add success for backward compatibility\n componentName: name,\n isCustomComponent: name === 'custom',\n };\n}\n\n/**\n * Validate a complete component definition (including nested children)\n */\nexport function validateComponentDefinition(\n component: unknown,\n options?: ValidationOptions\n): ComponentValidationResult {\n const result = validateAgainstSchema(\n ComponentDefinitionSchema,\n component,\n options\n );\n\n // Add component-specific metadata\n const componentResult: ComponentValidationResult = {\n ...result,\n };\n\n if (result.valid && result.data) {\n const comp = result.data as any;\n componentResult.componentName = comp.name;\n componentResult.isCustomComponent = !isStandardComponentName(comp.name);\n }\n\n return componentResult;\n}\n\n/**\n * Validate a custom component configuration with a custom schema.\n * Delegates to @json-to-office/shared/plugin to avoid duplication.\n */\nexport function validateCustomComponentProps<T>(\n componentSchema: TSchema,\n config: unknown,\n options?: ValidationOptions\n): ComponentValidationResult<T> {\n return sharedValidateCustomComponentProps<T>(\n componentSchema,\n config,\n options\n );\n}\n\n/**\n * Batch validate multiple components\n */\nexport function validateComponents(\n components: Array<{ name: string; props: unknown }>,\n options?: ValidationOptions\n): ComponentValidationResult[] {\n return components.map(({ name, props }) => {\n if (isStandardComponentName(name)) {\n return validateComponent(name, props, options);\n }\n return validateComponent('custom', props, options);\n });\n}\n\n/**\n * Type guards for component names\n */\nexport function isStandardComponentName(\n name: string\n): name is StandardComponentName {\n return name in COMPONENT_SCHEMA_MAP;\n}\n\nexport function isReportProps(\n config: unknown\n): config is Static<typeof ReportPropsSchema> {\n return Value.Check(ReportPropsSchema, config);\n}\n\nexport function isSectionProps(\n config: unknown\n): config is Static<typeof SectionPropsSchema> {\n return Value.Check(SectionPropsSchema, config);\n}\n\nexport function isHeadingProps(\n config: unknown\n): config is Static<typeof HeadingPropsSchema> {\n return Value.Check(HeadingPropsSchema, config);\n}\n\nexport function isParagraphProps(\n config: unknown\n): config is Static<typeof ParagraphPropsSchema> {\n return Value.Check(ParagraphPropsSchema, config);\n}\n\nexport function isColumnsProps(\n config: unknown\n): config is Static<typeof ColumnsPropsSchema> {\n return Value.Check(ColumnsPropsSchema, config);\n}\n\nexport function isImageProps(\n config: unknown\n): config is Static<typeof ImagePropsSchema> {\n return Value.Check(ImagePropsSchema, config);\n}\n\nexport function isStatisticProps(\n config: unknown\n): config is Static<typeof StatisticPropsSchema> {\n return Value.Check(StatisticPropsSchema, config);\n}\n\nexport function isTableProps(\n config: unknown\n): config is Static<typeof TablePropsSchema> {\n return Value.Check(TablePropsSchema, config);\n}\n\nexport function isListProps(\n config: unknown\n): config is Static<typeof ListPropsSchema> {\n return Value.Check(ListPropsSchema, config);\n}\n\nexport function isCustomComponentProps(\n config: unknown\n): config is Static<typeof CustomComponentDefinitionSchema> {\n return Value.Check(CustomComponentDefinitionSchema, config);\n}\n\n/**\n * Create a component validator with default options\n */\nexport function createComponentValidator(defaultOptions?: ValidationOptions) {\n return {\n validate: (name: string, props: unknown, options?: ValidationOptions) => {\n if (isStandardComponentName(name)) {\n return validateComponent(name, props, {\n ...defaultOptions,\n ...options,\n });\n }\n return validateComponent('custom', props, {\n ...defaultOptions,\n ...options,\n });\n },\n validateDefinition: (component: unknown, options?: ValidationOptions) =>\n validateComponentDefinition(component, { ...defaultOptions, ...options }),\n validateCustom: <T>(\n schema: TSchema,\n config: unknown,\n options?: ValidationOptions\n ) =>\n validateCustomComponentProps<T>(schema, config, {\n ...defaultOptions,\n ...options,\n }),\n };\n}\n\n// Export convenient validators with common configurations\nexport const componentValidator = createComponentValidator({\n clean: true,\n applyDefaults: true,\n});\n\nexport const strictComponentValidator = createComponentValidator({\n clean: false,\n applyDefaults: false,\n maxErrors: 10,\n});\n"],"mappings":"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","names":["DEFAULT_ERROR_CONFIG"]}
1
+ {"version":3,"sources":["../src/validation/unified/index.ts","../src/validation/unified/error-formatter-config.ts","../src/validation/unified/theme-validator.ts","../src/validation/unified/component-validator.ts"],"sourcesContent":["/**\n * Unified validation facade\n * Simple, clean API for all validation needs\n */\n\n// Format-agnostic types re-exported from @json-to-office/shared\nexport type { ValidationError, ValidationResult } from '@json-to-office/shared';\n\n// Docx-specific extended types (local)\nexport type {\n ValidationOptions,\n JsonValidationResult,\n ThemeValidationResult,\n DocumentValidationResult,\n ComponentValidationResult,\n EnhancedValueError,\n} from './types';\n\n// Format-agnostic error utilities re-exported from @json-to-office/shared\nexport {\n transformValueError,\n transformValueErrors,\n calculatePosition,\n formatErrorSummary,\n groupErrorsByPath,\n createJsonParseError,\n} from '@json-to-office/shared';\n\n// Docx-specific error transformer (local, extends shared with docx-specific messages)\nexport {\n transformValueError as transformDocxValueError,\n transformValueErrors as transformDocxValueErrors,\n} from './error-transformer';\n\n// Export deep validation utilities (docx-specific)\nexport {\n deepValidateDocument,\n comprehensiveValidateDocument,\n} from './deep-validator';\n\n// Format-agnostic schema utilities re-exported from @json-to-office/shared\nexport {\n isUnionSchema,\n isObjectSchema,\n isLiteralSchema,\n getObjectSchemaPropertyNames,\n getLiteralValue,\n extractStandardComponentNames,\n clearComponentNamesCache,\n getSchemaMetadata,\n} from '@json-to-office/shared';\n\n// Format-agnostic error formatter config re-exported from @json-to-office/shared\nexport {\n type ErrorFormatterConfig,\n DEFAULT_ERROR_CONFIG,\n ERROR_EMOJIS,\n createErrorConfig,\n formatErrorMessage,\n} from '@json-to-office/shared';\n\n// Docx-specific error formatter extras (local)\nexport { ERROR_TEMPLATES, DOC_LINKS } from './error-formatter-config';\n\n// Export base validator utilities\nexport {\n validateAgainstSchema,\n validateJson,\n validateBatch,\n validateWithEnhancement,\n createValidator,\n createJsonValidator,\n isValidationSuccess,\n getValidationSummary,\n} from './base-validator';\n\n// Export document validation\nexport {\n validateDocument,\n validateJsonDocument,\n isValidDocument,\n createDocumentValidator,\n documentValidator,\n strictDocumentValidator,\n // Legacy compatibility\n validateJsonComponent,\n validateDocumentWithSchema,\n} from './document-validator';\n\n// Export theme validation\nexport {\n validateTheme,\n validateThemeJson,\n validateThemeWithEnhancement,\n isValidTheme,\n createThemeValidator,\n themeValidator,\n strictThemeValidator,\n getThemeName,\n isThemeConfig,\n} from './theme-validator';\n\n// Export component validation\nexport {\n validateComponent,\n validateComponentDefinition,\n validateCustomComponentProps,\n validateComponents,\n isStandardComponentName,\n createComponentValidator,\n componentValidator,\n strictComponentValidator,\n // Type guards\n isReportProps,\n isSectionProps,\n isHeadingProps,\n isParagraphProps,\n isColumnsProps,\n isImageProps,\n isStatisticProps,\n isTableProps,\n isListProps,\n isCustomComponentProps,\n // Types\n type StandardComponentName,\n} from './component-validator';\n\n// Import the validators we need\nimport {\n documentValidator,\n strictDocumentValidator,\n} from './document-validator';\nimport { themeValidator, strictThemeValidator } from './theme-validator';\nimport {\n componentValidator,\n strictComponentValidator,\n} from './component-validator';\n\n/**\n * Simple validation API\n * The main entry point for most validation needs\n */\nexport const validate = {\n // Document validation\n document: (data: unknown) => documentValidator.validate(data),\n jsonDocument: (jsonInput: string | object) =>\n documentValidator.validateJson(jsonInput),\n\n // Theme validation\n theme: (data: unknown) => themeValidator.validate(data),\n jsonTheme: (jsonInput: string | object) =>\n themeValidator.validateJson(jsonInput),\n\n // Component validation\n component: (name: string, props: unknown) =>\n componentValidator.validate(name, props),\n componentDefinition: (component: unknown) =>\n componentValidator.validateDefinition(component),\n\n // Batch operations\n components: (components: Array<{ name: string; props: unknown }>) =>\n components.map((c) => componentValidator.validate(c.name, c.props)),\n\n // Type checking (non-throwing)\n isDocument: (data: unknown) => {\n const result = documentValidator.validate(data);\n return result.valid;\n },\n isTheme: (data: unknown) => {\n const result = themeValidator.validate(data);\n return result.valid;\n },\n isComponent: (name: string, props: unknown) => {\n const result = componentValidator.validate(name, props);\n return result.valid;\n },\n};\n\n/**\n * Strict validation API\n * For cases where you want no cleaning or defaults\n */\nexport const validateStrict = {\n document: (data: unknown) => strictDocumentValidator.validate(data),\n jsonDocument: (jsonInput: string | object) =>\n strictDocumentValidator.validateJson(jsonInput),\n theme: (data: unknown) => strictThemeValidator.validate(data),\n jsonTheme: (jsonInput: string | object) =>\n strictThemeValidator.validateJson(jsonInput),\n component: (name: string, props: unknown) =>\n strictComponentValidator.validate(name, props),\n componentDefinition: (component: unknown) =>\n strictComponentValidator.validateDefinition(component),\n};\n","/**\n * Error Formatter Configuration\n * Configurable error message formatting options\n */\n\n/**\n * Error formatter configuration options\n */\nexport interface ErrorFormatterConfig {\n /**\n * Include emoji indicators in error messages\n * Default: true (false in CI environments)\n */\n includeEmojis?: boolean;\n\n /**\n * Verbosity level for error messages\n * - minimal: Just the error message\n * - normal: Error message with path\n * - detailed: Full error with suggestions and context\n * Default: 'normal'\n */\n verbosity?: 'minimal' | 'normal' | 'detailed';\n\n /**\n * Include suggestions for fixing errors\n * Default: true\n */\n includeSuggestions?: boolean;\n\n /**\n * Include stack trace or error path\n * Default: true\n */\n includePath?: boolean;\n\n /**\n * Maximum error message length (0 = unlimited)\n * Default: 0\n */\n maxMessageLength?: number;\n\n /**\n * Include links to documentation\n * Default: false\n */\n includeDocLinks?: boolean;\n\n /**\n * Terminal color support\n * Default: auto-detected\n */\n colorSupport?: boolean;\n}\n\n/**\n * Get default configuration\n * Evaluates environment variables at call time, not module load time\n */\nfunction getDefaultConfig(): Required<ErrorFormatterConfig> {\n return {\n includeEmojis: !isCI(),\n verbosity: 'normal',\n includeSuggestions: true,\n includePath: true,\n maxMessageLength: 0,\n includeDocLinks: false,\n colorSupport: hasColorSupport(),\n };\n}\n\n/**\n * Default configuration (for backward compatibility)\n */\nexport const DEFAULT_ERROR_CONFIG: Required<ErrorFormatterConfig> =\n getDefaultConfig();\n\n/**\n * Error message templates\n */\nexport const ERROR_TEMPLATES = {\n UNION_NO_MATCH: 'Value doesn\\'t match any of the expected formats',\n TYPE_MISMATCH: 'Expected {expected} but got {actual}',\n MISSING_REQUIRED: 'Missing required field \\'{field}\\'',\n UNKNOWN_PROPERTY: 'Unknown property \\'{property}\\'',\n INVALID_FORMAT: 'Invalid {type} format',\n PATTERN_MISMATCH: 'Value doesn\\'t match the required pattern',\n} as const;\n\n/**\n * Emoji indicators for different error types\n */\nexport const ERROR_EMOJIS = {\n ERROR: '❌',\n WARNING: '⚠️',\n INFO: 'ℹ️',\n SUGGESTION: '💡',\n FIX: '🔧',\n LINK: '🔗',\n} as const;\n\n/**\n * Documentation links for common errors\n */\nexport const DOC_LINKS = {\n MODULE_TYPES: 'https://docs.json-to-docx.com/modules',\n THEME_CONFIG: 'https://docs.json-to-docx.com/themes',\n VALIDATION: 'https://docs.json-to-docx.com/validation',\n} as const;\n\n/**\n * Detect if running in CI environment\n */\nfunction isCI(): boolean {\n // Check if we're in a Node environment\n if (typeof process === 'undefined' || !process.env) {\n return false;\n }\n\n return !!(\n process.env.CI ||\n process.env.CONTINUOUS_INTEGRATION ||\n process.env.GITHUB_ACTIONS ||\n process.env.GITLAB_CI ||\n process.env.CIRCLECI ||\n process.env.TRAVIS ||\n process.env.JENKINS_URL\n );\n}\n\n/**\n * Detect terminal color support\n */\nfunction hasColorSupport(): boolean {\n // Check if we're in a Node environment\n if (typeof process === 'undefined') {\n return false;\n }\n\n // Check for explicit NO_COLOR env var\n if (process.env?.NO_COLOR) {\n return false;\n }\n\n // Check for explicit FORCE_COLOR env var\n if (process.env?.FORCE_COLOR) {\n return true;\n }\n\n // Check if stdout is a TTY\n if (process.stdout?.isTTY) {\n return true;\n }\n\n // Default to no color in CI environments\n return !isCI();\n}\n\n/**\n * Create a configuration with defaults\n */\nexport function createErrorConfig(\n config?: ErrorFormatterConfig\n): Required<ErrorFormatterConfig> {\n // Get fresh defaults that evaluate environment at call time\n const defaults = getDefaultConfig();\n return {\n ...defaults,\n ...config,\n };\n}\n\n/**\n * Format an error message based on configuration\n */\nexport function formatErrorMessage(\n message: string,\n config: ErrorFormatterConfig = {}\n): string {\n const finalConfig = createErrorConfig(config);\n\n let formatted = message;\n\n // Remove emojis if not wanted\n if (!finalConfig.includeEmojis) {\n Object.values(ERROR_EMOJIS).forEach((emoji) => {\n formatted = formatted.replace(new RegExp(emoji, 'g'), '');\n });\n // Clean up extra spaces\n formatted = formatted.replace(/\\s+/g, ' ').trim();\n }\n\n // Truncate if needed\n if (\n finalConfig.maxMessageLength > 0 &&\n formatted.length > finalConfig.maxMessageLength\n ) {\n formatted =\n formatted.substring(0, finalConfig.maxMessageLength - 3) + '...';\n }\n\n return formatted;\n}\n","/**\n * Theme validation implementation\n * Single source of truth for all theme validation\n */\n\nimport type { Static } from '@sinclair/typebox';\nimport { ThemeConfigSchema } from '../../schemas/theme';\nimport type { ValidationOptions } from './types';\nimport { validateAgainstSchema, validateJson } from './base-validator';\n\n// Re-export ThemeValidationResult type\nexport type { ThemeValidationResult } from './types';\nimport type { ThemeValidationResult } from './types';\n\n/**\n * Validate a theme configuration object\n */\nexport function validateTheme(\n data: unknown,\n options?: ValidationOptions\n): ThemeValidationResult {\n // Handle string input (theme name)\n if (typeof data === 'string') {\n // This is just a theme name, not a theme config\n // It will be resolved later by the theme resolver\n return {\n valid: true,\n themeName: data,\n };\n }\n\n const result = validateAgainstSchema(ThemeConfigSchema, data, options);\n\n // Add theme-specific metadata\n const themeResult: ThemeValidationResult = {\n ...result,\n };\n\n // Extract theme name if present\n if (result.valid && result.data) {\n const theme = result.data as any;\n if (theme.name) {\n themeResult.themeName = theme.name;\n }\n }\n\n return themeResult;\n}\n\n/**\n * Validate a theme JSON string or object\n * This replaces all three validateThemeJson implementations\n */\nexport function validateThemeJson(\n jsonInput: string | object,\n options?: ValidationOptions\n): ThemeValidationResult {\n const result = validateJson(ThemeConfigSchema, jsonInput, options);\n\n // Add theme-specific metadata\n const themeResult: ThemeValidationResult = {\n ...result,\n };\n\n // Extract theme name if present\n if (result.valid && result.data) {\n const theme = result.data as any;\n\n // Inject default $schema if missing and it's an object\n if (typeof theme === 'object' && !theme.$schema) {\n theme.$schema = './json-schemas/theme.schema.json';\n }\n\n if (theme.name) {\n themeResult.themeName = theme.name;\n }\n }\n\n return themeResult;\n}\n\n/**\n * Validate theme with enhanced error messages\n */\nexport function validateThemeWithEnhancement(\n data: unknown,\n options?: ValidationOptions\n): ThemeValidationResult {\n const result = validateTheme(data, options);\n\n // Enhance errors with theme-specific suggestions\n if (!result.valid && result.errors) {\n result.errors = result.errors.map((error) => {\n // Add specific suggestions for common theme errors\n if (error.path.includes('colors') && !error.suggestion) {\n error.suggestion = 'Colors must be valid hex, rgb, or named colors';\n }\n if (error.path.includes('fonts') && !error.suggestion) {\n error.suggestion = 'Fonts must include size and family properties';\n }\n if (error.path.includes('headings') && !error.suggestion) {\n error.suggestion = 'Headings must be an array of 6 style definitions';\n }\n return error;\n });\n }\n\n return result;\n}\n\n/**\n * Type guard for valid theme result\n */\nexport function isValidTheme(\n result: ThemeValidationResult\n): result is ThemeValidationResult & {\n valid: true;\n data: Static<typeof ThemeConfigSchema>;\n} {\n return result.valid === true && result.data !== undefined;\n}\n\n/**\n * Create a theme validator with default options\n */\nexport function createThemeValidator(defaultOptions?: ValidationOptions) {\n return {\n validate: (data: unknown, options?: ValidationOptions) =>\n validateTheme(data, { ...defaultOptions, ...options }),\n validateJson: (jsonInput: string | object, options?: ValidationOptions) =>\n validateThemeJson(jsonInput, { ...defaultOptions, ...options }),\n validateWithEnhancement: (data: unknown, options?: ValidationOptions) =>\n validateThemeWithEnhancement(data, { ...defaultOptions, ...options }),\n };\n}\n\n// Export convenient validators with common configurations\nexport const themeValidator = createThemeValidator({\n clean: true,\n applyDefaults: true,\n});\n\nexport const strictThemeValidator = createThemeValidator({\n clean: false,\n applyDefaults: false,\n maxErrors: 10,\n});\n\n/**\n * Get theme name from data\n */\nexport function getThemeName(data: unknown): string | undefined {\n if (typeof data === 'string') {\n return data;\n }\n\n if (typeof data === 'object' && data !== null && 'name' in data) {\n const theme = data as any;\n if (typeof theme.name === 'string') {\n return theme.name;\n }\n }\n\n return undefined;\n}\n\n/**\n * Check if theme config is valid (basic check without full validation)\n */\nexport function isThemeConfig(data: unknown): boolean {\n if (!data || typeof data !== 'object') {\n return false;\n }\n\n const theme = data as any;\n return !!(theme.colors && theme.fonts);\n}\n","/**\n * Component validation implementation\n * Single source of truth for all component validation\n */\n\nimport { Value } from '@sinclair/typebox/value';\nimport type { Static, TSchema } from '@sinclair/typebox';\nimport { validateCustomComponentProps as sharedValidateCustomComponentProps } from '@json-to-office/shared/plugin';\nimport {\n ReportPropsSchema,\n SectionPropsSchema,\n HeadingPropsSchema,\n ParagraphPropsSchema,\n ColumnsPropsSchema,\n ImagePropsSchema,\n StatisticPropsSchema,\n TablePropsSchema,\n ListPropsSchema,\n ComponentDefinitionSchema,\n} from '../../schemas/components';\nimport { CustomComponentDefinitionSchema } from '../../schemas/custom-components';\nimport type { ComponentValidationResult, ValidationOptions } from './types';\nimport { validateAgainstSchema } from './base-validator';\n\n// Map of standard component names to their schemas\nconst COMPONENT_SCHEMA_MAP = {\n report: ReportPropsSchema,\n section: SectionPropsSchema,\n heading: HeadingPropsSchema,\n paragraph: ParagraphPropsSchema,\n columns: ColumnsPropsSchema,\n image: ImagePropsSchema,\n statistic: StatisticPropsSchema,\n table: TablePropsSchema,\n list: ListPropsSchema,\n custom: CustomComponentDefinitionSchema,\n} as const;\n\nexport type StandardComponentName = keyof typeof COMPONENT_SCHEMA_MAP;\n\n/**\n * Validate a component configuration by type\n */\nexport function validateComponent<T extends StandardComponentName>(\n name: T,\n props: unknown,\n options?: ValidationOptions\n): ComponentValidationResult<any> {\n const schema = COMPONENT_SCHEMA_MAP[name];\n\n if (!schema) {\n // Unknown component type, try custom component schema\n const customResult = validateAgainstSchema(\n CustomComponentDefinitionSchema,\n props,\n options\n );\n\n return {\n ...customResult,\n success: customResult.valid, // Add success for backward compatibility\n componentName: name,\n isCustomComponent: true,\n };\n }\n\n const result = validateAgainstSchema(schema, props, options);\n\n return {\n ...result,\n success: result.valid, // Add success for backward compatibility\n componentName: name,\n isCustomComponent: name === 'custom',\n };\n}\n\n/**\n * Validate a complete component definition (including nested children)\n */\nexport function validateComponentDefinition(\n component: unknown,\n options?: ValidationOptions\n): ComponentValidationResult {\n const result = validateAgainstSchema(\n ComponentDefinitionSchema,\n component,\n options\n );\n\n // Add component-specific metadata\n const componentResult: ComponentValidationResult = {\n ...result,\n };\n\n if (result.valid && result.data) {\n const comp = result.data as any;\n componentResult.componentName = comp.name;\n componentResult.isCustomComponent = !isStandardComponentName(comp.name);\n }\n\n return componentResult;\n}\n\n/**\n * Validate a custom component configuration with a custom schema.\n * Delegates to @json-to-office/shared/plugin to avoid duplication.\n */\nexport function validateCustomComponentProps<T>(\n componentSchema: TSchema,\n config: unknown,\n options?: ValidationOptions\n): ComponentValidationResult<T> {\n return sharedValidateCustomComponentProps<T>(\n componentSchema,\n config,\n options\n );\n}\n\n/**\n * Batch validate multiple components\n */\nexport function validateComponents(\n components: Array<{ name: string; props: unknown }>,\n options?: ValidationOptions\n): ComponentValidationResult[] {\n return components.map(({ name, props }) => {\n if (isStandardComponentName(name)) {\n return validateComponent(name, props, options);\n }\n return validateComponent('custom', props, options);\n });\n}\n\n/**\n * Type guards for component names\n */\nexport function isStandardComponentName(\n name: string\n): name is StandardComponentName {\n return name in COMPONENT_SCHEMA_MAP;\n}\n\nexport function isReportProps(\n config: unknown\n): config is Static<typeof ReportPropsSchema> {\n return Value.Check(ReportPropsSchema, config);\n}\n\nexport function isSectionProps(\n config: unknown\n): config is Static<typeof SectionPropsSchema> {\n return Value.Check(SectionPropsSchema, config);\n}\n\nexport function isHeadingProps(\n config: unknown\n): config is Static<typeof HeadingPropsSchema> {\n return Value.Check(HeadingPropsSchema, config);\n}\n\nexport function isParagraphProps(\n config: unknown\n): config is Static<typeof ParagraphPropsSchema> {\n return Value.Check(ParagraphPropsSchema, config);\n}\n\nexport function isColumnsProps(\n config: unknown\n): config is Static<typeof ColumnsPropsSchema> {\n return Value.Check(ColumnsPropsSchema, config);\n}\n\nexport function isImageProps(\n config: unknown\n): config is Static<typeof ImagePropsSchema> {\n return Value.Check(ImagePropsSchema, config);\n}\n\nexport function isStatisticProps(\n config: unknown\n): config is Static<typeof StatisticPropsSchema> {\n return Value.Check(StatisticPropsSchema, config);\n}\n\nexport function isTableProps(\n config: unknown\n): config is Static<typeof TablePropsSchema> {\n return Value.Check(TablePropsSchema, config);\n}\n\nexport function isListProps(\n config: unknown\n): config is Static<typeof ListPropsSchema> {\n return Value.Check(ListPropsSchema, config);\n}\n\nexport function isCustomComponentProps(\n config: unknown\n): config is Static<typeof CustomComponentDefinitionSchema> {\n return Value.Check(CustomComponentDefinitionSchema, config);\n}\n\n/**\n * Create a component validator with default options\n */\nexport function createComponentValidator(defaultOptions?: ValidationOptions) {\n return {\n validate: (name: string, props: unknown, options?: ValidationOptions) => {\n if (isStandardComponentName(name)) {\n return validateComponent(name, props, {\n ...defaultOptions,\n ...options,\n });\n }\n return validateComponent('custom', props, {\n ...defaultOptions,\n ...options,\n });\n },\n validateDefinition: (component: unknown, options?: ValidationOptions) =>\n validateComponentDefinition(component, { ...defaultOptions, ...options }),\n validateCustom: <T>(\n schema: TSchema,\n config: unknown,\n options?: ValidationOptions\n ) =>\n validateCustomComponentProps<T>(schema, config, {\n ...defaultOptions,\n ...options,\n }),\n };\n}\n\n// Export convenient validators with common configurations\nexport const componentValidator = createComponentValidator({\n clean: true,\n applyDefaults: true,\n});\n\nexport const strictComponentValidator = createComponentValidator({\n clean: false,\n applyDefaults: false,\n maxErrors: 10,\n});\n"],"mappings":"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","names":["DEFAULT_ERROR_CONFIG"]}
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  createAllComponentSchemasNarrowed,
3
3
  getStandardComponent
4
- } from "./chunk-PN6JT3KF.js";
4
+ } from "./chunk-S5KMAUDZ.js";
5
5
 
6
6
  // src/schemas/generator.ts
7
7
  import { Type } from "@sinclair/typebox";
@@ -128,4 +128,4 @@ function generateUnifiedDocumentSchema(options = {}) {
128
128
  export {
129
129
  generateUnifiedDocumentSchema
130
130
  };
131
- //# sourceMappingURL=chunk-SK6LSPFN.js.map
131
+ //# sourceMappingURL=chunk-RFNU2AYT.js.map