vueless 0.0.373 → 0.0.375

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 (42) hide show
  1. package/composables/useUI.js +4 -2
  2. package/package.json +1 -1
  3. package/ui.button-link/storybook/stories.js +3 -3
  4. package/ui.button-link/useAttrs.js +23 -52
  5. package/ui.button-toggle/useAttrs.js +4 -25
  6. package/ui.button-toggle-item/config.js +9 -20
  7. package/ui.button-toggle-item/useAttrs.js +14 -23
  8. package/ui.container-accordion/config.js +1 -3
  9. package/ui.container-accordion/useAttrs.js +10 -21
  10. package/ui.container-card/useAttrs.js +14 -33
  11. package/ui.container-col/useAttrs.js +3 -25
  12. package/ui.container-divider/useAttrs.js +3 -26
  13. package/ui.container-group/useAttrs.js +3 -25
  14. package/ui.container-modal/useAttrs.js +14 -45
  15. package/ui.container-modal-confirm/useAttrs.js +4 -26
  16. package/ui.container-page/useAttrs.js +20 -46
  17. package/ui.container-row/useAttrs.js +4 -25
  18. package/ui.dropdown-badge/useAttrs.js +12 -34
  19. package/ui.dropdown-link/useAttrs.js +12 -34
  20. package/ui.dropdown-list/UDropdownList.vue +13 -17
  21. package/ui.dropdown-list/useAttrs.js +14 -38
  22. package/ui.form-input/useAttrs.js +8 -25
  23. package/ui.form-input-file/useAttrs.js +7 -25
  24. package/ui.form-input-money/useAttrs.js +4 -25
  25. package/ui.form-input-number/useAttrs.js +3 -25
  26. package/ui.form-input-rating/useAttrs.js +3 -25
  27. package/ui.form-input-search/useAttrs.js +4 -25
  28. package/ui.form-label/useAttrs.js +7 -25
  29. package/ui.form-radio/useAttrs.js +9 -27
  30. package/ui.form-radio-group/useAttrs.js +3 -26
  31. package/ui.form-select/USelect.vue +8 -7
  32. package/ui.text-alert/useAttrs.js +3 -26
  33. package/ui.text-badge/useAttrs.js +8 -28
  34. package/ui.text-block/useAttrs.js +3 -25
  35. package/ui.text-empty/useAttrs.js +3 -25
  36. package/ui.text-file/UFile.vue +2 -6
  37. package/ui.text-file/useAttrs.js +4 -27
  38. package/ui.text-files/useAttrs.js +3 -26
  39. package/ui.text-header/useAttrs.js +3 -26
  40. package/ui.text-money/useAttrs.js +3 -26
  41. package/ui.text-notify/useAttrs.js +4 -25
  42. package/web-types.json +2 -8
@@ -62,17 +62,19 @@ export default function useUI(defaultConfig = {}, propsConfigGetter = null, topL
62
62
  */
63
63
  function getClasses(key, mutatedProps = {}) {
64
64
  return computed(() => {
65
+ const color = toValue(mutatedProps)?.color || props.color;
66
+
65
67
  let value = config.value[key];
66
68
 
67
69
  if (isCVA(value)) {
68
70
  value = cva(value)({
69
71
  ...props,
70
72
  ...toValue(mutatedProps),
71
- color: props.color ? getColor(props.color) : null,
73
+ color: color ? getColor(color) : null,
72
74
  });
73
75
  }
74
76
 
75
- return props.color ? setColor(value, props.color) : value;
77
+ return color ? setColor(value, color) : value;
76
78
  });
77
79
  }
78
80
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "vueless",
3
- "version": "0.0.373",
3
+ "version": "0.0.375",
4
4
  "license": "MIT",
5
5
  "description": "Vue Styleless Component Framework.",
6
6
  "homepage": "https://vueless.com",
@@ -81,15 +81,15 @@ Underlined.args = { enum: "color", underlined: true, dashed: false };
81
81
  export const Dashed = EnumVariantTemplate.bind({});
82
82
  Dashed.args = { enum: "color", dashed: true };
83
83
 
84
- export const Url = DefaultTemplate.bind({});
85
- Url.args = { url: "https://storybook.js.org/docs/react/get-started/introduction" };
84
+ export const Href = DefaultTemplate.bind({});
85
+ Href.args = { href: "https://storybook.js.org/docs/react/get-started/introduction" };
86
86
 
87
87
  export const Route = DefaultTemplate.bind({});
88
88
  Route.args = { name: "SomeRouterRouteName" };
89
89
 
90
90
  export const TargetBlank = DefaultTemplate.bind({});
91
91
  TargetBlank.args = {
92
- url: "https://storybook.js.org/docs/react/get-started/introduction",
92
+ href: "https://storybook.js.org/docs/react/get-started/introduction",
93
93
  targetBlank: true,
94
94
  };
95
95
 
@@ -1,67 +1,38 @@
1
1
  import { computed, useSlots } from "vue";
2
2
  import useUI from "../composables/useUI.js";
3
- import { cva, cx } from "../utils/utilUI.js";
3
+
4
4
  import defaultConfig from "./config.js";
5
5
 
6
6
  export default function useAttrs(props, { isActive, isExactActive }) {
7
- const slots = useSlots();
8
-
9
- const { config, getAttrs, hasSlotContent, getColor, setColor, isSystemKey, isCVA } = useUI(
7
+ const { config, getKeysAttrs, hasSlotContent, getExtendingKeysClasses } = useUI(
10
8
  defaultConfig,
11
9
  () => props.config,
12
10
  );
13
- const attrs = {};
14
-
15
- for (const key in defaultConfig) {
16
- if (isSystemKey(key)) continue;
17
-
18
- const classes = computed(() => {
19
- let value = config.value[key];
20
-
21
- if (isCVA(value)) {
22
- value = cva(value)({
23
- ...props,
24
- color: getColor(props.color),
25
- });
26
- }
27
-
28
- return setColor(value, props.color);
29
- });
30
-
31
- attrs[`${key}Attrs`] = getAttrs(key, { classes });
32
-
33
- if (key === "wrapper") {
34
- const wrapperAttrs = attrs[`${key}Attrs`];
35
-
36
- attrs[`${key}Attrs`] = computed(() => ({
37
- ...wrapperAttrs.value,
38
- class: cx([
39
- wrapperAttrs.value.class,
40
- hasSlotContent(slots["default"]) && config.value.withChild,
41
- isActive.value && props.wrapperActiveClass,
42
- isExactActive.value && props.wrapperExactActiveClass,
43
- ]),
44
- }));
45
- }
46
-
47
- if (key === "link") {
48
- const linkAttrs = attrs[`${key}Attrs`];
11
+ const slots = useSlots();
49
12
 
50
- attrs[`${key}Attrs`] = computed(() => ({
51
- ...linkAttrs.value,
52
- class: cx([
53
- linkAttrs.value.class,
54
- hasSlotContent(slots["default"]) && config.value.withChild,
55
- isActive.value && props.activeClass,
56
- isExactActive.value && props.exactActiveClass,
57
- ]),
58
- }));
59
- }
60
- }
13
+ const extendingKeys = ["withChild"];
14
+ const extendingKeysClasses = getExtendingKeysClasses(extendingKeys);
15
+
16
+ const keysAttrs = getKeysAttrs({}, extendingKeys, {
17
+ wrapper: {
18
+ extend: computed(() => [
19
+ hasSlotContent(slots["default"]) && extendingKeysClasses.withChild.value,
20
+ isActive.value && props.wrapperActiveClass,
21
+ isExactActive.value && props.wrapperExactActiveClass,
22
+ ]),
23
+ },
24
+ link: {
25
+ extend: computed(() => [
26
+ hasSlotContent(slots["default"]) && extendingKeysClasses.withChild.value,
27
+ isActive.value && props.activeClass,
28
+ isExactActive.value && props.exactActiveClass,
29
+ ]),
30
+ },
31
+ });
61
32
 
62
33
  return {
63
- ...attrs,
64
34
  config,
35
+ ...keysAttrs,
65
36
  hasSlotContent,
66
37
  };
67
38
  }
@@ -1,36 +1,15 @@
1
- import { computed } from "vue";
2
1
  import useUI from "../composables/useUI.js";
3
- import { cva } from "../utils/utilUI.js";
2
+
4
3
  import defaultConfig from "./config.js";
5
4
 
6
5
  export default function useAttrs(props) {
7
- const { config, getAttrs, hasSlotContent, isSystemKey, isCVA } = useUI(
8
- defaultConfig,
9
- () => props.config,
10
- );
11
- const attrs = {};
12
-
13
- for (const key in defaultConfig) {
14
- if (isSystemKey(key)) continue;
15
-
16
- const classes = computed(() => {
17
- let value = config.value[key];
18
-
19
- if (isCVA(value)) {
20
- value = cva(value)({
21
- ...props,
22
- });
23
- }
24
-
25
- return value;
26
- });
6
+ const { config, getKeysAttrs, hasSlotContent } = useUI(defaultConfig, () => props.config);
27
7
 
28
- attrs[`${key}Attrs`] = getAttrs(key, { classes });
29
- }
8
+ const keysAttrs = getKeysAttrs();
30
9
 
31
10
  return {
32
- ...attrs,
33
11
  config,
12
+ ...keysAttrs,
34
13
  hasSlotContent,
35
14
  };
36
15
  }
@@ -19,27 +19,16 @@ export default /*tw*/ {
19
19
  `,
20
20
  },
21
21
  },
22
- compoundVariants: [
23
- {
24
- selected: true,
25
- class: "relative disabled:z-10",
26
- },
27
- {
28
- selected: true,
29
- variant: "primary",
30
- class: "!text-white bg-brand-600 border-brand-600",
31
- },
32
- {
33
- selected: true,
34
- variant: "secondary",
35
- class: "text-brand-600 border-brand-600 bg-brand-600/10",
36
- },
37
- {
38
- selected: true,
39
- variant: "thirdary",
40
- class: "!bg-brand-600/20",
22
+ },
23
+ toggleButtonActive: {
24
+ base: "relative disabled:z-10",
25
+ variants: {
26
+ variant: {
27
+ primary: "!text-white bg-brand-600 border-brand-600",
28
+ secondary: "text-brand-600 border-brand-600 bg-brand-600/10",
29
+ thirdary: "!bg-brand-600/20",
41
30
  },
42
- ],
31
+ },
43
32
  },
44
33
  toggleInput: "p-0 m-0 size-0 invisible absolute",
45
34
  defaults: {
@@ -1,40 +1,31 @@
1
1
  import { computed, toValue } from "vue";
2
2
  import useUI from "../composables/useUI.js";
3
- import { cva } from "../utils/utilUI.js";
3
+
4
4
  import defaultConfig from "./config.js";
5
5
 
6
6
  export default function useAttrs(props, { isSelected, separated, variant }) {
7
- const { config, getAttrs, isSystemKey, hasSlotContent, isCVA } = useUI(
7
+ const { config, getKeysAttrs, hasSlotContent, getExtendingKeysClasses } = useUI(
8
8
  defaultConfig,
9
9
  () => props.config,
10
10
  );
11
11
 
12
- const attrs = {};
13
-
14
- for (const key in defaultConfig) {
15
- if (isSystemKey(key)) continue;
16
-
17
- const classes = computed(() => {
18
- let value = config.value[key];
19
-
20
- if (isCVA(value)) {
21
- value = cva(value)({
22
- ...props,
23
- variant: toValue(variant),
24
- separated: toValue(separated),
25
- selected: isSelected.value,
26
- });
27
- }
12
+ const mutatedProps = computed(() => ({
13
+ variant: toValue(variant),
14
+ separated: toValue(separated),
15
+ }));
28
16
 
29
- return value;
30
- });
17
+ const extendingKeys = ["toggleButtonActive"];
18
+ const extendingKeysClasses = getExtendingKeysClasses(extendingKeys, mutatedProps);
31
19
 
32
- attrs[`${key}Attrs`] = getAttrs(key, { classes });
33
- }
20
+ const keysAttrs = getKeysAttrs(mutatedProps, extendingKeys, {
21
+ toggleButton: {
22
+ extend: computed(() => [isSelected.value && extendingKeysClasses.toggleButtonActive.value]),
23
+ },
24
+ });
34
25
 
35
26
  return {
36
- ...attrs,
37
27
  config,
28
+ ...keysAttrs,
38
29
  hasSlotContent,
39
30
  };
40
31
  }
@@ -19,11 +19,9 @@ export default /*tw*/ {
19
19
  md: "text-sm",
20
20
  lg: "text-base",
21
21
  },
22
- isOpened: {
23
- true: "pt-2 h-full opacity-100",
24
- },
25
22
  },
26
23
  },
24
+ isOpened: "pt-2 h-full opacity-100",
27
25
  toggleIcon: "{UIcon}",
28
26
  divider: "{UDivider} group-last:hidden",
29
27
  defaults: {
@@ -1,37 +1,26 @@
1
1
  import { computed } from "vue";
2
2
  import useUI from "../composables/useUI.js";
3
- import { cva } from "../utils/utilUI.js";
3
+
4
4
  import defaultConfig from "./config.js";
5
5
 
6
6
  export default function useAttrs(props, { isOpened }) {
7
- const { config, getAttrs, hasSlotContent, isSystemKey, isCVA } = useUI(
7
+ const { config, getKeysAttrs, hasSlotContent, getExtendingKeysClasses } = useUI(
8
8
  defaultConfig,
9
9
  () => props.config,
10
10
  );
11
- const attrs = {};
12
-
13
- for (const key in defaultConfig) {
14
- if (isSystemKey(key)) continue;
15
-
16
- const classes = computed(() => {
17
- let value = config.value[key];
18
-
19
- if (isCVA(value)) {
20
- value = cva(value)({
21
- ...props,
22
- isOpened: isOpened.value,
23
- });
24
- }
25
11
 
26
- return value;
27
- });
12
+ const extendingKeys = ["isOpened"];
13
+ const extendingKeysClasses = getExtendingKeysClasses(extendingKeys);
28
14
 
29
- attrs[`${key}Attrs`] = getAttrs(key, { classes });
30
- }
15
+ const keysAttrs = getKeysAttrs({}, extendingKeys, {
16
+ description: {
17
+ extend: computed(() => [isOpened.value && extendingKeysClasses.isOpened.value]),
18
+ },
19
+ });
31
20
 
32
21
  return {
33
- ...attrs,
34
22
  config,
23
+ ...keysAttrs,
35
24
  hasSlotContent,
36
25
  };
37
26
  }
@@ -1,49 +1,30 @@
1
+ import { computed } from "vue";
1
2
  import useUI from "../composables/useUI.js";
2
- import { cva, cx } from "../utils/utilUI.js";
3
3
 
4
4
  import defaultConfig from "./config.js";
5
- import { computed } from "vue";
6
5
 
7
6
  export default function useAttrs(props, { isMobileBreakpoint }) {
8
- const { config, getAttrs, hasSlotContent, isSystemKey, isCVA } = useUI(
7
+ const { config, getKeysAttrs, hasSlotContent, getExtendingKeysClasses } = useUI(
9
8
  defaultConfig,
10
9
  () => props.config,
11
10
  );
12
- const attrs = {};
13
-
14
- for (const key in defaultConfig) {
15
- if (isSystemKey(key)) continue;
16
-
17
- const classes = computed(() => {
18
- let value = config.value[key];
19
-
20
- if (isCVA(value)) {
21
- value = cva(value)({
22
- ...props,
23
- });
24
- }
25
-
26
- return value;
27
- });
28
-
29
- attrs[`${key}Attrs`] = getAttrs(key, { classes });
30
11
 
31
- if (key === "footer") {
32
- const footerAttrs = attrs[`${key}Attrs`];
12
+ const extendingKeys = ["footerMobileReverse"];
13
+ const extendingKeysClasses = getExtendingKeysClasses(extendingKeys);
33
14
 
34
- attrs[`${key}Attrs`] = computed(() => ({
35
- ...footerAttrs.value,
36
- class: cx([
37
- footerAttrs.value.class,
38
- props.mobileFooterReverse && isMobileBreakpoint.value && config.value.footerMobileReverse,
39
- ]),
40
- }));
41
- }
42
- }
15
+ const keysAttrs = getKeysAttrs({}, extendingKeys, {
16
+ footer: {
17
+ extend: computed(() => [
18
+ props.mobileFooterReverse &&
19
+ isMobileBreakpoint.value &&
20
+ extendingKeysClasses.footerMobileReverse.value,
21
+ ]),
22
+ },
23
+ });
43
24
 
44
25
  return {
45
- ...attrs,
46
26
  config,
27
+ ...keysAttrs,
47
28
  hasSlotContent,
48
29
  };
49
30
  }
@@ -1,37 +1,15 @@
1
1
  import useUI from "../composables/useUI.js";
2
- import { cva } from "../utils/utilUI.js";
3
2
 
4
3
  import defaultConfig from "./config.js";
5
- import { computed } from "vue";
6
4
 
7
5
  export default function useAttrs(props) {
8
- const { config, getAttrs, isSystemKey, hasSlotContent, isCVA } = useUI(
9
- defaultConfig,
10
- () => props.config,
11
- );
12
- const attrs = {};
6
+ const { config, getKeysAttrs, hasSlotContent } = useUI(defaultConfig, () => props.config);
13
7
 
14
- for (const key in defaultConfig) {
15
- if (isSystemKey(key)) continue;
16
-
17
- const classes = computed(() => {
18
- let value = config.value[key];
19
-
20
- if (isCVA(value)) {
21
- value = cva(value)({
22
- ...props,
23
- });
24
- }
25
-
26
- return value;
27
- });
28
-
29
- attrs[`${key}Attrs`] = getAttrs(key, { classes });
30
- }
8
+ const keysAttrs = getKeysAttrs();
31
9
 
32
10
  return {
33
- ...attrs,
34
11
  config,
12
+ ...keysAttrs,
35
13
  hasSlotContent,
36
14
  };
37
15
  }
@@ -1,38 +1,15 @@
1
1
  import useUI from "../composables/useUI.js";
2
- import { cva } from "../utils/utilUI.js";
3
2
 
4
3
  import defaultConfig from "./config.js";
5
- import { computed } from "vue";
6
4
 
7
5
  export default function useAttrs(props) {
8
- const { config, getAttrs, hasSlotContent, isSystemKey, isCVA } = useUI(
9
- defaultConfig,
10
- () => props.config,
11
- );
12
- const attrs = {};
6
+ const { config, getKeysAttrs, hasSlotContent } = useUI(defaultConfig, () => props.config);
13
7
 
14
- for (const key in defaultConfig) {
15
- if (isSystemKey(key)) continue;
16
-
17
- const classes = computed(() => {
18
- let value = config.value[key];
19
-
20
- if (isCVA(value)) {
21
- value = cva(value)({
22
- ...props,
23
- label: Boolean(props.label),
24
- });
25
- }
26
-
27
- return value;
28
- });
29
-
30
- attrs[`${key}Attrs`] = getAttrs(key, { classes });
31
- }
8
+ const keysAttrs = getKeysAttrs();
32
9
 
33
10
  return {
34
- ...attrs,
35
11
  config,
12
+ ...keysAttrs,
36
13
  hasSlotContent,
37
14
  };
38
15
  }
@@ -1,37 +1,15 @@
1
1
  import useUI from "../composables/useUI.js";
2
- import { cva } from "../utils/utilUI.js";
3
2
 
4
3
  import defaultConfig from "./config.js";
5
- import { computed } from "vue";
6
4
 
7
5
  export default function useAttrs(props) {
8
- const { config, getAttrs, isSystemKey, hasSlotContent, isCVA } = useUI(
9
- defaultConfig,
10
- () => props.config,
11
- );
12
- const attrs = {};
6
+ const { config, getKeysAttrs, hasSlotContent } = useUI(defaultConfig, () => props.config);
13
7
 
14
- for (const key in defaultConfig) {
15
- if (isSystemKey(key)) continue;
16
-
17
- const classes = computed(() => {
18
- let value = config.value[key];
19
-
20
- if (isCVA(value)) {
21
- value = cva(value)({
22
- ...props,
23
- });
24
- }
25
-
26
- return value;
27
- });
28
-
29
- attrs[`${key}Attrs`] = getAttrs(key, { classes });
30
- }
8
+ const keysAttrs = getKeysAttrs();
31
9
 
32
10
  return {
33
- ...attrs,
34
11
  config,
12
+ ...keysAttrs,
35
13
  hasSlotContent,
36
14
  };
37
15
  }
@@ -1,64 +1,33 @@
1
+ import { computed } from "vue";
1
2
  import useUI from "../composables/useUI.js";
2
- import { cva, cx } from "../utils/utilUI.js";
3
3
 
4
4
  import defaultConfig from "./config.js";
5
- import { computed } from "vue";
6
5
 
7
6
  import useBreakpoint from "../composables/useBreakpoint.js";
8
7
 
9
8
  export default function useAttrs(props) {
10
- const { config, getAttrs, hasSlotContent, isSystemKey, isCVA } = useUI(
9
+ const { config, getKeysAttrs, hasSlotContent, getExtendingKeysClasses } = useUI(
11
10
  defaultConfig,
12
11
  () => props.config,
13
12
  );
14
13
  const { isMobileBreakpoint } = useBreakpoint();
15
- const attrs = {};
16
-
17
- for (const key in defaultConfig) {
18
- if (isSystemKey(key)) continue;
19
-
20
- const classes = computed(() => {
21
- let value = config.value[key];
22
-
23
- if (isCVA(value)) {
24
- value = cva(value)({
25
- ...props,
26
- });
27
- }
28
-
29
- return value;
30
- });
31
-
32
- attrs[`${key}Attrs`] = getAttrs(key, { classes });
33
-
34
- if (key === "header") {
35
- const headerAttrs = attrs[`${key}Attrs`];
36
-
37
- attrs[`${key}Attrs`] = computed(() => ({
38
- ...headerAttrs.value,
39
- class: cx([
40
- headerAttrs.value.class,
41
- props.mobileFooterReverse && isMobileBreakpoint.value && config.value.footerMobileReverse,
42
- ]),
43
- }));
44
- }
45
14
 
46
- if (key === "footer") {
47
- const footerAttrs = attrs[`${key}Attrs`];
15
+ const extendingKeys = ["footerMobileReverse"];
16
+ const extendingKeysClasses = getExtendingKeysClasses(extendingKeys);
48
17
 
49
- attrs[`${key}Attrs`] = computed(() => ({
50
- ...footerAttrs.value,
51
- class: cx([
52
- footerAttrs.value.class,
53
- props.mobileFooterReverse && isMobileBreakpoint.value && config.value.footerMobileReverse,
54
- ]),
55
- }));
56
- }
57
- }
18
+ const keysAttrs = getKeysAttrs({}, extendingKeys, {
19
+ footer: {
20
+ extend: computed(() => [
21
+ props.mobileFooterReverse &&
22
+ isMobileBreakpoint.value &&
23
+ extendingKeysClasses.footerMobileReverse.value,
24
+ ]),
25
+ },
26
+ });
58
27
 
59
28
  return {
60
- ...attrs,
61
29
  config,
30
+ ...keysAttrs,
62
31
  hasSlotContent,
63
32
  };
64
33
  }
@@ -1,37 +1,15 @@
1
1
  import useUI from "../composables/useUI.js";
2
+
2
3
  import defaultConfig from "./config.js";
3
- import { cva } from "../utils/utilUI.js";
4
- import { computed } from "vue";
5
4
 
6
5
  export default function useAttrs(props) {
7
- const { config, getAttrs, hasSlotContent, getColor, setColor, isSystemKey, isCVA } = useUI(
8
- defaultConfig,
9
- () => props.config,
10
- );
11
- const attrs = {};
12
-
13
- for (const key in defaultConfig) {
14
- if (isSystemKey(key)) continue;
15
-
16
- const classes = computed(() => {
17
- let value = config.value[key];
18
-
19
- if (isCVA(value)) {
20
- value = cva(value)({
21
- ...props,
22
- color: getColor(props.color),
23
- });
24
- }
25
-
26
- return setColor(value, props.color);
27
- });
6
+ const { config, getKeysAttrs, hasSlotContent } = useUI(defaultConfig, () => props.config);
28
7
 
29
- attrs[`${key}Attrs`] = getAttrs(key, { classes });
30
- }
8
+ const keysAttrs = getKeysAttrs();
31
9
 
32
10
  return {
33
- ...attrs,
34
11
  config,
12
+ ...keysAttrs,
35
13
  hasSlotContent,
36
14
  };
37
15
  }