@milaboratories/uikit 2.10.44 → 2.10.46

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/.turbo/turbo-build.log +15 -15
  2. package/.turbo/turbo-formatter$colon$check.log +2 -2
  3. package/.turbo/turbo-linter$colon$check.log +2 -2
  4. package/.turbo/turbo-types$colon$check.log +1 -1
  5. package/CHANGELOG.md +12 -0
  6. package/dist/components/PlNumberField/PlNumberField.js.map +1 -1
  7. package/dist/components/PlNumberField/PlNumberField.vue.d.ts +45 -75
  8. package/dist/components/PlNumberField/PlNumberField.vue.d.ts.map +1 -1
  9. package/dist/components/PlNumberField/PlNumberField.vue2.js +129 -121
  10. package/dist/components/PlNumberField/PlNumberField.vue2.js.map +1 -1
  11. package/dist/components/PlNumberField/__test__/PlNumberField.spec.d.ts.map +1 -0
  12. package/dist/components/PlNumberField/__test__/parseNumber.spec.d.ts +2 -0
  13. package/dist/components/PlNumberField/__test__/parseNumber.spec.d.ts.map +1 -0
  14. package/dist/components/PlNumberField/parseNumber.d.ts +56 -7
  15. package/dist/components/PlNumberField/parseNumber.d.ts.map +1 -1
  16. package/dist/components/PlNumberField/parseNumber.js +40 -56
  17. package/dist/components/PlNumberField/parseNumber.js.map +1 -1
  18. package/dist/components/PlNumberField/pl-number-field.css +1 -1
  19. package/dist/components/PlSearchField/PlSearchField.js.map +1 -1
  20. package/dist/components/PlSearchField/PlSearchField.style.js.map +1 -1
  21. package/dist/components/PlSearchField/PlSearchField.vue.d.ts +20 -32
  22. package/dist/components/PlSearchField/PlSearchField.vue.d.ts.map +1 -1
  23. package/dist/components/PlSearchField/PlSearchField.vue2.js +4 -2
  24. package/dist/components/PlSearchField/PlSearchField.vue2.js.map +1 -1
  25. package/dist/components/PlTextField/PlTextField.js.map +1 -1
  26. package/dist/components/PlTextField/PlTextField.vue.d.ts +46 -118
  27. package/dist/components/PlTextField/PlTextField.vue.d.ts.map +1 -1
  28. package/dist/components/PlTextField/PlTextField.vue2.js +61 -58
  29. package/dist/components/PlTextField/PlTextField.vue2.js.map +1 -1
  30. package/package.json +5 -5
  31. package/src/components/PlAutocomplete/__tests__/PlAutocomplete.spec.ts +18 -12
  32. package/src/components/PlAutocompleteMulti/__tests__/PlAutocompleteMulti.spec.ts +16 -12
  33. package/src/components/PlDropdown/__tests__/PlDropdown.spec.ts +2 -4
  34. package/src/components/PlDropdownMulti/__tests__/PlDropdownMulti.spec.ts +4 -6
  35. package/src/components/PlDropdownMultiRef/__tests__/PlDropdownMultiRef.spec.ts +4 -7
  36. package/src/components/PlDropdownRef/__tests__/PlDropdownRef.spec.ts +2 -6
  37. package/src/components/PlNumberField/PlNumberField.vue +151 -143
  38. package/src/components/PlNumberField/__test__/PlNumberField.spec.ts +296 -0
  39. package/src/components/PlNumberField/__test__/parseNumber.spec.ts +204 -0
  40. package/src/components/PlNumberField/parseNumber.ts +125 -98
  41. package/src/components/PlNumberField/pl-number-field.scss +17 -4
  42. package/src/components/PlSearchField/PlSearchField.vue +8 -4
  43. package/src/components/PlTextField/PlTextField.vue +37 -49
  44. package/src/components/PlTextField/__tests__/TextField.spec.ts +2 -2
  45. package/dist/components/PlNumberField/__tests__/PlNumberField.spec.d.ts.map +0 -1
  46. package/src/components/PlNumberField/__tests__/PlNumberField.spec.ts +0 -182
  47. /package/dist/components/PlNumberField/{__tests__ → __test__}/PlNumberField.spec.d.ts +0 -0
@@ -1,182 +0,0 @@
1
- import PlNumberField from "../PlNumberField.vue";
2
- import { mount } from "@vue/test-utils";
3
- import { describe, expect, it } from "vitest";
4
-
5
- describe("NumberInput.vue", () => {
6
- it("renders correctly with default props", () => {
7
- const wrapper = mount(PlNumberField, {
8
- props: {
9
- modelValue: 10,
10
- },
11
- });
12
- expect(wrapper.find("input").element.value).toBe("10");
13
- });
14
-
15
- it("displays the label when provided", () => {
16
- const wrapper = mount(PlNumberField, {
17
- props: {
18
- modelValue: 10,
19
- label: "Test Label",
20
- },
21
- });
22
- expect(wrapper.find("label").text()).toBe("Test Label");
23
- });
24
-
25
- it("increments the value when increment button is clicked", async () => {
26
- const wrapper = mount(PlNumberField, {
27
- props: {
28
- modelValue: 10,
29
- step: 2,
30
- },
31
- });
32
- const incrementButton = wrapper.find(".pl-number-field__icons div:first-child");
33
- await incrementButton.trigger("click");
34
- expect(wrapper.vm.modelValue).toEqual(12);
35
- });
36
-
37
- it("decrements the value when decrement button is clicked", async () => {
38
- const wrapper = mount(PlNumberField, {
39
- props: {
40
- modelValue: 10,
41
- step: 1,
42
- },
43
- });
44
- const decrementButton = wrapper.find(".pl-number-field__icons div:last-child");
45
- await decrementButton.trigger("click");
46
- expect(wrapper.vm.modelValue).toEqual(9);
47
- });
48
-
49
- it("disables increment button when value exceeds maxValue", () => {
50
- const wrapper = mount(PlNumberField, {
51
- props: {
52
- modelValue: 10,
53
- maxValue: 10,
54
- },
55
- });
56
- const incrementButton = wrapper.find(".pl-number-field__icons div:first-child");
57
- expect(incrementButton.classes()).toContain("disabled");
58
- });
59
-
60
- it("disables decrement button when value is below minValue", () => {
61
- const wrapper = mount(PlNumberField, {
62
- props: {
63
- modelValue: 1,
64
- minValue: 1,
65
- },
66
- });
67
- const decrementButton = wrapper.find(".pl-number-field__icons div:last-child");
68
- expect(decrementButton.classes()).toContain("disabled");
69
- });
70
-
71
- it("renders error messages when there are validation errors", () => {
72
- const wrapper = mount(PlNumberField, {
73
- props: {
74
- modelValue: 5,
75
- minValue: 10,
76
- errorMessage: "Custom error message",
77
- },
78
- });
79
- expect(wrapper.find(".pl-number-field__error").text()).toContain("Custom error message");
80
- expect(wrapper.find(".pl-number-field__error").text()).toContain(
81
- "Value must be higher than 10",
82
- );
83
- });
84
-
85
- it("validates and updates the computedValue when the user types in the input field", async () => {
86
- const wrapper = mount(PlNumberField, {
87
- props: {
88
- modelValue: 5,
89
- },
90
- });
91
- const input = wrapper.find("input");
92
- await input.setValue("1.1.1");
93
- await input.trigger("focusout");
94
- expect(wrapper.vm.modelValue).toEqual(1.1);
95
-
96
- await input.setValue("15");
97
- await input.trigger("focusout");
98
- expect(wrapper.vm.modelValue).toEqual(15);
99
-
100
- await input.setValue(".");
101
- await input.trigger("focusout");
102
- expect(wrapper.vm.modelValue).toEqual(15);
103
-
104
- await input.setValue("..");
105
- await input.trigger("focusout");
106
- expect(wrapper.vm.modelValue).toEqual(15);
107
- expect(input.element.value).toEqual(".");
108
-
109
- await input.setValue(",,");
110
- await input.trigger("focusout");
111
- expect(wrapper.vm.modelValue).toEqual(15);
112
- expect(input.element.value).toEqual(".");
113
-
114
- await input.setValue("-");
115
- await input.trigger("focusout");
116
- expect(wrapper.vm.modelValue).toEqual(15);
117
- expect(input.element.value).toEqual("-");
118
-
119
- await input.setValue("-a");
120
- await input.trigger("focusout");
121
- expect(wrapper.vm.modelValue).toEqual(15);
122
- expect(input.element.value).toEqual("-");
123
-
124
- await input.setValue("-1");
125
- await input.trigger("focusout");
126
- expect(wrapper.vm.modelValue).toEqual(-1);
127
- expect(input.element.value).toEqual("-1");
128
-
129
- await input.setValue(",");
130
- await input.trigger("focusout");
131
- expect(wrapper.vm.modelValue).toEqual(-1);
132
-
133
- await input.setValue("1,1");
134
- await input.trigger("focusout");
135
- expect(wrapper.vm.modelValue).toEqual(1.1);
136
- expect(input.element.value).toEqual("1.1");
137
-
138
- await input.setValue("-1.1");
139
- await input.trigger("focusout");
140
- expect(wrapper.vm.modelValue).toEqual(-1.1);
141
- expect(input.element.value).toEqual("-1.1");
142
- });
143
-
144
- it("update model with undefined when input is cleared", async () => {
145
- const wrapper = mount(PlNumberField, {
146
- props: {
147
- modelValue: 10,
148
- },
149
- });
150
- const input = wrapper.find("input");
151
- await input.setValue("");
152
- await input.trigger("focusout");
153
- expect(wrapper.vm.modelValue).toEqual(undefined);
154
- });
155
-
156
- it("external modelValue change", async () => {
157
- const wrapper = mount(PlNumberField, {
158
- props: {
159
- modelValue: 10,
160
- },
161
- });
162
-
163
- const input = wrapper.find("input");
164
- await input.trigger("focusout");
165
- expect(wrapper.vm.modelValue).toEqual(10);
166
- expect(input.element.value).toEqual("10");
167
-
168
- await input.setValue("");
169
- await input.trigger("focusout");
170
- expect(wrapper.vm.modelValue).toEqual(undefined);
171
-
172
- wrapper.setProps({ modelValue: 1 });
173
-
174
- await input.trigger("focusout");
175
- expect(wrapper.vm.modelValue).toEqual(1);
176
- expect(input.element.value).toEqual("1");
177
-
178
- await input.setValue(10);
179
- expect(wrapper.vm.modelValue).toEqual(10);
180
- expect(input.element.value).toEqual("10");
181
- });
182
- });