@frontmcp/ui 0.6.0 → 0.6.1
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.
- package/README.md +140 -362
- package/bridge/runtime/index.d.ts +2 -1
- package/bridge/runtime/index.d.ts.map +1 -1
- package/bundler/file-cache/component-builder.d.ts +1 -1
- package/bundler/file-cache/component-builder.d.ts.map +1 -1
- package/bundler/file-cache/hash-calculator.d.ts +1 -1
- package/bundler/file-cache/hash-calculator.d.ts.map +1 -1
- package/bundler/file-cache/storage/filesystem.d.ts +1 -1
- package/bundler/file-cache/storage/filesystem.d.ts.map +1 -1
- package/bundler/file-cache/storage/interface.d.ts +1 -1
- package/bundler/file-cache/storage/interface.d.ts.map +1 -1
- package/bundler/file-cache/storage/redis.d.ts +1 -1
- package/bundler/file-cache/storage/redis.d.ts.map +1 -1
- package/bundler/index.js +10 -1057
- package/components/alert.schema.d.ts +6 -6
- package/components/avatar.schema.d.ts +9 -9
- package/components/badge.schema.d.ts +9 -9
- package/components/button.schema.d.ts +9 -9
- package/components/card.schema.d.ts +7 -7
- package/components/form.schema.d.ts +24 -24
- package/components/index.js +128 -198
- package/components/modal.schema.d.ts +8 -8
- package/components/table.schema.d.ts +6 -6
- package/esm/bridge/runtime/index.d.ts +2 -1
- package/esm/bridge/runtime/index.d.ts.map +1 -1
- package/esm/bundler/file-cache/component-builder.d.ts +1 -1
- package/esm/bundler/file-cache/component-builder.d.ts.map +1 -1
- package/esm/bundler/file-cache/hash-calculator.d.ts +1 -1
- package/esm/bundler/file-cache/hash-calculator.d.ts.map +1 -1
- package/esm/bundler/file-cache/storage/filesystem.d.ts +1 -1
- package/esm/bundler/file-cache/storage/filesystem.d.ts.map +1 -1
- package/esm/bundler/file-cache/storage/interface.d.ts +1 -1
- package/esm/bundler/file-cache/storage/interface.d.ts.map +1 -1
- package/esm/bundler/file-cache/storage/redis.d.ts +1 -1
- package/esm/bundler/file-cache/storage/redis.d.ts.map +1 -1
- package/esm/bundler/index.js +3 -1050
- package/esm/components/alert.schema.d.ts +6 -6
- package/esm/components/avatar.schema.d.ts +9 -9
- package/esm/components/badge.schema.d.ts +9 -9
- package/esm/components/button.schema.d.ts +9 -9
- package/esm/components/card.schema.d.ts +7 -7
- package/esm/components/form.schema.d.ts +24 -24
- package/esm/components/index.js +136 -196
- package/esm/components/modal.schema.d.ts +8 -8
- package/esm/components/table.schema.d.ts +6 -6
- package/esm/index.d.ts +23 -39
- package/esm/index.d.ts.map +1 -1
- package/esm/index.js +4256 -16441
- package/esm/layouts/base.d.ts +2 -2
- package/esm/layouts/base.d.ts.map +1 -1
- package/esm/layouts/index.js +33 -516
- package/esm/package.json +8 -26
- package/esm/pages/index.js +100 -627
- package/esm/react/Alert.d.ts +1 -2
- package/esm/react/Alert.d.ts.map +1 -1
- package/esm/react/Badge.d.ts +1 -2
- package/esm/react/Badge.d.ts.map +1 -1
- package/esm/react/Button.d.ts +1 -2
- package/esm/react/Button.d.ts.map +1 -1
- package/esm/react/Card.d.ts +1 -2
- package/esm/react/Card.d.ts.map +1 -1
- package/esm/react/hooks/context.d.ts +1 -1
- package/esm/react/hooks/context.d.ts.map +1 -1
- package/esm/react/index.d.ts +5 -6
- package/esm/react/index.d.ts.map +1 -1
- package/esm/react/index.js +2074 -322
- package/esm/react/types.d.ts +1 -2
- package/esm/react/types.d.ts.map +1 -1
- package/esm/renderers/index.d.ts +10 -25
- package/esm/renderers/index.d.ts.map +1 -1
- package/esm/renderers/index.js +171 -1617
- package/esm/{runtime/adapters → renderers}/react.adapter.d.ts +2 -2
- package/esm/renderers/react.adapter.d.ts.map +1 -0
- package/esm/renderers/react.renderer.d.ts +3 -3
- package/esm/renderers/react.renderer.d.ts.map +1 -1
- package/esm/universal/index.js +1755 -0
- package/esm/web-components/index.js +232 -287
- package/esm/widgets/index.js +89 -147
- package/index.d.ts +23 -39
- package/index.d.ts.map +1 -1
- package/index.js +6123 -18539
- package/layouts/base.d.ts +2 -2
- package/layouts/base.d.ts.map +1 -1
- package/layouts/index.js +43 -536
- package/package.json +8 -26
- package/pages/index.js +111 -648
- package/react/Alert.d.ts +1 -2
- package/react/Alert.d.ts.map +1 -1
- package/react/Badge.d.ts +1 -2
- package/react/Badge.d.ts.map +1 -1
- package/react/Button.d.ts +1 -2
- package/react/Button.d.ts.map +1 -1
- package/react/Card.d.ts +1 -2
- package/react/Card.d.ts.map +1 -1
- package/react/hooks/context.d.ts +1 -1
- package/react/hooks/context.d.ts.map +1 -1
- package/react/index.d.ts +5 -6
- package/react/index.d.ts.map +1 -1
- package/react/index.js +2065 -335
- package/react/types.d.ts +1 -2
- package/react/types.d.ts.map +1 -1
- package/renderers/index.d.ts +10 -25
- package/renderers/index.d.ts.map +1 -1
- package/renderers/index.js +175 -1641
- package/{runtime/adapters → renderers}/react.adapter.d.ts +2 -2
- package/renderers/react.adapter.d.ts.map +1 -0
- package/renderers/react.renderer.d.ts +3 -3
- package/renderers/react.renderer.d.ts.map +1 -1
- package/universal/index.js +1841 -0
- package/web-components/index.js +224 -289
- package/widgets/index.js +80 -148
- package/adapters/index.d.ts +0 -13
- package/adapters/index.d.ts.map +0 -1
- package/adapters/index.js +0 -462
- package/adapters/platform-meta.d.ts +0 -166
- package/adapters/platform-meta.d.ts.map +0 -1
- package/adapters/response-builder.d.ts +0 -108
- package/adapters/response-builder.d.ts.map +0 -1
- package/adapters/serving-mode.d.ts +0 -107
- package/adapters/serving-mode.d.ts.map +0 -1
- package/base-template/bridge.d.ts +0 -90
- package/base-template/bridge.d.ts.map +0 -1
- package/base-template/default-base-template.d.ts +0 -92
- package/base-template/default-base-template.d.ts.map +0 -1
- package/base-template/index.d.ts +0 -15
- package/base-template/index.d.ts.map +0 -1
- package/base-template/index.js +0 -1398
- package/base-template/polyfills.d.ts +0 -31
- package/base-template/polyfills.d.ts.map +0 -1
- package/base-template/theme-styles.d.ts +0 -74
- package/base-template/theme-styles.d.ts.map +0 -1
- package/build/cdn-resources.d.ts +0 -243
- package/build/cdn-resources.d.ts.map +0 -1
- package/build/index.d.ts +0 -295
- package/build/index.d.ts.map +0 -1
- package/build/index.js +0 -7096
- package/build/widget-manifest.d.ts +0 -362
- package/build/widget-manifest.d.ts.map +0 -1
- package/dependency/cdn-registry.d.ts +0 -98
- package/dependency/cdn-registry.d.ts.map +0 -1
- package/dependency/import-map.d.ts +0 -186
- package/dependency/import-map.d.ts.map +0 -1
- package/dependency/import-parser.d.ts +0 -82
- package/dependency/import-parser.d.ts.map +0 -1
- package/dependency/index.d.ts +0 -17
- package/dependency/index.d.ts.map +0 -1
- package/dependency/resolver.d.ts +0 -164
- package/dependency/resolver.d.ts.map +0 -1
- package/dependency/schemas.d.ts +0 -486
- package/dependency/schemas.d.ts.map +0 -1
- package/dependency/template-loader.d.ts +0 -204
- package/dependency/template-loader.d.ts.map +0 -1
- package/dependency/template-processor.d.ts +0 -118
- package/dependency/template-processor.d.ts.map +0 -1
- package/dependency/types.d.ts +0 -739
- package/dependency/types.d.ts.map +0 -1
- package/esm/adapters/index.d.ts +0 -13
- package/esm/adapters/index.d.ts.map +0 -1
- package/esm/adapters/index.js +0 -427
- package/esm/adapters/platform-meta.d.ts +0 -166
- package/esm/adapters/platform-meta.d.ts.map +0 -1
- package/esm/adapters/response-builder.d.ts +0 -108
- package/esm/adapters/response-builder.d.ts.map +0 -1
- package/esm/adapters/serving-mode.d.ts +0 -107
- package/esm/adapters/serving-mode.d.ts.map +0 -1
- package/esm/base-template/bridge.d.ts +0 -90
- package/esm/base-template/bridge.d.ts.map +0 -1
- package/esm/base-template/default-base-template.d.ts +0 -92
- package/esm/base-template/default-base-template.d.ts.map +0 -1
- package/esm/base-template/index.d.ts +0 -15
- package/esm/base-template/index.d.ts.map +0 -1
- package/esm/base-template/index.js +0 -1364
- package/esm/base-template/polyfills.d.ts +0 -31
- package/esm/base-template/polyfills.d.ts.map +0 -1
- package/esm/base-template/theme-styles.d.ts +0 -74
- package/esm/base-template/theme-styles.d.ts.map +0 -1
- package/esm/build/cdn-resources.d.ts +0 -243
- package/esm/build/cdn-resources.d.ts.map +0 -1
- package/esm/build/index.d.ts +0 -295
- package/esm/build/index.d.ts.map +0 -1
- package/esm/build/index.js +0 -7021
- package/esm/build/widget-manifest.d.ts +0 -362
- package/esm/build/widget-manifest.d.ts.map +0 -1
- package/esm/dependency/cdn-registry.d.ts +0 -98
- package/esm/dependency/cdn-registry.d.ts.map +0 -1
- package/esm/dependency/import-map.d.ts +0 -186
- package/esm/dependency/import-map.d.ts.map +0 -1
- package/esm/dependency/import-parser.d.ts +0 -82
- package/esm/dependency/import-parser.d.ts.map +0 -1
- package/esm/dependency/index.d.ts +0 -17
- package/esm/dependency/index.d.ts.map +0 -1
- package/esm/dependency/resolver.d.ts +0 -164
- package/esm/dependency/resolver.d.ts.map +0 -1
- package/esm/dependency/schemas.d.ts +0 -486
- package/esm/dependency/schemas.d.ts.map +0 -1
- package/esm/dependency/template-loader.d.ts +0 -204
- package/esm/dependency/template-loader.d.ts.map +0 -1
- package/esm/dependency/template-processor.d.ts +0 -118
- package/esm/dependency/template-processor.d.ts.map +0 -1
- package/esm/dependency/types.d.ts +0 -739
- package/esm/dependency/types.d.ts.map +0 -1
- package/esm/handlebars/expression-extractor.d.ts +0 -147
- package/esm/handlebars/expression-extractor.d.ts.map +0 -1
- package/esm/handlebars/helpers.d.ts +0 -339
- package/esm/handlebars/helpers.d.ts.map +0 -1
- package/esm/handlebars/index.d.ts +0 -195
- package/esm/handlebars/index.d.ts.map +0 -1
- package/esm/handlebars/index.js +0 -587
- package/esm/registry/index.d.ts +0 -46
- package/esm/registry/index.d.ts.map +0 -1
- package/esm/registry/index.js +0 -6422
- package/esm/registry/render-template.d.ts +0 -91
- package/esm/registry/render-template.d.ts.map +0 -1
- package/esm/registry/tool-ui.registry.d.ts +0 -294
- package/esm/registry/tool-ui.registry.d.ts.map +0 -1
- package/esm/registry/uri-utils.d.ts +0 -56
- package/esm/registry/uri-utils.d.ts.map +0 -1
- package/esm/renderers/cache.d.ts +0 -145
- package/esm/renderers/cache.d.ts.map +0 -1
- package/esm/renderers/html.renderer.d.ts +0 -123
- package/esm/renderers/html.renderer.d.ts.map +0 -1
- package/esm/renderers/mdx.renderer.d.ts +0 -120
- package/esm/renderers/mdx.renderer.d.ts.map +0 -1
- package/esm/renderers/registry.d.ts +0 -134
- package/esm/renderers/registry.d.ts.map +0 -1
- package/esm/renderers/types.d.ts +0 -342
- package/esm/renderers/types.d.ts.map +0 -1
- package/esm/renderers/utils/detect.d.ts +0 -107
- package/esm/renderers/utils/detect.d.ts.map +0 -1
- package/esm/renderers/utils/hash.d.ts +0 -40
- package/esm/renderers/utils/hash.d.ts.map +0 -1
- package/esm/renderers/utils/index.d.ts +0 -9
- package/esm/renderers/utils/index.d.ts.map +0 -1
- package/esm/renderers/utils/transpiler.d.ts +0 -89
- package/esm/renderers/utils/transpiler.d.ts.map +0 -1
- package/esm/runtime/adapters/html.adapter.d.ts +0 -59
- package/esm/runtime/adapters/html.adapter.d.ts.map +0 -1
- package/esm/runtime/adapters/index.d.ts +0 -26
- package/esm/runtime/adapters/index.d.ts.map +0 -1
- package/esm/runtime/adapters/mdx.adapter.d.ts +0 -73
- package/esm/runtime/adapters/mdx.adapter.d.ts.map +0 -1
- package/esm/runtime/adapters/react.adapter.d.ts.map +0 -1
- package/esm/runtime/adapters/types.d.ts +0 -95
- package/esm/runtime/adapters/types.d.ts.map +0 -1
- package/esm/runtime/csp.d.ts +0 -48
- package/esm/runtime/csp.d.ts.map +0 -1
- package/esm/runtime/index.d.ts +0 -17
- package/esm/runtime/index.d.ts.map +0 -1
- package/esm/runtime/index.js +0 -5186
- package/esm/runtime/mcp-bridge.d.ts +0 -101
- package/esm/runtime/mcp-bridge.d.ts.map +0 -1
- package/esm/runtime/renderer-runtime.d.ts +0 -133
- package/esm/runtime/renderer-runtime.d.ts.map +0 -1
- package/esm/runtime/sanitizer.d.ts +0 -172
- package/esm/runtime/sanitizer.d.ts.map +0 -1
- package/esm/runtime/types.d.ts +0 -415
- package/esm/runtime/types.d.ts.map +0 -1
- package/esm/runtime/wrapper.d.ts +0 -421
- package/esm/runtime/wrapper.d.ts.map +0 -1
- package/esm/styles/index.d.ts +0 -8
- package/esm/styles/index.d.ts.map +0 -1
- package/esm/styles/index.js +0 -171
- package/esm/styles/variants.d.ts +0 -51
- package/esm/styles/variants.d.ts.map +0 -1
- package/esm/theme/cdn.d.ts +0 -195
- package/esm/theme/cdn.d.ts.map +0 -1
- package/esm/theme/index.d.ts +0 -18
- package/esm/theme/index.d.ts.map +0 -1
- package/esm/theme/index.js +0 -700
- package/esm/theme/platforms.d.ts +0 -107
- package/esm/theme/platforms.d.ts.map +0 -1
- package/esm/theme/presets/github-openai.d.ts +0 -50
- package/esm/theme/presets/github-openai.d.ts.map +0 -1
- package/esm/theme/presets/index.d.ts +0 -11
- package/esm/theme/presets/index.d.ts.map +0 -1
- package/esm/theme/theme.d.ts +0 -396
- package/esm/theme/theme.d.ts.map +0 -1
- package/esm/tool-template/builder.d.ts +0 -213
- package/esm/tool-template/builder.d.ts.map +0 -1
- package/esm/tool-template/index.d.ts +0 -16
- package/esm/tool-template/index.d.ts.map +0 -1
- package/esm/tool-template/index.js +0 -3515
- package/esm/types/index.d.ts +0 -14
- package/esm/types/index.d.ts.map +0 -1
- package/esm/types/index.js +0 -75
- package/esm/types/ui-config.d.ts +0 -639
- package/esm/types/ui-config.d.ts.map +0 -1
- package/esm/types/ui-runtime.d.ts +0 -1007
- package/esm/types/ui-runtime.d.ts.map +0 -1
- package/esm/typings/cache/cache-adapter.d.ts +0 -125
- package/esm/typings/cache/cache-adapter.d.ts.map +0 -1
- package/esm/typings/cache/index.d.ts +0 -10
- package/esm/typings/cache/index.d.ts.map +0 -1
- package/esm/typings/cache/memory-cache.d.ts +0 -92
- package/esm/typings/cache/memory-cache.d.ts.map +0 -1
- package/esm/typings/dts-parser.d.ts +0 -90
- package/esm/typings/dts-parser.d.ts.map +0 -1
- package/esm/typings/index.d.ts +0 -48
- package/esm/typings/index.d.ts.map +0 -1
- package/esm/typings/schemas.d.ts +0 -232
- package/esm/typings/schemas.d.ts.map +0 -1
- package/esm/typings/type-fetcher.d.ts +0 -89
- package/esm/typings/type-fetcher.d.ts.map +0 -1
- package/esm/typings/types.d.ts +0 -320
- package/esm/typings/types.d.ts.map +0 -1
- package/esm/utils/escape-html.d.ts +0 -58
- package/esm/utils/escape-html.d.ts.map +0 -1
- package/esm/utils/index.d.ts +0 -10
- package/esm/utils/index.d.ts.map +0 -1
- package/esm/utils/index.js +0 -40
- package/esm/utils/safe-stringify.d.ts +0 -30
- package/esm/utils/safe-stringify.d.ts.map +0 -1
- package/esm/validation/error-box.d.ts +0 -56
- package/esm/validation/error-box.d.ts.map +0 -1
- package/esm/validation/index.d.ts +0 -13
- package/esm/validation/index.d.ts.map +0 -1
- package/esm/validation/index.js +0 -562
- package/esm/validation/schema-paths.d.ts +0 -118
- package/esm/validation/schema-paths.d.ts.map +0 -1
- package/esm/validation/template-validator.d.ts +0 -143
- package/esm/validation/template-validator.d.ts.map +0 -1
- package/esm/validation/wrapper.d.ts +0 -97
- package/esm/validation/wrapper.d.ts.map +0 -1
- package/handlebars/expression-extractor.d.ts +0 -147
- package/handlebars/expression-extractor.d.ts.map +0 -1
- package/handlebars/helpers.d.ts +0 -339
- package/handlebars/helpers.d.ts.map +0 -1
- package/handlebars/index.d.ts +0 -195
- package/handlebars/index.d.ts.map +0 -1
- package/handlebars/index.js +0 -666
- package/registry/index.d.ts +0 -46
- package/registry/index.d.ts.map +0 -1
- package/registry/index.js +0 -6465
- package/registry/render-template.d.ts +0 -91
- package/registry/render-template.d.ts.map +0 -1
- package/registry/tool-ui.registry.d.ts +0 -294
- package/registry/tool-ui.registry.d.ts.map +0 -1
- package/registry/uri-utils.d.ts +0 -56
- package/registry/uri-utils.d.ts.map +0 -1
- package/renderers/cache.d.ts +0 -145
- package/renderers/cache.d.ts.map +0 -1
- package/renderers/html.renderer.d.ts +0 -123
- package/renderers/html.renderer.d.ts.map +0 -1
- package/renderers/mdx.renderer.d.ts +0 -120
- package/renderers/mdx.renderer.d.ts.map +0 -1
- package/renderers/registry.d.ts +0 -134
- package/renderers/registry.d.ts.map +0 -1
- package/renderers/types.d.ts +0 -342
- package/renderers/types.d.ts.map +0 -1
- package/renderers/utils/detect.d.ts +0 -107
- package/renderers/utils/detect.d.ts.map +0 -1
- package/renderers/utils/hash.d.ts +0 -40
- package/renderers/utils/hash.d.ts.map +0 -1
- package/renderers/utils/index.d.ts +0 -9
- package/renderers/utils/index.d.ts.map +0 -1
- package/renderers/utils/transpiler.d.ts +0 -89
- package/renderers/utils/transpiler.d.ts.map +0 -1
- package/runtime/adapters/html.adapter.d.ts +0 -59
- package/runtime/adapters/html.adapter.d.ts.map +0 -1
- package/runtime/adapters/index.d.ts +0 -26
- package/runtime/adapters/index.d.ts.map +0 -1
- package/runtime/adapters/mdx.adapter.d.ts +0 -73
- package/runtime/adapters/mdx.adapter.d.ts.map +0 -1
- package/runtime/adapters/react.adapter.d.ts.map +0 -1
- package/runtime/adapters/types.d.ts +0 -95
- package/runtime/adapters/types.d.ts.map +0 -1
- package/runtime/csp.d.ts +0 -48
- package/runtime/csp.d.ts.map +0 -1
- package/runtime/index.d.ts +0 -17
- package/runtime/index.d.ts.map +0 -1
- package/runtime/index.js +0 -5264
- package/runtime/mcp-bridge.d.ts +0 -101
- package/runtime/mcp-bridge.d.ts.map +0 -1
- package/runtime/renderer-runtime.d.ts +0 -133
- package/runtime/renderer-runtime.d.ts.map +0 -1
- package/runtime/sanitizer.d.ts +0 -172
- package/runtime/sanitizer.d.ts.map +0 -1
- package/runtime/types.d.ts +0 -415
- package/runtime/types.d.ts.map +0 -1
- package/runtime/wrapper.d.ts +0 -421
- package/runtime/wrapper.d.ts.map +0 -1
- package/styles/index.d.ts +0 -8
- package/styles/index.d.ts.map +0 -1
- package/styles/index.js +0 -222
- package/styles/variants.d.ts +0 -51
- package/styles/variants.d.ts.map +0 -1
- package/theme/cdn.d.ts +0 -195
- package/theme/cdn.d.ts.map +0 -1
- package/theme/index.d.ts +0 -18
- package/theme/index.d.ts.map +0 -1
- package/theme/index.js +0 -757
- package/theme/platforms.d.ts +0 -107
- package/theme/platforms.d.ts.map +0 -1
- package/theme/presets/github-openai.d.ts +0 -50
- package/theme/presets/github-openai.d.ts.map +0 -1
- package/theme/presets/index.d.ts +0 -11
- package/theme/presets/index.d.ts.map +0 -1
- package/theme/theme.d.ts +0 -396
- package/theme/theme.d.ts.map +0 -1
- package/tool-template/builder.d.ts +0 -213
- package/tool-template/builder.d.ts.map +0 -1
- package/tool-template/index.d.ts +0 -16
- package/tool-template/index.d.ts.map +0 -1
- package/tool-template/index.js +0 -3559
- package/types/index.d.ts +0 -14
- package/types/index.d.ts.map +0 -1
- package/types/index.js +0 -108
- package/types/ui-config.d.ts +0 -639
- package/types/ui-config.d.ts.map +0 -1
- package/types/ui-runtime.d.ts +0 -1007
- package/types/ui-runtime.d.ts.map +0 -1
- package/typings/cache/cache-adapter.d.ts +0 -125
- package/typings/cache/cache-adapter.d.ts.map +0 -1
- package/typings/cache/index.d.ts +0 -10
- package/typings/cache/index.d.ts.map +0 -1
- package/typings/cache/memory-cache.d.ts +0 -92
- package/typings/cache/memory-cache.d.ts.map +0 -1
- package/typings/dts-parser.d.ts +0 -90
- package/typings/dts-parser.d.ts.map +0 -1
- package/typings/index.d.ts +0 -48
- package/typings/index.d.ts.map +0 -1
- package/typings/schemas.d.ts +0 -232
- package/typings/schemas.d.ts.map +0 -1
- package/typings/type-fetcher.d.ts +0 -89
- package/typings/type-fetcher.d.ts.map +0 -1
- package/typings/types.d.ts +0 -320
- package/typings/types.d.ts.map +0 -1
- package/utils/escape-html.d.ts +0 -58
- package/utils/escape-html.d.ts.map +0 -1
- package/utils/index.d.ts +0 -10
- package/utils/index.d.ts.map +0 -1
- package/utils/index.js +0 -70
- package/utils/safe-stringify.d.ts +0 -30
- package/utils/safe-stringify.d.ts.map +0 -1
- package/validation/error-box.d.ts +0 -56
- package/validation/error-box.d.ts.map +0 -1
- package/validation/index.d.ts +0 -13
- package/validation/index.d.ts.map +0 -1
- package/validation/index.js +0 -603
- package/validation/schema-paths.d.ts +0 -118
- package/validation/schema-paths.d.ts.map +0 -1
- package/validation/template-validator.d.ts +0 -143
- package/validation/template-validator.d.ts.map +0 -1
- package/validation/wrapper.d.ts +0 -97
- package/validation/wrapper.d.ts.map +0 -1
package/esm/layouts/base.d.ts
CHANGED
|
@@ -7,7 +7,7 @@
|
|
|
7
7
|
* - CDN resource management
|
|
8
8
|
* - Responsive layouts
|
|
9
9
|
*/
|
|
10
|
-
import { type PlatformCapabilities, type ThemeConfig, type DeepPartial } from '
|
|
10
|
+
import { type PlatformCapabilities, type ThemeConfig, type DeepPartial } from '@frontmcp/uipack/theme';
|
|
11
11
|
/**
|
|
12
12
|
* Page type determines the layout structure
|
|
13
13
|
*/
|
|
@@ -68,7 +68,7 @@ export interface BaseLayoutOptions {
|
|
|
68
68
|
type?: string;
|
|
69
69
|
};
|
|
70
70
|
}
|
|
71
|
-
export { escapeHtml } from '
|
|
71
|
+
export { escapeHtml } from '@frontmcp/uipack/utils';
|
|
72
72
|
/**
|
|
73
73
|
* Build the complete HTML document
|
|
74
74
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../src/layouts/base.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EACL,KAAK,oBAAoB,EACzB,KAAK,WAAW,EAChB,KAAK,WAAW,EAWjB,MAAM,
|
|
1
|
+
{"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../src/layouts/base.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EACL,KAAK,oBAAoB,EACzB,KAAK,WAAW,EAChB,KAAK,WAAW,EAWjB,MAAM,wBAAwB,CAAC;AAOhC;;GAEG;AACH,MAAM,MAAM,QAAQ,GAChB,MAAM,GACN,SAAS,GACT,OAAO,GACP,SAAS,GACT,SAAS,GACT,WAAW,GACX,QAAQ,GACR,UAAU,GACV,QAAQ,CAAC;AAEb;;GAEG;AACH,MAAM,MAAM,UAAU,GAClB,IAAI,GACJ,IAAI,GACJ,IAAI,GACJ,IAAI,GACJ,IAAI,GACJ,KAAK,GACL,KAAK,GACL,MAAM,CAAC;AAEX;;GAEG;AACH,MAAM,MAAM,eAAe,GACvB,OAAO,GACP,UAAU,GACV,SAAS,GACT,MAAM,CAAC;AAEX;;GAEG;AACH,MAAM,MAAM,eAAe,GACvB,QAAQ,GACR,KAAK,GACL,OAAO,CAAC;AAMZ;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,kDAAkD;IAClD,KAAK,EAAE,MAAM,CAAC;IAEd,qCAAqC;IACrC,QAAQ,CAAC,EAAE,QAAQ,CAAC;IAEpB,oBAAoB;IACpB,IAAI,CAAC,EAAE,UAAU,CAAC;IAElB,wBAAwB;IACxB,SAAS,CAAC,EAAE,eAAe,CAAC;IAE5B,uBAAuB;IACvB,UAAU,CAAC,EAAE,eAAe,CAAC;IAE7B,6CAA6C;IAC7C,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB,mCAAmC;IACnC,QAAQ,CAAC,EAAE,oBAAoB,CAAC;IAEhC,+EAA+E;IAC/E,KAAK,CAAC,EAAE,WAAW,CAAC,WAAW,CAAC,CAAC;IAEjC,gDAAgD;IAChD,WAAW,CAAC,EAAE,OAAO,CAAC;IAEtB,yCAAyC;IACzC,aAAa,CAAC,EAAE,OAAO,CAAC;IAExB,4CAA4C;IAC5C,YAAY,CAAC,EAAE,OAAO,CAAC;IAEvB,8BAA8B;IAC9B,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,iCAAiC;IACjC,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAEnC,0BAA0B;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,4BAA4B;IAC5B,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB,kBAAkB;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB,2BAA2B;IAC3B,EAAE,CAAC,EAAE;QACH,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,IAAI,CAAC,EAAE,MAAM,CAAC;KACf,CAAC;CACH;AAOD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AA8FpD;;;;;;GAMG;AACH,wBAAgB,UAAU,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,iBAAiB,GAAG,MAAM,CAuG9E;AAMD;;;;GAIG;AACH,wBAAgB,mBAAmB,CACjC,QAAQ,EAAE,OAAO,CAAC,iBAAiB,CAAC,GACnC,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,OAAO,CAAC,iBAAiB,CAAC,KAAK,MAAM,CAyBnE"}
|
package/esm/layouts/index.js
CHANGED
|
@@ -1,500 +1,17 @@
|
|
|
1
|
-
// libs/ui/src/theme/cdn.ts
|
|
2
|
-
var CDN = {
|
|
3
|
-
/**
|
|
4
|
-
* Tailwind CSS v4 Browser CDN
|
|
5
|
-
* Generates styles on-the-fly with @theme support
|
|
6
|
-
* @see https://tailwindcss.com/docs/installation/play-cdn
|
|
7
|
-
*/
|
|
8
|
-
tailwind: "https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4",
|
|
9
|
-
/**
|
|
10
|
-
* HTMX 2.x - High power tools for HTML
|
|
11
|
-
* Enables AJAX, WebSockets, Server Sent Events directly in HTML
|
|
12
|
-
* @see https://htmx.org
|
|
13
|
-
*/
|
|
14
|
-
htmx: {
|
|
15
|
-
url: "https://cdnjs.cloudflare.com/ajax/libs/htmx/2.0.7/htmx.min.js",
|
|
16
|
-
integrity: "sha512-T6VLg/MJYMbLTmQ8VLvonbWg8VOvmDhXcOvHzCwo6ShdGuUU5SEcp1IAPXL4k9lVoMi8gRXl5K/S/zh43Y9rJA=="
|
|
17
|
-
},
|
|
18
|
-
/**
|
|
19
|
-
* Alpine.js - Lightweight reactive framework
|
|
20
|
-
* Used for more complex client-side interactions
|
|
21
|
-
* @see https://alpinejs.dev
|
|
22
|
-
*/
|
|
23
|
-
alpine: {
|
|
24
|
-
url: "https://cdn.jsdelivr.net/npm/alpinejs@3.14.3/dist/cdn.min.js",
|
|
25
|
-
integrity: "sha384-6zY8MFQJ/EqS1r4RJl+7j8rvZPuBWpT0RzWf+IFcKhxqUzQNmJzA1X1VEVZhYaEz"
|
|
26
|
-
},
|
|
27
|
-
/**
|
|
28
|
-
* Google Fonts - Inter for modern UI typography
|
|
29
|
-
*/
|
|
30
|
-
fonts: {
|
|
31
|
-
preconnect: ["https://fonts.googleapis.com", "https://fonts.gstatic.com"],
|
|
32
|
-
inter: "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap",
|
|
33
|
-
mono: "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&display=swap"
|
|
34
|
-
},
|
|
35
|
-
/**
|
|
36
|
-
* Lucide Icons - Beautiful & consistent icons
|
|
37
|
-
* @see https://lucide.dev
|
|
38
|
-
*/
|
|
39
|
-
icons: {
|
|
40
|
-
url: "https://cdn.jsdelivr.net/npm/lucide@0.294.0/dist/umd/lucide.min.js",
|
|
41
|
-
integrity: "sha384-wpLmHb7v7V1LsEuTmPQ9tXqWZvTtRWWVqJuE+Yz6X0I6O2T6bHJVeXH1lVWqF4qE"
|
|
42
|
-
}
|
|
43
|
-
};
|
|
44
|
-
var scriptCache = /* @__PURE__ */ new Map();
|
|
45
|
-
function getCachedScript(url) {
|
|
46
|
-
return scriptCache.get(url);
|
|
47
|
-
}
|
|
48
|
-
function isScriptCached(url) {
|
|
49
|
-
return scriptCache.has(url);
|
|
50
|
-
}
|
|
51
|
-
function buildFontPreconnect() {
|
|
52
|
-
return CDN.fonts.preconnect.map((url, i) => `<link rel="preconnect" href="${url}"${i > 0 ? " crossorigin" : ""}>`).join("\n ");
|
|
53
|
-
}
|
|
54
|
-
function buildFontStylesheets(options = {}) {
|
|
55
|
-
const { inter = true, mono = false } = options;
|
|
56
|
-
const links = [];
|
|
57
|
-
if (inter) {
|
|
58
|
-
links.push(`<link href="${CDN.fonts.inter}" rel="stylesheet">`);
|
|
59
|
-
}
|
|
60
|
-
if (mono) {
|
|
61
|
-
links.push(`<link href="${CDN.fonts.mono}" rel="stylesheet">`);
|
|
62
|
-
}
|
|
63
|
-
return links.join("\n ");
|
|
64
|
-
}
|
|
65
|
-
function buildScriptTag(url, integrity, options = {}) {
|
|
66
|
-
const attrs = [`src="${url}"`];
|
|
67
|
-
if (integrity) {
|
|
68
|
-
attrs.push(`integrity="${integrity}"`);
|
|
69
|
-
attrs.push('crossorigin="anonymous"');
|
|
70
|
-
}
|
|
71
|
-
if (options.defer) attrs.push("defer");
|
|
72
|
-
if (options.async) attrs.push("async");
|
|
73
|
-
return `<script ${attrs.join(" ")}></script>`;
|
|
74
|
-
}
|
|
75
|
-
function buildInlineScriptTag(content) {
|
|
76
|
-
return `<script>${content}</script>`;
|
|
77
|
-
}
|
|
78
|
-
function buildCdnScripts(options = {}) {
|
|
79
|
-
const { tailwind = true, htmx = true, alpine = false, icons = false, inline = false } = options;
|
|
80
|
-
const scripts = [];
|
|
81
|
-
if (inline) {
|
|
82
|
-
if (tailwind) {
|
|
83
|
-
if (isScriptCached(CDN.tailwind)) {
|
|
84
|
-
scripts.push(buildInlineScriptTag(getCachedScript(CDN.tailwind)));
|
|
85
|
-
} else {
|
|
86
|
-
console.warn(
|
|
87
|
-
"[frontmcp/ui] Inline mode requested but Tailwind script not cached. Call fetchAndCacheScripts() first."
|
|
88
|
-
);
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
if (htmx) {
|
|
92
|
-
if (isScriptCached(CDN.htmx.url)) {
|
|
93
|
-
scripts.push(buildInlineScriptTag(getCachedScript(CDN.htmx.url)));
|
|
94
|
-
} else {
|
|
95
|
-
console.warn(
|
|
96
|
-
"[frontmcp/ui] Inline mode requested but HTMX script not cached. Call fetchAndCacheScripts() first."
|
|
97
|
-
);
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
if (alpine) {
|
|
101
|
-
if (isScriptCached(CDN.alpine.url)) {
|
|
102
|
-
scripts.push(buildInlineScriptTag(getCachedScript(CDN.alpine.url)));
|
|
103
|
-
} else {
|
|
104
|
-
console.warn(
|
|
105
|
-
"[frontmcp/ui] Inline mode requested but Alpine.js script not cached. Call fetchAndCacheScripts() first."
|
|
106
|
-
);
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
if (icons) {
|
|
110
|
-
if (isScriptCached(CDN.icons.url)) {
|
|
111
|
-
scripts.push(buildInlineScriptTag(getCachedScript(CDN.icons.url)));
|
|
112
|
-
} else {
|
|
113
|
-
console.warn(
|
|
114
|
-
"[frontmcp/ui] Inline mode requested but Lucide icons script not cached. Call fetchAndCacheScripts() first."
|
|
115
|
-
);
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
} else {
|
|
119
|
-
if (tailwind) {
|
|
120
|
-
scripts.push(buildScriptTag(CDN.tailwind));
|
|
121
|
-
}
|
|
122
|
-
if (htmx) {
|
|
123
|
-
scripts.push(buildScriptTag(CDN.htmx.url, CDN.htmx.integrity));
|
|
124
|
-
}
|
|
125
|
-
if (alpine) {
|
|
126
|
-
scripts.push(buildScriptTag(CDN.alpine.url, CDN.alpine.integrity, { defer: true }));
|
|
127
|
-
}
|
|
128
|
-
if (icons) {
|
|
129
|
-
scripts.push(buildScriptTag(CDN.icons.url, CDN.icons.integrity));
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
return scripts.join("\n ");
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
// libs/ui/src/theme/platforms.ts
|
|
136
|
-
var OPENAI_PLATFORM = {
|
|
137
|
-
id: "openai",
|
|
138
|
-
name: "OpenAI",
|
|
139
|
-
supportsWidgets: true,
|
|
140
|
-
supportsTailwind: true,
|
|
141
|
-
supportsHtmx: true,
|
|
142
|
-
networkMode: "full",
|
|
143
|
-
scriptStrategy: "cdn",
|
|
144
|
-
options: {
|
|
145
|
-
sdk: "apps-sdk",
|
|
146
|
-
version: "1.0"
|
|
147
|
-
}
|
|
148
|
-
};
|
|
149
|
-
var CLAUDE_PLATFORM = {
|
|
150
|
-
id: "claude",
|
|
151
|
-
name: "Claude (Artifacts)",
|
|
152
|
-
supportsWidgets: true,
|
|
153
|
-
supportsTailwind: true,
|
|
154
|
-
supportsHtmx: false,
|
|
155
|
-
// Network blocked, HTMX won't work for API calls
|
|
156
|
-
networkMode: "blocked",
|
|
157
|
-
scriptStrategy: "inline",
|
|
158
|
-
maxInlineSize: 100 * 1024,
|
|
159
|
-
// 100KB limit for artifacts
|
|
160
|
-
cspRestrictions: ["script-src 'unsafe-inline'", "connect-src 'none'"],
|
|
161
|
-
options: {
|
|
162
|
-
mode: "artifacts",
|
|
163
|
-
framework: "react"
|
|
164
|
-
// Claude artifacts prefer React
|
|
165
|
-
}
|
|
166
|
-
};
|
|
167
|
-
function canUseCdn(platform) {
|
|
168
|
-
return platform.networkMode === "full" && platform.scriptStrategy === "cdn";
|
|
169
|
-
}
|
|
170
|
-
function needsInlineScripts(platform) {
|
|
171
|
-
return platform.scriptStrategy === "inline" || platform.networkMode === "blocked";
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
// libs/ui/src/theme/presets/github-openai.ts
|
|
175
|
-
var GITHUB_OPENAI_THEME = {
|
|
176
|
-
name: "github-openai",
|
|
177
|
-
colors: {
|
|
178
|
-
semantic: {
|
|
179
|
-
// Primary: Near-black for main actions and branding
|
|
180
|
-
primary: "#24292f",
|
|
181
|
-
// Secondary: Medium gray for secondary elements
|
|
182
|
-
secondary: "#57606a",
|
|
183
|
-
// Accent: Blue for links, focus states, and highlights
|
|
184
|
-
accent: "#0969da",
|
|
185
|
-
// Status colors
|
|
186
|
-
success: "#1a7f37",
|
|
187
|
-
// GitHub green
|
|
188
|
-
warning: "#9a6700",
|
|
189
|
-
// Amber warning
|
|
190
|
-
danger: "#cf222e",
|
|
191
|
-
// GitHub red
|
|
192
|
-
info: "#0969da"
|
|
193
|
-
// Blue info
|
|
194
|
-
},
|
|
195
|
-
surface: {
|
|
196
|
-
// Pure white background
|
|
197
|
-
background: "#ffffff",
|
|
198
|
-
// Light gray surface (GitHub code background style)
|
|
199
|
-
surface: "#f6f8fa",
|
|
200
|
-
// White elevated surfaces (modals, cards)
|
|
201
|
-
elevated: "#ffffff",
|
|
202
|
-
// Dark semi-transparent overlay
|
|
203
|
-
overlay: "rgba(27, 31, 36, 0.5)"
|
|
204
|
-
},
|
|
205
|
-
text: {
|
|
206
|
-
// Near-black for primary text
|
|
207
|
-
primary: "#24292f",
|
|
208
|
-
// Gray for secondary/muted text
|
|
209
|
-
secondary: "#57606a",
|
|
210
|
-
// Light gray for disabled text
|
|
211
|
-
disabled: "#8c959f",
|
|
212
|
-
// White for text on dark backgrounds
|
|
213
|
-
inverse: "#ffffff",
|
|
214
|
-
// Blue for links
|
|
215
|
-
link: "#0969da"
|
|
216
|
-
},
|
|
217
|
-
border: {
|
|
218
|
-
// Light gray border (GitHub style)
|
|
219
|
-
default: "#d0d7de",
|
|
220
|
-
// Medium gray on hover
|
|
221
|
-
hover: "#8c959f",
|
|
222
|
-
// Blue focus ring
|
|
223
|
-
focus: "#0969da",
|
|
224
|
-
// Subtle divider
|
|
225
|
-
divider: "#d8dee4"
|
|
226
|
-
}
|
|
227
|
-
},
|
|
228
|
-
typography: {
|
|
229
|
-
families: {
|
|
230
|
-
// System UI font stack (GitHub/Apple style)
|
|
231
|
-
sans: '-apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji"',
|
|
232
|
-
// Monospace stack
|
|
233
|
-
mono: 'ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas, "Liberation Mono", monospace'
|
|
234
|
-
},
|
|
235
|
-
sizes: {
|
|
236
|
-
xs: "0.75rem",
|
|
237
|
-
// 12px
|
|
238
|
-
sm: "0.875rem",
|
|
239
|
-
// 14px
|
|
240
|
-
base: "1rem",
|
|
241
|
-
// 16px
|
|
242
|
-
lg: "1.125rem",
|
|
243
|
-
// 18px
|
|
244
|
-
xl: "1.25rem",
|
|
245
|
-
// 20px
|
|
246
|
-
"2xl": "1.5rem",
|
|
247
|
-
// 24px
|
|
248
|
-
"3xl": "1.875rem",
|
|
249
|
-
// 30px
|
|
250
|
-
"4xl": "2.25rem"
|
|
251
|
-
// 36px
|
|
252
|
-
},
|
|
253
|
-
weights: {
|
|
254
|
-
normal: "400",
|
|
255
|
-
medium: "500",
|
|
256
|
-
semibold: "600",
|
|
257
|
-
bold: "700"
|
|
258
|
-
}
|
|
259
|
-
},
|
|
260
|
-
radius: {
|
|
261
|
-
none: "0",
|
|
262
|
-
sm: "3px",
|
|
263
|
-
// GitHub uses smaller radii
|
|
264
|
-
md: "6px",
|
|
265
|
-
lg: "8px",
|
|
266
|
-
xl: "12px",
|
|
267
|
-
"2xl": "16px",
|
|
268
|
-
full: "9999px"
|
|
269
|
-
},
|
|
270
|
-
shadows: {
|
|
271
|
-
// Subtle shadows with gray tones
|
|
272
|
-
sm: "0 1px 0 rgba(27, 31, 36, 0.04)",
|
|
273
|
-
md: "0 3px 6px rgba(140, 149, 159, 0.15)",
|
|
274
|
-
lg: "0 8px 24px rgba(140, 149, 159, 0.2)",
|
|
275
|
-
xl: "0 12px 28px rgba(140, 149, 159, 0.3)"
|
|
276
|
-
},
|
|
277
|
-
components: {
|
|
278
|
-
button: {
|
|
279
|
-
radius: "6px",
|
|
280
|
-
paddingX: "16px",
|
|
281
|
-
paddingY: "5px",
|
|
282
|
-
fontSize: "14px",
|
|
283
|
-
fontWeight: "500"
|
|
284
|
-
},
|
|
285
|
-
card: {
|
|
286
|
-
radius: "6px",
|
|
287
|
-
padding: "16px",
|
|
288
|
-
shadow: "0 1px 0 rgba(27, 31, 36, 0.04)",
|
|
289
|
-
borderWidth: "1px"
|
|
290
|
-
},
|
|
291
|
-
input: {
|
|
292
|
-
radius: "6px",
|
|
293
|
-
paddingX: "12px",
|
|
294
|
-
paddingY: "5px",
|
|
295
|
-
borderWidth: "1px",
|
|
296
|
-
focusRingWidth: "3px"
|
|
297
|
-
}
|
|
298
|
-
},
|
|
299
|
-
cdn: {
|
|
300
|
-
fonts: {
|
|
301
|
-
preconnect: ["https://fonts.googleapis.com", "https://fonts.gstatic.com"],
|
|
302
|
-
stylesheets: [
|
|
303
|
-
// System UI fonts don't need external stylesheets, but we include
|
|
304
|
-
// Inter as an optional enhancement for consistent cross-platform rendering
|
|
305
|
-
"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap"
|
|
306
|
-
]
|
|
307
|
-
},
|
|
308
|
-
icons: {
|
|
309
|
-
script: {
|
|
310
|
-
url: "https://cdn.jsdelivr.net/npm/lucide@0.294.0/dist/umd/lucide.min.js"
|
|
311
|
-
}
|
|
312
|
-
},
|
|
313
|
-
scripts: {
|
|
314
|
-
tailwind: "https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4",
|
|
315
|
-
htmx: {
|
|
316
|
-
url: "https://cdnjs.cloudflare.com/ajax/libs/htmx/2.0.7/htmx.min.js",
|
|
317
|
-
integrity: "sha512-T6VLg/MJYMbLTmQ8VLvonbWg8VOvmDhXcOvHzCwo6ShdGuUU5SEcp1IAPXL4k9lVoMi8gRXl5K/S/zh43Y9rJA=="
|
|
318
|
-
},
|
|
319
|
-
alpine: {
|
|
320
|
-
url: "https://cdn.jsdelivr.net/npm/alpinejs@3.14.3/dist/cdn.min.js",
|
|
321
|
-
integrity: "sha384-6zY8MFQJ/EqS1r4RJl+7j8rvZPuBWpT0RzWf+IFcKhxqUzQNmJzA1X1VEVZhYaEz"
|
|
322
|
-
}
|
|
323
|
-
}
|
|
324
|
-
}
|
|
325
|
-
};
|
|
326
|
-
var DEFAULT_THEME = GITHUB_OPENAI_THEME;
|
|
327
|
-
|
|
328
|
-
// libs/ui/src/theme/theme.ts
|
|
329
|
-
function mergeThemesCore(base, override) {
|
|
330
|
-
const baseColors = base.colors ?? { semantic: { primary: "#24292f" } };
|
|
331
|
-
const filterStrings = (arr) => arr.filter((s) => s !== void 0);
|
|
332
|
-
return {
|
|
333
|
-
...base,
|
|
334
|
-
...override,
|
|
335
|
-
colors: {
|
|
336
|
-
...baseColors,
|
|
337
|
-
...override.colors,
|
|
338
|
-
semantic: { ...baseColors.semantic, ...override.colors?.semantic },
|
|
339
|
-
surface: { ...baseColors.surface, ...override.colors?.surface },
|
|
340
|
-
text: { ...baseColors.text, ...override.colors?.text },
|
|
341
|
-
border: { ...baseColors.border, ...override.colors?.border },
|
|
342
|
-
custom: { ...baseColors.custom, ...override.colors?.custom }
|
|
343
|
-
},
|
|
344
|
-
typography: {
|
|
345
|
-
...base.typography,
|
|
346
|
-
...override.typography,
|
|
347
|
-
families: { ...base.typography?.families, ...override.typography?.families },
|
|
348
|
-
sizes: { ...base.typography?.sizes, ...override.typography?.sizes },
|
|
349
|
-
weights: { ...base.typography?.weights, ...override.typography?.weights },
|
|
350
|
-
lineHeight: { ...base.typography?.lineHeight, ...override.typography?.lineHeight }
|
|
351
|
-
},
|
|
352
|
-
spacing: { ...base.spacing, ...override.spacing },
|
|
353
|
-
radius: { ...base.radius, ...override.radius },
|
|
354
|
-
shadows: { ...base.shadows, ...override.shadows },
|
|
355
|
-
components: {
|
|
356
|
-
...base.components,
|
|
357
|
-
...override.components,
|
|
358
|
-
button: { ...base.components?.button, ...override.components?.button },
|
|
359
|
-
card: { ...base.components?.card, ...override.components?.card },
|
|
360
|
-
input: { ...base.components?.input, ...override.components?.input }
|
|
361
|
-
},
|
|
362
|
-
cdn: {
|
|
363
|
-
...base.cdn,
|
|
364
|
-
...override.cdn,
|
|
365
|
-
fonts: {
|
|
366
|
-
// Concatenate then dedupe so base entries are preserved without duplicates
|
|
367
|
-
preconnect: filterStrings(
|
|
368
|
-
Array.from(/* @__PURE__ */ new Set([...base.cdn?.fonts?.preconnect ?? [], ...override.cdn?.fonts?.preconnect ?? []]))
|
|
369
|
-
),
|
|
370
|
-
stylesheets: filterStrings(
|
|
371
|
-
Array.from(/* @__PURE__ */ new Set([...base.cdn?.fonts?.stylesheets ?? [], ...override.cdn?.fonts?.stylesheets ?? []]))
|
|
372
|
-
)
|
|
373
|
-
},
|
|
374
|
-
icons: {
|
|
375
|
-
...base.cdn?.icons,
|
|
376
|
-
...override.cdn?.icons,
|
|
377
|
-
// Deep merge script to preserve integrity when only url is overridden
|
|
378
|
-
script: override.cdn?.icons?.script ? { ...base.cdn?.icons?.script, ...override.cdn?.icons?.script } : base.cdn?.icons?.script
|
|
379
|
-
},
|
|
380
|
-
scripts: {
|
|
381
|
-
// tailwind is a simple string, just use override or base
|
|
382
|
-
tailwind: override.cdn?.scripts?.tailwind ?? base.cdn?.scripts?.tailwind,
|
|
383
|
-
// Deep merge htmx/alpine to preserve integrity when only url is overridden
|
|
384
|
-
htmx: override.cdn?.scripts?.htmx ? { ...base.cdn?.scripts?.htmx, ...override.cdn?.scripts?.htmx } : base.cdn?.scripts?.htmx,
|
|
385
|
-
alpine: override.cdn?.scripts?.alpine ? { ...base.cdn?.scripts?.alpine, ...override.cdn?.scripts?.alpine } : base.cdn?.scripts?.alpine
|
|
386
|
-
}
|
|
387
|
-
},
|
|
388
|
-
customVars: { ...base.customVars, ...override.customVars },
|
|
389
|
-
customCss: [base.customCss, override.customCss].filter(Boolean).join("\n")
|
|
390
|
-
};
|
|
391
|
-
}
|
|
392
|
-
function mergeThemes(base, override) {
|
|
393
|
-
const merged = mergeThemesCore(base, override);
|
|
394
|
-
let darkVariant;
|
|
395
|
-
if (override.dark !== void 0) {
|
|
396
|
-
const darkBase = base.dark ?? base;
|
|
397
|
-
const { dark: _nestedDark, ...overrideDarkWithoutNested } = override.dark;
|
|
398
|
-
darkVariant = mergeThemesCore(darkBase, overrideDarkWithoutNested);
|
|
399
|
-
} else if (base.dark !== void 0) {
|
|
400
|
-
const { dark: _nestedDark, ...baseDarkWithoutNested } = base.dark;
|
|
401
|
-
darkVariant = baseDarkWithoutNested;
|
|
402
|
-
}
|
|
403
|
-
return {
|
|
404
|
-
...merged,
|
|
405
|
-
dark: darkVariant
|
|
406
|
-
};
|
|
407
|
-
}
|
|
408
|
-
function emitColorScale(lines, name, scale) {
|
|
409
|
-
for (const [shade, value] of Object.entries(scale)) {
|
|
410
|
-
if (value) lines.push(`--color-${name}-${shade}: ${value};`);
|
|
411
|
-
}
|
|
412
|
-
}
|
|
413
|
-
function buildThemeCss(theme) {
|
|
414
|
-
const lines = [];
|
|
415
|
-
const semantic = theme.colors.semantic;
|
|
416
|
-
if (typeof semantic.primary === "string") {
|
|
417
|
-
lines.push(`--color-primary: ${semantic.primary};`);
|
|
418
|
-
} else if (semantic.primary) {
|
|
419
|
-
emitColorScale(lines, "primary", semantic.primary);
|
|
420
|
-
}
|
|
421
|
-
if (semantic.secondary) {
|
|
422
|
-
if (typeof semantic.secondary === "string") {
|
|
423
|
-
lines.push(`--color-secondary: ${semantic.secondary};`);
|
|
424
|
-
} else {
|
|
425
|
-
emitColorScale(lines, "secondary", semantic.secondary);
|
|
426
|
-
}
|
|
427
|
-
}
|
|
428
|
-
if (semantic.accent) {
|
|
429
|
-
if (typeof semantic.accent === "string") {
|
|
430
|
-
lines.push(`--color-accent: ${semantic.accent};`);
|
|
431
|
-
} else {
|
|
432
|
-
emitColorScale(lines, "accent", semantic.accent);
|
|
433
|
-
}
|
|
434
|
-
}
|
|
435
|
-
if (semantic.neutral) {
|
|
436
|
-
if (typeof semantic.neutral === "string") {
|
|
437
|
-
lines.push(`--color-neutral: ${semantic.neutral};`);
|
|
438
|
-
} else {
|
|
439
|
-
emitColorScale(lines, "neutral", semantic.neutral);
|
|
440
|
-
}
|
|
441
|
-
}
|
|
442
|
-
if (semantic.success) lines.push(`--color-success: ${semantic.success};`);
|
|
443
|
-
if (semantic.warning) lines.push(`--color-warning: ${semantic.warning};`);
|
|
444
|
-
if (semantic.danger) lines.push(`--color-danger: ${semantic.danger};`);
|
|
445
|
-
if (semantic.info) lines.push(`--color-info: ${semantic.info};`);
|
|
446
|
-
const surface = theme.colors.surface;
|
|
447
|
-
if (surface?.background) lines.push(`--color-background: ${surface.background};`);
|
|
448
|
-
if (surface?.surface) lines.push(`--color-surface: ${surface.surface};`);
|
|
449
|
-
if (surface?.elevated) lines.push(`--color-elevated: ${surface.elevated};`);
|
|
450
|
-
if (surface?.overlay) lines.push(`--color-overlay: ${surface.overlay};`);
|
|
451
|
-
const text = theme.colors.text;
|
|
452
|
-
if (text?.primary) lines.push(`--color-text-primary: ${text.primary};`);
|
|
453
|
-
if (text?.secondary) lines.push(`--color-text-secondary: ${text.secondary};`);
|
|
454
|
-
if (text?.disabled) lines.push(`--color-text-disabled: ${text.disabled};`);
|
|
455
|
-
if (text?.inverse) lines.push(`--color-text-inverse: ${text.inverse};`);
|
|
456
|
-
if (text?.link) lines.push(`--color-text-link: ${text.link};`);
|
|
457
|
-
const border = theme.colors.border;
|
|
458
|
-
if (border?.default) lines.push(`--color-border: ${border.default};`);
|
|
459
|
-
if (border?.hover) lines.push(`--color-border-hover: ${border.hover};`);
|
|
460
|
-
if (border?.focus) lines.push(`--color-border-focus: ${border.focus};`);
|
|
461
|
-
if (border?.divider) lines.push(`--color-divider: ${border.divider};`);
|
|
462
|
-
if (theme.colors.custom) {
|
|
463
|
-
for (const [key, value] of Object.entries(theme.colors.custom)) {
|
|
464
|
-
lines.push(`--color-${key}: ${value};`);
|
|
465
|
-
}
|
|
466
|
-
}
|
|
467
|
-
const typography = theme.typography;
|
|
468
|
-
if (typography?.families?.sans) lines.push(`--font-sans: ${typography.families.sans};`);
|
|
469
|
-
if (typography?.families?.serif) lines.push(`--font-serif: ${typography.families.serif};`);
|
|
470
|
-
if (typography?.families?.mono) lines.push(`--font-mono: ${typography.families.mono};`);
|
|
471
|
-
if (typography?.families?.display) lines.push(`--font-display: ${typography.families.display};`);
|
|
472
|
-
const radius = theme.radius;
|
|
473
|
-
if (radius?.none) lines.push(`--radius-none: ${radius.none};`);
|
|
474
|
-
if (radius?.sm) lines.push(`--radius-sm: ${radius.sm};`);
|
|
475
|
-
if (radius?.md) lines.push(`--radius-md: ${radius.md};`);
|
|
476
|
-
if (radius?.lg) lines.push(`--radius-lg: ${radius.lg};`);
|
|
477
|
-
if (radius?.xl) lines.push(`--radius-xl: ${radius.xl};`);
|
|
478
|
-
if (radius?.["2xl"]) lines.push(`--radius-2xl: ${radius["2xl"]};`);
|
|
479
|
-
if (radius?.full) lines.push(`--radius-full: ${radius.full};`);
|
|
480
|
-
if (theme.customVars) {
|
|
481
|
-
for (const [key, value] of Object.entries(theme.customVars)) {
|
|
482
|
-
lines.push(`${key}: ${value};`);
|
|
483
|
-
}
|
|
484
|
-
}
|
|
485
|
-
return lines.join("\n ");
|
|
486
|
-
}
|
|
487
|
-
|
|
488
|
-
// libs/ui/src/utils/escape-html.ts
|
|
489
|
-
function escapeHtml(str) {
|
|
490
|
-
if (str === null || str === void 0) {
|
|
491
|
-
return "";
|
|
492
|
-
}
|
|
493
|
-
const s = String(str);
|
|
494
|
-
return s.replace(/&/g, "&").replace(/</g, "<").replace(/>/g, ">").replace(/"/g, """).replace(/'/g, "'").replace(/\u2028/g, "\\u2028").replace(/\u2029/g, "\\u2029");
|
|
495
|
-
}
|
|
496
|
-
|
|
497
1
|
// libs/ui/src/layouts/base.ts
|
|
2
|
+
import {
|
|
3
|
+
OPENAI_PLATFORM,
|
|
4
|
+
canUseCdn,
|
|
5
|
+
needsInlineScripts,
|
|
6
|
+
DEFAULT_THEME,
|
|
7
|
+
buildThemeCss,
|
|
8
|
+
mergeThemes,
|
|
9
|
+
buildFontPreconnect,
|
|
10
|
+
buildFontStylesheets,
|
|
11
|
+
buildCdnScripts
|
|
12
|
+
} from "@frontmcp/uipack/theme";
|
|
13
|
+
import { escapeHtml } from "@frontmcp/uipack/utils";
|
|
14
|
+
import { escapeHtml as escapeHtml2 } from "@frontmcp/uipack/utils";
|
|
498
15
|
function getSizeClass(size) {
|
|
499
16
|
const sizeMap = {
|
|
500
17
|
xs: "max-w-sm",
|
|
@@ -684,20 +201,20 @@ function authLayout(content, options) {
|
|
|
684
201
|
function consentLayout(content, options) {
|
|
685
202
|
const { clientName, clientIcon, userInfo, ...baseOptions } = options;
|
|
686
203
|
const headerHtml = clientName ? `<div class="text-center mb-6">
|
|
687
|
-
${clientIcon ? `<img src="${
|
|
204
|
+
${clientIcon ? `<img src="${escapeHtml2(clientIcon)}" alt="${escapeHtml2(
|
|
688
205
|
clientName
|
|
689
206
|
)}" class="w-16 h-16 rounded-xl mx-auto mb-4">` : `<div class="inline-flex items-center justify-center w-16 h-16 rounded-xl bg-gradient-to-br from-primary to-secondary text-white font-bold text-2xl mx-auto mb-4">
|
|
690
|
-
${
|
|
207
|
+
${escapeHtml2(clientName.charAt(0).toUpperCase())}
|
|
691
208
|
</div>`}
|
|
692
|
-
<h1 class="text-2xl font-bold text-text-primary">${
|
|
209
|
+
<h1 class="text-2xl font-bold text-text-primary">${escapeHtml2(clientName)}</h1>
|
|
693
210
|
</div>` : "";
|
|
694
211
|
const userInfoHtml = userInfo ? `<div class="flex items-center gap-3 p-3 bg-gray-50 rounded-lg mb-6">
|
|
695
|
-
${userInfo.avatar ? `<img src="${
|
|
696
|
-
${
|
|
212
|
+
${userInfo.avatar ? `<img src="${escapeHtml2(userInfo.avatar)}" class="w-10 h-10 rounded-full">` : `<div class="w-10 h-10 rounded-full bg-primary text-white flex items-center justify-center font-medium">
|
|
213
|
+
${escapeHtml2((userInfo.name || userInfo.email || "U").charAt(0).toUpperCase())}
|
|
697
214
|
</div>`}
|
|
698
215
|
<div>
|
|
699
|
-
${userInfo.name ? `<div class="font-medium text-text-primary">${
|
|
700
|
-
${userInfo.email ? `<div class="text-sm text-text-secondary">${
|
|
216
|
+
${userInfo.name ? `<div class="font-medium text-text-primary">${escapeHtml2(userInfo.name)}</div>` : ""}
|
|
217
|
+
${userInfo.email ? `<div class="text-sm text-text-secondary">${escapeHtml2(userInfo.email)}</div>` : ""}
|
|
701
218
|
</div>
|
|
702
219
|
</div>` : "";
|
|
703
220
|
const wrappedContent = `
|
|
@@ -733,15 +250,15 @@ function errorLayout(content, options) {
|
|
|
733
250
|
</svg>
|
|
734
251
|
</div>
|
|
735
252
|
|
|
736
|
-
${errorCode ? `<p class="text-6xl font-bold text-danger mb-2">${
|
|
737
|
-
<h1 class="text-2xl font-bold text-text-primary mb-4">${
|
|
738
|
-
${errorMessage ? `<p class="text-text-secondary mb-8">${
|
|
253
|
+
${errorCode ? `<p class="text-6xl font-bold text-danger mb-2">${escapeHtml2(errorCode)}</p>` : ""}
|
|
254
|
+
<h1 class="text-2xl font-bold text-text-primary mb-4">${escapeHtml2(errorTitle)}</h1>
|
|
255
|
+
${errorMessage ? `<p class="text-text-secondary mb-8">${escapeHtml2(errorMessage)}</p>` : ""}
|
|
739
256
|
|
|
740
257
|
${content}
|
|
741
258
|
|
|
742
259
|
<div class="flex gap-4 justify-center mt-8">
|
|
743
|
-
${showRetry ? `<button onclick="${retryUrl ? `window.location.href='${
|
|
744
|
-
${showHome ? `<a href="${
|
|
260
|
+
${showRetry ? `<button onclick="${retryUrl ? `window.location.href='${escapeHtml2(retryUrl)}'` : "window.location.reload()"}" class="px-6 py-3 bg-primary hover:bg-primary/90 text-white font-medium rounded-lg transition-colors">Try Again</button>` : ""}
|
|
261
|
+
${showHome ? `<a href="${escapeHtml2(
|
|
745
262
|
homeUrl
|
|
746
263
|
)}" class="px-6 py-3 bg-gray-100 hover:bg-gray-200 text-text-primary font-medium rounded-lg transition-colors">Go Home</a>` : ""}
|
|
747
264
|
</div>
|
|
@@ -770,7 +287,7 @@ function loadingLayout(content, options) {
|
|
|
770
287
|
const loadingHtml = `
|
|
771
288
|
<div class="text-center">
|
|
772
289
|
${spinnerHtml}
|
|
773
|
-
<h2 class="text-xl font-medium text-text-primary mb-2">${
|
|
290
|
+
<h2 class="text-xl font-medium text-text-primary mb-2">${escapeHtml2(message)}</h2>
|
|
774
291
|
${progressHtml}
|
|
775
292
|
${content}
|
|
776
293
|
</div>
|
|
@@ -801,7 +318,7 @@ function successLayout(content, options) {
|
|
|
801
318
|
if (countdownEl) countdownEl.textContent = countdown;
|
|
802
319
|
if (countdown <= 0) {
|
|
803
320
|
clearInterval(interval);
|
|
804
|
-
${continueUrl ? `window.location.href = '${
|
|
321
|
+
${continueUrl ? `window.location.href = '${escapeHtml2(continueUrl)}';` : "window.close();"}
|
|
805
322
|
}
|
|
806
323
|
}, 1000);
|
|
807
324
|
</script>` : "";
|
|
@@ -814,14 +331,14 @@ function successLayout(content, options) {
|
|
|
814
331
|
</svg>
|
|
815
332
|
</div>
|
|
816
333
|
|
|
817
|
-
<h1 class="text-2xl font-bold text-text-primary mb-4">${
|
|
818
|
-
${successMessage ? `<p class="text-text-secondary mb-8">${
|
|
334
|
+
<h1 class="text-2xl font-bold text-text-primary mb-4">${escapeHtml2(successTitle)}</h1>
|
|
335
|
+
${successMessage ? `<p class="text-text-secondary mb-8">${escapeHtml2(successMessage)}</p>` : ""}
|
|
819
336
|
|
|
820
337
|
${content}
|
|
821
338
|
|
|
822
|
-
${continueUrl ? `<a href="${
|
|
339
|
+
${continueUrl ? `<a href="${escapeHtml2(
|
|
823
340
|
continueUrl
|
|
824
|
-
)}" class="inline-block mt-6 px-6 py-3 bg-primary hover:bg-primary/90 text-white font-medium rounded-lg transition-colors">${
|
|
341
|
+
)}" class="inline-block mt-6 px-6 py-3 bg-primary hover:bg-primary/90 text-white font-medium rounded-lg transition-colors">${escapeHtml2(
|
|
825
342
|
continueText
|
|
826
343
|
)}</a>` : ""}
|
|
827
344
|
|
|
@@ -846,7 +363,7 @@ function widgetLayout(content, options) {
|
|
|
846
363
|
transparent ? "" : "bg-surface"
|
|
847
364
|
].filter(Boolean).join(" ");
|
|
848
365
|
const wrappedContent = `
|
|
849
|
-
<div class="${containerClasses}" style="max-width: ${
|
|
366
|
+
<div class="${containerClasses}" style="max-width: ${escapeHtml2(maxWidth)}">
|
|
850
367
|
${content}
|
|
851
368
|
</div>
|
|
852
369
|
`;
|
|
@@ -885,7 +402,7 @@ export {
|
|
|
885
402
|
createLayoutBuilder,
|
|
886
403
|
errorLayout,
|
|
887
404
|
errorLayoutBuilder,
|
|
888
|
-
escapeHtml,
|
|
405
|
+
escapeHtml2 as escapeHtml,
|
|
889
406
|
loadingLayout,
|
|
890
407
|
successLayout,
|
|
891
408
|
widgetLayout
|