divhunt 2.0.4 → 2.0.6

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 (125) hide show
  1. package/addons/render/assets/back/functions/import.js +44 -0
  2. package/addons/render/assets/back/load.js +2 -0
  3. package/package.json +3 -3
  4. package/addons/render/elements/front/items/self/base/menu/menu.js +0 -96
  5. package/addons/render/elements/front/items/self/base/menu/styles/base.css +0 -116
  6. package/addons/render/elements/front/items/self/base/menu/styles/sizes.css +0 -27
  7. package/addons/render/elements/front/items/self/base/menu/styles/variants.css +0 -99
  8. package/addons/render/elements/front/items/self/base/tag/tag.css +0 -199
  9. package/addons/render/elements/front/items/self/base/tag/tag.js +0 -37
  10. package/addons/render/elements/front/items/self/cards/basic/basic.js +0 -89
  11. package/addons/render/elements/front/items/self/cards/basic/styles/base.css +0 -66
  12. package/addons/render/elements/front/items/self/cards/basic/styles/sizes.css +0 -32
  13. package/addons/render/elements/front/items/self/cards/basic/styles/variants.css +0 -99
  14. package/addons/render/elements/front/items/self/cards/list/list.js +0 -108
  15. package/addons/render/elements/front/items/self/cards/list/styles/base.css +0 -96
  16. package/addons/render/elements/front/items/self/cards/list/styles/sizes.css +0 -32
  17. package/addons/render/elements/front/items/self/cards/list/styles/variants.css +0 -99
  18. package/addons/render/elements/front/items/self/cards/media/media.js +0 -116
  19. package/addons/render/elements/front/items/self/cards/media/styles/base.css +0 -126
  20. package/addons/render/elements/front/items/self/cards/media/styles/sizes.css +0 -49
  21. package/addons/render/elements/front/items/self/cards/media/styles/variants.css +0 -74
  22. package/addons/render/elements/front/items/self/cards/profile/profile.js +0 -95
  23. package/addons/render/elements/front/items/self/cards/profile/styles/base.css +0 -142
  24. package/addons/render/elements/front/items/self/cards/profile/styles/sizes.css +0 -43
  25. package/addons/render/elements/front/items/self/cards/profile/styles/variants.css +0 -131
  26. package/addons/render/elements/front/items/self/cards/stat/stat.js +0 -117
  27. package/addons/render/elements/front/items/self/cards/stat/styles/base.css +0 -97
  28. package/addons/render/elements/front/items/self/cards/stat/styles/sizes.css +0 -49
  29. package/addons/render/elements/front/items/self/cards/stat/styles/variants.css +0 -124
  30. package/addons/render/elements/front/items/self/content/html/html.css +0 -93
  31. package/addons/render/elements/front/items/self/content/html/html.js +0 -40
  32. package/addons/render/elements/front/items/self/content/markdown/markdown.css +0 -200
  33. package/addons/render/elements/front/items/self/content/markdown/markdown.js +0 -120
  34. package/addons/render/elements/front/items/self/data/comments/comments.css +0 -253
  35. package/addons/render/elements/front/items/self/data/comments/comments.js +0 -134
  36. package/addons/render/elements/front/items/self/data/files/files.css +0 -116
  37. package/addons/render/elements/front/items/self/data/files/files.js +0 -85
  38. package/addons/render/elements/front/items/self/data/folders/folders.css +0 -104
  39. package/addons/render/elements/front/items/self/data/folders/folders.js +0 -73
  40. package/addons/render/elements/front/items/self/data/inbox/inbox.css +0 -225
  41. package/addons/render/elements/front/items/self/data/inbox/inbox.js +0 -111
  42. package/addons/render/elements/front/items/self/data/logs/logs.css +0 -133
  43. package/addons/render/elements/front/items/self/data/logs/logs.js +0 -65
  44. package/addons/render/elements/front/items/self/data/plans/plans.css +0 -231
  45. package/addons/render/elements/front/items/self/data/plans/plans.js +0 -104
  46. package/addons/render/elements/front/items/self/data/properties/properties.css +0 -108
  47. package/addons/render/elements/front/items/self/data/properties/properties.js +0 -156
  48. package/addons/render/elements/front/items/self/data/table/table.css +0 -153
  49. package/addons/render/elements/front/items/self/data/table/table.js +0 -106
  50. package/addons/render/elements/front/items/self/data/timeline/timeline.css +0 -127
  51. package/addons/render/elements/front/items/self/data/timeline/timeline.js +0 -57
  52. package/addons/render/elements/front/items/self/feedback/alert/alert.css +0 -258
  53. package/addons/render/elements/front/items/self/feedback/alert/alert.js +0 -67
  54. package/addons/render/elements/front/items/self/feedback/confirm/confirm.css +0 -229
  55. package/addons/render/elements/front/items/self/feedback/confirm/confirm.js +0 -81
  56. package/addons/render/elements/front/items/self/feedback/loader/loader.css +0 -203
  57. package/addons/render/elements/front/items/self/feedback/loader/loader.js +0 -25
  58. package/addons/render/elements/front/items/self/feedback/progress/progress.css +0 -136
  59. package/addons/render/elements/front/items/self/feedback/progress/progress.js +0 -40
  60. package/addons/render/elements/front/items/self/form/button/button.js +0 -105
  61. package/addons/render/elements/front/items/self/form/button/styles/base.css +0 -176
  62. package/addons/render/elements/front/items/self/form/button/styles/sizes.css +0 -78
  63. package/addons/render/elements/front/items/self/form/button/styles/variants.css +0 -421
  64. package/addons/render/elements/front/items/self/form/checkbox/checkbox.js +0 -57
  65. package/addons/render/elements/front/items/self/form/checkbox/styles/base.css +0 -52
  66. package/addons/render/elements/front/items/self/form/checkbox/styles/sizes.css +0 -39
  67. package/addons/render/elements/front/items/self/form/checkbox/styles/variants.css +0 -121
  68. package/addons/render/elements/front/items/self/form/field/field.css +0 -96
  69. package/addons/render/elements/front/items/self/form/field/field.js +0 -39
  70. package/addons/render/elements/front/items/self/form/input/input.css +0 -111
  71. package/addons/render/elements/front/items/self/form/input/input.js +0 -78
  72. package/addons/render/elements/front/items/self/form/input/styles/base.css +0 -26
  73. package/addons/render/elements/front/items/self/form/input/styles/sizes.css +0 -15
  74. package/addons/render/elements/front/items/self/form/input/styles/variants.css +0 -98
  75. package/addons/render/elements/front/items/self/form/radio/radio.js +0 -57
  76. package/addons/render/elements/front/items/self/form/radio/styles/base.css +0 -48
  77. package/addons/render/elements/front/items/self/form/radio/styles/sizes.css +0 -36
  78. package/addons/render/elements/front/items/self/form/radio/styles/variants.css +0 -121
  79. package/addons/render/elements/front/items/self/form/rating/rating.css +0 -95
  80. package/addons/render/elements/front/items/self/form/rating/rating.js +0 -88
  81. package/addons/render/elements/front/items/self/form/section/section.css +0 -107
  82. package/addons/render/elements/front/items/self/form/section/section.js +0 -39
  83. package/addons/render/elements/front/items/self/form/slider/slider.css +0 -244
  84. package/addons/render/elements/front/items/self/form/slider/slider.js +0 -69
  85. package/addons/render/elements/front/items/self/form/textarea/textarea.css +0 -117
  86. package/addons/render/elements/front/items/self/form/textarea/textarea.js +0 -69
  87. package/addons/render/elements/front/items/self/layout/empty/empty.css +0 -154
  88. package/addons/render/elements/front/items/self/layout/empty/empty.js +0 -43
  89. package/addons/render/elements/front/items/self/layout/heading/heading.css +0 -117
  90. package/addons/render/elements/front/items/self/layout/heading/heading.js +0 -47
  91. package/addons/render/elements/front/items/self/layout/hero/hero.js +0 -88
  92. package/addons/render/elements/front/items/self/layout/hero/styles/base.css +0 -81
  93. package/addons/render/elements/front/items/self/layout/hero/styles/sizes.css +0 -24
  94. package/addons/render/elements/front/items/self/layout/hero/styles/variants.css +0 -98
  95. package/addons/render/elements/front/items/self/navigation/breadcrumb/addon/_class/addon.js +0 -9
  96. package/addons/render/elements/front/items/self/navigation/breadcrumb/addon/functions/get.js +0 -22
  97. package/addons/render/elements/front/items/self/navigation/breadcrumb/breadcrumb.css +0 -13
  98. package/addons/render/elements/front/items/self/navigation/breadcrumb/breadcrumb.js +0 -51
  99. package/addons/render/elements/front/items/self/navigation/footer/addon/_class/addon.js +0 -11
  100. package/addons/render/elements/front/items/self/navigation/footer/addon/functions/columns.js +0 -11
  101. package/addons/render/elements/front/items/self/navigation/footer/addon/functions/get.js +0 -34
  102. package/addons/render/elements/front/items/self/navigation/footer/footer.css +0 -283
  103. package/addons/render/elements/front/items/self/navigation/footer/footer.js +0 -139
  104. package/addons/render/elements/front/items/self/navigation/navbar/addon/_class/addon.js +0 -13
  105. package/addons/render/elements/front/items/self/navigation/navbar/addon/functions/active.js +0 -7
  106. package/addons/render/elements/front/items/self/navigation/navbar/addon/functions/get.js +0 -31
  107. package/addons/render/elements/front/items/self/navigation/navbar/navbar.css +0 -140
  108. package/addons/render/elements/front/items/self/navigation/navbar/navbar.js +0 -118
  109. package/addons/render/elements/front/items/self/navigation/pagination/pagination.css +0 -160
  110. package/addons/render/elements/front/items/self/navigation/pagination/pagination.js +0 -131
  111. package/addons/render/elements/front/items/self/navigation/sidebar/addon/_class/addon.js +0 -12
  112. package/addons/render/elements/front/items/self/navigation/sidebar/addon/functions/active.js +0 -7
  113. package/addons/render/elements/front/items/self/navigation/sidebar/addon/functions/get.js +0 -35
  114. package/addons/render/elements/front/items/self/navigation/sidebar/addon/functions/groups.js +0 -10
  115. package/addons/render/elements/front/items/self/navigation/sidebar/sidebar.css +0 -278
  116. package/addons/render/elements/front/items/self/navigation/sidebar/sidebar.js +0 -85
  117. package/addons/render/elements/front/items/self/navigation/stepper/stepper.css +0 -202
  118. package/addons/render/elements/front/items/self/navigation/stepper/stepper.js +0 -82
  119. package/addons/render/elements/front/items/self/navigation/tabs/addon.js +0 -32
  120. package/addons/render/elements/front/items/self/navigation/tabs/tabs.css +0 -239
  121. package/addons/render/elements/front/items/self/navigation/tabs/tabs.js +0 -76
  122. package/addons/render/elements/front/items/self/preview/html/html.css +0 -377
  123. package/addons/render/elements/front/items/self/preview/html/html.js +0 -107
  124. package/lib/LICENSE.txt +0 -40
  125. /package/lib/{load.back.js → load.js} +0 -0
@@ -0,0 +1,44 @@
1
+ import assets from '../addon.js';
2
+
3
+ import { dirname, resolve } from 'path';
4
+ import { fileURLToPath } from 'url';
5
+
6
+ const root = resolve(dirname(fileURLToPath(import.meta.url)), '..', '..', '..', '..', '..');
7
+
8
+ const map =
9
+ {
10
+ framework: { js: 'lib', ignore: ['lib/load.js'] },
11
+ commands: { js: 'addons/core/commands/front', css: 'addons/core/commands/front' },
12
+ database: { js: 'addons/core/database/front' },
13
+ actions: { js: 'addons/modules/actions/front' },
14
+ bugs: { js: 'addons/modules/bugs/front' },
15
+ events: { js: 'addons/modules/events/front' },
16
+ schedules: { js: 'addons/modules/schedules/front' },
17
+ shortcuts: { js: 'addons/modules/shortcuts/front' },
18
+ sources: { js: 'addons/modules/sources/front' },
19
+ directives: { js: 'addons/render/directives/front' },
20
+ transforms: { js: 'addons/render/transforms/front' },
21
+ pages: { js: 'addons/render/pages/front', css: 'addons/render/pages/front' },
22
+ elements: { js: 'addons/render/elements/front', css: 'addons/render/elements/front' },
23
+ float: { js: 'addons/float', css: 'addons/float' }
24
+ };
25
+
26
+ assets.Fn('import', function(modules)
27
+ {
28
+ for (let i = 0; i < modules.length; i++)
29
+ {
30
+ const config = map[modules[i]];
31
+
32
+ if (!config) continue;
33
+
34
+ if (config.js)
35
+ {
36
+ assets.Item({ type: 'js', order: i, path: resolve(root, config.js), ignore: config.ignore || [] });
37
+ }
38
+
39
+ if (config.css)
40
+ {
41
+ assets.Item({ type: 'css', order: i, path: resolve(root, config.css) });
42
+ }
43
+ }
44
+ });
@@ -10,6 +10,8 @@ import './functions/scan/directories.js';
10
10
  import './functions/utils/read.js';
11
11
  import './functions/utils/transform.js';
12
12
 
13
+ import './functions/import.js';
14
+
13
15
  /* Items */
14
16
  import './items/commands/css.js';
15
17
  import './items/commands/js.js';
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "divhunt",
3
- "version": "2.0.4",
3
+ "version": "2.0.6",
4
4
  "description": "Full-stack isomorphic JavaScript framework built from scratch. One addon abstraction powers databases, servers, commands, pages, directives, queues, and more.",
5
5
  "type": "module",
6
- "main": "lib/load.back.js",
6
+ "main": "lib/load.js",
7
7
  "browser": "lib/browser.js",
8
8
  "exports": {
9
- ".": "./lib/load.back.js",
9
+ ".": "./lib/load.js",
10
10
  "./browser": "./lib/browser.js",
11
11
  "./database": "./addons/core/database/back/load.js",
12
12
  "./servers/grpc": "./addons/core/servers/back/grpc/load.js",
@@ -1,96 +0,0 @@
1
- import elements from '#elements/load.js';
2
-
3
- elements.ItemAdd({
4
- id: 'menu',
5
- icon: 'list',
6
- name: 'Menu',
7
- description: 'Menu item with icon, label, badge, expandable children, and nested level support.',
8
- category: 'Navigation',
9
- author: 'Divhunt',
10
- config: {
11
- icon: {
12
- type: 'string',
13
- value: 'folder'
14
- },
15
- label: {
16
- type: 'string',
17
- value: 'Dashboard'
18
- },
19
- badge: {
20
- type: 'string',
21
- value: ''
22
- },
23
- href: {
24
- type: 'string',
25
- value: '#'
26
- },
27
- level: {
28
- type: 'number',
29
- value: 0
30
- },
31
- active: {
32
- type: 'boolean',
33
- value: false
34
- },
35
- expanded: {
36
- type: 'boolean',
37
- value: false
38
- },
39
- expandable: {
40
- type: 'boolean',
41
- value: false
42
- },
43
- disabled: {
44
- type: 'boolean',
45
- value: false
46
- },
47
- variant: {
48
- type: 'array',
49
- value: ['size-m'],
50
- options: ['bg-1', 'bg-2', 'bg-3', 'bg-4', 'border', 'brand', 'blue', 'red', 'orange', 'green', 'size-s', 'size-m', 'size-l']
51
- },
52
- onClick: {
53
- type: 'function'
54
- },
55
- onExpand: {
56
- type: 'function'
57
- }
58
- },
59
- render: function()
60
- {
61
- this.handleClick = () =>
62
- {
63
- if (this.disabled) return;
64
-
65
- if (this.onClick)
66
- {
67
- this.onClick();
68
- }
69
- };
70
-
71
- this.handleExpand = (e) =>
72
- {
73
- e.preventDefault();
74
- e.stopPropagation();
75
-
76
- if (this.disabled) return;
77
-
78
- this.expanded = !this.expanded;
79
-
80
- if (this.onExpand)
81
- {
82
- this.onExpand({ expanded: this.expanded });
83
- }
84
- };
85
-
86
- return `
87
- <a :href="href" class="holder" :variant="variant.join(' ')" :level="level" :active="active" :expanded="expanded" :disabled="disabled" dh-click="handleClick">
88
- <i dh-if="expandable" class="chevron" dh-click="handleExpand">chevron_right</i>
89
- <i dh-if="icon">{{ icon }}</i>
90
- <span>{{ label }}</span>
91
- <e-tag dh-if="badge" :text="badge" :variant="['bg-3', 'size-s']"></e-tag>
92
- <slot name="end"></slot>
93
- </a>
94
- `;
95
- }
96
- });
@@ -1,116 +0,0 @@
1
- .e-4de878b > .holder
2
- {
3
- display: flex;
4
- align-items: center;
5
- gap: var(--dh-spacing-s);
6
- width: 100%;
7
- padding: var(--dh-spacing-s) var(--dh-spacing-m);
8
- color: var(--dh-text-1);
9
- text-decoration: none;
10
- font-size: var(--dh-size-m);
11
- font-weight: 500;
12
- line-height: 1.5;
13
- border-radius: 0;
14
- border-bottom: 1px solid var(--dh-bg-3-border);
15
- cursor: pointer;
16
- user-select: none;
17
- transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
18
- }
19
-
20
- .e-4de878b > .holder:last-child
21
- {
22
- border-bottom: none;
23
- }
24
-
25
- .e-4de878b > .holder:focus-visible
26
- {
27
- outline: 2px inset var(--dh-brand);
28
- outline-offset: 1px;
29
- }
30
-
31
- .e-4de878b > .holder:hover
32
- {
33
- background: var(--dh-bg-3);
34
- }
35
-
36
- .e-4de878b > .holder[active]
37
- {
38
- background: var(--dh-bg-3);
39
- color: var(--dh-brand);
40
- font-weight: 600;
41
- border-left: 3px solid var(--dh-brand);
42
- padding-left: calc(var(--dh-spacing-m) - 3px);
43
- transform: scale(1.01);
44
- }
45
-
46
- .e-4de878b > .holder[active] > i
47
- {
48
- color: var(--dh-brand);
49
- }
50
-
51
- .e-4de878b > .holder[disabled]
52
- {
53
- opacity: 0.5;
54
- cursor: not-allowed;
55
- pointer-events: none;
56
- }
57
-
58
- .e-4de878b > .holder[level="1"]
59
- {
60
- padding-left: var(--dh-spacing-l);
61
- }
62
-
63
- .e-4de878b > .holder[level="2"]
64
- {
65
- padding-left: 50px;
66
- }
67
-
68
- .e-4de878b > .holder[level="3"]
69
- {
70
- padding-left: 66px;
71
- }
72
-
73
- .e-4de878b > .holder[level="4"]
74
- {
75
- padding-left: 82px;
76
- }
77
-
78
- .e-4de878b > .holder > .chevron
79
- {
80
- flex-shrink: 0;
81
- font-size: var(--dh-size-s);
82
- color: var(--dh-text-2);
83
- transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
84
- }
85
-
86
- .e-4de878b > .holder[expanded] > .chevron
87
- {
88
- transform: rotate(90deg);
89
- }
90
-
91
- .e-4de878b > .holder > i
92
- {
93
- flex-shrink: 0;
94
- width: 20px;
95
- height: 20px;
96
- font-size: 20px;
97
- color: var(--dh-text-2);
98
- transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
99
- display: flex;
100
- align-items: center;
101
- justify-content: center;
102
- }
103
-
104
- .e-4de878b > .holder:hover > i
105
- {
106
- color: var(--dh-text-1);
107
- }
108
-
109
- .e-4de878b > .holder > span
110
- {
111
- flex: 1;
112
- min-width: 0;
113
- white-space: nowrap;
114
- overflow: hidden;
115
- text-overflow: ellipsis;
116
- }
@@ -1,27 +0,0 @@
1
- .e-4de878b > .holder[variant*="size-s"]
2
- {
3
- min-height: 24px;
4
- padding: 2px var(--dh-spacing-x);
5
- font-size: var(--dh-size-s);
6
- }
7
-
8
- .e-4de878b > .holder[variant*="size-s"] > i
9
- {
10
- font-size: var(--dh-size-s);
11
- }
12
-
13
- .e-4de878b > .holder[variant*="size-m"]
14
- {
15
- min-height: 36px;
16
- }
17
-
18
- .e-4de878b > .holder[variant*="size-l"]
19
- {
20
- min-height: 38px;
21
- font-size: var(--dh-size-l);
22
- }
23
-
24
- .e-4de878b > .holder[variant*="size-l"] > i
25
- {
26
- font-size: var(--dh-size-l);
27
- }
@@ -1,99 +0,0 @@
1
- .e-4de878b > .holder[variant*="bg-1"]
2
- {
3
- background: var(--dh-bg-1);
4
- }
5
-
6
- .e-4de878b > .holder[variant*="bg-1"]:hover
7
- {
8
- background: var(--dh-bg-1-hover);
9
- }
10
-
11
- .e-4de878b > .holder[variant*="bg-2"]
12
- {
13
- background: var(--dh-bg-2);
14
- }
15
-
16
- .e-4de878b > .holder[variant*="bg-2"]:hover
17
- {
18
- background: var(--dh-bg-2-hover);
19
- }
20
-
21
- .e-4de878b > .holder[variant*="bg-3"]
22
- {
23
- background: var(--dh-bg-3);
24
- }
25
-
26
- .e-4de878b > .holder[variant*="bg-3"]:hover
27
- {
28
- background: var(--dh-bg-3-hover);
29
- }
30
-
31
- .e-4de878b > .holder[variant*="bg-4"]
32
- {
33
- background: var(--dh-bg-4);
34
- }
35
-
36
- .e-4de878b > .holder[variant*="bg-4"]:hover
37
- {
38
- background: var(--dh-bg-4-hover);
39
- }
40
-
41
- .e-4de878b > .holder[variant*="border"]
42
- {
43
- border: 1px solid var(--dh-bg-3-border);
44
- }
45
-
46
- .e-4de878b > .holder[variant*="brand"]
47
- {
48
- background: var(--dh-brand-opacity);
49
- color: var(--dh-brand);
50
- }
51
-
52
- .e-4de878b > .holder[variant*="brand"] > i
53
- {
54
- color: var(--dh-brand);
55
- }
56
-
57
- .e-4de878b > .holder[variant*="blue"]
58
- {
59
- background: var(--dh-blue-opacity);
60
- color: var(--dh-blue);
61
- }
62
-
63
- .e-4de878b > .holder[variant*="blue"] > i
64
- {
65
- color: var(--dh-blue);
66
- }
67
-
68
- .e-4de878b > .holder[variant*="red"]
69
- {
70
- background: var(--dh-red-opacity);
71
- color: var(--dh-red);
72
- }
73
-
74
- .e-4de878b > .holder[variant*="red"] > i
75
- {
76
- color: var(--dh-red);
77
- }
78
-
79
- .e-4de878b > .holder[variant*="orange"]
80
- {
81
- background: var(--dh-orange-opacity);
82
- color: var(--dh-orange);
83
- }
84
-
85
- .e-4de878b > .holder[variant*="orange"] > i
86
- {
87
- color: var(--dh-orange);
88
- }
89
-
90
- .e-4de878b > .holder[variant*="green"]
91
- {
92
- background: var(--dh-green-opacity);
93
- color: var(--dh-green);
94
- }
95
-
96
- .e-4de878b > .holder[variant*="green"] > i
97
- {
98
- color: var(--dh-green);
99
- }
@@ -1,199 +0,0 @@
1
- .e-21305e3c > .holder
2
- {
3
- display: inline-flex;
4
- align-items: center;
5
- justify-content: center;
6
- gap: var(--dh-spacing-x);
7
- padding: var(--dh-spacing-x) var(--dh-spacing-s);
8
- border-radius: var(--dh-radius-s);
9
- border: 1px solid;
10
- font-weight: 500;
11
- font-size: var(--dh-size-s);
12
- transition: all 0.2s;
13
- cursor: pointer;
14
- background: transparent;
15
- border-color: transparent;
16
- color: var(--dh-text-1);
17
- }
18
-
19
- .e-21305e3c > .holder:hover
20
- {
21
- background: var(--dh-bg-2);
22
- }
23
-
24
- .e-21305e3c > .holder i
25
- {
26
- font-size: 14px;
27
- }
28
-
29
- .e-21305e3c > .holder > .text
30
- {
31
- line-height: 1;
32
- }
33
-
34
- /* Variants - Background */
35
- .e-21305e3c > .holder[variant*="transparent"]
36
- {
37
- background: transparent;
38
- border-color: transparent;
39
- color: var(--dh-text-1);
40
- }
41
-
42
- .e-21305e3c > .holder[variant*="transparent"]:hover
43
- {
44
- background: var(--dh-bg-2);
45
- }
46
-
47
- .e-21305e3c > .holder[variant*="border"]
48
- {
49
- background: transparent;
50
- border-color: var(--dh-bg-1-border);
51
- color: var(--dh-text-1);
52
- }
53
-
54
- .e-21305e3c > .holder[variant*="border"]:hover
55
- {
56
- background: var(--dh-bg-2);
57
- border-color: var(--dh-bg-2-border);
58
- }
59
-
60
- .e-21305e3c > .holder[variant*="bg-1"]
61
- {
62
- background: var(--dh-bg-1);
63
- border-color: var(--dh-bg-1-border);
64
- color: var(--dh-text-1);
65
- }
66
-
67
- .e-21305e3c > .holder[variant*="bg-1"]:hover
68
- {
69
- background: var(--dh-bg-1-hover);
70
- }
71
-
72
- .e-21305e3c > .holder[variant*="bg-2"]
73
- {
74
- background: var(--dh-bg-2);
75
- border-color: var(--dh-bg-2-border);
76
- color: var(--dh-text-1);
77
- }
78
-
79
- .e-21305e3c > .holder[variant*="bg-2"]:hover
80
- {
81
- background: var(--dh-bg-2-hover);
82
- }
83
-
84
- .e-21305e3c > .holder[variant*="bg-3"]
85
- {
86
- background: var(--dh-bg-3);
87
- border-color: var(--dh-bg-3-border);
88
- color: var(--dh-text-1);
89
- }
90
-
91
- .e-21305e3c > .holder[variant*="bg-3"]:hover
92
- {
93
- background: var(--dh-bg-3-hover);
94
- }
95
-
96
- .e-21305e3c > .holder[variant*="bg-4"]
97
- {
98
- background: var(--dh-bg-4);
99
- border-color: var(--dh-bg-4-border);
100
- color: var(--dh-text-1);
101
- }
102
-
103
- .e-21305e3c > .holder[variant*="bg-4"]:hover
104
- {
105
- background: var(--dh-bg-4-hover);
106
- }
107
-
108
- .e-21305e3c > .holder[variant*="brand"]
109
- {
110
- background: var(--dh-brand);
111
- border-color: var(--dh-brand-border);
112
- color: white;
113
- }
114
-
115
- .e-21305e3c > .holder[variant*="brand"]:hover
116
- {
117
- background: var(--dh-brand-hover);
118
- }
119
-
120
- .e-21305e3c > .holder[variant*="blue"]
121
- {
122
- background: var(--dh-blue);
123
- border-color: var(--dh-blue-border);
124
- color: white;
125
- }
126
-
127
- .e-21305e3c > .holder[variant*="blue"]:hover
128
- {
129
- background: var(--dh-blue-hover);
130
- }
131
-
132
- .e-21305e3c > .holder[variant*="red"]
133
- {
134
- background: var(--dh-red);
135
- border-color: var(--dh-red-border);
136
- color: white;
137
- }
138
-
139
- .e-21305e3c > .holder[variant*="red"]:hover
140
- {
141
- background: var(--dh-red-hover);
142
- }
143
-
144
- .e-21305e3c > .holder[variant*="orange"]
145
- {
146
- background: var(--dh-orange);
147
- border-color: var(--dh-orange-border);
148
- color: white;
149
- }
150
-
151
- .e-21305e3c > .holder[variant*="orange"]:hover
152
- {
153
- background: var(--dh-orange-hover);
154
- }
155
-
156
- .e-21305e3c > .holder[variant*="green"]
157
- {
158
- background: var(--dh-green);
159
- border-color: var(--dh-green-border);
160
- color: white;
161
- }
162
-
163
- .e-21305e3c > .holder[variant*="green"]:hover
164
- {
165
- background: var(--dh-green-hover);
166
- }
167
-
168
- .e-21305e3c > .holder[variant*="size-s"]
169
- {
170
- padding: 2px var(--dh-spacing-x);
171
- font-size: 11px;
172
- }
173
-
174
- .e-21305e3c > .holder[variant*="size-s"] i
175
- {
176
- font-size: 12px;
177
- }
178
-
179
- .e-21305e3c > .holder[variant*="size-m"]
180
- {
181
- padding: var(--dh-spacing-x) var(--dh-spacing-s);
182
- font-size: var(--dh-size-s);
183
- }
184
-
185
- .e-21305e3c > .holder[variant*="size-m"] i
186
- {
187
- font-size: 14px;
188
- }
189
-
190
- .e-21305e3c > .holder[variant*="size-l"]
191
- {
192
- padding: var(--dh-spacing-s) var(--dh-spacing-m);
193
- font-size: var(--dh-size-m);
194
- }
195
-
196
- .e-21305e3c > .holder[variant*="size-l"] i
197
- {
198
- font-size: 16px;
199
- }
@@ -1,37 +0,0 @@
1
- import elements from '#elements/load.js';
2
-
3
- elements.ItemAdd({
4
- id: 'tag',
5
- icon: 'label',
6
- name: 'Tag',
7
- description: 'Label/badge component with icon, color variants, sizes, and click handler support.',
8
- category: 'Base',
9
- author: 'Divhunt',
10
- config: {
11
- icon: {
12
- type: 'string',
13
- value: ''
14
- },
15
- text: {
16
- type: 'string',
17
- value: 'Tag'
18
- },
19
- variant: {
20
- type: 'array',
21
- value: ['bg-3', 'size-m'],
22
- options: ['transparent', 'border', 'bg-1', 'bg-2', 'bg-3', 'bg-4', 'brand', 'blue', 'red', 'orange', 'green', 'size-s', 'size-m', 'size-l']
23
- },
24
- onClick: {
25
- type: 'function'
26
- }
27
- },
28
- render: function()
29
- {
30
- return `
31
- <div class="holder" :variant="variant.join(' ')" dh-click="onClick">
32
- <i dh-if="icon">{{ icon }}</i>
33
- <span class="text">{{ text }}</span>
34
- </div>
35
- `;
36
- }
37
- });