@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
@@ -15,152 +15,152 @@ import {IconSize} from '../__types/AntIcon.types';
15
15
  defineEmits(['click', 'blur']);
16
16
 
17
17
  const props = withDefaults(defineProps<{
18
- filled?: boolean;
19
- size?: Size;
20
- colorType?: ColorType;
21
- iconLeft?: IconDefinition;
22
- iconRight?: IconDefinition;
23
- to?: RouteLocationRaw;
24
- disabled?: boolean;
25
- grouped?: Grouped;
26
- skeleton?: boolean;
27
- spinner?: boolean;
28
- readonly?: boolean;
29
- expanded?: boolean;
30
- submit?: boolean;
31
- outlined?: boolean;
32
- noFocus?: boolean;
18
+ filled?: boolean;
19
+ size?: Size;
20
+ colorType?: ColorType;
21
+ iconLeft?: IconDefinition;
22
+ iconRight?: IconDefinition;
23
+ to?: RouteLocationRaw;
24
+ disabled?: boolean;
25
+ grouped?: Grouped;
26
+ skeleton?: boolean;
27
+ spinner?: boolean;
28
+ readonly?: boolean;
29
+ expanded?: boolean;
30
+ submit?: boolean;
31
+ outlined?: boolean;
32
+ noFocus?: boolean;
33
33
  }>(), {
34
- colorType: ColorType.base,
35
- disabled: false,
36
- filled: false,
37
- skeleton: false,
38
- spinner: false,
39
- size: Size.md,
40
- grouped: Grouped.none,
41
- readonly: false,
42
- expanded: false,
43
- submit: false,
44
- outlined: true,
45
- noFocus: false,
34
+ colorType: ColorType.base,
35
+ disabled: false,
36
+ filled: false,
37
+ skeleton: false,
38
+ spinner: false,
39
+ size: Size.md,
40
+ grouped: Grouped.none,
41
+ readonly: false,
42
+ expanded: false,
43
+ submit: false,
44
+ outlined: true,
45
+ noFocus: false,
46
46
  });
47
47
 
48
48
  const hasAction = computed(() => (props.skeleton || props.readonly || props.disabled))
49
49
  const groupedClassList = computed(() => ({
50
- 'rounded-tl-md rounded-bl-md rounded-tr-none rounded-br-none -mr-px': props.grouped === Grouped.left,
51
- 'rounded-none -mx-px': props.grouped === Grouped.center,
52
- 'rounded-tl-none rounded-bl-none rounded-tr-md rounded-br-md -ml-px': props.grouped === Grouped.right,
53
- 'rounded-md': props.grouped === Grouped.none,
50
+ 'rounded-tl-md rounded-bl-md rounded-tr-none rounded-br-none -mr-px': props.grouped === Grouped.left,
51
+ 'rounded-none -mx-px': props.grouped === Grouped.center,
52
+ 'rounded-tl-none rounded-bl-none rounded-tr-md rounded-br-md -ml-px': props.grouped === Grouped.right,
53
+ 'rounded-md': props.grouped === Grouped.none,
54
54
  }));
55
55
  const classes = computed(() => {
56
- const variants = {
57
- [ColorType.base]: 'ring-primary-200 outline-neutral-300',
58
- [ColorType.danger]: 'ring-danger-200 outline-danger-500',
59
- [ColorType.info]: 'ring-info-200 outline-info-500',
60
- [ColorType.primary]: 'ring-primary-200 outline-primary-500',
61
- [ColorType.secondary]: 'ring-secondary-200 outline-secondary-500',
62
- [ColorType.success]: 'ring-success-200 outline-success-500',
63
- [ColorType.warning]: 'ring-warning-200 outline-warning-500',
64
- };
65
- const notFilledVariants = {
66
- [ColorType.base]: 'bg-white text-neutral-50-font',
67
- [ColorType.danger]: 'bg-white text-danger-500',
68
- [ColorType.info]: 'bg-white text-info-500',
69
- [ColorType.primary]: 'bg-white text-primary-500',
70
- [ColorType.secondary]: 'bg-white text-secondary-500',
71
- [ColorType.success]: 'bg-white text-success-500',
72
- [ColorType.warning]: 'bg-white text-warning-500',
73
- };
74
- const notFilledHoverVariants = {
75
- [ColorType.base]: 'hover:bg-neutral-100',
76
- [ColorType.danger]: 'hover:bg-danger-100',
77
- [ColorType.info]: 'hover:bg-info-100',
78
- [ColorType.primary]: 'hover:bg-primary-100',
79
- [ColorType.secondary]: 'hover:bg-secondary-100',
80
- [ColorType.success]: 'hover:bg-success-100',
81
- [ColorType.warning]: 'hover:bg-warning-100',
82
- };
83
- const filledVariants = {
84
- [ColorType.base]: 'bg-neutral-50 text-neutral-50-font',
85
- [ColorType.danger]: 'bg-danger-500 text-danger-500-font',
86
- [ColorType.info]: 'bg-info-500 text-info-500-font',
87
- [ColorType.primary]: 'bg-primary-500 text-primary-500-font',
88
- [ColorType.secondary]: 'bg-secondary-500 text-secondary-500-font',
89
- [ColorType.success]: 'bg-success-500 text-success-500-font',
90
- [ColorType.warning]: 'bg-warning-500 text-warning-500-font',
91
- };
92
- const filledHoverVariants = {
93
- [ColorType.base]: 'hover:bg-neutral-200',
94
- [ColorType.danger]: 'hover:bg-danger-600',
95
- [ColorType.info]: 'hover:bg-info-600',
96
- [ColorType.primary]: 'hover:bg-primary-600',
97
- [ColorType.secondary]: 'hover:bg-secondary-600',
98
- [ColorType.success]: 'hover:bg-success-600',
99
- [ColorType.warning]: 'hover:bg-warning-600',
100
- };
56
+ const variants = {
57
+ [ColorType.base]: 'ring-primary-200 outline-neutral-300',
58
+ [ColorType.danger]: 'ring-danger-200 outline-danger-500',
59
+ [ColorType.info]: 'ring-info-200 outline-info-500',
60
+ [ColorType.primary]: 'ring-primary-200 outline-primary-500',
61
+ [ColorType.secondary]: 'ring-secondary-200 outline-secondary-500',
62
+ [ColorType.success]: 'ring-success-200 outline-success-500',
63
+ [ColorType.warning]: 'ring-warning-200 outline-warning-500',
64
+ };
65
+ const notFilledVariants = {
66
+ [ColorType.base]: 'bg-white text-for-white-bg-font',
67
+ [ColorType.danger]: 'bg-white text-danger-500',
68
+ [ColorType.info]: 'bg-white text-info-500',
69
+ [ColorType.primary]: 'bg-white text-primary-500',
70
+ [ColorType.secondary]: 'bg-white text-secondary-500',
71
+ [ColorType.success]: 'bg-white text-success-500',
72
+ [ColorType.warning]: 'bg-white text-warning-500',
73
+ };
74
+ const notFilledHoverVariants = {
75
+ [ColorType.base]: 'hover:bg-neutral-100',
76
+ [ColorType.danger]: 'hover:bg-danger-100',
77
+ [ColorType.info]: 'hover:bg-info-100',
78
+ [ColorType.primary]: 'hover:bg-primary-100',
79
+ [ColorType.secondary]: 'hover:bg-secondary-100',
80
+ [ColorType.success]: 'hover:bg-success-100',
81
+ [ColorType.warning]: 'hover:bg-warning-100',
82
+ };
83
+ const filledVariants = {
84
+ [ColorType.base]: 'bg-neutral-50 text-neutral-50-font',
85
+ [ColorType.danger]: 'bg-danger-500 text-danger-500-font',
86
+ [ColorType.info]: 'bg-info-500 text-info-500-font',
87
+ [ColorType.primary]: 'bg-primary-500 text-primary-500-font',
88
+ [ColorType.secondary]: 'bg-secondary-500 text-secondary-500-font',
89
+ [ColorType.success]: 'bg-success-500 text-success-500-font',
90
+ [ColorType.warning]: 'bg-warning-500 text-warning-500-font',
91
+ };
92
+ const filledHoverVariants = {
93
+ [ColorType.base]: 'hover:bg-neutral-200',
94
+ [ColorType.danger]: 'hover:bg-danger-600',
95
+ [ColorType.info]: 'hover:bg-info-600',
96
+ [ColorType.primary]: 'hover:bg-primary-600',
97
+ [ColorType.secondary]: 'hover:bg-secondary-600',
98
+ [ColorType.success]: 'hover:bg-success-600',
99
+ [ColorType.warning]: 'hover:bg-warning-600',
100
+ };
101
101
 
102
- return {
103
- 'transition-all inline-flex items-center justify-center relative font-medium': true,
104
- 'focus:z-10': true,
105
- 'active:shadow-[inset_0_4px_4px_rgba(0,0,0,0.25)]': !hasAction.value,
106
- 'py-1.5 px-2.5 text-xs gap-1': props.size === Size.sm,
107
- 'py-2.5 px-3.5 text-sm gap-2.5': props.size === Size.md,
108
- 'disabled:opacity-50 disabled:cursor-not-allowed': true,
109
- 'cursor-default': props.readonly,
110
- 'focus:ring-2': !props.readonly && props.size === Size.sm,
111
- 'focus:ring-4': !props.readonly && props.size === Size.md,
112
- 'w-full': props.expanded,
113
- 'invisible': props.skeleton,
114
- 'outline outline-1 outline-offset-[-1px]': props.outlined,
115
- ...groupedClassList.value,
116
- [variants[props.colorType]]: true,
117
- [notFilledVariants[props.colorType]]: !props.filled,
118
- [notFilledHoverVariants[props.colorType]]: !props.filled && !hasAction.value,
119
- [filledVariants[props.colorType]]: props.filled,
120
- [filledHoverVariants[props.colorType]]: props.filled && !hasAction.value,
121
- };
102
+ return {
103
+ 'transition-all inline-flex items-center justify-center relative font-medium': true,
104
+ 'focus:z-10': true,
105
+ 'active:shadow-[inset_0_4px_4px_rgba(0,0,0,0.25)]': !hasAction.value,
106
+ 'py-1.5 px-2.5 text-xs gap-1': props.size === Size.sm,
107
+ 'py-2.5 px-3.5 text-sm gap-2.5': props.size === Size.md,
108
+ 'disabled:opacity-50 disabled:cursor-not-allowed': true,
109
+ 'cursor-default': props.readonly,
110
+ 'focus:ring-2': !props.readonly && props.size === Size.sm,
111
+ 'focus:ring-4': !props.readonly && props.size === Size.md,
112
+ 'w-full': props.expanded,
113
+ 'invisible': props.skeleton,
114
+ 'outline outline-1 outline-offset-[-1px]': props.outlined,
115
+ ...groupedClassList.value,
116
+ [variants[props.colorType]]: true,
117
+ [notFilledVariants[props.colorType]]: !props.filled,
118
+ [notFilledHoverVariants[props.colorType]]: !props.filled && !hasAction.value,
119
+ [filledVariants[props.colorType]]: props.filled,
120
+ [filledHoverVariants[props.colorType]]: props.filled && !hasAction.value,
121
+ };
122
122
  });
123
123
  const iconColor = computed(() => {
124
- const notFilledVariants = {
125
- [ColorType.base]: 'text-neutral-50-font',
126
- [ColorType.danger]: 'text-danger-500',
127
- [ColorType.info]: 'text-info-500',
128
- [ColorType.primary]: 'text-primary-500',
129
- [ColorType.secondary]: 'text-secondary-500',
130
- [ColorType.success]: 'text-success-500',
131
- [ColorType.warning]: 'text-warning-500',
132
- };
133
- const filledVariants = {
134
- [ColorType.base]: 'text-neutral-50-font',
135
- [ColorType.danger]: 'text-danger-500-font',
136
- [ColorType.info]: 'text-info-500-font',
137
- [ColorType.primary]: 'text-primary-500-font',
138
- [ColorType.secondary]: 'text-secondary-500-font',
139
- [ColorType.success]: 'text-success-500-font',
140
- [ColorType.warning]: 'text-warning-500-font',
141
- };
124
+ const notFilledVariants = {
125
+ [ColorType.base]: 'text-for-white-bg-font',
126
+ [ColorType.danger]: 'text-danger-500',
127
+ [ColorType.info]: 'text-info-500',
128
+ [ColorType.primary]: 'text-primary-500',
129
+ [ColorType.secondary]: 'text-secondary-500',
130
+ [ColorType.success]: 'text-success-500',
131
+ [ColorType.warning]: 'text-warning-500',
132
+ };
133
+ const filledVariants = {
134
+ [ColorType.base]: 'text-for-white-bg-font',
135
+ [ColorType.danger]: 'text-danger-500-font',
136
+ [ColorType.info]: 'text-info-500-font',
137
+ [ColorType.primary]: 'text-primary-500-font',
138
+ [ColorType.secondary]: 'text-secondary-500-font',
139
+ [ColorType.success]: 'text-success-500-font',
140
+ [ColorType.warning]: 'text-warning-500-font',
141
+ };
142
142
 
143
- return props.filled ? filledVariants[props.colorType] : notFilledVariants[props.colorType];
143
+ return props.filled ? filledVariants[props.colorType] : notFilledVariants[props.colorType];
144
144
  });
145
145
  const type = computed(() => {
146
- if (props.to !== undefined) {
147
- return undefined;
148
- }
146
+ if (props.to !== undefined) {
147
+ return undefined;
148
+ }
149
149
 
150
- return props.submit ? ButtonType.submit : ButtonType.button;
150
+ return props.submit ? ButtonType.submit : ButtonType.button;
151
151
  });
152
152
  const is = computed(() => {
153
- if (props.readonly) {
154
- return 'div';
155
- }
153
+ if (props.readonly) {
154
+ return 'div';
155
+ }
156
156
 
157
- return props.to !== undefined ? 'router-link' : 'button'
157
+ return props.to !== undefined ? 'router-link' : 'button'
158
158
  })
159
159
 
160
160
  onMounted(() => {
161
- handleEnumValidation(props.size, Size, 'size');
162
- handleEnumValidation(props.colorType, ColorType, 'colorType');
163
- handleEnumValidation(props.grouped, Grouped, 'grouped');
161
+ handleEnumValidation(props.size, Size, 'size');
162
+ handleEnumValidation(props.colorType, ColorType, 'colorType');
163
+ handleEnumValidation(props.grouped, Grouped, 'grouped');
164
164
  });
165
165
  </script>
166
166
 
@@ -20,6 +20,7 @@ withDefaults(defineProps<{
20
20
 
21
21
  <template>
22
22
  <AntActionButton
23
+ :filled="false"
23
24
  :size="size"
24
25
  :disabled="disabled"
25
26
  :grouped="grouped"
@@ -4,9 +4,11 @@ import {Size} from '../../enums/Size.enum';
4
4
  import {ColorType} from '../../enums/ColorType.enum';
5
5
  import AntActionButton from './AntActionButton.vue';
6
6
  import {Position} from '../../enums';
7
+ import {faTrash} from '@fortawesome/free-solid-svg-icons';
7
8
 
8
9
  defineEmits(['click', 'blur']);
9
10
  withDefaults(defineProps<{
11
+ iconVariant?: boolean;
10
12
  size?: Size;
11
13
  disabled?: boolean;
12
14
  grouped?: Grouped;
@@ -15,12 +17,15 @@ withDefaults(defineProps<{
15
17
  canDelete?: boolean;
16
18
  invalidPermissionTooltipPosition?: Position;
17
19
  }>(), {
20
+ iconVariant: false,
18
21
  canDelete: true
19
22
  })
20
23
  </script>
21
24
 
22
25
  <template>
23
26
  <AntActionButton
27
+ :icon-left="iconVariant ? faTrash : undefined"
28
+ :filled="false"
24
29
  :size="size"
25
30
  :disabled="disabled"
26
31
  :grouped="grouped"
@@ -33,7 +38,12 @@ withDefaults(defineProps<{
33
38
  @click="$emit('click')"
34
39
  @blur="$emit('blur')"
35
40
  >
36
- <template #default>Delete</template>
41
+ <template
42
+ v-if="!iconVariant"
43
+ #default
44
+ >
45
+ Delete
46
+ </template>
37
47
 
38
48
  <template #invalidPermissionTooltipContent>
39
49
  You have no permission to delete this entry.<br>
@@ -0,0 +1,42 @@
1
+ <script lang="ts" setup>
2
+ import {Grouped} from '../../enums/Grouped.enum';
3
+ import {Size} from '../../enums/Size.enum';
4
+ import AntActionButton from './AntActionButton.vue';
5
+ import {ColorType, Position} from '../../enums';
6
+ import {faCopy} from '@fortawesome/free-solid-svg-icons';
7
+
8
+ defineEmits(['click', 'blur']);
9
+ withDefaults(defineProps<{
10
+ size?: Size;
11
+ disabled?: boolean;
12
+ grouped?: Grouped;
13
+ skeleton?: boolean;
14
+ expanded?: boolean;
15
+ canDuplicate?: boolean;
16
+ invalidPermissionTooltipPosition?: Position;
17
+ }>(), {
18
+ canDuplicate: true
19
+ });
20
+ </script>
21
+
22
+ <template>
23
+ <AntActionButton
24
+ :icon-left="faCopy"
25
+ :color-type="ColorType.base"
26
+ :size="size"
27
+ :disabled="disabled"
28
+ :grouped="grouped"
29
+ :skeleton="skeleton"
30
+ :expanded="expanded"
31
+ :has-permission="canDuplicate"
32
+ :invalid-permission-tooltip-position="invalidPermissionTooltipPosition"
33
+ data-e2e="create-button"
34
+ @click="$emit('click')"
35
+ @blur="$emit('blur')"
36
+ >
37
+ <template #invalidPermissionTooltipContent>
38
+ You have no permission to duplicate entries.<br>
39
+ Please contact your administrator.
40
+ </template>
41
+ </AntActionButton>
42
+ </template>
@@ -7,33 +7,36 @@ withDefaults(defineProps<{
7
7
  </script>
8
8
 
9
9
  <template>
10
- <div class="flex w-full h-full" data-e2e="crud">
10
+ <div
11
+ class="flex w-full h-full"
12
+ data-e2e="crud"
13
+ >
11
14
  <div
12
15
  class="left-content h-full flex flex-col bg-neutral-300 gap-px overflow-hidden"
13
16
  :class="{'w-[40rem]': showDetail, 'w-full': !showDetail}"
14
17
  >
15
- <div class="bg-neutral-50">
16
- <slot name="search-section"/>
18
+ <div class="bg-white">
19
+ <slot name="search-section" />
17
20
  </div>
18
21
 
19
- <div class="bg-neutral-50 flex-grow h-full overflow-hidden">
20
- <slot name="table-section"/>
22
+ <div class="bg-white flex-grow h-full overflow-hidden">
23
+ <slot name="table-section" />
21
24
  </div>
22
25
 
23
- <div class="bg-neutral-50">
24
- <slot name="table-nav-section"/>
26
+ <div class="bg-white">
27
+ <slot name="table-nav-section" />
25
28
  </div>
26
29
  </div>
27
30
 
28
- <transition name="right-content">
31
+ <Transition name="right-content">
29
32
  <div
30
33
  v-if="showDetail"
31
34
  class="flex flex-col gap-px border-l border-neutral-300 overflow-hidden"
32
35
  :class="{'w-full': showDetail}"
33
36
  >
34
- <slot/>
37
+ <slot />
35
38
  </div>
36
- </transition>
39
+ </Transition>
37
40
  </div>
38
41
  </template>
39
42
 
@@ -2,7 +2,7 @@
2
2
  <div class="flex flex-col bg-neutral-300 gap-px h-full" data-e2e="crud-detail">
3
3
  <slot name="header"/>
4
4
 
5
- <div class="flex-grow bg-neutral-50 h-full overflow-y-auto">
5
+ <div class="flex-grow bg-white h-full overflow-y-auto">
6
6
  <slot/>
7
7
  </div>
8
8
 
@@ -18,7 +18,7 @@ withDefaults(defineProps<{
18
18
 
19
19
  <template>
20
20
  <div
21
- class="flex justify-between p-2.5 gap-2.5 bg-neutral-50"
21
+ class="flex justify-between p-2.5 gap-2.5 bg-white"
22
22
  data-e2e="crud-detail-actions"
23
23
  >
24
24
  <div class="flex gap-2.5">
@@ -23,7 +23,7 @@ const dialogOpen = ref(false);
23
23
 
24
24
  <template>
25
25
  <div
26
- class="flex justify-between items-stretch gap-2.5 bg-neutral-50"
26
+ class="flex justify-between items-stretch gap-2.5 bg-white"
27
27
  data-e2e="crud-detail-nav"
28
28
  >
29
29
  <slot name="tabs">
@@ -62,7 +62,7 @@ watch(() => props.fullWidth, (val) => {
62
62
 
63
63
  <template>
64
64
  <div
65
- class="flex h-full items-center p-2.5 gap-2.5 bg-neutral-50"
65
+ class="flex h-full items-center p-2.5 gap-2.5 bg-white"
66
66
  data-e2e="crud-table-filter"
67
67
  >
68
68
  <div
@@ -90,11 +90,15 @@ watch(() => props.fullWidth, (val) => {
90
90
  >
91
91
  <div
92
92
  v-if="_fullWidth"
93
- class="flex gap-2 items-center text-neutral-50-font text-sm"
93
+ class="flex gap-2 items-center text-for-white-bg-font text-sm"
94
94
  data-e2e="items-per-page"
95
95
  >
96
96
  <span class="relative">
97
- <AntSkeleton v-if="skeleton" rounded absolute/>
97
+ <AntSkeleton
98
+ v-if="skeleton"
99
+ rounded
100
+ absolute
101
+ />
98
102
  Items per page
99
103
  </span>
100
104
 
@@ -105,8 +109,15 @@ watch(() => props.fullWidth, (val) => {
105
109
  :expanded="false"
106
110
  />
107
111
 
108
- <div v-if="count !== null" class="flex gap-1 relative">
109
- <AntSkeleton v-if="skeleton" rounded absolute/>
112
+ <div
113
+ v-if="count !== null"
114
+ class="flex gap-1 relative"
115
+ >
116
+ <AntSkeleton
117
+ v-if="skeleton"
118
+ rounded
119
+ absolute
120
+ />
110
121
 
111
122
  <span class="font-medium">{{ fromItems }} - {{ itemsPerPage * page }}</span>
112
123
  <span>of</span>
@@ -80,14 +80,14 @@ function confirmDialog() {
80
80
  </script>
81
81
 
82
82
  <template>
83
- <transition name="fade">
83
+ <Transition name="fade">
84
84
  <div
85
85
  v-if="openBackground"
86
86
  class="absolute inset-0 flex items-center justify-center z-50 cursor-pointer overflow-hidden bg-black/50 backdrop-blur-sm"
87
87
  data-e2e="dialog"
88
88
  @click.self="closeDialog"
89
89
  >
90
- <transition :name="'bounce'">
90
+ <Transition :name="'bounce'">
91
91
  <div
92
92
  v-if="openDialog"
93
93
  class="flex flex-col gap-px bg-neutral-300 overflow-hidden cursor-auto w-96 border border-neutral-300 rounded-md shadow-md"
@@ -101,7 +101,7 @@ function confirmDialog() {
101
101
  </slot>
102
102
  </div>
103
103
 
104
- <div class="bg-neutral-50 p-2.5 grow flex items-center gap-2.5 text-sm">
104
+ <div class="bg-white p-2.5 grow flex items-center gap-2.5 text-sm">
105
105
  <slot name="icon">
106
106
  <AntIcon
107
107
  v-if="icons[colorType]"
@@ -112,11 +112,11 @@ function confirmDialog() {
112
112
  />
113
113
  </slot>
114
114
 
115
- <slot/>
115
+ <slot />
116
116
  </div>
117
117
 
118
118
  <div
119
- class="bg-neutral-100 p-2.5 gap-2.5 text-neutral-50-font flex w-full justify-end"
119
+ class="bg-neutral-100 p-2.5 gap-2.5 text-for-white-bg-font flex w-full justify-end"
120
120
  >
121
121
  <slot name="footer">
122
122
  <AntButton
@@ -137,9 +137,9 @@ function confirmDialog() {
137
137
  </slot>
138
138
  </div>
139
139
  </div>
140
- </transition>
140
+ </Transition>
141
141
  </div>
142
- </transition>
142
+ </Transition>
143
143
  </template>
144
144
 
145
145
  <style scoped>
@@ -113,7 +113,7 @@ onMounted(() => {
113
113
  <AntIcon
114
114
  v-if="_value"
115
115
  :icon="faCheck"
116
- class="absolute !text-neutral-50 pointer-events-none"
116
+ class="absolute !text-white pointer-events-none"
117
117
  :size="size as unknown as IconSize"
118
118
  />
119
119
 
@@ -137,7 +137,6 @@ onMounted(() => {
137
137
  </div>
138
138
  </div>
139
139
  </AntField>
140
-
141
140
  </template>
142
141
 
143
142
  <style scoped>