@heartlandone/vega 2.62.0 → 2.63.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 (62) hide show
  1. package/dist/cjs/loader.cjs.js +1 -1
  2. package/dist/cjs/{min-number-rule-965fc43d.js → min-number-rule-dc555309.js} +14 -8
  3. package/dist/cjs/vega-breadcrumb.cjs.entry.js +38 -71
  4. package/dist/cjs/vega-button-link.cjs.entry.js +15 -13
  5. package/dist/cjs/vega-env-manager-23b8b23c.js +2 -2
  6. package/dist/cjs/vega-input-numeric.cjs.entry.js +47 -1
  7. package/dist/cjs/vega-input.cjs.entry.js +1 -1
  8. package/dist/cjs/vega-stepper.cjs.entry.js +1 -1
  9. package/dist/cjs/vega-textarea.cjs.entry.js +7 -1
  10. package/dist/cjs/vega-time-picker_2.cjs.entry.js +8 -0
  11. package/dist/cjs/vega.cjs.js +1 -1
  12. package/dist/collection/components/vega-breadcrumb/slimmers/renderers/vega-breadcrumb-collapsed-item-renderer.js +4 -13
  13. package/dist/collection/components/vega-breadcrumb/slimmers/renderers/vega-breadcrumb-item-renderer.js +19 -5
  14. package/dist/collection/components/vega-breadcrumb/vega-breadcrumb.js +6 -5
  15. package/dist/collection/components/vega-button-link/vega-button-link.js +18 -19
  16. package/dist/collection/components/vega-input-numeric/slimmers/renderers/vega-input-numeric-renderer.js +27 -1
  17. package/dist/collection/components/vega-input-numeric/vega-input-numeric.js +64 -0
  18. package/dist/collection/components/vega-textarea/vega-textarea.js +28 -1
  19. package/dist/collection/components/vega-time-picker/vega-time-picker.js +10 -2
  20. package/dist/collection/helpers/validator/rules/max-number-rule.js +7 -4
  21. package/dist/collection/helpers/validator/rules/min-number-rule.js +7 -4
  22. package/dist/esm/loader.js +1 -1
  23. package/dist/esm/{min-number-rule-86421853.js → min-number-rule-2f1cfbf9.js} +14 -8
  24. package/dist/esm/vega-breadcrumb.entry.js +39 -72
  25. package/dist/esm/vega-button-link.entry.js +15 -13
  26. package/dist/esm/vega-env-manager-8f8dc473.js +2 -2
  27. package/dist/esm/vega-input-numeric.entry.js +48 -2
  28. package/dist/esm/vega-input.entry.js +1 -1
  29. package/dist/esm/vega-stepper.entry.js +1 -1
  30. package/dist/esm/vega-textarea.entry.js +7 -1
  31. package/dist/esm/vega-time-picker_2.entry.js +8 -0
  32. package/dist/esm/vega.js +1 -1
  33. package/dist/types/components/vega-breadcrumb/slimmers/renderers/vega-breadcrumb-collapsed-item-renderer.d.ts +1 -1
  34. package/dist/types/components/vega-breadcrumb/slimmers/renderers/vega-breadcrumb-item-renderer.d.ts +2 -1
  35. package/dist/types/components/vega-breadcrumb/types.d.ts +1 -0
  36. package/dist/types/components/vega-breadcrumb/vega-breadcrumb.d.ts +2 -2
  37. package/dist/types/components/vega-button-link/vega-button-link.d.ts +5 -8
  38. package/dist/types/components/vega-input-numeric/slimmers/renderers/vega-input-numeric-renderer.d.ts +3 -0
  39. package/dist/types/components/vega-input-numeric/vega-input-numeric.d.ts +12 -0
  40. package/dist/types/components/vega-textarea/vega-textarea.d.ts +6 -0
  41. package/dist/types/components/vega-time-picker/vega-time-picker.d.ts +8 -0
  42. package/dist/types/components.d.ts +38 -10
  43. package/dist/types/helpers/validator/rules/max-number-rule.d.ts +3 -1
  44. package/dist/types/helpers/validator/rules/min-number-rule.d.ts +3 -1
  45. package/dist/vega/p-2591f217.entry.js +1 -0
  46. package/dist/vega/p-56ff8559.entry.js +1 -0
  47. package/dist/vega/p-5f377954.js +1 -1
  48. package/dist/vega/p-9b2d8516.entry.js +1 -0
  49. package/dist/vega/p-b1054e18.entry.js +1 -0
  50. package/dist/vega/p-c08ba4d7.entry.js +1 -0
  51. package/dist/vega/{p-e365aba9.entry.js → p-da6369d4.entry.js} +1 -1
  52. package/dist/vega/p-f0ff4463.js +1 -0
  53. package/dist/vega/vega.esm.js +1 -1
  54. package/package.json +1 -1
  55. package/dist/collection/components/vega-breadcrumb/slimmers/controllers/vega-breadcrumb-click-controller.js +0 -43
  56. package/dist/types/components/vega-breadcrumb/slimmers/controllers/vega-breadcrumb-click-controller.d.ts +0 -26
  57. package/dist/vega/p-327cd6ec.entry.js +0 -1
  58. package/dist/vega/p-4e68dfd9.js +0 -1
  59. package/dist/vega/p-9ab3bb6f.entry.js +0 -1
  60. package/dist/vega/p-a1362aa4.entry.js +0 -1
  61. package/dist/vega/p-ac5c5221.entry.js +0 -1
  62. package/dist/vega/p-fe2cb3a1.entry.js +0 -1
@@ -2,10 +2,11 @@ import { h, F as Fragment, r as registerInstance, c as createEvent, H as Host, g
2
2
  import { c as MapToComponentField, V as VegaSlimmer, I as InjectVegaSlimmer } from './global-slimmer-registry-17c4efd4.js';
3
3
  import { g as getDeviceType, D as DeviceType } from './ui-c20be16d.js';
4
4
  import { V as VegaComponentUsageRuntimeMetricsSlimmer, I as InjectVegaGlobalSlimmer } from './component-usage-runtime-metrics-a84cc93e.js';
5
- import { D as DomNodeSubjectObserverFactory, V as VegaDropdownClick, a as VegaClick } from './dom-node-subject-observer-factory-c7bc3035.js';
5
+ import { D as DomNodeSubjectObserverFactory, a as VegaClick } from './dom-node-subject-observer-factory-c7bc3035.js';
6
6
  import { s as sanitizeVegaComponent } from './component-7d906393.js';
7
7
  import { C as ChildNodesEventPreventSlimmer } from './child-nodes-event-prevent-slimmer-7fe3dc57.js';
8
8
  import { c as createEventEmitSlimmer } from './event-emit-slimmer-3922d816.js';
9
+ import { C as ComponentGlobalStyleSlimmer } from './component-global-style-slimmer-dad40b64.js';
9
10
  import './change-manager-6a7eb88c.js';
10
11
  import './observer-3959f9dd.js';
11
12
  import './internal-vega-event-manager-cb06e987.js';
@@ -16,7 +17,7 @@ import './_commonjsHelpers-9943807e.js';
16
17
  import './dynamic-slimmer-90b8af32.js';
17
18
  import './try-get-document-bef0f526.js';
18
19
 
19
- var __decorate$4 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
20
+ var __decorate$3 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
20
21
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
21
22
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
22
23
  else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
@@ -60,20 +61,20 @@ class VegaBreadcrumbRenderer extends VegaSlimmer {
60
61
  this.items.length > this.maxItems);
61
62
  }
62
63
  }
63
- __decorate$4([
64
+ __decorate$3([
64
65
  MapToComponentField()
65
66
  ], VegaBreadcrumbRenderer.prototype, "items", void 0);
66
- __decorate$4([
67
+ __decorate$3([
67
68
  MapToComponentField()
68
69
  ], VegaBreadcrumbRenderer.prototype, "maxItems", void 0);
69
- __decorate$4([
70
+ __decorate$3([
70
71
  MapToComponentField()
71
72
  ], VegaBreadcrumbRenderer.prototype, "itemRenderer", void 0);
72
- __decorate$4([
73
+ __decorate$3([
73
74
  MapToComponentField()
74
75
  ], VegaBreadcrumbRenderer.prototype, "collapsedItemRenderer", void 0);
75
76
 
76
- var __decorate$3 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
77
+ var __decorate$2 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
77
78
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
78
79
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
79
80
  else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
@@ -81,31 +82,33 @@ var __decorate$3 = (undefined && undefined.__decorate) || function (decorators,
81
82
  };
82
83
  class VegaBreadcrumbCollapsedItemRenderer extends VegaSlimmer {
83
84
  render(items) {
84
- const source = items.map((item) => ({
85
- label: item.label,
86
- key: item.label,
87
- }));
88
85
  return (h("div", { class: "vega-breadcrumb-item" },
89
- h("vega-dropdown", { source: source, placement: ['bottom'], alignment: 'center', maxHeight: 200, ref: (ref) => {
90
- DomNodeSubjectObserverFactory.addUniqueObserverToNode(ref, VegaDropdownClick, (payload) => {
91
- this.clickController.dropdownClick(payload.detail);
92
- });
93
- } },
94
- h("vega-text", null, "...")),
86
+ h("vega-dropdown", { placement: ['bottom'], alignment: 'center', maxHeight: 200 },
87
+ h("vega-text", null, "..."),
88
+ h("vega-box", { slot: "items" }, items.map((item) => (h("vega-dropdown-item", { key: item.label, label: item.label }, this.itemRenderer.render(item, { isInDropdown: true })))))),
95
89
  h("vega-icon", { icon: "chevron-right-rounded", size: "size-12", color: "text-secondary" })));
96
90
  }
97
91
  }
98
- __decorate$3([
92
+ __decorate$2([
99
93
  MapToComponentField()
100
- ], VegaBreadcrumbCollapsedItemRenderer.prototype, "clickController", void 0);
94
+ ], VegaBreadcrumbCollapsedItemRenderer.prototype, "itemRenderer", void 0);
101
95
 
102
- var __decorate$2 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
96
+ var __decorate$1 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
103
97
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
104
98
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
105
99
  else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
106
100
  return c > 3 && r && Object.defineProperty(target, key, r), r;
107
101
  };
108
102
  class VegaBreadcrumbItemRenderer extends VegaSlimmer {
103
+ constructor() {
104
+ super(...arguments);
105
+ this.onButtonLinkClick = (payload, item) => {
106
+ const event = this.clickEventEmitter.emit(item);
107
+ if (event && event.defaultPrevented) {
108
+ payload.preventDefault();
109
+ }
110
+ };
111
+ }
109
112
  render(item, options) {
110
113
  return (h("div", { class: "vega-breadcrumb-item", key: item.label }, this.renderContent(item, options)));
111
114
  }
@@ -118,6 +121,9 @@ class VegaBreadcrumbItemRenderer extends VegaSlimmer {
118
121
  else if (options.isLastItem) {
119
122
  return this.renderLabel(item, true);
120
123
  }
124
+ else if (options.isInDropdown) {
125
+ return this.renderLink(item, false, true);
126
+ }
121
127
  else {
122
128
  return (h(Fragment, null,
123
129
  this.renderLabel(item),
@@ -130,60 +136,21 @@ class VegaBreadcrumbItemRenderer extends VegaSlimmer {
130
136
  renderLabel(item, isLastItem) {
131
137
  return item.tooltip ? (h("vega-tooltip", { text: item.tooltip, placement: ['bottom'] }, this.renderLink(item, isLastItem))) : (this.renderLink(item, isLastItem));
132
138
  }
133
- renderLink(item, isLastItem) {
134
- return isLastItem ? (h("span", { class: "vega-breadcrumb-last-label" }, item.label)) : (h("vega-button-link", { label: item.label, ref: (ref) => {
135
- DomNodeSubjectObserverFactory.addUniqueObserverToNode(ref, VegaClick, () => {
136
- this.clickController.click(item);
139
+ renderLink(item, isLastItem, isInDropdown = false) {
140
+ return isLastItem ? (h("span", { class: "vega-breadcrumb-last-label" }, item.label)) : (h("vega-button-link", { label: item.label, link: item.href, eventful: true, class: {
141
+ 'vega-breadcrumb-dropdown-link': isInDropdown,
142
+ }, ref: (ref) => {
143
+ DomNodeSubjectObserverFactory.addUniqueObserverToNode(ref, VegaClick, (payload) => {
144
+ this.onButtonLinkClick(payload, item);
137
145
  });
138
146
  } }));
139
147
  }
140
148
  }
141
- __decorate$2([
142
- MapToComponentField()
143
- ], VegaBreadcrumbItemRenderer.prototype, "clickController", void 0);
144
-
145
- var __decorate$1 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
146
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
147
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
148
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
149
- return c > 3 && r && Object.defineProperty(target, key, r), r;
150
- };
151
- /**
152
- * The VegaBreadcrumbClickController class handles the click event of breadcrumb items, either redirecting the user to a URL or emitting an event.
153
- */
154
- class VegaBreadcrumbClickController extends VegaSlimmer {
155
- /**
156
- * The click function either redirects the user to a specified URL or emits an event when a breadcrumb
157
- * item is clicked.
158
- *
159
- * @param {VegaBreadcrumbItemType} item - The parameter "item" is of type "VegaBreadcrumbItemType".
160
- * @returns {void} The ID of the notification.
161
- */
162
- click(item) {
163
- const event = this.clickEventEmitter.emit(item);
164
- if (event && !event.defaultPrevented && item.href) {
165
- window.location.href = item.href;
166
- }
167
- }
168
- /**
169
- * The `dropdownClick` method is a function that is called when a breadcrumb item is selected from a dropdown menu.
170
- * It takes a `selectedKey` parameter, which is the label of the selected breadcrumb item.
171
- *
172
- * @param {string} selectedKey - The selected key.
173
- * @returns {void} -
174
- */
175
- dropdownClick(selectedKey) {
176
- const item = this.items.find((item) => item.label === selectedKey);
177
- if (item)
178
- this.click(item);
179
- }
180
- }
181
- __decorate$1([
182
- MapToComponentField()
183
- ], VegaBreadcrumbClickController.prototype, "items", void 0);
184
149
  __decorate$1([
185
150
  MapToComponentField()
186
- ], VegaBreadcrumbClickController.prototype, "clickEventEmitter", void 0);
151
+ ], VegaBreadcrumbItemRenderer.prototype, "clickEventEmitter", void 0);
152
+
153
+ const vegaBreadcrumbGlobalCss = ".vega-breadcrumb-dropdown-link::part(label-text){color:rgba(var(--v-text-primary, 32, 54, 69, 1));font-size:16px;font-weight:400;line-height:24px;letter-spacing:0px}";
187
154
 
188
155
  const vegaBreadcrumbCss = ":host{display:block}:host .vega-breadcrumb{display:flex;gap:8px;flex-wrap:wrap}:host .vega-breadcrumb-hidden{display:none !important}:host .vega-breadcrumb-item{display:flex;gap:8px;align-items:center}:host .vega-breadcrumb-item vega-button-link::part(label-text){font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px}@media screen and (min-width: 768px) and (max-width: 1023px){:host .vega-breadcrumb-item vega-button-link::part(label-text){font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px}}@media screen and (min-width: 1024px) and (max-width: 1439px){:host .vega-breadcrumb-item vega-button-link::part(label-text){font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px}}@media screen and (min-width: 1440px) and (max-width: 9999px){:host .vega-breadcrumb-item vega-button-link::part(label-text){font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px}}:host .vega-breadcrumb-item vega-dropdown vega-text{cursor:pointer;font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px;color:rgba(var(--v-text-link, 19, 98, 226, 1))}@media screen and (min-width: 768px) and (max-width: 1023px){:host .vega-breadcrumb-item vega-dropdown vega-text{font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px}}@media screen and (min-width: 1024px) and (max-width: 1439px){:host .vega-breadcrumb-item vega-dropdown vega-text{font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px}}@media screen and (min-width: 1440px) and (max-width: 9999px){:host .vega-breadcrumb-item vega-dropdown vega-text{font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px}}:host .vega-breadcrumb-item vega-icon{flex-shrink:0}:host .vega-breadcrumb-item .vega-breadcrumb-last-label{font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px;color:rgba(var(--v-text-primary, 32, 54, 69, 1))}@media screen and (min-width: 768px) and (max-width: 1023px){:host .vega-breadcrumb-item .vega-breadcrumb-last-label{font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px}}@media screen and (min-width: 1024px) and (max-width: 1439px){:host .vega-breadcrumb-item .vega-breadcrumb-last-label{font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px}}@media screen and (min-width: 1440px) and (max-width: 9999px){:host .vega-breadcrumb-item .vega-breadcrumb-last-label{font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px}}:host .vega-breadcrumb-item vega-button-link::part(label-container){text-decoration:none}:host .vega-breadcrumb.mobile>.vega-breadcrumb-item{display:none}:host .vega-breadcrumb.mobile .vega-breadcrumb-item:nth-last-child(2){display:flex}:host .vega-breadcrumb.mobile.single .vega-breadcrumb-item{display:flex;font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px;color:rgba(var(--v-text-primary, 32, 54, 69, 1))}@media screen and (min-width: 768px) and (max-width: 1023px){:host .vega-breadcrumb.mobile.single .vega-breadcrumb-item{font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px}}@media screen and (min-width: 1024px) and (max-width: 1439px){:host .vega-breadcrumb.mobile.single .vega-breadcrumb-item{font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px}}@media screen and (min-width: 1440px) and (max-width: 9999px){:host .vega-breadcrumb.mobile.single .vega-breadcrumb-item{font-family:\"Inter\", sans-serif;font-size:16px;font-weight:500;line-height:22px;letter-spacing:0px}}:host .vega-breadcrumb.collapsed .vega-breadcrumb-item:nth-child(n+3):not(:last-child){display:none}";
189
156
 
@@ -206,9 +173,9 @@ const VegaBreadcrumb = class {
206
173
  this.renderer = new VegaBreadcrumbRenderer();
207
174
  this.collapsedItemRenderer = new VegaBreadcrumbCollapsedItemRenderer();
208
175
  this.itemRenderer = new VegaBreadcrumbItemRenderer();
209
- this.clickController = new VegaBreadcrumbClickController();
210
176
  this.eventsPrevent = new ChildNodesEventPreventSlimmer([VegaClick], () => this.renderer.getBreadcrumbContainerRef());
211
177
  this.clickEventEmitter = createEventEmitSlimmer(VegaBreadcrumb, VegaClick);
178
+ this.componentGlobalStyleSlimmer = new ComponentGlobalStyleSlimmer(vegaBreadcrumbGlobalCss);
212
179
  this.vegaComponentUsageRuntimeMetricsSlimmer = new VegaComponentUsageRuntimeMetricsSlimmer();
213
180
  /**
214
181
  * Determines the maximum number of visible items in the `vega-breadcrumb` component,
@@ -248,15 +215,15 @@ __decorate([
248
215
  __decorate([
249
216
  InjectVegaSlimmer()
250
217
  ], VegaBreadcrumb.prototype, "itemRenderer", void 0);
251
- __decorate([
252
- InjectVegaSlimmer()
253
- ], VegaBreadcrumb.prototype, "clickController", void 0);
254
218
  __decorate([
255
219
  InjectVegaSlimmer()
256
220
  ], VegaBreadcrumb.prototype, "eventsPrevent", void 0);
257
221
  __decorate([
258
222
  InjectVegaSlimmer()
259
223
  ], VegaBreadcrumb.prototype, "clickEventEmitter", void 0);
224
+ __decorate([
225
+ InjectVegaSlimmer()
226
+ ], VegaBreadcrumb.prototype, "componentGlobalStyleSlimmer", void 0);
260
227
  __decorate([
261
228
  InjectVegaSlimmer()
262
229
  ], VegaBreadcrumb.prototype, "vegaComponentUsageRuntimeMetricsSlimmer", void 0);
@@ -66,6 +66,8 @@ const VegaButtonLink = class {
66
66
  this.vegaComponentUsageRuntimeMetricsSlimmer = new VegaComponentUsageRuntimeMetricsSlimmer(VegaButtonLinkRuntimeMetricsPayloadDefinition);
67
67
  /**
68
68
  * Specifies the URL associated with the button link.
69
+ * If no URL is set, the component behaves as a button and triggers the click event.
70
+ * If a URL is provided, it behaves as a link and the click event is not emitted.
69
71
  *
70
72
  * @vegaVersion 1.0.4
71
73
  * @defaultValue javascript:void(0);
@@ -121,17 +123,12 @@ const VegaButtonLink = class {
121
123
  this.danger = false;
122
124
  /**
123
125
  * Specifies whether the button link will emit a vegaClick event when clicked.
124
- *
125
- * - If set to `true`, the event will be emitted.
126
- * - If set to `false`, the component will function as
127
- * a regular link to another page or URL,
128
- * and no events will be emitted.
129
- *
130
- * @deprecated Setting the `link` property internally manages the eventful state of a Button Link.
126
+ * When set to true, the component behaves as a link but also triggers the click event when clicked,
127
+ * allowing both navigation and custom click handling.
131
128
  *
132
129
  * @vegaVersion 1.3.0
133
130
  */
134
- this.eventful = true;
131
+ this.eventful = false;
135
132
  /**
136
133
  * Specifies the location where the linked document will be opened,
137
134
  * helping users understand how the link will behave when activated.
@@ -140,11 +137,16 @@ const VegaButtonLink = class {
140
137
  */
141
138
  this.target = '_self';
142
139
  this.onClick = (e) => {
140
+ if (!this.isButton() && !this.eventful)
141
+ return;
143
142
  if (this.disabled) {
144
143
  e.preventDefault();
145
144
  }
146
145
  else {
147
- this.clickEventEmitter.emit(this.host.dataset.key, e);
146
+ const clickEvent = this.clickEventEmitter.emit(this.host.dataset.key, e);
147
+ if (clickEvent.defaultPrevented) {
148
+ e.preventDefault();
149
+ }
148
150
  }
149
151
  };
150
152
  }
@@ -155,11 +157,11 @@ const VegaButtonLink = class {
155
157
  this.host.innerHTML = '';
156
158
  }
157
159
  render() {
158
- const isEventLink = this.isEventLink();
159
- const href = isEventLink ? VegaButtonLink.defaultLink : this.link;
160
+ const isButton = this.isButton();
161
+ const href = isButton ? VegaButtonLink.defaultLink : this.link;
160
162
  return sanitizeVegaComponent(h(Host, { class: {
161
163
  'vega-button-link-disabled': this.disabled,
162
- } }, h("a", { part: "link", tabIndex: this.disabled ? -1 : 0, role: isEventLink ? 'button' : 'link', "aria-label": this.label.trim() || 'No label defined', href: href, onClick: isEventLink && this.onClick, class: {
164
+ } }, h("a", { part: "link", tabIndex: this.disabled ? -1 : 0, role: isButton ? 'button' : 'link', "aria-label": this.label.trim() || 'No label defined', href: href, onClick: this.onClick, class: {
163
165
  'vega-button-link': true,
164
166
  [`vega-button-link-size-${this.size}`]: true,
165
167
  'vega-button-link-left-button': this.hasIconButton('left'),
@@ -200,7 +202,7 @@ const VegaButtonLink = class {
200
202
  renderVegaIcon() {
201
203
  return h("vega-icon", { icon: this.icon, size: this.size === 'large' ? 'size-24' : 'size-16' });
202
204
  }
203
- isEventLink() {
205
+ isButton() {
204
206
  return !this.link || this.link === VegaButtonLink.defaultLink;
205
207
  }
206
208
  get host() { return getElement(this); }
@@ -9,9 +9,9 @@ var FrameworkEnum;
9
9
  /** The VegaEnvManager class manages vega environment parameters. */
10
10
  class VegaEnvManager {
11
11
  constructor() {
12
- // The `2.62.0` will be replaced to a version string when running publish script.
12
+ // The `2.63.0` will be replaced to a version string when running publish script.
13
13
  // eslint-disable-next-line @typescript-eslint/no-magic-numbers
14
- this.vegaVersion = '2.62.0';
14
+ this.vegaVersion = '2.63.0';
15
15
  this.framework = FrameworkEnum.VanillaJs;
16
16
  }
17
17
  /**
@@ -2,16 +2,17 @@ import { h, r as registerInstance, c as createEvent, H as Host, g as getElement
2
2
  import { s as sanitizeVegaComponent } from './component-7d906393.js';
3
3
  import { c as MapToComponentField, V as VegaSlimmer, M as MapToComponentMethod, I as InjectVegaSlimmer } from './global-slimmer-registry-17c4efd4.js';
4
4
  import { V as VegaComponentUsageRuntimeMetricsSlimmer, I as InjectVegaGlobalSlimmer } from './component-usage-runtime-metrics-a84cc93e.js';
5
- import { D as DomNodeSubjectObserverFactory, f as VegaChange } from './dom-node-subject-observer-factory-c7bc3035.js';
5
+ import { D as DomNodeSubjectObserverFactory, f as VegaChange, E as VegaBlur } from './dom-node-subject-observer-factory-c7bc3035.js';
6
+ import { n as normalizeNumberByRanger, c as convertToNumber, b as countDecimals } from './number-4398f2e1.js';
6
7
  import { C as ChildNodesEventPreventSlimmer } from './child-nodes-event-prevent-slimmer-7fe3dc57.js';
7
8
  import { c as createEventEmitSlimmer } from './event-emit-slimmer-3922d816.js';
8
9
  import { b as FORM_ELEMENT_VALUE_CHANGE } from './static-subject-title-633b3474.js';
9
10
  import { C as ChangeManager } from './change-manager-6a7eb88c.js';
10
11
  import { K as KeyboardManagerSlimmer } from './keyboard-manager-slimmer-cae3a002.js';
11
- import { c as convertToNumber, b as countDecimals } from './number-4398f2e1.js';
12
12
  import { F as FormFieldControllerSlimmer } from './form-field-controller-slimmer-f7e8845b.js';
13
13
  import { R as RequiredFieldRule } from './required-field-rule-ab4bdc47.js';
14
14
  import { c as createSubStateNotifySlimmer } from './sub-state-notify-slimmer-4252a90e.js';
15
+ import { M as MinNumberRule, a as MaxNumberRule } from './min-number-rule-2f1cfbf9.js';
15
16
  import './observer-3959f9dd.js';
16
17
  import './ui-c20be16d.js';
17
18
  import './internal-vega-event-manager-cb06e987.js';
@@ -49,6 +50,24 @@ class VegaInputNumericRenderer extends VegaSlimmer {
49
50
  this.onInputChange = (payload) => {
50
51
  this.valueController.updateValue(payload.detail);
51
52
  };
53
+ this.onInputBlur = (payload) => {
54
+ const vegaInput = payload.host;
55
+ const normalizedValue = vegaInput.value.replace(/,/g, '');
56
+ if (normalizedValue !== '' && !isNaN(normalizedValue)) {
57
+ let inputValue = normalizeNumberByRanger(Number(normalizedValue), this.min, this.max);
58
+ if (this.integerOnly) {
59
+ if (inputValue === this.min) {
60
+ inputValue = Math.ceil(this.min);
61
+ }
62
+ else if (inputValue === this.max) {
63
+ inputValue = Math.floor(this.max);
64
+ }
65
+ }
66
+ if (inputValue !== Number(normalizedValue)) {
67
+ this.valueController.updateValue(inputValue.toString());
68
+ }
69
+ }
70
+ };
52
71
  }
53
72
  getInputRef() {
54
73
  return this.vegaInputRef.shadowRoot.querySelector('input');
@@ -66,6 +85,7 @@ class VegaInputNumericRenderer extends VegaSlimmer {
66
85
  return (h("vega-input", { value: this.value || '', showClearIcon: this.showClearIcon, disabled: this.disabled, label: this.label, hint: this.hint, required: this.required, type: "number", placeholder: this.placeholder, size: this.size === 'small' ? 'small' : 'default', prefixIcon: this.prefixIcon, ref: (ref) => {
67
86
  this.vegaInputRef = ref;
68
87
  DomNodeSubjectObserverFactory.addUniqueObserverToNode(ref, VegaChange, (payload) => this.onInputChange(payload));
88
+ DomNodeSubjectObserverFactory.addUniqueObserverToNode(ref, VegaBlur, (payload) => this.onInputBlur(payload));
69
89
  }, maskConfig: {
70
90
  type: 'number',
71
91
  options: maskOptions,
@@ -105,6 +125,12 @@ __decorate$3([
105
125
  __decorate$3([
106
126
  MapToComponentField()
107
127
  ], VegaInputNumericRenderer.prototype, "integerOnly", void 0);
128
+ __decorate$3([
129
+ MapToComponentField()
130
+ ], VegaInputNumericRenderer.prototype, "min", void 0);
131
+ __decorate$3([
132
+ MapToComponentField()
133
+ ], VegaInputNumericRenderer.prototype, "max", void 0);
108
134
  __decorate$3([
109
135
  MapToComponentField()
110
136
  ], VegaInputNumericRenderer.prototype, "valueController", void 0);
@@ -258,6 +284,14 @@ const VegaInputNumeric = class {
258
284
  propertyName: 'required',
259
285
  ruleFactory: (isRequired) => (isRequired ? new RequiredFieldRule() : null),
260
286
  },
287
+ {
288
+ propertyName: 'min',
289
+ ruleFactory: (min) => typeof min === 'number' ? new MinNumberRule({ minValue: min }) : null,
290
+ },
291
+ {
292
+ propertyName: 'max',
293
+ ruleFactory: (max) => typeof max === 'number' ? new MaxNumberRule({ maxValue: max }) : null,
294
+ },
261
295
  ],
262
296
  validationRulesName: 'validationRules',
263
297
  inputContainerGetter: () => this.renderer.getContainerRef(),
@@ -362,6 +396,18 @@ const VegaInputNumeric = class {
362
396
  * @vegaVersion 2.53.0
363
397
  */
364
398
  this.showClearIcon = true;
399
+ /**
400
+ * Sets the minimum allowable value for the numeric input.
401
+ *
402
+ * @vegaVersion 2.63.0
403
+ */
404
+ this.min = null;
405
+ /**
406
+ * Sets the maximum allowable value for the numeric input.
407
+ *
408
+ * @vegaVersion 2.63.0
409
+ */
410
+ this.max = null;
365
411
  }
366
412
  watchPrefixText() {
367
413
  }
@@ -1,6 +1,6 @@
1
1
  import { h, r as registerInstance, c as createEvent, H as Host, g as getElement } from './index-057d0f70.js';
2
2
  import { I as InternalFormFieldValidationRule } from './internal-form-field-validation-rule.abstract-f5b6bdbf.js';
3
- import { M as MinNumberRule, a as MaxNumberRule } from './min-number-rule-86421853.js';
3
+ import { M as MinNumberRule, a as MaxNumberRule } from './min-number-rule-2f1cfbf9.js';
4
4
  import { M as MinStringLengthRule, a as MaxStringLengthRule } from './min-string-length-rule-c31c89f4.js';
5
5
  import { R as RequiredFieldRule } from './required-field-rule-ab4bdc47.js';
6
6
  import { s as sanitizeVegaComponent } from './component-7d906393.js';
@@ -1,5 +1,5 @@
1
1
  import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-057d0f70.js';
2
- import { M as MinNumberRule, a as MaxNumberRule } from './min-number-rule-86421853.js';
2
+ import { M as MinNumberRule, a as MaxNumberRule } from './min-number-rule-2f1cfbf9.js';
3
3
  import { s as sanitizeVegaComponent } from './component-7d906393.js';
4
4
  import { c as convertToNumber, n as normalizeNumberByRanger } from './number-4398f2e1.js';
5
5
  import { I as InjectVegaSlimmer } from './global-slimmer-registry-17c4efd4.js';
@@ -196,6 +196,12 @@ const VegaTextarea = class {
196
196
  * @vegaVersion 2.19.0
197
197
  */
198
198
  this.resizable = true;
199
+ /**
200
+ * Specifies the number of visible lines in the textarea. The value must be an integer greater than or equal to 2.
201
+ *
202
+ * @vegaVersion 2.63.0
203
+ */
204
+ this.rows = 5;
199
205
  /**
200
206
  * Specifies custom validation rules for the text area.
201
207
  *
@@ -203,7 +209,7 @@ const VegaTextarea = class {
203
209
  */
204
210
  this.validationRules = [];
205
211
  this.renderTextareaContainer = () => {
206
- return (h("div", { class: { 'vega-textarea-container': true, 'vega-textarea-not-resizable': !this.resizable }, ref: (e) => (this.inputContainerRef = e) }, h("textarea", { rows: 4, placeholder: this.placeholder, disabled: this.disabled, required: this.required, ref: this.setTextareaRef, maxLength: this.maxLength, minLength: this.minLength, value: this.value, onBlur: this.handleTextareaBlur, "aria-label": this.label || 'No label defined' }), this.showCounter && this.renderCharacterCounter()));
212
+ return (h("div", { class: { 'vega-textarea-container': true, 'vega-textarea-not-resizable': !this.resizable }, ref: (e) => (this.inputContainerRef = e) }, h("textarea", { rows: this.rows >= 2 ? this.rows - 1 : 4, placeholder: this.placeholder, disabled: this.disabled, required: this.required, ref: this.setTextareaRef, maxLength: this.maxLength, minLength: this.minLength, value: this.value, onBlur: this.handleTextareaBlur, "aria-label": this.label || 'No label defined' }), this.showCounter && this.renderCharacterCounter()));
207
213
  };
208
214
  this.renderHintMessage = () => {
209
215
  return h("vega-text", null, this.hint);
@@ -1840,6 +1840,8 @@ const VegaTimePicker = class {
1840
1840
  /**
1841
1841
  * Specifies the format in which the time is displayed
1842
1842
  * in the time picker.
1843
+ * - `24-hour` displays time as "HH:mm".
1844
+ * - `12-hour` displays time as "hh:mm a".
1843
1845
  *
1844
1846
  * @vegaVersion 1.12.0
1845
1847
  */
@@ -1847,6 +1849,12 @@ const VegaTimePicker = class {
1847
1849
  /**
1848
1850
  * Specifies the initial value or selected time
1849
1851
  * for the time picker.
1852
+ * - In `single` mode, the value is a string:
1853
+ * - `24-hour` format: "HH:mm".
1854
+ * - `12-hour` format: "hh:mm a".
1855
+ * - In `range` mode, the value is an array of two strings:
1856
+ * - `24-hour` format: ["HH:mm", "HH:mm"].
1857
+ * - `12-hour` format: ["hh:mm a", "hh:mm a"]
1850
1858
  *
1851
1859
  * @vegaVersion 1.12.0
1852
1860
  */