@weni/unnnic-system 3.9.1-alpha.0 → 3.9.1-alpha.2

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 (94) hide show
  1. package/CHANGELOG.md +1 -1
  2. package/dist/components/Button/Button.vue.d.ts.map +1 -1
  3. package/dist/components/DateFilter/DateFilter.vue.d.ts +3 -82
  4. package/dist/components/Input/BaseInput.vue.d.ts +0 -22
  5. package/dist/components/Input/BaseInput.vue.d.ts.map +1 -1
  6. package/dist/components/Input/Input.vue.d.ts +3 -82
  7. package/dist/components/Input/Input.vue.d.ts.map +1 -1
  8. package/dist/components/Input/TextInput.vue.d.ts +2 -53
  9. package/dist/components/Input/TextInput.vue.d.ts.map +1 -1
  10. package/dist/components/InputDatePicker/InputDatePicker.vue.d.ts +4 -83
  11. package/dist/components/InputNext/InputNext.vue.d.ts +1 -1
  12. package/dist/components/ModalDialog/ModalDialog.vue.d.ts +29 -194
  13. package/dist/components/ModalDialog/ModalDialog.vue.d.ts.map +1 -1
  14. package/dist/components/ModalNext/ModalNext.vue.d.ts +3 -82
  15. package/dist/components/SelectSmart/SelectSmart.vue.d.ts +2 -53
  16. package/dist/components/SelectTime/index.vue.d.ts +2 -53
  17. package/dist/components/Tag/DefaultTag.vue.d.ts.map +1 -1
  18. package/dist/components/index.d.ts +236 -1728
  19. package/dist/components/index.d.ts.map +1 -1
  20. package/dist/{es-ed9b7d22.mjs → es-d456f02a.mjs} +1 -1
  21. package/dist/{index-bbfce723.mjs → index-120e037a.mjs} +11411 -12212
  22. package/dist/locales/en.json.d.ts +1 -2
  23. package/dist/locales/es.json.d.ts +1 -2
  24. package/dist/locales/pt_br.json.d.ts +1 -2
  25. package/dist/{pt-br-8c45d7e7.mjs → pt-br-b627c074.mjs} +1 -1
  26. package/dist/style.css +1 -1
  27. package/dist/unnnic.mjs +179 -195
  28. package/dist/unnnic.umd.js +34 -41
  29. package/package.json +1 -1
  30. package/src/assets/scss/tailwind.scss +0 -8
  31. package/src/components/Alert/__tests__/__snapshots__/Version1dot1.spec.js.snap +1 -1
  32. package/src/components/Button/Button.vue +0 -1
  33. package/src/components/Input/BaseInput.vue +2 -21
  34. package/src/components/Input/Input.scss +3 -3
  35. package/src/components/Input/Input.vue +1 -19
  36. package/src/components/Input/TextInput.vue +21 -62
  37. package/src/components/ModalDialog/ModalDialog.vue +146 -60
  38. package/src/components/ModalDialog/__tests__/__snapshots__/ModalDialog.spec.js.snap +22 -1
  39. package/src/components/Radio/__test__/__snapshots__/Radio.spec.js.snap +1 -0
  40. package/src/components/Tag/DefaultTag.vue +0 -5
  41. package/src/components/index.ts +23 -55
  42. package/src/locales/en.json +1 -2
  43. package/src/locales/es.json +1 -2
  44. package/src/locales/pt_br.json +1 -2
  45. package/src/stories/ModalDialog.mdx +0 -3
  46. package/src/stories/ModalDialog.stories.js +1 -1
  47. package/dist/components/PageHeader/PageHeader.vue.d.ts +0 -28
  48. package/dist/components/PageHeader/PageHeader.vue.d.ts.map +0 -1
  49. package/dist/components/PageHeader/index.d.ts +0 -3
  50. package/dist/components/PageHeader/index.d.ts.map +0 -1
  51. package/dist/components/PageHeader/types.d.ts +0 -9
  52. package/dist/components/PageHeader/types.d.ts.map +0 -1
  53. package/dist/components/ui/dialog/Dialog.vue.d.ts +0 -23
  54. package/dist/components/ui/dialog/Dialog.vue.d.ts.map +0 -1
  55. package/dist/components/ui/dialog/DialogClose.vue.d.ts +0 -19
  56. package/dist/components/ui/dialog/DialogClose.vue.d.ts.map +0 -1
  57. package/dist/components/ui/dialog/DialogContent.vue.d.ts +0 -40
  58. package/dist/components/ui/dialog/DialogContent.vue.d.ts.map +0 -1
  59. package/dist/components/ui/dialog/DialogFooter.vue.d.ts +0 -25
  60. package/dist/components/ui/dialog/DialogFooter.vue.d.ts.map +0 -1
  61. package/dist/components/ui/dialog/DialogHeader.vue.d.ts +0 -29
  62. package/dist/components/ui/dialog/DialogHeader.vue.d.ts.map +0 -1
  63. package/dist/components/ui/dialog/DialogTitle.vue.d.ts +0 -23
  64. package/dist/components/ui/dialog/DialogTitle.vue.d.ts.map +0 -1
  65. package/dist/components/ui/dialog/DialogTrigger.vue.d.ts +0 -19
  66. package/dist/components/ui/dialog/DialogTrigger.vue.d.ts.map +0 -1
  67. package/dist/components/ui/dialog/index.d.ts +0 -8
  68. package/dist/components/ui/dialog/index.d.ts.map +0 -1
  69. package/src/components/Alert/SIMPLE_MIGRATION_GUIDE.md +0 -152
  70. package/src/components/PageHeader/PageHeader.vue +0 -154
  71. package/src/components/PageHeader/index.ts +0 -2
  72. package/src/components/PageHeader/types.ts +0 -10
  73. package/src/components/Popover/__tests__/Popover.spec.js +0 -147
  74. package/src/components/Popover/__tests__/__snapshots__/Popover.spec.js.snap +0 -8
  75. package/src/components/Popover/index.vue +0 -146
  76. package/src/components/Select/SelectOption.vue +0 -65
  77. package/src/components/Select/__tests__/Select.spec.js +0 -412
  78. package/src/components/Select/__tests__/SelectItem.spec.js +0 -330
  79. package/src/components/Select/__tests__/SelectOption.spec.js +0 -174
  80. package/src/components/Select/__tests__/__snapshots__/Select.spec.js.snap +0 -97
  81. package/src/components/Select/__tests__/__snapshots__/SelectItem.spec.js.snap +0 -15
  82. package/src/components/Select/__tests__/__snapshots__/SelectOption.spec.js.snap +0 -25
  83. package/src/components/Select/index.vue +0 -245
  84. package/src/components/ui/dialog/Dialog.vue +0 -15
  85. package/src/components/ui/dialog/DialogClose.vue +0 -25
  86. package/src/components/ui/dialog/DialogContent.vue +0 -114
  87. package/src/components/ui/dialog/DialogFooter.vue +0 -46
  88. package/src/components/ui/dialog/DialogHeader.vue +0 -79
  89. package/src/components/ui/dialog/DialogTitle.vue +0 -34
  90. package/src/components/ui/dialog/DialogTrigger.vue +0 -12
  91. package/src/components/ui/dialog/index.ts +0 -7
  92. package/src/stories/Dialog.stories.js +0 -832
  93. package/src/stories/PageHeader.stories.js +0 -330
  94. package/src/stories/Select.stories.js +0 -158
@@ -1,154 +0,0 @@
1
- <template>
2
- <header
3
- :class="`page-header
4
- ${hasBackButton ? 'page-header--has-back-button' : ''}
5
- ${hasTabsSlot ? 'page-header--has-tabs' : ''}
6
- `"
7
- >
8
- <UnnnicButton
9
- v-if="hasBackButton"
10
- data-testid="back-button"
11
- type="tertiary"
12
- iconCenter="arrow_back_ios_new"
13
- class="page-header__back-button"
14
- @click="handleBackClick"
15
- />
16
-
17
- <section class="page-header__infos">
18
- <section class="page-header__main-infos">
19
- <h1
20
- class="page-header__title"
21
- data-testid="page-title"
22
- >
23
- {{ title }}
24
- </h1>
25
-
26
- <slot name="tag" />
27
- </section>
28
-
29
- <p
30
- v-if="description"
31
- class="page-header__description"
32
- data-testid="page-description"
33
- >
34
- {{ description }}
35
- </p>
36
- </section>
37
-
38
- <section
39
- v-if="hasActionsSlot"
40
- class="page-header__actions"
41
- data-testid="page-actions"
42
- >
43
- <slot name="actions" />
44
- </section>
45
-
46
- <section
47
- v-if="hasTabsSlot"
48
- class="page-header__tabs"
49
- data-testid="page-tabs"
50
- >
51
- <slot name="tabs" />
52
- </section>
53
- </header>
54
- </template>
55
-
56
- <script setup lang="ts">
57
- import { useSlots } from 'vue';
58
-
59
- import UnnnicButton from '../Button/Button.vue';
60
-
61
- import type { PageHeaderProps, PageHeaderEmits } from './types';
62
-
63
- withDefaults(defineProps<PageHeaderProps>(), {
64
- description: '',
65
- hasBackButton: false,
66
- });
67
-
68
- const emit = defineEmits<PageHeaderEmits>();
69
-
70
- const slots = useSlots();
71
- const hasActionsSlot = !!slots.actions;
72
- const hasTabsSlot = !!slots.tabs;
73
-
74
- const handleBackClick = (): void => {
75
- emit('back');
76
- };
77
- </script>
78
-
79
- <style lang="scss" scoped>
80
- @use '@/assets/scss/unnnic' as *;
81
-
82
- * {
83
- margin: 0;
84
- padding: 0;
85
- box-sizing: border-box;
86
- }
87
-
88
- .page-header {
89
- width: 100%;
90
-
91
- margin-top: $unnnic-space-2;
92
- padding-bottom: $unnnic-space-6;
93
-
94
- display: grid;
95
- gap: $unnnic-space-4;
96
- grid-template-columns: 1fr minmax(250px, 20%); // TODO: Verify if is 250px or 20% (8fr 2fr)
97
- align-items: center;
98
-
99
- border-bottom: 1px solid $unnnic-color-border-soft;
100
-
101
- &--has-back-button {
102
- grid-template-columns: auto 1fr minmax(250px, 20%);
103
- }
104
-
105
- &--has-tabs {
106
- border-bottom: none;
107
- }
108
-
109
- &__infos {
110
- display: flex;
111
- flex-direction: column;
112
- gap: $unnnic-space-2;
113
- }
114
-
115
- &__main-infos {
116
- display: flex;
117
- align-items: center;
118
- gap: $unnnic-space-2;
119
- }
120
-
121
- &__title {
122
- overflow: hidden;
123
- text-overflow: ellipsis;
124
- white-space: nowrap;
125
-
126
- color: $unnnic-color-fg-emphasized;
127
- text-overflow: ellipsis;
128
-
129
- font: $unnnic-font-display-1;
130
- }
131
-
132
- &__description {
133
- color: $unnnic-color-fg-base;
134
-
135
- font: $unnnic-font-body;
136
- }
137
-
138
- &__actions {
139
- display: flex;
140
- gap: $unnnic-space-2;
141
- align-items: center;
142
- justify-content: flex-end;
143
-
144
- > * {
145
- width: 100%;
146
- }
147
- }
148
-
149
- &__tabs {
150
- grid-column: 1 / -1;
151
- grid-row: 2 / 3;
152
- }
153
- }
154
- </style>
@@ -1,2 +0,0 @@
1
- export { default } from './PageHeader.vue';
2
- export { default as PageHeader } from './PageHeader.vue';
@@ -1,10 +0,0 @@
1
- export interface PageHeaderProps {
2
- title: string;
3
- description?: string;
4
-
5
- hasBackButton?: boolean;
6
- }
7
-
8
- export interface PageHeaderEmits {
9
- (event: 'back'): void;
10
- }
@@ -1,147 +0,0 @@
1
- import { mount } from '@vue/test-utils';
2
- import { beforeEach, describe, expect, afterEach, test, vi } from 'vitest';
3
- import UnnnicPopover from '@/components/Popover/index.vue';
4
-
5
- vi.mock('@vueuse/core', () => ({
6
- onClickOutside: vi.fn(),
7
- useResizeObserver: vi.fn(),
8
- }));
9
-
10
- describe('UnnnicPopover.vue', () => {
11
- let wrapper;
12
-
13
- const defaultSlots = {
14
- trigger: '<button data-testid="trigger-button">Click me</button>',
15
- content: '<div data-testid="popover-content">Popover content</div>',
16
- };
17
-
18
- const mountWrapper = (props) => {
19
- return mount(UnnnicPopover, {
20
- slots: defaultSlots,
21
- props: {
22
- ...props,
23
- },
24
- });
25
- };
26
-
27
- beforeEach(() => {
28
- wrapper = mountWrapper();
29
- });
30
-
31
- afterEach(() => {
32
- wrapper?.unmount();
33
- });
34
-
35
- test('renders correctly', () => {
36
- expect(wrapper.exists()).toBe(true);
37
- expect(wrapper.find('.unnnic-popover').exists()).toBe(true);
38
- });
39
-
40
- test('renders trigger slot', () => {
41
- const trigger = wrapper.find('[data-testid="popover-trigger"]');
42
- const triggerButton = wrapper.find('[data-testid="trigger-button"]');
43
-
44
- expect(trigger.exists()).toBe(true);
45
- expect(triggerButton.exists()).toBe(true);
46
- expect(triggerButton.text()).toBe('Click me');
47
- });
48
-
49
- test('renders content slot inside balloon', async () => {
50
- wrapper.vm.open = true;
51
- await wrapper.vm.$nextTick();
52
- const balloon = wrapper.find('[data-testid="popover-balloon"]');
53
- const content = wrapper.find('[data-testid="popover-content"]');
54
-
55
- expect(balloon.exists()).toBe(true);
56
- expect(content.exists()).toBe(true);
57
- expect(content.text()).toBe('Popover content');
58
- });
59
-
60
- test('balloon is hidden by default', () => {
61
- const balloon = wrapper.find('[data-testid="popover-balloon"]');
62
- expect(balloon.exists()).toBe(false);
63
- });
64
-
65
- test('toggles balloon visibility when trigger is clicked', async () => {
66
- const trigger = wrapper.find('[data-testid="popover-trigger"]');
67
-
68
- let balloon = wrapper.find('[data-testid="popover-balloon"]');
69
-
70
- expect(balloon.exists()).toBe(false);
71
-
72
- await trigger.trigger('click');
73
- await wrapper.vm.$nextTick();
74
-
75
- balloon = wrapper.find('[data-testid="popover-balloon"]');
76
-
77
- expect(balloon.exists()).toBe(true);
78
- });
79
-
80
- test('uses modelValue when provided', async () => {
81
- const wrapper = mountWrapper({ modelValue: true });
82
- const balloon = wrapper.find('[data-testid="popover-balloon"]');
83
- expect(balloon.isVisible()).toBe(true);
84
- });
85
-
86
- test('emits update:modelValue when open state changes', async () => {
87
- await wrapper.setProps({ modelValue: false });
88
-
89
- const trigger = wrapper.find('[data-testid="popover-trigger"]');
90
- await trigger.trigger('click');
91
-
92
- expect(wrapper.emitted('update:modelValue')).toBeTruthy();
93
- expect(wrapper.emitted('update:modelValue')[0]).toEqual([true]);
94
- });
95
-
96
- test('does not emit update:modelValue when modelValue is undefined', async () => {
97
- const trigger = wrapper.find('[data-testid="popover-trigger"]');
98
- await trigger.trigger('click');
99
-
100
- expect(wrapper.emitted('update:modelValue')).toBeFalsy();
101
- });
102
-
103
- test('exposes open ref', () => {
104
- expect(wrapper.vm.open).toBeDefined();
105
- expect(typeof wrapper.vm.open).toBe('boolean');
106
- });
107
-
108
- test('open ref can be controlled programmatically', async () => {
109
- wrapper.vm.open = true;
110
- await wrapper.vm.$nextTick();
111
-
112
- const balloon = wrapper.find('[data-testid="popover-balloon"]');
113
- expect(balloon.isVisible()).toBe(true);
114
- });
115
-
116
- test('persistent prop prevents closing on outside click', async () => {
117
- await wrapper.setProps({ persistent: true });
118
-
119
- const { onClickOutside } = await import('@vueuse/core');
120
- const mockOnClickOutside = vi.mocked(onClickOutside);
121
-
122
- const callback = mockOnClickOutside.mock.calls[0][1];
123
-
124
- wrapper.vm.open = true;
125
- await wrapper.vm.$nextTick();
126
-
127
- callback();
128
-
129
- const balloon = wrapper.find('[data-testid="popover-balloon"]');
130
- expect(balloon.isVisible()).toBe(true);
131
- });
132
-
133
- test('applies correct CSS classes', async () => {
134
- wrapper.vm.open = true;
135
- await wrapper.vm.$nextTick();
136
-
137
- const popover = wrapper.find('.unnnic-popover');
138
- const balloon = wrapper.find('.unnnic-popover__balloon');
139
-
140
- expect(popover.exists()).toBe(true);
141
- expect(balloon.exists()).toBe(true);
142
- });
143
-
144
- test('matches the snapshot', () => {
145
- expect(wrapper.html()).toMatchSnapshot();
146
- });
147
- });
@@ -1,8 +0,0 @@
1
- // Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
2
-
3
- exports[`UnnnicPopover.vue > matches the snapshot 1`] = `
4
- "<section data-v-5a3125ac="" class="unnnic-popover">
5
- <div data-v-5a3125ac="" class="unnnic-popover__trigger" data-testid="popover-trigger"><button data-testid="trigger-button">Click me</button></div>
6
- <!--v-if-->
7
- </section>"
8
- `;
@@ -1,146 +0,0 @@
1
- <template>
2
- <section
3
- ref="popover"
4
- class="unnnic-popover"
5
- >
6
- <div
7
- class="unnnic-popover__trigger"
8
- data-testid="popover-trigger"
9
- @click="toggleOpen()"
10
- >
11
- <slot name="trigger" />
12
- </div>
13
- <div
14
- v-if="open"
15
- class="unnnic-popover__balloon"
16
- data-testid="popover-balloon"
17
- >
18
- <slot name="content" />
19
- </div>
20
- </section>
21
- </template>
22
-
23
- <script setup lang="ts">
24
- import { computed, onMounted, ref, useTemplateRef, watch } from 'vue';
25
- import { onClickOutside, useResizeObserver } from '@vueuse/core';
26
-
27
- const target = useTemplateRef<HTMLDivElement>('popover');
28
-
29
- const popoverWidth = ref<string>('');
30
-
31
- useResizeObserver(target, (entries) => {
32
- const entry = entries[0];
33
- const { width } = entry.contentRect;
34
- popoverWidth.value = `${width}px`;
35
- });
36
-
37
- onClickOutside(target, () => {
38
- if (props.persistent) return;
39
- open.value = false;
40
- });
41
-
42
- defineOptions({
43
- name: 'UnnnicPopover',
44
- });
45
-
46
- interface PopoverBalloonProps {
47
- width?: string;
48
- height?: string;
49
- maxHeight?: string;
50
- }
51
-
52
- interface PopoverProps {
53
- modelValue?: boolean;
54
- persistent?: boolean;
55
- popoverBalloonProps?: PopoverBalloonProps;
56
- }
57
-
58
- const props = withDefaults(defineProps<PopoverProps>(), {
59
- modelValue: undefined,
60
- persistent: false,
61
- });
62
-
63
- const emit = defineEmits<{
64
- 'update:modelValue': [value: boolean];
65
- }>();
66
-
67
- const useModelValue = computed(() => props.modelValue !== undefined);
68
-
69
- const open = ref<boolean>(
70
- useModelValue.value ? Boolean(props.modelValue) : false,
71
- );
72
-
73
- const toggleOpen = () => {
74
- open.value = !open.value;
75
- };
76
-
77
- const calculatedPopoverWidth = computed(() => {
78
- return props.popoverBalloonProps?.width || popoverWidth.value;
79
- });
80
-
81
- const popoverHeight = computed(() => {
82
- return props.popoverBalloonProps?.height || 'unset';
83
- });
84
-
85
- const popoverMaxHeight = computed(() => {
86
- return props.popoverBalloonProps?.maxHeight || 'unset';
87
- });
88
-
89
- onMounted(() => {
90
- if (useModelValue.value) {
91
- open.value = Boolean(props.modelValue);
92
- }
93
- });
94
-
95
- watch(open, (value) => {
96
- if (useModelValue.value) {
97
- emit('update:modelValue', value);
98
- }
99
- });
100
-
101
- watch(
102
- () => props.modelValue,
103
- (value) => {
104
- open.value = !!value;
105
- },
106
- );
107
- </script>
108
-
109
- <style lang="scss" scoped>
110
- @use '@/assets/scss/unnnic' as *;
111
-
112
- * {
113
- margin: 0;
114
- padding: 0;
115
- box-sizing: border-box;
116
- }
117
-
118
- .unnnic-popover {
119
- &__balloon {
120
- border-radius: $unnnic-radius-2;
121
- padding: $unnnic-space-4;
122
- background: $unnnic-color-bg-base;
123
- box-shadow: 0 4px 16px 0 rgba(0, 0, 0, 0.16);
124
- // margin-top: $unnnic-space-1;
125
- position: fixed;
126
- width: v-bind(calculatedPopoverWidth);
127
- height: v-bind(popoverHeight);
128
- max-height: v-bind(popoverMaxHeight);
129
- overflow: auto;
130
-
131
- &::-webkit-scrollbar {
132
- width: $unnnic-spacing-inline-nano;
133
- }
134
-
135
- &::-webkit-scrollbar-thumb {
136
- background: $unnnic-color-neutral-cleanest;
137
- border-radius: $unnnic-border-radius-pill;
138
- }
139
-
140
- &::-webkit-scrollbar-track {
141
- background: $unnnic-color-neutral-soft;
142
- border-radius: $unnnic-border-radius-pill;
143
- }
144
- }
145
- }
146
- </style>
@@ -1,65 +0,0 @@
1
- <template>
2
- <div
3
- :class="[
4
- 'unnnic-select-option',
5
- {
6
- 'unnnic-select-option--disabled': props.disabled,
7
- 'unnnic-select-option--active': props.active,
8
- 'unnnic-select-option--focused': props.focused,
9
- },
10
- ]"
11
- >
12
- <p class="unnnic-select-option__label">{{ props.label }}</p>
13
- </div>
14
- </template>
15
-
16
- <script setup lang="ts">
17
- defineOptions({
18
- name: 'UnnnicSelectOption',
19
- });
20
-
21
- interface SelectOptionProps {
22
- label: string;
23
- disabled?: boolean;
24
- active?: boolean;
25
- focused?: boolean;
26
- }
27
-
28
- const props = withDefaults(defineProps<SelectOptionProps>(), {
29
- disabled: false,
30
- active: false,
31
- focused: false,
32
- });
33
- </script>
34
-
35
- <style lang="scss" scoped>
36
- @use '@/assets/scss/unnnic' as *;
37
- * {
38
- margin: 0;
39
- padding: 0;
40
- box-sizing: border-box;
41
- }
42
-
43
- .unnnic-select-option {
44
- cursor: pointer;
45
- border-radius: $unnnic-radius-1;
46
- padding: $unnnic-space-2 $unnnic-space-4;
47
- font: $unnnic-font-emphasis;
48
-
49
- &:hover:not(&--active):not(&--disabled),
50
- &--focused {
51
- background-color: $unnnic-color-bg-soft;
52
- }
53
-
54
- &--active {
55
- background-color: $unnnic-color-bg-active;
56
- color: $unnnic-color-fg-inverted;
57
- }
58
-
59
- &--disabled {
60
- color: $unnnic-color-fg-muted;
61
- background-color: $unnnic-color-bg-muted;
62
- cursor: not-allowed;
63
- }
64
- }
65
- </style>