divhunt 2.0.5 → 2.0.9

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 (159) hide show
  1. package/addons/core/commands/back/functions/expose.js +14 -0
  2. package/addons/core/commands/back/functions/find.js +1 -1
  3. package/addons/core/commands/back/functions/grpc/client.js +1 -1
  4. package/addons/core/commands/back/functions/grpc/server.js +1 -1
  5. package/addons/core/commands/back/functions/hide.js +14 -0
  6. package/addons/core/commands/back/functions/http/server.js +1 -1
  7. package/addons/core/commands/back/items/{many.js → self/many.js} +2 -4
  8. package/addons/core/commands/back/items/{one.js → self/one.js} +2 -4
  9. package/addons/core/commands/back/items/{run.js → self/run.js} +3 -7
  10. package/addons/core/commands/core/functions/run.js +13 -0
  11. package/addons/core/commands/{back → core}/item/functions/run.js +1 -1
  12. package/addons/core/commands/core/load.js +25 -0
  13. package/addons/core/commands/front/directives/run.js +84 -0
  14. package/addons/core/commands/front/directives/submit.js +150 -0
  15. package/addons/core/commands/front/functions/api.js +30 -0
  16. package/addons/render/assets/back/functions/import.js +1 -1
  17. package/examples/basic-front/back/assets.js +11 -0
  18. package/examples/basic-front/back/index.js +13 -0
  19. package/examples/basic-front/back/items/commands/html.js +14 -0
  20. package/examples/basic-front/back/items/commands/test.js +19 -0
  21. package/examples/basic-front/back/items/html/fonts.js +12 -0
  22. package/examples/basic-front/front/pages/home.js +16 -0
  23. package/examples/basic-front/front/styles/main.css +31 -0
  24. package/examples/basic-front/front/test.js +7 -0
  25. package/examples/basic-front/package.json +7 -0
  26. package/lib/src/divhunt.js +2 -0
  27. package/lib/src/mixins/form.js +67 -0
  28. package/package.json +3 -3
  29. package/test/front/test.js +31 -0
  30. package/test.js +52 -0
  31. package/addons/core/commands/LICENSE.txt +0 -40
  32. package/addons/core/commands/README.md +0 -294
  33. package/addons/core/commands/back/load.js +0 -18
  34. package/addons/core/commands/front/#register/addon.js +0 -9
  35. package/addons/core/commands/front/functions/find.js +0 -22
  36. package/addons/core/commands/front/item/functions/run.js +0 -96
  37. package/addons/core/commands/front/items/elements/table/table.css +0 -18
  38. package/addons/core/commands/front/items/elements/table/table.js +0 -254
  39. package/addons/render/elements/front/items/self/base/menu/menu.js +0 -96
  40. package/addons/render/elements/front/items/self/base/menu/styles/base.css +0 -116
  41. package/addons/render/elements/front/items/self/base/menu/styles/sizes.css +0 -27
  42. package/addons/render/elements/front/items/self/base/menu/styles/variants.css +0 -99
  43. package/addons/render/elements/front/items/self/base/tag/tag.css +0 -199
  44. package/addons/render/elements/front/items/self/base/tag/tag.js +0 -37
  45. package/addons/render/elements/front/items/self/cards/basic/basic.js +0 -89
  46. package/addons/render/elements/front/items/self/cards/basic/styles/base.css +0 -66
  47. package/addons/render/elements/front/items/self/cards/basic/styles/sizes.css +0 -32
  48. package/addons/render/elements/front/items/self/cards/basic/styles/variants.css +0 -99
  49. package/addons/render/elements/front/items/self/cards/list/list.js +0 -108
  50. package/addons/render/elements/front/items/self/cards/list/styles/base.css +0 -96
  51. package/addons/render/elements/front/items/self/cards/list/styles/sizes.css +0 -32
  52. package/addons/render/elements/front/items/self/cards/list/styles/variants.css +0 -99
  53. package/addons/render/elements/front/items/self/cards/media/media.js +0 -116
  54. package/addons/render/elements/front/items/self/cards/media/styles/base.css +0 -126
  55. package/addons/render/elements/front/items/self/cards/media/styles/sizes.css +0 -49
  56. package/addons/render/elements/front/items/self/cards/media/styles/variants.css +0 -74
  57. package/addons/render/elements/front/items/self/cards/profile/profile.js +0 -95
  58. package/addons/render/elements/front/items/self/cards/profile/styles/base.css +0 -142
  59. package/addons/render/elements/front/items/self/cards/profile/styles/sizes.css +0 -43
  60. package/addons/render/elements/front/items/self/cards/profile/styles/variants.css +0 -131
  61. package/addons/render/elements/front/items/self/cards/stat/stat.js +0 -117
  62. package/addons/render/elements/front/items/self/cards/stat/styles/base.css +0 -97
  63. package/addons/render/elements/front/items/self/cards/stat/styles/sizes.css +0 -49
  64. package/addons/render/elements/front/items/self/cards/stat/styles/variants.css +0 -124
  65. package/addons/render/elements/front/items/self/content/html/html.css +0 -93
  66. package/addons/render/elements/front/items/self/content/html/html.js +0 -40
  67. package/addons/render/elements/front/items/self/content/markdown/markdown.css +0 -200
  68. package/addons/render/elements/front/items/self/content/markdown/markdown.js +0 -120
  69. package/addons/render/elements/front/items/self/data/comments/comments.css +0 -253
  70. package/addons/render/elements/front/items/self/data/comments/comments.js +0 -134
  71. package/addons/render/elements/front/items/self/data/files/files.css +0 -116
  72. package/addons/render/elements/front/items/self/data/files/files.js +0 -85
  73. package/addons/render/elements/front/items/self/data/folders/folders.css +0 -104
  74. package/addons/render/elements/front/items/self/data/folders/folders.js +0 -73
  75. package/addons/render/elements/front/items/self/data/inbox/inbox.css +0 -225
  76. package/addons/render/elements/front/items/self/data/inbox/inbox.js +0 -111
  77. package/addons/render/elements/front/items/self/data/logs/logs.css +0 -133
  78. package/addons/render/elements/front/items/self/data/logs/logs.js +0 -65
  79. package/addons/render/elements/front/items/self/data/plans/plans.css +0 -231
  80. package/addons/render/elements/front/items/self/data/plans/plans.js +0 -104
  81. package/addons/render/elements/front/items/self/data/properties/properties.css +0 -108
  82. package/addons/render/elements/front/items/self/data/properties/properties.js +0 -156
  83. package/addons/render/elements/front/items/self/data/table/table.css +0 -153
  84. package/addons/render/elements/front/items/self/data/table/table.js +0 -106
  85. package/addons/render/elements/front/items/self/data/timeline/timeline.css +0 -127
  86. package/addons/render/elements/front/items/self/data/timeline/timeline.js +0 -57
  87. package/addons/render/elements/front/items/self/feedback/alert/alert.css +0 -258
  88. package/addons/render/elements/front/items/self/feedback/alert/alert.js +0 -67
  89. package/addons/render/elements/front/items/self/feedback/confirm/confirm.css +0 -229
  90. package/addons/render/elements/front/items/self/feedback/confirm/confirm.js +0 -81
  91. package/addons/render/elements/front/items/self/feedback/loader/loader.css +0 -203
  92. package/addons/render/elements/front/items/self/feedback/loader/loader.js +0 -25
  93. package/addons/render/elements/front/items/self/feedback/progress/progress.css +0 -136
  94. package/addons/render/elements/front/items/self/feedback/progress/progress.js +0 -40
  95. package/addons/render/elements/front/items/self/form/button/button.js +0 -105
  96. package/addons/render/elements/front/items/self/form/button/styles/base.css +0 -176
  97. package/addons/render/elements/front/items/self/form/button/styles/sizes.css +0 -78
  98. package/addons/render/elements/front/items/self/form/button/styles/variants.css +0 -421
  99. package/addons/render/elements/front/items/self/form/checkbox/checkbox.js +0 -57
  100. package/addons/render/elements/front/items/self/form/checkbox/styles/base.css +0 -52
  101. package/addons/render/elements/front/items/self/form/checkbox/styles/sizes.css +0 -39
  102. package/addons/render/elements/front/items/self/form/checkbox/styles/variants.css +0 -121
  103. package/addons/render/elements/front/items/self/form/field/field.css +0 -96
  104. package/addons/render/elements/front/items/self/form/field/field.js +0 -39
  105. package/addons/render/elements/front/items/self/form/input/input.css +0 -111
  106. package/addons/render/elements/front/items/self/form/input/input.js +0 -78
  107. package/addons/render/elements/front/items/self/form/input/styles/base.css +0 -26
  108. package/addons/render/elements/front/items/self/form/input/styles/sizes.css +0 -15
  109. package/addons/render/elements/front/items/self/form/input/styles/variants.css +0 -98
  110. package/addons/render/elements/front/items/self/form/radio/radio.js +0 -57
  111. package/addons/render/elements/front/items/self/form/radio/styles/base.css +0 -48
  112. package/addons/render/elements/front/items/self/form/radio/styles/sizes.css +0 -36
  113. package/addons/render/elements/front/items/self/form/radio/styles/variants.css +0 -121
  114. package/addons/render/elements/front/items/self/form/rating/rating.css +0 -95
  115. package/addons/render/elements/front/items/self/form/rating/rating.js +0 -88
  116. package/addons/render/elements/front/items/self/form/section/section.css +0 -107
  117. package/addons/render/elements/front/items/self/form/section/section.js +0 -39
  118. package/addons/render/elements/front/items/self/form/slider/slider.css +0 -244
  119. package/addons/render/elements/front/items/self/form/slider/slider.js +0 -69
  120. package/addons/render/elements/front/items/self/form/textarea/textarea.css +0 -117
  121. package/addons/render/elements/front/items/self/form/textarea/textarea.js +0 -69
  122. package/addons/render/elements/front/items/self/layout/empty/empty.css +0 -154
  123. package/addons/render/elements/front/items/self/layout/empty/empty.js +0 -43
  124. package/addons/render/elements/front/items/self/layout/heading/heading.css +0 -117
  125. package/addons/render/elements/front/items/self/layout/heading/heading.js +0 -47
  126. package/addons/render/elements/front/items/self/layout/hero/hero.js +0 -88
  127. package/addons/render/elements/front/items/self/layout/hero/styles/base.css +0 -81
  128. package/addons/render/elements/front/items/self/layout/hero/styles/sizes.css +0 -24
  129. package/addons/render/elements/front/items/self/layout/hero/styles/variants.css +0 -98
  130. package/addons/render/elements/front/items/self/navigation/breadcrumb/addon/_class/addon.js +0 -9
  131. package/addons/render/elements/front/items/self/navigation/breadcrumb/addon/functions/get.js +0 -22
  132. package/addons/render/elements/front/items/self/navigation/breadcrumb/breadcrumb.css +0 -13
  133. package/addons/render/elements/front/items/self/navigation/breadcrumb/breadcrumb.js +0 -51
  134. package/addons/render/elements/front/items/self/navigation/footer/addon/_class/addon.js +0 -11
  135. package/addons/render/elements/front/items/self/navigation/footer/addon/functions/columns.js +0 -11
  136. package/addons/render/elements/front/items/self/navigation/footer/addon/functions/get.js +0 -34
  137. package/addons/render/elements/front/items/self/navigation/footer/footer.css +0 -283
  138. package/addons/render/elements/front/items/self/navigation/footer/footer.js +0 -139
  139. package/addons/render/elements/front/items/self/navigation/navbar/addon/_class/addon.js +0 -13
  140. package/addons/render/elements/front/items/self/navigation/navbar/addon/functions/active.js +0 -7
  141. package/addons/render/elements/front/items/self/navigation/navbar/addon/functions/get.js +0 -31
  142. package/addons/render/elements/front/items/self/navigation/navbar/navbar.css +0 -140
  143. package/addons/render/elements/front/items/self/navigation/navbar/navbar.js +0 -118
  144. package/addons/render/elements/front/items/self/navigation/pagination/pagination.css +0 -160
  145. package/addons/render/elements/front/items/self/navigation/pagination/pagination.js +0 -131
  146. package/addons/render/elements/front/items/self/navigation/sidebar/addon/_class/addon.js +0 -12
  147. package/addons/render/elements/front/items/self/navigation/sidebar/addon/functions/active.js +0 -7
  148. package/addons/render/elements/front/items/self/navigation/sidebar/addon/functions/get.js +0 -35
  149. package/addons/render/elements/front/items/self/navigation/sidebar/addon/functions/groups.js +0 -10
  150. package/addons/render/elements/front/items/self/navigation/sidebar/sidebar.css +0 -278
  151. package/addons/render/elements/front/items/self/navigation/sidebar/sidebar.js +0 -85
  152. package/addons/render/elements/front/items/self/navigation/stepper/stepper.css +0 -202
  153. package/addons/render/elements/front/items/self/navigation/stepper/stepper.js +0 -82
  154. package/addons/render/elements/front/items/self/navigation/tabs/addon.js +0 -32
  155. package/addons/render/elements/front/items/self/navigation/tabs/tabs.css +0 -239
  156. package/addons/render/elements/front/items/self/navigation/tabs/tabs.js +0 -76
  157. package/addons/render/elements/front/items/self/preview/html/html.css +0 -377
  158. package/addons/render/elements/front/items/self/preview/html/html.js +0 -107
  159. /package/addons/core/commands/{back → core}/addon.js +0 -0
@@ -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
- });
@@ -1,89 +0,0 @@
1
- import elements from '#elements/load.js';
2
-
3
- elements.ItemAdd({
4
- id: 'card-basic',
5
- icon: 'crop_square',
6
- name: 'Card Basic',
7
- description: 'Base card with icon, title, description, badge, and action buttons.',
8
- category: 'Cards',
9
- author: 'Divhunt',
10
- config: {
11
- icon: {
12
- type: 'string',
13
- value: 'folder'
14
- },
15
- title: {
16
- type: 'string',
17
- value: 'Project Alpha'
18
- },
19
- description: {
20
- type: 'string',
21
- value: 'A comprehensive project management solution for modern teams.'
22
- },
23
- badge: {
24
- type: 'string',
25
- value: 'Active'
26
- },
27
- actions: {
28
- type: 'array',
29
- value: [
30
- { text: 'Edit', icon: 'edit', variant: ['border', 'size-s'] },
31
- { text: 'Delete', icon: 'delete', variant: ['border', 'size-s'] }
32
- ],
33
- each: {
34
- type: 'object',
35
- config: {
36
- text: { type: 'string', value: '' },
37
- icon: { type: 'string', value: '' },
38
- variant: { type: 'array', value: ['border', 'size-s'] }
39
- }
40
- }
41
- },
42
- variant: {
43
- type: 'array',
44
- value: ['bg-2', 'border', 'size-m'],
45
- options: ['border', 'bg-1', 'bg-2', 'bg-3', 'bg-4', 'brand', 'blue', 'red', 'orange', 'green', 'size-s', 'size-m', 'size-l']
46
- },
47
- onClick: {
48
- type: 'function'
49
- },
50
- onAction: {
51
- type: 'function'
52
- }
53
- },
54
- render: function()
55
- {
56
- this.handleClick = () =>
57
- {
58
- if (this.onClick)
59
- {
60
- this.onClick();
61
- }
62
- };
63
-
64
- this.handleAction = (action, index) =>
65
- {
66
- if (this.onAction)
67
- {
68
- this.onAction({ action, index });
69
- }
70
- };
71
-
72
- return `
73
- <div class="holder" :variant="variant.join(' ')" dh-click="handleClick">
74
- <div class="header">
75
- <i dh-if="icon">{{ icon }}</i>
76
- <e-tag dh-if="badge" :text="badge" :variant="['bg-3', 'size-s']"></e-tag>
77
- </div>
78
- <div class="content">
79
- <h3 dh-if="title">{{ title }}</h3>
80
- <p dh-if="description">{{ description }}</p>
81
- </div>
82
- <div dh-if="actions.length" class="actions">
83
- <e-button dh-for="action, index in actions" :text="action.text" :icon="action.icon" :variant="action.variant" :onClick="() => handleAction(action, index)"></e-button>
84
- </div>
85
- <slot name="footer"></slot>
86
- </div>
87
- `;
88
- }
89
- });
@@ -1,66 +0,0 @@
1
- .e-a0811c7 > .holder
2
- {
3
- display: flex;
4
- flex-direction: column;
5
- border-radius: var(--dh-radius-m);
6
- overflow: hidden;
7
- transition: all 0.2s;
8
- height: 100%;
9
- }
10
-
11
- .e-a0811c7 > .holder:hover
12
- {
13
- transform: translateY(-2px);
14
- }
15
-
16
- .e-a0811c7 > .holder > .header
17
- {
18
- display: flex;
19
- align-items: center;
20
- gap: var(--dh-spacing-s);
21
- }
22
-
23
- .e-a0811c7 > .holder > .header > i
24
- {
25
- font-size: var(--dh-size-l);
26
- color: var(--dh-text-2);
27
- transition: all 0.2s;
28
- }
29
-
30
- .e-a0811c7 > .holder:hover > .header > i
31
- {
32
- color: var(--dh-text-1);
33
- }
34
-
35
- .e-a0811c7 > .holder > .content
36
- {
37
- display: flex;
38
- flex-direction: column;
39
- gap: var(--dh-spacing-x);
40
- }
41
-
42
- .e-a0811c7 > .holder > .content > h3
43
- {
44
- font-size: var(--dh-size-m);
45
- font-weight: 600;
46
- color: var(--dh-text-1);
47
- margin: 0;
48
- }
49
-
50
- .e-a0811c7 > .holder > .content > p
51
- {
52
- font-size: var(--dh-size-s);
53
- color: var(--dh-text-2);
54
- margin: 0;
55
- line-height: 1.5;
56
- }
57
-
58
- .e-a0811c7 > .holder > .actions
59
- {
60
- display: flex;
61
- align-items: center;
62
- gap: var(--dh-spacing-s);
63
- margin-top: auto;
64
- padding-top: var(--dh-spacing-s);
65
- border-top: 1px solid var(--dh-bg-3-border);
66
- }
@@ -1,32 +0,0 @@
1
- .e-a0811c7 > .holder[variant*="size-s"]
2
- {
3
- padding: var(--dh-spacing-s);
4
- gap: var(--dh-spacing-s);
5
- }
6
-
7
- .e-a0811c7 > .holder[variant*="size-s"] > .header > i
8
- {
9
- font-size: var(--dh-size-m);
10
- }
11
-
12
- .e-a0811c7 > .holder[variant*="size-m"]
13
- {
14
- padding: var(--dh-spacing-m);
15
- gap: var(--dh-spacing-m);
16
- }
17
-
18
- .e-a0811c7 > .holder[variant*="size-l"]
19
- {
20
- padding: var(--dh-spacing-l);
21
- gap: var(--dh-spacing-l);
22
- }
23
-
24
- .e-a0811c7 > .holder[variant*="size-l"] > .header > i
25
- {
26
- font-size: 28px;
27
- }
28
-
29
- .e-a0811c7 > .holder[variant*="size-l"] > .content > h3
30
- {
31
- font-size: var(--dh-size-l);
32
- }
@@ -1,99 +0,0 @@
1
- .e-a0811c7 > .holder[variant*="bg-1"]
2
- {
3
- background: var(--dh-bg-1);
4
- }
5
-
6
- .e-a0811c7 > .holder[variant*="bg-2"]
7
- {
8
- background: var(--dh-bg-2);
9
- }
10
-
11
- .e-a0811c7 > .holder[variant*="bg-3"]
12
- {
13
- background: var(--dh-bg-3);
14
- }
15
-
16
- .e-a0811c7 > .holder[variant*="bg-4"]
17
- {
18
- background: var(--dh-bg-4);
19
- }
20
-
21
- .e-a0811c7 > .holder[variant*="bg-1"]:hover
22
- {
23
- background: var(--dh-bg-1-hover);
24
- }
25
-
26
- .e-a0811c7 > .holder[variant*="bg-2"]:hover
27
- {
28
- background: var(--dh-bg-2-hover);
29
- }
30
-
31
- .e-a0811c7 > .holder[variant*="bg-3"]:hover
32
- {
33
- background: var(--dh-bg-3-hover);
34
- }
35
-
36
- .e-a0811c7 > .holder[variant*="bg-4"]:hover
37
- {
38
- background: var(--dh-bg-4-hover);
39
- }
40
-
41
- .e-a0811c7 > .holder[variant*="border"]
42
- {
43
- border: 1px solid var(--dh-bg-3-border);
44
- }
45
-
46
- .e-a0811c7 > .holder[variant*="brand"]
47
- {
48
- border-color: var(--dh-brand-border);
49
- background: var(--dh-brand-opacity);
50
- }
51
-
52
- .e-a0811c7 > .holder[variant*="brand"] > .header > i
53
- {
54
- color: var(--dh-brand);
55
- }
56
-
57
- .e-a0811c7 > .holder[variant*="blue"]
58
- {
59
- border-color: var(--dh-blue-border);
60
- background: var(--dh-blue-opacity);
61
- }
62
-
63
- .e-a0811c7 > .holder[variant*="blue"] > .header > i
64
- {
65
- color: var(--dh-blue);
66
- }
67
-
68
- .e-a0811c7 > .holder[variant*="red"]
69
- {
70
- border-color: var(--dh-red-border);
71
- background: var(--dh-red-opacity);
72
- }
73
-
74
- .e-a0811c7 > .holder[variant*="red"] > .header > i
75
- {
76
- color: var(--dh-red);
77
- }
78
-
79
- .e-a0811c7 > .holder[variant*="orange"]
80
- {
81
- border-color: var(--dh-orange-border);
82
- background: var(--dh-orange-opacity);
83
- }
84
-
85
- .e-a0811c7 > .holder[variant*="orange"] > .header > i
86
- {
87
- color: var(--dh-orange);
88
- }
89
-
90
- .e-a0811c7 > .holder[variant*="green"]
91
- {
92
- border-color: var(--dh-green-border);
93
- background: var(--dh-green-opacity);
94
- }
95
-
96
- .e-a0811c7 > .holder[variant*="green"] > .header > i
97
- {
98
- color: var(--dh-green);
99
- }
@@ -1,108 +0,0 @@
1
- import elements from '#elements/load.js';
2
-
3
- elements.ItemAdd({
4
- id: 'card-list',
5
- icon: 'list',
6
- name: 'Card List',
7
- description: 'List item card with icon, title, description, meta info, badge, status, and checkbox.',
8
- category: 'Cards',
9
- author: 'Divhunt',
10
- config: {
11
- icon: {
12
- type: 'string',
13
- value: 'description'
14
- },
15
- title: {
16
- type: 'string',
17
- value: 'Project Requirements.pdf'
18
- },
19
- description: {
20
- type: 'string',
21
- value: 'Technical specification document for Q1 release'
22
- },
23
- badge: {
24
- type: 'string',
25
- value: 'New'
26
- },
27
- status: {
28
- type: 'string',
29
- value: 'success',
30
- options: ['', 'success', 'warning', 'error', 'info']
31
- },
32
- meta: {
33
- type: 'array',
34
- value: [
35
- { label: '2.4 MB', icon: '' },
36
- { label: 'Modified 2h ago', icon: 'schedule' }
37
- ],
38
- each: {
39
- type: 'object',
40
- config: {
41
- label: { type: 'string', value: '' },
42
- icon: { type: 'string', value: '' }
43
- }
44
- }
45
- },
46
- checkbox: {
47
- type: 'boolean',
48
- value: false
49
- },
50
- checked: {
51
- type: 'boolean',
52
- value: false
53
- },
54
- variant: {
55
- type: 'array',
56
- value: ['bg-2', 'border', 'size-m'],
57
- options: ['border', 'bg-1', 'bg-2', 'bg-3', 'bg-4', 'brand', 'blue', 'red', 'orange', 'green', 'size-s', 'size-m', 'size-l']
58
- },
59
- onClick: {
60
- type: 'function'
61
- },
62
- onCheck: {
63
- type: 'function'
64
- }
65
- },
66
- render: function()
67
- {
68
- this.handleClick = () =>
69
- {
70
- if (this.onClick)
71
- {
72
- this.onClick();
73
- }
74
- };
75
-
76
- this.handleCheck = (e) =>
77
- {
78
- e.stopPropagation();
79
- this.checked = !this.checked;
80
-
81
- if (this.onCheck)
82
- {
83
- this.onCheck({ checked: this.checked });
84
- }
85
- };
86
-
87
- return `
88
- <div class="holder" :variant="variant.join(' ')" dh-click="handleClick">
89
- <e-checkbox dh-if="checkbox" :checked="checked" :onChange="handleCheck"></e-checkbox>
90
- <i dh-if="icon && !checkbox" :status="status">{{ icon }}</i>
91
- <div class="content">
92
- <div class="header">
93
- <strong>{{ title }}</strong>
94
- <e-tag dh-if="badge" :text="badge" :variant="['brand', 'size-s']"></e-tag>
95
- </div>
96
- <span dh-if="description">{{ description }}</span>
97
- <div dh-if="meta.length" class="meta">
98
- <small dh-for="item in meta">
99
- <i dh-if="item.icon">{{ item.icon }}</i>
100
- {{ item.label }}
101
- </small>
102
- </div>
103
- </div>
104
- <slot name="end"></slot>
105
- </div>
106
- `;
107
- }
108
- });