@shwfed/config 2.10.7 → 2.10.9

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 (84) hide show
  1. package/dist/mcp.mjs +1171 -1049
  2. package/dist/module.json +1 -1
  3. package/dist/preview/assets/{FieldGroup.vue_vue_type_script_setup_true_lang-CV3u1wuG.js → FieldGroup.vue_vue_type_script_setup_true_lang-CysVgnB5.js} +1 -1
  4. package/dist/preview/assets/{badge-De7TI8Ef.js → badge-DdxT1J-1.js} +1 -1
  5. package/dist/preview/assets/{config-A0pwpJhu.js → config-073z__NM.js} +1 -1
  6. package/dist/preview/assets/{config-Cc-RiKc0.js → config-91HQEKhM.js} +1 -1
  7. package/dist/preview/assets/{config-DccYHX13.js → config-B8k8y1J1.js} +1 -1
  8. package/dist/preview/assets/{config-Ckn8NixF.js → config-BK8WZ3pm.js} +1 -1
  9. package/dist/preview/assets/{config-RuqJAgHJ.js → config-BX05eMo3.js} +1 -1
  10. package/dist/preview/assets/{config-BF4I0Pko.js → config-BXP8aJwW.js} +1 -1
  11. package/dist/preview/assets/{config-DqHlKqr-.js → config-BhPAyftm.js} +1 -1
  12. package/dist/preview/assets/{config-DBrYVSus.js → config-BzHBSkht.js} +1 -1
  13. package/dist/preview/assets/{config-BJL5R6TO.js → config-C3eoRHUo.js} +1 -1
  14. package/dist/preview/assets/{config-DGj2Xh1R.js → config-CJ-NzxkH.js} +1 -1
  15. package/dist/preview/assets/{config-C6AzmvwL.js → config-CYRj2ZVL.js} +1 -1
  16. package/dist/preview/assets/{config-CtW_DgDv.js → config-DLNjjMZY.js} +1 -1
  17. package/dist/preview/assets/{config-Bei-4M8U.js → config-DudxzmzF.js} +1 -1
  18. package/dist/preview/assets/{config-CnPPWHxs.js → config-cwlK3BMD.js} +1 -1
  19. package/dist/preview/assets/{definition.vue_vue_type_script_setup_true_lang-Ceh2rttd.js → definition.vue_vue_type_script_setup_true_lang-l59C6Dgs.js} +1 -1
  20. package/dist/preview/assets/index-BL58N7_5.js +763 -0
  21. package/dist/preview/assets/index-CA4hsfRv.js +1 -0
  22. package/dist/preview/assets/index-CyVzfRGQ.css +1 -0
  23. package/dist/preview/assets/{index-DAjdcrqQ.js → index-uAwC9Itb.js} +1 -1
  24. package/dist/preview/assets/{item-BNOUeB-e.js → item-C79mwh5T.js} +1 -1
  25. package/dist/preview/assets/{runtime-DzDI7B5M.js → runtime-1_EaFcPI.js} +1 -1
  26. package/dist/preview/assets/{runtime-BtDC6qh0.js → runtime-2yzxOLnF.js} +1 -1
  27. package/dist/preview/assets/{runtime-CXSBPV7c.js → runtime-8Fe67mkZ.js} +1 -1
  28. package/dist/preview/assets/{runtime-B-m0fZl0.js → runtime-8oME8Env.js} +1 -1
  29. package/dist/preview/assets/{runtime-DDz8U0kg.js → runtime-CCMixJjP.js} +1 -1
  30. package/dist/preview/assets/{runtime-CdrOV1KF.js → runtime-CD1Q4rZ3.js} +1 -1
  31. package/dist/preview/assets/{runtime-DCyGTrMp.js → runtime-Cb-qIo5p.js} +1 -1
  32. package/dist/preview/assets/{runtime-Bb0APo4d.js → runtime-CvgAq3mp.js} +1 -1
  33. package/dist/preview/assets/{runtime-D2Qtb13C.js → runtime-DkWCpjKe.js} +1 -1
  34. package/dist/preview/assets/{runtime-CtG2gR_k.js → runtime-mYNyG7UH.js} +1 -1
  35. package/dist/preview/assets/{schema-meta-DmDYh6aL.js → schema-meta-BlTKRs15.js} +1 -1
  36. package/dist/preview/index.html +2 -2
  37. package/dist/runtime/components/form/fields/2026-04-27/com.shwfed.form.field.daterange/config.d.vue.ts +4 -4
  38. package/dist/runtime/components/form/fields/2026-04-27/com.shwfed.form.field.daterange/config.vue.d.ts +4 -4
  39. package/dist/runtime/components/form/fields/2026-04-27/com.shwfed.form.field.datetimerange/config.d.vue.ts +6 -6
  40. package/dist/runtime/components/form/fields/2026-04-27/com.shwfed.form.field.datetimerange/config.vue.d.ts +6 -6
  41. package/dist/runtime/components/form/fields/2026-04-27/com.shwfed.form.field.timerange/config.d.vue.ts +2 -2
  42. package/dist/runtime/components/form/fields/2026-04-27/com.shwfed.form.field.timerange/config.vue.d.ts +2 -2
  43. package/dist/runtime/components/form/fields/2026-05-13/com.shwfed.form.field.list/config.d.vue.ts +2 -0
  44. package/dist/runtime/components/form/fields/2026-05-13/com.shwfed.form.field.list/config.vue +32 -1
  45. package/dist/runtime/components/form/fields/2026-05-13/com.shwfed.form.field.list/config.vue.d.ts +2 -0
  46. package/dist/runtime/components/form/fields/2026-05-13/com.shwfed.form.field.list/runtime.vue +2 -0
  47. package/dist/runtime/components/form/fields/2026-05-13/com.shwfed.form.field.list/schema.d.ts +2 -0
  48. package/dist/runtime/components/form/fields/2026-05-13/com.shwfed.form.field.list/schema.js +4 -0
  49. package/dist/runtime/components/form/fields/2026-05-17/com.shwfed.form.field.checkbox.group/config.vue +202 -112
  50. package/dist/runtime/components/form/fields/2026-05-17/com.shwfed.form.field.radio.group/config.vue +202 -112
  51. package/dist/runtime/components/form/fields/2026-05-24/com.shwfed.form.field.monthrange/config.d.vue.ts +4 -4
  52. package/dist/runtime/components/form/fields/2026-05-24/com.shwfed.form.field.monthrange/config.vue.d.ts +4 -4
  53. package/dist/runtime/components/form/fields/2026-06-14/com.shwfed.form.field.combobox.multi/config.vue +223 -132
  54. package/dist/runtime/components/form/fields/2026-06-14/com.shwfed.form.field.combobox.single/config.vue +223 -132
  55. package/dist/runtime/components/form/fields/2026-06-20/com.shwfed.form.field.tabs/config.d.vue.ts +59 -0
  56. package/dist/runtime/components/form/fields/2026-06-20/com.shwfed.form.field.tabs/config.vue +345 -0
  57. package/dist/runtime/components/form/fields/2026-06-20/com.shwfed.form.field.tabs/config.vue.d.ts +59 -0
  58. package/dist/runtime/components/form/fields/2026-06-20/com.shwfed.form.field.tabs/runtime.d.vue.ts +8 -0
  59. package/dist/runtime/components/form/fields/2026-06-20/com.shwfed.form.field.tabs/runtime.vue +113 -0
  60. package/dist/runtime/components/form/fields/2026-06-20/com.shwfed.form.field.tabs/runtime.vue.d.ts +8 -0
  61. package/dist/runtime/components/form/fields/2026-06-20/com.shwfed.form.field.tabs/schema.d.ts +79 -0
  62. package/dist/runtime/components/form/fields/2026-06-20/com.shwfed.form.field.tabs/schema.js +86 -0
  63. package/dist/runtime/components/form/unit-config.d.vue.ts +27 -0
  64. package/dist/runtime/components/form/unit-config.vue +117 -73
  65. package/dist/runtime/components/form/unit-config.vue.d.ts +27 -0
  66. package/dist/runtime/components/table/schema.js +24 -25
  67. package/dist/runtime/components/ui/date-picker/DatePickerInput.d.vue.ts +1 -1
  68. package/dist/runtime/components/ui/date-picker/DatePickerInput.vue.d.ts +1 -1
  69. package/dist/runtime/components/ui/date-picker/DatePickerTimeInput.d.vue.ts +1 -1
  70. package/dist/runtime/components/ui/date-picker/DatePickerTimeInput.vue.d.ts +1 -1
  71. package/dist/runtime/components/ui/date-range-picker/DateRangePickerInput.d.vue.ts +1 -1
  72. package/dist/runtime/components/ui/date-range-picker/DateRangePickerInput.vue.d.ts +1 -1
  73. package/dist/runtime/components/ui/date-range-picker/DateRangePickerTimeInput.d.vue.ts +2 -2
  74. package/dist/runtime/components/ui/date-range-picker/DateRangePickerTimeInput.vue.d.ts +2 -2
  75. package/dist/runtime/components/ui/markdown/Markdown.vue +19 -16
  76. package/dist/runtime/utils/markdown.d.ts +5 -2
  77. package/dist/runtime/utils/markdown.js +22 -1
  78. package/dist/runtime/vendor/cel-js/CLAUDE.md +1 -0
  79. package/dist/runtime/vendor/cel-js/lib/evaluator.d.ts +1 -0
  80. package/dist/runtime/vendor/cel-js/lib/evaluator.js +4 -0
  81. package/package.json +1 -1
  82. package/dist/preview/assets/index-BQIP6UfB.js +0 -763
  83. package/dist/preview/assets/index-Cj7bRG7B.css +0 -1
  84. package/dist/preview/assets/index-DpLMRp28.js +0 -1
@@ -1,4 +1,5 @@
1
1
  <script>
2
+ import { useRuntimeConfig } from "#app";
2
3
  import { computed, defineComponent, h } from "vue";
3
4
  import { md } from "../../../utils/markdown";
4
5
  import { TRIGGER_CLASS } from "../../../utils/markdown-tooltip";
@@ -16,20 +17,20 @@ const tokenAttrs = (tok) => {
16
17
  for (const [name, value] of tok.attrs) out[name] = value;
17
18
  return out;
18
19
  };
19
- const renderTooltip = (tok) => {
20
+ const renderTooltip = (tok, env) => {
20
21
  const meta = tok.meta;
21
22
  return h(Tooltip, { delayDuration: 180 }, () => [
22
23
  h(TooltipTrigger, { asChild: true }, () => h("span", {
23
24
  class: TRIGGER_CLASS,
24
- innerHTML: md.renderInline(meta.trigger)
25
+ innerHTML: md.renderInline(meta.trigger, env)
25
26
  })),
26
27
  h(TooltipContent, { class: "max-w-xs text-xs" }, () => h("span", {
27
28
  class: "prose prose-zinc text-xs",
28
- innerHTML: md.render(meta.content)
29
+ innerHTML: md.render(meta.content, env)
29
30
  }))
30
31
  ]);
31
32
  };
32
- const renderInlineChildren = (children) => {
33
+ const renderInlineChildren = (children, env) => {
33
34
  const vnodes = [];
34
35
  let bufferStart = 0;
35
36
  for (let i = 0; i <= children.length; i++) {
@@ -38,11 +39,11 @@ const renderInlineChildren = (children) => {
38
39
  if (!tok || isTooltip) {
39
40
  if (i > bufferStart) {
40
41
  const run = children.slice(bufferStart, i);
41
- const html = md.renderer.render(run, md.options, {});
42
+ const html = md.renderer.render(run, md.options, env);
42
43
  vnodes.push(h("span", { innerHTML: html }));
43
44
  }
44
45
  if (tok && isTooltip) {
45
- vnodes.push(renderTooltip(tok));
46
+ vnodes.push(renderTooltip(tok, env));
46
47
  bufferStart = i + 1;
47
48
  }
48
49
  }
@@ -61,7 +62,7 @@ const findMatchingClose = (tokens, openIdx) => {
61
62
  }
62
63
  return tokens.length;
63
64
  };
64
- const renderBlockTokens = (tokens) => {
65
+ const renderBlockTokens = (tokens, env) => {
65
66
  const vnodes = [];
66
67
  let i = 0;
67
68
  while (i < tokens.length) {
@@ -69,13 +70,13 @@ const renderBlockTokens = (tokens) => {
69
70
  if (tok.nesting === 1) {
70
71
  const closeIdx = findMatchingClose(tokens, i);
71
72
  const children = tokens.slice(i + 1, closeIdx);
72
- vnodes.push(h(tok.tag || "div", tokenAttrs(tok), renderBlockTokens(children)));
73
+ vnodes.push(h(tok.tag || "div", tokenAttrs(tok), renderBlockTokens(children, env)));
73
74
  i = closeIdx + 1;
74
75
  } else if (tok.type === "inline") {
75
- vnodes.push(...renderInlineChildren(tok.children ?? []));
76
+ vnodes.push(...renderInlineChildren(tok.children ?? [], env));
76
77
  i++;
77
78
  } else {
78
- const html = md.renderer.render([tok], md.options, {});
79
+ const html = md.renderer.render([tok], md.options, env);
79
80
  vnodes.push(h("span", { innerHTML: html }));
80
81
  i++;
81
82
  }
@@ -89,15 +90,17 @@ export default defineComponent({
89
90
  block: { type: Boolean, default: false }
90
91
  },
91
92
  setup(props) {
93
+ const base = useRuntimeConfig().app.baseURL || "/";
94
+ const env = { base };
92
95
  const rendered = computed(() => {
93
96
  if (props.block) {
94
- const tokens = md.parse(props.source, {});
95
- if (!hasTooltip(tokens)) return { fast: md.render(props.source) };
96
- return { vnodes: renderBlockTokens(tokens) };
97
+ const tokens = md.parse(props.source, env);
98
+ if (!hasTooltip(tokens)) return { fast: md.render(props.source, env) };
99
+ return { vnodes: renderBlockTokens(tokens, env) };
97
100
  }
98
- const children = md.parseInline(props.source, {})[0]?.children ?? [];
99
- if (!hasTooltip(children)) return { fast: md.renderInline(props.source) };
100
- return { vnodes: renderInlineChildren(children) };
101
+ const children = md.parseInline(props.source, env)[0]?.children ?? [];
102
+ if (!hasTooltip(children)) return { fast: md.renderInline(props.source, env) };
103
+ return { vnodes: renderInlineChildren(children, env) };
101
104
  });
102
105
  return () => {
103
106
  const r = rendered.value;
@@ -1,5 +1,8 @@
1
1
  import MarkdownIt from 'markdown-it';
2
2
  export declare const md: MarkdownIt;
3
- export declare function renderMarkdown(source: string, options?: {
3
+ export interface RenderMarkdownOptions {
4
4
  block?: boolean;
5
- }): string;
5
+ /** App base URL (`app.baseURL`) used to rewrite root-relative link hrefs. */
6
+ base?: string;
7
+ }
8
+ export declare function renderMarkdown(source: string, options?: RenderMarkdownOptions): string;
@@ -1,6 +1,27 @@
1
1
  import MarkdownIt from "markdown-it";
2
2
  import tooltipPlugin from "./markdown-tooltip.js";
3
3
  export const md = new MarkdownIt({ html: true, linkify: false, breaks: true }).use(tooltipPlugin);
4
+ function withBase(path, base) {
5
+ const b = base.endsWith("/") ? base.slice(0, -1) : base;
6
+ if (!b) return path;
7
+ if (path === b || path.startsWith(`${b}/`)) return path;
8
+ return b + path;
9
+ }
10
+ function isRootRelative(href) {
11
+ return href.startsWith("/") && !href.startsWith("//");
12
+ }
13
+ const renderToken = (tokens, idx, options, _env, self) => self.renderToken(tokens, idx, options);
14
+ const baseLinkOpen = md.renderer.rules.link_open ?? renderToken;
15
+ md.renderer.rules.link_open = (tokens, idx, options, env, self) => {
16
+ const base = env?.base;
17
+ if (base) {
18
+ const token = tokens[idx];
19
+ const href = token.attrGet("href");
20
+ if (href && isRootRelative(href)) token.attrSet("href", withBase(href, base));
21
+ }
22
+ return baseLinkOpen(tokens, idx, options, env, self);
23
+ };
4
24
  export function renderMarkdown(source, options) {
5
- return options?.block ? md.render(source) : md.renderInline(source);
25
+ const env = options?.base ? { base: options.base } : {};
26
+ return options?.block ? md.render(source, env) : md.renderInline(source, env);
6
27
  }
@@ -69,6 +69,7 @@ import { Environment, ParseError, TypeError, EvaluationError } from './lib/index
69
69
  - `.check(expr)` — Returns `Either<string, ParseError | TypeError>` (success = type name string)
70
70
  - `.evaluate<T>(expr, ctx?)` — Returns `Effect<T, ParseError | TypeError | EvaluationError>`
71
71
  - `.registerVariable(name, type, options?)`
72
+ - `.deleteVariable(name)` — Remove a previously-registered variable (no-op if absent). Lets a narrower scope override an inherited declaration with a different type (e.g. the table cell-style scope's per-row `selected: bool` vs. an enclosing toolbar's `selected: list<dyn>`), since `registerVariable` throws on a duplicate name.
72
73
  - `.registerConstant(name, type, value)`
73
74
  - `.registerFunction(signature, handler, options?)`
74
75
  - `.registerOperator(signature, handler)`
@@ -26,6 +26,7 @@ declare class Environment {
26
26
  registerOperator(signature: string, handler?: (...args: unknown[]) => unknown, opts?: unknown): this;
27
27
  registerType(typename: string, constructor: unknown): this;
28
28
  registerVariable(name: string, type?: unknown, opts?: unknown): this;
29
+ deleteVariable(name: string): this;
29
30
  registerConstant(name: string, type: unknown, value: unknown): this;
30
31
  getDefinitions(): ReturnType<Registry['getDefinitions']>;
31
32
  check(expression: string): Either.Either<string, ParseError | TypeError>;
@@ -54,6 +54,10 @@ class Environment {
54
54
  this.#registry.registerVariable(name, type, opts);
55
55
  return this;
56
56
  }
57
+ deleteVariable(name) {
58
+ this.#registry.deleteVariable(name);
59
+ return this;
60
+ }
57
61
  registerConstant(name, type, value) {
58
62
  this.#registry.registerConstant(name, type, value);
59
63
  return this;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@shwfed/config",
3
- "version": "2.10.7",
3
+ "version": "2.10.9",
4
4
  "description": "Configurable UI for SHWFED",
5
5
  "type": "module",
6
6
  "publishConfig": {