divhunt 2.0.5 → 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 (121) hide show
  1. package/package.json +1 -1
  2. package/addons/render/elements/front/items/self/base/menu/menu.js +0 -96
  3. package/addons/render/elements/front/items/self/base/menu/styles/base.css +0 -116
  4. package/addons/render/elements/front/items/self/base/menu/styles/sizes.css +0 -27
  5. package/addons/render/elements/front/items/self/base/menu/styles/variants.css +0 -99
  6. package/addons/render/elements/front/items/self/base/tag/tag.css +0 -199
  7. package/addons/render/elements/front/items/self/base/tag/tag.js +0 -37
  8. package/addons/render/elements/front/items/self/cards/basic/basic.js +0 -89
  9. package/addons/render/elements/front/items/self/cards/basic/styles/base.css +0 -66
  10. package/addons/render/elements/front/items/self/cards/basic/styles/sizes.css +0 -32
  11. package/addons/render/elements/front/items/self/cards/basic/styles/variants.css +0 -99
  12. package/addons/render/elements/front/items/self/cards/list/list.js +0 -108
  13. package/addons/render/elements/front/items/self/cards/list/styles/base.css +0 -96
  14. package/addons/render/elements/front/items/self/cards/list/styles/sizes.css +0 -32
  15. package/addons/render/elements/front/items/self/cards/list/styles/variants.css +0 -99
  16. package/addons/render/elements/front/items/self/cards/media/media.js +0 -116
  17. package/addons/render/elements/front/items/self/cards/media/styles/base.css +0 -126
  18. package/addons/render/elements/front/items/self/cards/media/styles/sizes.css +0 -49
  19. package/addons/render/elements/front/items/self/cards/media/styles/variants.css +0 -74
  20. package/addons/render/elements/front/items/self/cards/profile/profile.js +0 -95
  21. package/addons/render/elements/front/items/self/cards/profile/styles/base.css +0 -142
  22. package/addons/render/elements/front/items/self/cards/profile/styles/sizes.css +0 -43
  23. package/addons/render/elements/front/items/self/cards/profile/styles/variants.css +0 -131
  24. package/addons/render/elements/front/items/self/cards/stat/stat.js +0 -117
  25. package/addons/render/elements/front/items/self/cards/stat/styles/base.css +0 -97
  26. package/addons/render/elements/front/items/self/cards/stat/styles/sizes.css +0 -49
  27. package/addons/render/elements/front/items/self/cards/stat/styles/variants.css +0 -124
  28. package/addons/render/elements/front/items/self/content/html/html.css +0 -93
  29. package/addons/render/elements/front/items/self/content/html/html.js +0 -40
  30. package/addons/render/elements/front/items/self/content/markdown/markdown.css +0 -200
  31. package/addons/render/elements/front/items/self/content/markdown/markdown.js +0 -120
  32. package/addons/render/elements/front/items/self/data/comments/comments.css +0 -253
  33. package/addons/render/elements/front/items/self/data/comments/comments.js +0 -134
  34. package/addons/render/elements/front/items/self/data/files/files.css +0 -116
  35. package/addons/render/elements/front/items/self/data/files/files.js +0 -85
  36. package/addons/render/elements/front/items/self/data/folders/folders.css +0 -104
  37. package/addons/render/elements/front/items/self/data/folders/folders.js +0 -73
  38. package/addons/render/elements/front/items/self/data/inbox/inbox.css +0 -225
  39. package/addons/render/elements/front/items/self/data/inbox/inbox.js +0 -111
  40. package/addons/render/elements/front/items/self/data/logs/logs.css +0 -133
  41. package/addons/render/elements/front/items/self/data/logs/logs.js +0 -65
  42. package/addons/render/elements/front/items/self/data/plans/plans.css +0 -231
  43. package/addons/render/elements/front/items/self/data/plans/plans.js +0 -104
  44. package/addons/render/elements/front/items/self/data/properties/properties.css +0 -108
  45. package/addons/render/elements/front/items/self/data/properties/properties.js +0 -156
  46. package/addons/render/elements/front/items/self/data/table/table.css +0 -153
  47. package/addons/render/elements/front/items/self/data/table/table.js +0 -106
  48. package/addons/render/elements/front/items/self/data/timeline/timeline.css +0 -127
  49. package/addons/render/elements/front/items/self/data/timeline/timeline.js +0 -57
  50. package/addons/render/elements/front/items/self/feedback/alert/alert.css +0 -258
  51. package/addons/render/elements/front/items/self/feedback/alert/alert.js +0 -67
  52. package/addons/render/elements/front/items/self/feedback/confirm/confirm.css +0 -229
  53. package/addons/render/elements/front/items/self/feedback/confirm/confirm.js +0 -81
  54. package/addons/render/elements/front/items/self/feedback/loader/loader.css +0 -203
  55. package/addons/render/elements/front/items/self/feedback/loader/loader.js +0 -25
  56. package/addons/render/elements/front/items/self/feedback/progress/progress.css +0 -136
  57. package/addons/render/elements/front/items/self/feedback/progress/progress.js +0 -40
  58. package/addons/render/elements/front/items/self/form/button/button.js +0 -105
  59. package/addons/render/elements/front/items/self/form/button/styles/base.css +0 -176
  60. package/addons/render/elements/front/items/self/form/button/styles/sizes.css +0 -78
  61. package/addons/render/elements/front/items/self/form/button/styles/variants.css +0 -421
  62. package/addons/render/elements/front/items/self/form/checkbox/checkbox.js +0 -57
  63. package/addons/render/elements/front/items/self/form/checkbox/styles/base.css +0 -52
  64. package/addons/render/elements/front/items/self/form/checkbox/styles/sizes.css +0 -39
  65. package/addons/render/elements/front/items/self/form/checkbox/styles/variants.css +0 -121
  66. package/addons/render/elements/front/items/self/form/field/field.css +0 -96
  67. package/addons/render/elements/front/items/self/form/field/field.js +0 -39
  68. package/addons/render/elements/front/items/self/form/input/input.css +0 -111
  69. package/addons/render/elements/front/items/self/form/input/input.js +0 -78
  70. package/addons/render/elements/front/items/self/form/input/styles/base.css +0 -26
  71. package/addons/render/elements/front/items/self/form/input/styles/sizes.css +0 -15
  72. package/addons/render/elements/front/items/self/form/input/styles/variants.css +0 -98
  73. package/addons/render/elements/front/items/self/form/radio/radio.js +0 -57
  74. package/addons/render/elements/front/items/self/form/radio/styles/base.css +0 -48
  75. package/addons/render/elements/front/items/self/form/radio/styles/sizes.css +0 -36
  76. package/addons/render/elements/front/items/self/form/radio/styles/variants.css +0 -121
  77. package/addons/render/elements/front/items/self/form/rating/rating.css +0 -95
  78. package/addons/render/elements/front/items/self/form/rating/rating.js +0 -88
  79. package/addons/render/elements/front/items/self/form/section/section.css +0 -107
  80. package/addons/render/elements/front/items/self/form/section/section.js +0 -39
  81. package/addons/render/elements/front/items/self/form/slider/slider.css +0 -244
  82. package/addons/render/elements/front/items/self/form/slider/slider.js +0 -69
  83. package/addons/render/elements/front/items/self/form/textarea/textarea.css +0 -117
  84. package/addons/render/elements/front/items/self/form/textarea/textarea.js +0 -69
  85. package/addons/render/elements/front/items/self/layout/empty/empty.css +0 -154
  86. package/addons/render/elements/front/items/self/layout/empty/empty.js +0 -43
  87. package/addons/render/elements/front/items/self/layout/heading/heading.css +0 -117
  88. package/addons/render/elements/front/items/self/layout/heading/heading.js +0 -47
  89. package/addons/render/elements/front/items/self/layout/hero/hero.js +0 -88
  90. package/addons/render/elements/front/items/self/layout/hero/styles/base.css +0 -81
  91. package/addons/render/elements/front/items/self/layout/hero/styles/sizes.css +0 -24
  92. package/addons/render/elements/front/items/self/layout/hero/styles/variants.css +0 -98
  93. package/addons/render/elements/front/items/self/navigation/breadcrumb/addon/_class/addon.js +0 -9
  94. package/addons/render/elements/front/items/self/navigation/breadcrumb/addon/functions/get.js +0 -22
  95. package/addons/render/elements/front/items/self/navigation/breadcrumb/breadcrumb.css +0 -13
  96. package/addons/render/elements/front/items/self/navigation/breadcrumb/breadcrumb.js +0 -51
  97. package/addons/render/elements/front/items/self/navigation/footer/addon/_class/addon.js +0 -11
  98. package/addons/render/elements/front/items/self/navigation/footer/addon/functions/columns.js +0 -11
  99. package/addons/render/elements/front/items/self/navigation/footer/addon/functions/get.js +0 -34
  100. package/addons/render/elements/front/items/self/navigation/footer/footer.css +0 -283
  101. package/addons/render/elements/front/items/self/navigation/footer/footer.js +0 -139
  102. package/addons/render/elements/front/items/self/navigation/navbar/addon/_class/addon.js +0 -13
  103. package/addons/render/elements/front/items/self/navigation/navbar/addon/functions/active.js +0 -7
  104. package/addons/render/elements/front/items/self/navigation/navbar/addon/functions/get.js +0 -31
  105. package/addons/render/elements/front/items/self/navigation/navbar/navbar.css +0 -140
  106. package/addons/render/elements/front/items/self/navigation/navbar/navbar.js +0 -118
  107. package/addons/render/elements/front/items/self/navigation/pagination/pagination.css +0 -160
  108. package/addons/render/elements/front/items/self/navigation/pagination/pagination.js +0 -131
  109. package/addons/render/elements/front/items/self/navigation/sidebar/addon/_class/addon.js +0 -12
  110. package/addons/render/elements/front/items/self/navigation/sidebar/addon/functions/active.js +0 -7
  111. package/addons/render/elements/front/items/self/navigation/sidebar/addon/functions/get.js +0 -35
  112. package/addons/render/elements/front/items/self/navigation/sidebar/addon/functions/groups.js +0 -10
  113. package/addons/render/elements/front/items/self/navigation/sidebar/sidebar.css +0 -278
  114. package/addons/render/elements/front/items/self/navigation/sidebar/sidebar.js +0 -85
  115. package/addons/render/elements/front/items/self/navigation/stepper/stepper.css +0 -202
  116. package/addons/render/elements/front/items/self/navigation/stepper/stepper.js +0 -82
  117. package/addons/render/elements/front/items/self/navigation/tabs/addon.js +0 -32
  118. package/addons/render/elements/front/items/self/navigation/tabs/tabs.css +0 -239
  119. package/addons/render/elements/front/items/self/navigation/tabs/tabs.js +0 -76
  120. package/addons/render/elements/front/items/self/preview/html/html.css +0 -377
  121. package/addons/render/elements/front/items/self/preview/html/html.js +0 -107
@@ -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
- });
@@ -1,96 +0,0 @@
1
- .e-523d241b > .holder
2
- {
3
- display: flex;
4
- align-items: center;
5
- border-radius: var(--dh-radius-m);
6
- transition: all 0.2s;
7
- }
8
-
9
- .e-523d241b > .holder:hover
10
- {
11
- transform: translateY(-2px);
12
- }
13
-
14
- .e-523d241b > .holder > i
15
- {
16
- flex-shrink: 0;
17
- font-size: var(--dh-size-l);
18
- color: var(--dh-text-2);
19
- transition: all 0.2s;
20
- }
21
-
22
- .e-523d241b > .holder:hover > i
23
- {
24
- color: var(--dh-text-1);
25
- }
26
-
27
- .e-523d241b > .holder > i[status="success"]
28
- {
29
- color: var(--dh-green);
30
- }
31
-
32
- .e-523d241b > .holder > i[status="warning"]
33
- {
34
- color: var(--dh-orange);
35
- }
36
-
37
- .e-523d241b > .holder > i[status="error"]
38
- {
39
- color: var(--dh-red);
40
- }
41
-
42
- .e-523d241b > .holder > i[status="info"]
43
- {
44
- color: var(--dh-blue);
45
- }
46
-
47
- .e-523d241b > .holder > .content
48
- {
49
- display: flex;
50
- flex-direction: column;
51
- flex: 1;
52
- min-width: 0;
53
- gap: var(--dh-spacing-x);
54
- }
55
-
56
- .e-523d241b > .holder > .content > .header
57
- {
58
- display: flex;
59
- align-items: center;
60
- gap: var(--dh-spacing-s);
61
- }
62
-
63
- .e-523d241b > .holder > .content > .header > strong
64
- {
65
- font-size: var(--dh-size-m);
66
- font-weight: 500;
67
- color: var(--dh-text-1);
68
- }
69
-
70
- .e-523d241b > .holder > .content > span
71
- {
72
- font-size: var(--dh-size-s);
73
- color: var(--dh-text-2);
74
- line-height: 1.4;
75
- }
76
-
77
- .e-523d241b > .holder > .content > .meta
78
- {
79
- display: flex;
80
- align-items: center;
81
- gap: var(--dh-spacing-m);
82
- }
83
-
84
- .e-523d241b > .holder > .content > .meta > small
85
- {
86
- display: flex;
87
- align-items: center;
88
- gap: var(--dh-spacing-x);
89
- font-size: var(--dh-size-s);
90
- color: var(--dh-text-2);
91
- }
92
-
93
- .e-523d241b > .holder > .content > .meta > small > i
94
- {
95
- font-size: var(--dh-size-s);
96
- }
@@ -1,32 +0,0 @@
1
- .e-523d241b > .holder[variant*="size-s"]
2
- {
3
- padding: var(--dh-spacing-s);
4
- gap: var(--dh-spacing-s);
5
- }
6
-
7
- .e-523d241b > .holder[variant*="size-s"] > i
8
- {
9
- font-size: var(--dh-size-m);
10
- }
11
-
12
- .e-523d241b > .holder[variant*="size-m"]
13
- {
14
- padding: var(--dh-spacing-m);
15
- gap: var(--dh-spacing-m);
16
- }
17
-
18
- .e-523d241b > .holder[variant*="size-l"]
19
- {
20
- padding: var(--dh-spacing-l);
21
- gap: var(--dh-spacing-l);
22
- }
23
-
24
- .e-523d241b > .holder[variant*="size-l"] > i
25
- {
26
- font-size: 28px;
27
- }
28
-
29
- .e-523d241b > .holder[variant*="size-l"] > .content > .header > strong
30
- {
31
- font-size: var(--dh-size-l);
32
- }
@@ -1,99 +0,0 @@
1
- .e-523d241b > .holder[variant*="bg-1"]
2
- {
3
- background: var(--dh-bg-1);
4
- }
5
-
6
- .e-523d241b > .holder[variant*="bg-2"]
7
- {
8
- background: var(--dh-bg-2);
9
- }
10
-
11
- .e-523d241b > .holder[variant*="bg-3"]
12
- {
13
- background: var(--dh-bg-3);
14
- }
15
-
16
- .e-523d241b > .holder[variant*="bg-4"]
17
- {
18
- background: var(--dh-bg-4);
19
- }
20
-
21
- .e-523d241b > .holder[variant*="bg-1"]:hover
22
- {
23
- background: var(--dh-bg-1-hover);
24
- }
25
-
26
- .e-523d241b > .holder[variant*="bg-2"]:hover
27
- {
28
- background: var(--dh-bg-2-hover);
29
- }
30
-
31
- .e-523d241b > .holder[variant*="bg-3"]:hover
32
- {
33
- background: var(--dh-bg-3-hover);
34
- }
35
-
36
- .e-523d241b > .holder[variant*="bg-4"]:hover
37
- {
38
- background: var(--dh-bg-4-hover);
39
- }
40
-
41
- .e-523d241b > .holder[variant*="border"]
42
- {
43
- border: 1px solid var(--dh-bg-3-border);
44
- }
45
-
46
- .e-523d241b > .holder[variant*="brand"]
47
- {
48
- border-color: var(--dh-brand-border);
49
- background: var(--dh-brand-opacity);
50
- }
51
-
52
- .e-523d241b > .holder[variant*="brand"] > i
53
- {
54
- color: var(--dh-brand);
55
- }
56
-
57
- .e-523d241b > .holder[variant*="blue"]
58
- {
59
- border-color: var(--dh-blue-border);
60
- background: var(--dh-blue-opacity);
61
- }
62
-
63
- .e-523d241b > .holder[variant*="blue"] > i
64
- {
65
- color: var(--dh-blue);
66
- }
67
-
68
- .e-523d241b > .holder[variant*="red"]
69
- {
70
- border-color: var(--dh-red-border);
71
- background: var(--dh-red-opacity);
72
- }
73
-
74
- .e-523d241b > .holder[variant*="red"] > i
75
- {
76
- color: var(--dh-red);
77
- }
78
-
79
- .e-523d241b > .holder[variant*="orange"]
80
- {
81
- border-color: var(--dh-orange-border);
82
- background: var(--dh-orange-opacity);
83
- }
84
-
85
- .e-523d241b > .holder[variant*="orange"] > i
86
- {
87
- color: var(--dh-orange);
88
- }
89
-
90
- .e-523d241b > .holder[variant*="green"]
91
- {
92
- border-color: var(--dh-green-border);
93
- background: var(--dh-green-opacity);
94
- }
95
-
96
- .e-523d241b > .holder[variant*="green"] > i
97
- {
98
- color: var(--dh-green);
99
- }
@@ -1,116 +0,0 @@
1
- import elements from '#elements/load.js';
2
-
3
- elements.ItemAdd({
4
- id: 'card-media',
5
- icon: 'image',
6
- name: 'Card Media',
7
- description: 'Media card with image, title, description, tags, and author metadata.',
8
- category: 'Cards',
9
- author: 'Divhunt',
10
- config: {
11
- src: {
12
- type: 'string',
13
- value: 'https://placehold.co/600x400'
14
- },
15
- alt: {
16
- type: 'string',
17
- value: 'Featured Image'
18
- },
19
- ratio: {
20
- type: 'string',
21
- value: '16/9',
22
- options: ['1/1', '4/3', '16/9', '21/9']
23
- },
24
- badge: {
25
- type: 'string',
26
- value: 'Featured'
27
- },
28
- title: {
29
- type: 'string',
30
- value: 'Getting Started with Modern Web Development'
31
- },
32
- description: {
33
- type: 'string',
34
- value: 'Learn the fundamentals of building fast, responsive web applications using the latest tools and techniques.'
35
- },
36
- tags: {
37
- type: 'array',
38
- value: ['Development', 'Tutorial', 'Web'],
39
- each: {
40
- type: 'string'
41
- }
42
- },
43
- author: {
44
- type: 'object',
45
- value: {
46
- name: 'Jane Smith',
47
- avatar: ''
48
- },
49
- config: {
50
- name: { type: 'string', value: '' },
51
- avatar: { type: 'string', value: '' }
52
- }
53
- },
54
- date: {
55
- type: 'string',
56
- value: 'Jan 15, 2026'
57
- },
58
- readTime: {
59
- type: 'string',
60
- value: '5 min read'
61
- },
62
- variant: {
63
- type: 'array',
64
- value: ['bg-2', 'border', 'size-m'],
65
- options: ['border', 'bg-1', 'bg-2', 'bg-3', 'bg-4', 'brand', 'blue', 'red', 'orange', 'green', 'size-s', 'size-m', 'size-l']
66
- },
67
- onClick: {
68
- type: 'function'
69
- }
70
- },
71
- render: function()
72
- {
73
- this.handleClick = () =>
74
- {
75
- if (this.onClick)
76
- {
77
- this.onClick();
78
- }
79
- };
80
-
81
- this.getInitials = () =>
82
- {
83
- if (!this.author?.name) return '';
84
- return this.author.name.split(' ').map(n => n[0]).join('').substring(0, 2).toUpperCase();
85
- };
86
-
87
- return `
88
- <div class="holder" :variant="variant.join(' ')" dh-click="handleClick">
89
- <div dh-if="src" class="media" :style="'aspect-ratio: ' + ratio">
90
- <img :src="src" :alt="alt">
91
- <e-tag dh-if="badge" :text="badge" :variant="['bg-2', 'size-s']"></e-tag>
92
- <slot name="overlay"></slot>
93
- </div>
94
- <div class="content">
95
- <div dh-if="tags.length" class="tags">
96
- <e-tag dh-for="tag in tags" :text="tag" :variant="['transparent', 'size-s']"></e-tag>
97
- </div>
98
- <h3 dh-if="title">{{ title }}</h3>
99
- <p dh-if="description">{{ description }}</p>
100
- </div>
101
- <div dh-if="author?.name || date || readTime" class="meta">
102
- <div dh-if="author?.name" class="author">
103
- <div class="avatar">
104
- <img dh-if="author.avatar" :src="author.avatar" :alt="author.name">
105
- <span dh-if="!author.avatar">{{ getInitials() }}</span>
106
- </div>
107
- <span>{{ author.name }}</span>
108
- </div>
109
- <span dh-if="date">{{ date }}</span>
110
- <span dh-if="readTime">{{ readTime }}</span>
111
- </div>
112
- <slot name="footer"></slot>
113
- </div>
114
- `;
115
- }
116
- });