@antify/ui-module 1.4.0 → 1.5.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 (71) hide show
  1. package/dist/module.json +1 -1
  2. package/dist/module.mjs +2 -1
  3. package/dist/runtime/components/AntAccordionItem.vue +17 -14
  4. package/dist/runtime/components/AntDropdown.vue +6 -6
  5. package/dist/runtime/components/AntListGroupItem.vue +16 -10
  6. package/dist/runtime/components/AntModal.vue +10 -9
  7. package/dist/runtime/components/AntPopover.vue +10 -8
  8. package/dist/runtime/components/AntTooltip.vue +2 -2
  9. package/dist/runtime/components/buttons/AntActionButton.vue +5 -0
  10. package/dist/runtime/components/buttons/AntButton.vue +126 -126
  11. package/dist/runtime/components/buttons/AntCreateButton.vue +1 -0
  12. package/dist/runtime/components/buttons/AntDeleteButton.vue +11 -1
  13. package/dist/runtime/components/buttons/AntDuplicateButton.vue +42 -0
  14. package/dist/runtime/components/buttons/__stories/AntActionButton.stories.mjs +6 -4
  15. package/dist/runtime/components/buttons/__stories/AntButton.stories.mjs +130 -130
  16. package/dist/runtime/components/buttons/__stories/AntCreateButton.stories.mjs +4 -3
  17. package/dist/runtime/components/buttons/__stories/AntDeleteButton.stories.d.ts +1 -0
  18. package/dist/runtime/components/buttons/__stories/AntDeleteButton.stories.mjs +11 -3
  19. package/dist/runtime/components/buttons/__stories/AntDuplicateButton.stories.d.ts +11 -0
  20. package/dist/runtime/components/buttons/__stories/AntDuplicateButton.stories.mjs +67 -0
  21. package/dist/runtime/components/buttons/__stories/AntSaveAndNewButton.stories.mjs +4 -3
  22. package/dist/runtime/components/buttons/__stories/AntSaveButton.stories.mjs +4 -3
  23. package/dist/runtime/components/crud/AntCrud.vue +13 -10
  24. package/dist/runtime/components/crud/AntCrudDetail.vue +1 -1
  25. package/dist/runtime/components/crud/AntCrudDetailActions.vue +1 -1
  26. package/dist/runtime/components/crud/AntCrudDetailNav.vue +1 -1
  27. package/dist/runtime/components/crud/AntCrudTableFilter.vue +1 -1
  28. package/dist/runtime/components/crud/AntCrudTableNav.vue +15 -4
  29. package/dist/runtime/components/dialogs/AntDialog.vue +7 -7
  30. package/dist/runtime/components/form/AntCheckboxWidget/AntCheckbox.vue +1 -2
  31. package/dist/runtime/components/form/AntSelect.vue +57 -53
  32. package/dist/runtime/components/form/AntSwitch.vue +13 -10
  33. package/dist/runtime/components/form/AntSwitcher.vue +4 -4
  34. package/dist/runtime/components/form/AntTextarea.vue +6 -3
  35. package/dist/runtime/components/form/Elements/AntBaseInput.vue +45 -41
  36. package/dist/runtime/components/form/Elements/AntDropDown.vue +1 -1
  37. package/dist/runtime/components/layouts/AntNavLeftLayout.vue +4 -4
  38. package/dist/runtime/components/table/AntTable.vue +95 -73
  39. package/dist/runtime/components/table/AntTableSortButton.vue +16 -4
  40. package/dist/runtime/components/tabs/AntTabItem.vue +7 -4
  41. package/dist/runtime/tailwind.config.mjs +1 -1
  42. package/package.json +1 -1
  43. package/src/runtime/components/AntAccordionItem.vue +17 -14
  44. package/src/runtime/components/AntDropdown.vue +6 -6
  45. package/src/runtime/components/AntListGroupItem.vue +16 -10
  46. package/src/runtime/components/AntModal.vue +10 -9
  47. package/src/runtime/components/AntPopover.vue +10 -8
  48. package/src/runtime/components/AntTooltip.vue +2 -2
  49. package/src/runtime/components/buttons/AntActionButton.vue +5 -0
  50. package/src/runtime/components/buttons/AntButton.vue +126 -126
  51. package/src/runtime/components/buttons/AntCreateButton.vue +1 -0
  52. package/src/runtime/components/buttons/AntDeleteButton.vue +11 -1
  53. package/src/runtime/components/buttons/AntDuplicateButton.vue +42 -0
  54. package/src/runtime/components/crud/AntCrud.vue +13 -10
  55. package/src/runtime/components/crud/AntCrudDetail.vue +1 -1
  56. package/src/runtime/components/crud/AntCrudDetailActions.vue +1 -1
  57. package/src/runtime/components/crud/AntCrudDetailNav.vue +1 -1
  58. package/src/runtime/components/crud/AntCrudTableFilter.vue +1 -1
  59. package/src/runtime/components/crud/AntCrudTableNav.vue +15 -4
  60. package/src/runtime/components/dialogs/AntDialog.vue +7 -7
  61. package/src/runtime/components/form/AntCheckboxWidget/AntCheckbox.vue +1 -2
  62. package/src/runtime/components/form/AntSelect.vue +57 -53
  63. package/src/runtime/components/form/AntSwitch.vue +13 -10
  64. package/src/runtime/components/form/AntSwitcher.vue +4 -4
  65. package/src/runtime/components/form/AntTextarea.vue +6 -3
  66. package/src/runtime/components/form/Elements/AntBaseInput.vue +45 -41
  67. package/src/runtime/components/form/Elements/AntDropDown.vue +1 -1
  68. package/src/runtime/components/layouts/AntNavLeftLayout.vue +4 -4
  69. package/src/runtime/components/table/AntTable.vue +95 -73
  70. package/src/runtime/components/table/AntTableSortButton.vue +16 -4
  71. package/src/runtime/components/tabs/AntTabItem.vue +7 -4
@@ -95,81 +95,98 @@ function rowClick(elem: Record<string, unknown>): void {
95
95
  :class="{'h-full': data.length === 0 && !_loading}"
96
96
  >
97
97
  <thead class="bg-neutral-100 sticky top-0 z-10">
98
- <tr>
99
- <slot name="headerFirstCell"/>
100
-
101
- <template v-for="(header, index) in _headers">
102
- <AntTh
103
- v-if="!_showLightVersion || (_showLightVersion && header.lightVersion)"
104
- :key="`table-header-${header.identifier}-${index}`"
105
- :header="header"
106
- @sort="sortTable"
107
- >
108
- <template #headerContent>
109
- <slot name="headerContent" v-bind="header"/>
110
- </template>
111
- </AntTh>
112
- </template>
113
-
114
- <slot name="headerLastCell"></slot>
115
- </tr>
98
+ <tr>
99
+ <slot name="headerFirstCell" />
100
+
101
+ <template v-for="(header, index) in _headers">
102
+ <AntTh
103
+ v-if="!_showLightVersion || (_showLightVersion && header.lightVersion)"
104
+ :key="`table-header-${header.identifier}-${index}`"
105
+ :header="header"
106
+ @sort="sortTable"
107
+ >
108
+ <template #headerContent>
109
+ <slot
110
+ name="headerContent"
111
+ v-bind="header"
112
+ />
113
+ </template>
114
+ </AntTh>
115
+ </template>
116
+
117
+ <slot name="headerLastCell"></slot>
118
+ </tr>
116
119
  </thead>
117
120
 
118
121
  <tbody class="bg-white relative">
119
- <!-- TODO:: Add some kind of virtual list for very large tree data (or required pagination??) -->
120
- <tr
121
- v-for="(elem, index) in data"
122
- :key="`table-row-${elem[rowKey]}-${index}`"
123
- :id="elem[rowKey] as string"
124
- class="transition-all"
125
- :class="{
126
- 'bg-primary-300 text-primary-300-font': elem === selected,
127
- 'bg-neutral-50 text-neutral-50-font': elem !== selected && index % 2 === 0,
128
- 'bg-neutral-100 text-neutral-100-font': elem !== selected && index % 2 !== 0,
129
- 'cursor-pointer': selectableRows
130
- }"
131
- >
132
- <slot name="rowFirstCell" v-bind="{ elem }"/>
133
-
134
- <template v-for="(header, index) in _headers">
135
- <AntTd
136
- v-if="!_showLightVersion || (_showLightVersion && header.lightVersion)"
137
- :header="header"
138
- :element="elem"
139
- :align="header.align"
140
- :key="`table-cell-${header.identifier}-${index}`"
141
- @click="rowClick(elem)"
142
- >
143
- <template #beforeCellContent="props">
144
- <slot name="beforeCellContent" v-bind="props"/>
145
- </template>
146
-
147
- <template #cellContent="props">
148
- <slot name="cellContent" v-bind="props"/>
149
- </template>
150
-
151
- <template #afterCellContent="props">
152
- <slot name="afterCellContent" v-bind="props"/>
153
- </template>
154
- </AntTd>
155
- </template>
156
-
157
- <slot name="rowLastCell" v-bind="{ elem }"/>
158
- </tr>
159
-
160
- <tr v-if="data.length <= 0 && !_loading">
161
- <td
162
- colspan="100"
163
- class="w-full h-full py-2 text-center text-neutral-50-font text-lg"
122
+ <!-- TODO:: Add some kind of virtual list for very large tree data (or required pagination??) -->
123
+ <tr
124
+ v-for="(elem, index) in data"
125
+ :id="elem[rowKey] as string"
126
+ :key="`table-row-${elem[rowKey]}-${index}`"
127
+ class="transition-all"
128
+ :class="{
129
+ 'bg-primary-300 text-primary-300-font': elem === selected,
130
+ 'bg-white text-for-white-bg-font': elem !== selected && index % 2 === 0,
131
+ 'bg-neutral-100 text-neutral-100-font': elem !== selected && index % 2 !== 0,
132
+ 'cursor-pointer': selectableRows
133
+ }"
164
134
  >
165
- <slot name="emptyState">
166
- <div class="flex items-center flex-col">
167
- <span class="font-semibold">We couldn't find any entry</span>
168
- </div>
169
- </slot>
170
- </td>
171
- </tr>
172
-
135
+ <slot
136
+ name="rowFirstCell"
137
+ v-bind="{ elem }"
138
+ />
139
+
140
+ <template v-for="(header, index) in _headers">
141
+ <AntTd
142
+ v-if="!_showLightVersion || (_showLightVersion && header.lightVersion)"
143
+ :key="`table-cell-${header.identifier}-${index}`"
144
+ :header="header"
145
+ :element="elem"
146
+ :align="header.align"
147
+ @click="rowClick(elem)"
148
+ >
149
+ <template #beforeCellContent="props">
150
+ <slot
151
+ name="beforeCellContent"
152
+ v-bind="props"
153
+ />
154
+ </template>
155
+
156
+ <template #cellContent="props">
157
+ <slot
158
+ name="cellContent"
159
+ v-bind="props"
160
+ />
161
+ </template>
162
+
163
+ <template #afterCellContent="props">
164
+ <slot
165
+ name="afterCellContent"
166
+ v-bind="props"
167
+ />
168
+ </template>
169
+ </AntTd>
170
+ </template>
171
+
172
+ <slot
173
+ name="rowLastCell"
174
+ v-bind="{ elem }"
175
+ />
176
+ </tr>
177
+
178
+ <tr v-if="data.length <= 0 && !_loading">
179
+ <td
180
+ colspan="100"
181
+ class="w-full h-full py-2 text-center text-for-white-bg-font text-lg"
182
+ >
183
+ <slot name="emptyState">
184
+ <div class="flex items-center flex-col">
185
+ <span class="font-semibold">We couldn't find any entry</span>
186
+ </div>
187
+ </slot>
188
+ </td>
189
+ </tr>
173
190
  </tbody>
174
191
  </table>
175
192
  </div>
@@ -178,7 +195,10 @@ function rowClick(elem: Record<string, unknown>): void {
178
195
  v-if="data.length > 0 && _loading"
179
196
  class="absolute bg-opacity-50 w-full top-0 bottom-0 bg-neutral-300 flex items-center justify-center"
180
197
  >
181
- <AntSpinner class="!w-24 !h-24" :color-type="ColorType.primary"/>
198
+ <AntSpinner
199
+ class="!w-24 !h-24"
200
+ :color-type="ColorType.primary"
201
+ />
182
202
  </div>
183
203
 
184
204
  <div
@@ -186,7 +206,9 @@ function rowClick(elem: Record<string, unknown>): void {
186
206
  class="absolute bg-opacity-50 w-full top-[40px] bottom-0 bg-neutral-300 flex items-center justify-center"
187
207
  >
188
208
  <AntSkeleton
189
- v-model="_loading" absolute/>
209
+ v-model="_loading"
210
+ absolute
211
+ />
190
212
  </div>
191
213
  </div>
192
214
  </template>
@@ -16,11 +16,23 @@ withDefaults(
16
16
 
17
17
  <template>
18
18
  <button
19
- class="bg-neutral-50 text-neutral-50-font rounded h-[26px] w-[26px] flex items-center justify-center"
19
+ class="bg-white text-for-white-bg-font rounded h-[26px] w-[26px] flex items-center justify-center"
20
20
  @click="$emit('sortClick')"
21
21
  >
22
- <AntIcon v-if="sortDirection === AntTableSortDirection.asc" :icon="faAngleDown" :size="IconSize.sm"/>
23
- <AntIcon v-if="sortDirection === AntTableSortDirection.desc" :icon="faAngleUp" :size="IconSize.sm"/>
24
- <AntIcon v-if="sortDirection === AntTableSortDirection.neutral" :icon="faMinus" :size="IconSize.sm"/>
22
+ <AntIcon
23
+ v-if="sortDirection === AntTableSortDirection.asc"
24
+ :icon="faAngleDown"
25
+ :size="IconSize.sm"
26
+ />
27
+ <AntIcon
28
+ v-if="sortDirection === AntTableSortDirection.desc"
29
+ :icon="faAngleUp"
30
+ :size="IconSize.sm"
31
+ />
32
+ <AntIcon
33
+ v-if="sortDirection === AntTableSortDirection.neutral"
34
+ :icon="faMinus"
35
+ :size="IconSize.sm"
36
+ />
25
37
  </button>
26
38
  </template>
@@ -52,13 +52,13 @@ const containerClasses = computed(() => {
52
52
  [ColorType.danger]: 'text-danger-500 border-danger-500',
53
53
  };
54
54
  const notActiveVariants: Record<ColorType, string> = {
55
- [ColorType.base]: 'text-neutral-50-font border-neutral-50',
55
+ [ColorType.base]: 'text-for-white-bg-font border-white',
56
56
  [ColorType.warning]: 'text-warning-500',
57
57
  [ColorType.danger]: 'text-danger-500',
58
58
  };
59
59
 
60
60
  return {
61
- 'p-2.5 hover:cursor-pointer text-center flex items-center justify-center gap-2.5 bg-neutral-50 transition-[background-color] relative': true,
61
+ 'p-2.5 hover:cursor-pointer text-center flex items-center justify-center gap-2.5 bg-white transition-[background-color] relative': true,
62
62
  'grow': props.expanded,
63
63
  [variants[props.colorType]]: true,
64
64
  [activeVariants[props.colorType]]: _active.value,
@@ -98,7 +98,7 @@ const iconColor = computed(() => {
98
98
  <AntIcon
99
99
  v-if="icon"
100
100
  :icon="icon"
101
- :color="_active ? 'text-primary-500' : 'text-neutral-50-font'"
101
+ :color="_active ? 'text-primary-500' : 'text-for-white-bg-font'"
102
102
  />
103
103
  </slot>
104
104
 
@@ -110,6 +110,9 @@ const iconColor = computed(() => {
110
110
  :color="iconColor"
111
111
  />
112
112
 
113
- <div v-if="_active" :class="borderBoxClasses" />
113
+ <div
114
+ v-if="_active"
115
+ :class="borderBoxClasses"
116
+ />
114
117
  </component>
115
118
  </template>
@@ -82,7 +82,7 @@ const colors = {
82
82
  "danger-950": defaultColors.red["950"]
83
83
  };
84
84
  const fontColors = {
85
- "for-white-bg-font": colors["neutral-900"],
85
+ "for-white-bg-font": colors["neutral-600"],
86
86
  "for-black-bg-font": colors["neutral-100"],
87
87
  "neutral-50-font": colors["neutral-600"],
88
88
  "neutral-100-font": colors["neutral-600"],
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@antify/ui-module",
3
3
  "private": false,
4
- "version": "1.4.0",
4
+ "version": "1.5.0",
5
5
  "license": "MIT",
6
6
  "type": "module",
7
7
  "exports": {
@@ -24,21 +24,24 @@ function onClick() {
24
24
 
25
25
  <template>
26
26
  <div
27
- class="p-2.5 select-none cursor-pointer transition-colors"
28
- :class="{'bg-primary-500 text-primary-500-font': isOpen, 'bg-neutral-50 text-neutral-50-font': !isOpen}"
29
- @click="onClick"
27
+ class="p-2.5 select-none cursor-pointer transition-colors"
28
+ :class="{'bg-primary-500 text-primary-500-font': isOpen, 'bg-white text-for-white-bg-font': !isOpen}"
29
+ @click="onClick"
30
30
  >
31
- <slot name="label" v-bind="{ isOpen: isOpen }">
31
+ <slot
32
+ name="label"
33
+ v-bind="{ isOpen: isOpen }"
34
+ >
32
35
  <div
33
- class="hover:text-gray-800 flex justify-between items-center"
36
+ class="hover:text-gray-800 flex justify-between items-center"
34
37
  >
35
38
  <span class="text-sm font-semibold">
36
39
  {{ label }}
37
40
  </span>
38
41
 
39
42
  <AntIcon
40
- :icon="isOpen ? faAngleUp : faAngleDown"
41
- :color="isOpen ? 'text-primary-500-font' : undefined"
43
+ :icon="isOpen ? faAngleUp : faAngleDown"
44
+ :color="isOpen ? 'text-primary-500-font' : undefined"
42
45
  />
43
46
  </div>
44
47
  </slot>
@@ -46,17 +49,17 @@ function onClick() {
46
49
 
47
50
  <AntTransitionCollapseHeight>
48
51
  <div
49
- v-show="isOpen"
50
- class="bg-white overflow-hidden -mt-px"
52
+ v-show="isOpen"
53
+ class="bg-white overflow-hidden -mt-px"
51
54
  >
52
- <transition name="bounce">
55
+ <Transition name="bounce">
53
56
  <div
54
- v-show="isOpen"
55
- class="p-2.5 bg-neutral-50"
57
+ v-show="isOpen"
58
+ class="p-2.5 bg-white"
56
59
  >
57
- <slot/>
60
+ <slot />
58
61
  </div>
59
- </transition>
62
+ </Transition>
60
63
  </div>
61
64
  </AntTransitionCollapseHeight>
62
65
  </template>
@@ -52,25 +52,25 @@ function onClickOutside() {
52
52
 
53
53
  <template>
54
54
  <div
55
+ v-on-click-outside="onClickOutside"
55
56
  class="relative inline-flex justify-center items-end z-40"
56
57
  data-e2e="dropdown"
57
- v-on-click-outside="onClickOutside"
58
58
  >
59
- <slot/>
59
+ <slot />
60
60
 
61
- <transition name="bounce">
61
+ <Transition name="bounce">
62
62
  <div
63
63
  v-if="showDropdown"
64
64
  :class="_dropdownClasses"
65
65
  >
66
66
  <div
67
- class="shadow-lg border border-neutral-300 rounded-md text-sm relative inline-flex flex-col relative bg-neutral-50 text-neutral-50-font w-full"
67
+ class="shadow-lg border border-neutral-300 rounded-md text-sm relative inline-flex flex-col relative bg-white text-for-white-bg-font w-full"
68
68
  :class="{'p-2.5': contentPadding}"
69
69
  >
70
- <slot name="content"/>
70
+ <slot name="content" />
71
71
  </div>
72
72
  </div>
73
- </transition>
73
+ </Transition>
74
74
  </div>
75
75
  </template>
76
76
 
@@ -21,7 +21,7 @@ const classes = computed(() => {
21
21
  [ListGroupItemColorType.info]: 'bg-info-500 text-info-500-font',
22
22
  [ListGroupItemColorType.neutral700]: 'bg-neutral-700 text-neutral-700-font',
23
23
  [ListGroupItemColorType.neutral300]: 'bg-neutral-300 text-neutral-300-font',
24
- [ListGroupItemColorType.neutral50]: 'bg-neutral-50 text-neutral-50-font',
24
+ [ListGroupItemColorType.neutral50]: 'bg-white text-for-white-bg-font',
25
25
  [ListGroupItemColorType.primary]: 'bg-primary-500 text-primary-500-font',
26
26
  [ListGroupItemColorType.secondary]: 'bg-secondary-500 text-secondary-500-font',
27
27
  [ListGroupItemColorType.success]: 'bg-success-500 text-success-500-font',
@@ -39,7 +39,7 @@ const contentWrapperClasses = computed(() => {
39
39
  [ListGroupItemColorType.info]: 'text-info-500-font',
40
40
  [ListGroupItemColorType.neutral700]: 'text-neutral-700-font',
41
41
  [ListGroupItemColorType.neutral300]: 'text-neutral-300-font',
42
- [ListGroupItemColorType.neutral50]: 'text-neutral-50-font',
42
+ [ListGroupItemColorType.neutral50]: 'text-for-white-bg-font',
43
43
  [ListGroupItemColorType.primary]: 'text-primary-500-font',
44
44
  [ListGroupItemColorType.secondary]: 'text-secondary-500-font',
45
45
  [ListGroupItemColorType.success]: 'text-success-500-font',
@@ -60,21 +60,27 @@ onMounted(() => {
60
60
 
61
61
  <template>
62
62
  <component
63
- :is="to !== undefined ? 'router-link' : 'div'"
64
- :to="to"
65
- :class="classes"
63
+ :is="to !== undefined ? 'router-link' : 'div'"
64
+ :to="to"
65
+ :class="classes"
66
66
  >
67
67
  <div :class="contentWrapperClasses">
68
68
  <div class="flex items-center gap-2.5">
69
- <slot v-if="iconLeft" name="icon-left">
70
- <AntIcon :icon="iconLeft"/>
69
+ <slot
70
+ v-if="iconLeft"
71
+ name="icon-left"
72
+ >
73
+ <AntIcon :icon="iconLeft" />
71
74
  </slot>
72
75
 
73
- <slot/>
76
+ <slot />
74
77
  </div>
75
78
 
76
- <slot v-if="iconRight" name="icon-right">
77
- <AntIcon :icon="iconRight"/>
79
+ <slot
80
+ v-if="iconRight"
81
+ name="icon-right"
82
+ >
83
+ <AntIcon :icon="iconRight" />
78
84
  </slot>
79
85
  </div>
80
86
  </component>
@@ -39,21 +39,22 @@ function closeModal() {
39
39
  </script>
40
40
 
41
41
  <template>
42
- <transition name="fade">
42
+ <Transition name="fade">
43
43
  <div
44
44
  v-if="openBackground"
45
45
  class="absolute inset-0 flex items-center justify-center z-50 cursor-pointer overflow-hidden"
46
46
  :class="{'bg-black/50 backdrop-blur-sm': !fullscreen}"
47
47
  @click.self="closeModal"
48
48
  >
49
- <transition :name="!fullscreen ? 'bounce' : 'bounce-slow'">
49
+ <Transition :name="!fullscreen ? 'bounce' : 'bounce-slow'">
50
50
  <div
51
51
  v-if="openModal"
52
52
  class="flex flex-col gap-px bg-neutral-300 overflow-hidden cursor-auto"
53
53
  :class="{'w-full h-full': fullscreen, 'border border-neutral-300 rounded-md shadow-md': !fullscreen}"
54
54
  >
55
55
  <div
56
- class="bg-neutral-50 p-2.5 flex items-center justify-between text-neutral-50-font text-lg font-medium">
56
+ class="bg-white p-2.5 flex items-center justify-between text-for-white-bg-font text-lg font-medium"
57
+ >
57
58
  <slot name="title">
58
59
  {{ title }}
59
60
  </slot>
@@ -66,20 +67,20 @@ function closeModal() {
66
67
  />
67
68
  </div>
68
69
 
69
- <div class="bg-neutral-50 p-2.5 grow overflow-y-auto">
70
- <slot/>
70
+ <div class="bg-white p-2.5 grow overflow-y-auto">
71
+ <slot />
71
72
  </div>
72
73
 
73
74
  <div
74
75
  v-if="useSlots()['footer'] || false"
75
- class="bg-neutral-50 p-2.5 text-neutral-50-font"
76
+ class="bg-white p-2.5 text-for-white-bg-font"
76
77
  >
77
- <slot name="footer"/>
78
+ <slot name="footer" />
78
79
  </div>
79
80
  </div>
80
- </transition>
81
+ </Transition>
81
82
  </div>
82
- </transition>
83
+ </Transition>
83
84
  </template>
84
85
 
85
86
  <style scoped>
@@ -44,9 +44,9 @@ onMounted(() => {
44
44
 
45
45
  <template>
46
46
  <div class="relative inline-flex justify-center items-end">
47
- <slot/>
47
+ <slot />
48
48
 
49
- <transition name="bounce">
49
+ <Transition name="bounce">
50
50
  <template v-if="showPopover">
51
51
  <div :class="_popoverClasses">
52
52
  <div class="shadow-lg border-neutral-300 rounded-md text-sm relative inline-flex flex-col relative">
@@ -66,12 +66,12 @@ onMounted(() => {
66
66
  >
67
67
  <path
68
68
  d="M20.3284 1.82843L23.1569 4.65685C24.6571 6.15715 26.692 7 28.8137 7L6.18629 7C8.30802 7 10.3429 6.15715 11.8431 4.65686L14.6716 1.82843C16.2337 0.266331 18.7663 0.266328 20.3284 1.82843Z"
69
- :class="{'fill-neutral-100': position === Position.bottom, 'fill-neutral-50': position === Position.top || position === Position.right || position === Position.left}"
69
+ :class="{'fill-neutral-100': position === Position.bottom, 'fill-white': position === Position.top || position === Position.right || position === Position.left}"
70
70
  />
71
71
 
72
72
  <path
73
73
  d="M34.5 7L28.8137 7C26.692 7 24.6571 6.15715 23.1569 4.65685L20.3284 1.82843C18.7663 0.266328 16.2337 0.266331 14.6716 1.82843L11.8431 4.65686C10.3429 6.15715 8.30802 7 6.18629 7L0.5 7L34.5 7Z"
74
- :class="{'stroke-neutral-100': position === Position.bottom, 'stroke-neutral-50': position === Position.top || position === Position.right || position === Position.left}"
74
+ :class="{'stroke-neutral-100': position === Position.bottom, 'stroke-white': position === Position.top || position === Position.right || position === Position.left}"
75
75
  />
76
76
  </svg>
77
77
 
@@ -92,18 +92,20 @@ onMounted(() => {
92
92
  </div>
93
93
 
94
94
  <div
95
- class="border-neutral-300 border-b p-2.5 bg-neutral-100 rounded-t-md border-t border-l border-r text-neutral-100-font font-semibold">
95
+ class="border-neutral-300 border-b p-2.5 bg-neutral-100 rounded-t-md border-t border-l border-r text-neutral-100-font font-semibold"
96
+ >
96
97
  {{ title }}
97
98
  </div>
98
99
 
99
100
  <div
100
- class="p-2.5 rounded-b-md text-neutral-50-font border-neutral-300 border-l border-b border-r bg-neutral-50">
101
- <slot name="content"/>
101
+ class="p-2.5 rounded-b-md text-for-white-bg-font border-neutral-300 border-l border-b border-r bg-white"
102
+ >
103
+ <slot name="content" />
102
104
  </div>
103
105
  </div>
104
106
  </div>
105
107
  </template>
106
- </transition>
108
+ </Transition>
107
109
  </div>
108
110
  </template>
109
111
 
@@ -42,7 +42,7 @@ const itemContainerClasses = computed(() => ({
42
42
  }));
43
43
  const contentClasses = computed(() => {
44
44
  const variants: Record<InputColorType, string> = {
45
- [InputColorType.base]: 'text-neutral-50-font bg-neutral-50 border-neutral-300',
45
+ [InputColorType.base]: 'text-for-white-bg-font bg-white border-neutral-300',
46
46
  [InputColorType.danger]: 'text-danger-500-font bg-danger-500 border-danger-500',
47
47
  [InputColorType.info]: 'text-info-500-font bg-info-500 border-info-500',
48
48
  [InputColorType.success]: 'text-success-500-font bg-success-500 border-success-500',
@@ -53,7 +53,7 @@ const contentClasses = computed(() => {
53
53
  });
54
54
  const svgPathClasses = computed(() => {
55
55
  const variants: Record<InputColorType, string> = {
56
- [InputColorType.base]: 'fill-neutral-50 stroke-neutral-50',
56
+ [InputColorType.base]: 'fill-white stroke-white',
57
57
  [InputColorType.danger]: 'fill-danger-500 stroke-danger-500',
58
58
  [InputColorType.info]: 'fill-info-500 stroke-info-500',
59
59
  [InputColorType.success]: 'fill-success-500 stroke-success-500',
@@ -9,10 +9,13 @@ import {ColorType, InputColorType} from '../../enums/ColorType.enum';
9
9
  import {Position} from '../../enums/Position.enum';
10
10
  import AntButton from './AntButton.vue';
11
11
  import AntTooltip from '../AntTooltip.vue';
12
+ import type {IconDefinition} from '@fortawesome/free-solid-svg-icons';
12
13
 
13
14
  defineEmits(['click', 'blur']);
14
15
  withDefaults(
15
16
  defineProps<{
17
+ iconLeft?: IconDefinition;
18
+ iconRight?: IconDefinition;
16
19
  size?: Size;
17
20
  disabled?: boolean;
18
21
  grouped?: Grouped;
@@ -38,6 +41,8 @@ withDefaults(
38
41
  >
39
42
  <slot name="button">
40
43
  <AntButton
44
+ :icon-left="iconLeft"
45
+ :icon-right="iconRight"
41
46
  :size="size"
42
47
  :disabled="disabled || !hasPermission"
43
48
  :grouped="grouped"