@design.estate/dees-catalog 3.51.0 → 3.51.2
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.
- package/dist_bundle/bundle.js +2374 -2188
- package/dist_ts_web/00_commitinfo_data.js +1 -1
- package/dist_ts_web/elements/00group-chart/dees-chart-area/component.d.ts +10 -0
- package/dist_ts_web/elements/00group-chart/dees-chart-area/component.js +35 -8
- package/dist_ts_web/elements/00group-chart/dees-chart-area/styles.js +41 -24
- package/dist_ts_web/elements/00group-chart/dees-chart-area/template.js +17 -4
- package/dist_ts_web/elements/00group-chart/dees-chart-log/dees-chart-log.d.ts +1 -0
- package/dist_ts_web/elements/00group-chart/dees-chart-log/dees-chart-log.js +16 -24
- package/dist_ts_web/elements/00group-dataview/dees-dataview-codebox/dees-dataview-codebox.d.ts +1 -0
- package/dist_ts_web/elements/00group-dataview/dees-dataview-codebox/dees-dataview-codebox.js +14 -28
- package/dist_ts_web/elements/00group-dataview/dees-dataview-statusobject/dees-dataview-statusobject.d.ts +1 -0
- package/dist_ts_web/elements/00group-dataview/dees-dataview-statusobject/dees-dataview-statusobject.js +52 -51
- package/dist_ts_web/elements/00group-dataview/dees-statsgrid/dees-statsgrid.d.ts +1 -0
- package/dist_ts_web/elements/00group-dataview/dees-statsgrid/dees-statsgrid.js +22 -29
- package/dist_ts_web/elements/00group-dataview/dees-table/dees-table.d.ts +1 -0
- package/dist_ts_web/elements/00group-dataview/dees-table/dees-table.js +6 -6
- package/dist_ts_web/elements/00group-dataview/dees-table/styles.js +51 -44
- package/dist_ts_web/elements/00group-input/dees-input-code/dees-input-code.d.ts +1 -0
- package/dist_ts_web/elements/00group-input/dees-input-code/dees-input-code.js +7 -14
- package/dist_ts_web/elements/00group-input/dees-input-richtext/component.d.ts +1 -0
- package/dist_ts_web/elements/00group-input/dees-input-richtext/component.js +2 -1
- package/dist_ts_web/elements/00group-input/dees-input-richtext/styles.js +12 -20
- package/dist_ts_web/elements/00group-input/dees-input-richtext/template.js +5 -5
- package/dist_ts_web/elements/00group-layout/dees-tile/dees-tile.d.ts +34 -0
- package/dist_ts_web/elements/00group-layout/dees-tile/dees-tile.demo.d.ts +2 -0
- package/dist_ts_web/elements/00group-layout/dees-tile/dees-tile.demo.js +67 -0
- package/dist_ts_web/elements/00group-layout/dees-tile/dees-tile.js +187 -0
- package/dist_ts_web/elements/00group-layout/dees-tile/index.d.ts +1 -0
- package/dist_ts_web/elements/00group-layout/dees-tile/index.js +2 -0
- package/dist_ts_web/elements/00group-layout/index.d.ts +1 -0
- package/dist_ts_web/elements/00group-layout/index.js +2 -1
- package/dist_ts_web/elements/00group-simple/dees-shopping-productcard/dees-shopping-productcard.d.ts +1 -0
- package/dist_ts_web/elements/00group-simple/dees-shopping-productcard/dees-shopping-productcard.js +82 -74
- package/dist_ts_web/elements/00group-workspace/dees-workspace-terminal-preview/dees-workspace-terminal-preview.d.ts +1 -0
- package/dist_ts_web/elements/00group-workspace/dees-workspace-terminal-preview/dees-workspace-terminal-preview.js +8 -15
- package/dist_watch/bundle.js +2374 -2188
- package/dist_watch/bundle.js.map +4 -4
- package/package.json +1 -1
- package/ts_web/00_commitinfo_data.ts +1 -1
- package/ts_web/elements/00group-chart/dees-chart-area/component.ts +29 -6
- package/ts_web/elements/00group-chart/dees-chart-area/styles.ts +40 -23
- package/ts_web/elements/00group-chart/dees-chart-area/template.ts +16 -4
- package/ts_web/elements/00group-chart/dees-chart-log/dees-chart-log.ts +15 -23
- package/ts_web/elements/00group-dataview/dees-dataview-codebox/dees-dataview-codebox.ts +13 -27
- package/ts_web/elements/00group-dataview/dees-dataview-statusobject/dees-dataview-statusobject.ts +51 -50
- package/ts_web/elements/00group-dataview/dees-statsgrid/dees-statsgrid.ts +21 -28
- package/ts_web/elements/00group-dataview/dees-table/dees-table.ts +5 -5
- package/ts_web/elements/00group-dataview/dees-table/styles.ts +50 -43
- package/ts_web/elements/00group-input/dees-input-code/dees-input-code.ts +6 -13
- package/ts_web/elements/00group-input/dees-input-richtext/component.ts +1 -0
- package/ts_web/elements/00group-input/dees-input-richtext/styles.ts +11 -19
- package/ts_web/elements/00group-input/dees-input-richtext/template.ts +5 -5
- package/ts_web/elements/00group-layout/dees-tile/dees-tile.demo.ts +67 -0
- package/ts_web/elements/00group-layout/dees-tile/dees-tile.ts +139 -0
- package/ts_web/elements/00group-layout/dees-tile/index.ts +1 -0
- package/ts_web/elements/00group-layout/index.ts +1 -0
- package/ts_web/elements/00group-simple/dees-shopping-productcard/dees-shopping-productcard.ts +92 -84
- package/ts_web/elements/00group-workspace/dees-workspace-terminal-preview/dees-workspace-terminal-preview.ts +7 -14
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { html, css, cssManager } from '@design.estate/dees-element';
|
|
2
|
+
import './dees-tile.js';
|
|
3
|
+
export const demoFunc = () => {
|
|
4
|
+
return html `
|
|
5
|
+
<dees-demowrapper>
|
|
6
|
+
<style>
|
|
7
|
+
${css `
|
|
8
|
+
.demoBox {
|
|
9
|
+
background: ${cssManager.bdTheme('hsl(0 0% 95%)', 'hsl(0 0% 9%)')};
|
|
10
|
+
padding: 40px;
|
|
11
|
+
display: flex;
|
|
12
|
+
flex-direction: column;
|
|
13
|
+
gap: 24px;
|
|
14
|
+
}
|
|
15
|
+
.tile-demo-content {
|
|
16
|
+
position: absolute;
|
|
17
|
+
inset: 0;
|
|
18
|
+
display: flex;
|
|
19
|
+
align-items: center;
|
|
20
|
+
justify-content: center;
|
|
21
|
+
color: ${cssManager.bdTheme('hsl(0 0% 45%)', 'hsl(0 0% 55%)')};
|
|
22
|
+
font-size: 13px;
|
|
23
|
+
}
|
|
24
|
+
.footer-stats {
|
|
25
|
+
display: flex;
|
|
26
|
+
align-items: center;
|
|
27
|
+
gap: 24px;
|
|
28
|
+
font-size: 11px;
|
|
29
|
+
width: 100%;
|
|
30
|
+
}
|
|
31
|
+
.footer-stats .stat {
|
|
32
|
+
display: flex;
|
|
33
|
+
align-items: center;
|
|
34
|
+
gap: 6px;
|
|
35
|
+
}
|
|
36
|
+
.footer-stats .stat strong {
|
|
37
|
+
color: ${cssManager.bdTheme('hsl(0 0% 15%)', 'hsl(0 0% 90%)')};
|
|
38
|
+
}
|
|
39
|
+
`}
|
|
40
|
+
</style>
|
|
41
|
+
<div class="demoBox">
|
|
42
|
+
<dees-tile heading="Simple Tile" style="height: 200px;">
|
|
43
|
+
<div class="tile-demo-content">Content area with rounded corners</div>
|
|
44
|
+
</dees-tile>
|
|
45
|
+
|
|
46
|
+
<dees-tile heading="Tile with Footer" style="height: 200px;">
|
|
47
|
+
<div class="tile-demo-content">Content goes here</div>
|
|
48
|
+
<div slot="footer" class="footer-stats">
|
|
49
|
+
<span class="stat">latest <strong>42</strong></span>
|
|
50
|
+
<span class="stat">min <strong>12</strong></span>
|
|
51
|
+
<span class="stat">max <strong>87</strong></span>
|
|
52
|
+
<span class="stat">avg <strong>45.3</strong></span>
|
|
53
|
+
</div>
|
|
54
|
+
</dees-tile>
|
|
55
|
+
|
|
56
|
+
<dees-tile style="height: 200px;">
|
|
57
|
+
<div slot="header" style="display:flex;align-items:center;gap:12px;width:100%;">
|
|
58
|
+
<span style="font-weight:500;">Custom Header</span>
|
|
59
|
+
<input type="text" placeholder="Search..." style="flex:1;max-width:200px;padding:2px 8px;border:1px solid;border-radius:4px;font-size:12px;background:transparent;color:inherit;border-color:inherit;">
|
|
60
|
+
</div>
|
|
61
|
+
<div class="tile-demo-content">Custom header slot with search input</div>
|
|
62
|
+
</dees-tile>
|
|
63
|
+
</div>
|
|
64
|
+
</dees-demowrapper>
|
|
65
|
+
`;
|
|
66
|
+
};
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVlcy10aWxlLmRlbW8uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi90c193ZWIvZWxlbWVudHMvMDBncm91cC1sYXlvdXQvZGVlcy10aWxlL2RlZXMtdGlsZS5kZW1vLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLFVBQVUsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ3BFLE9BQU8sZ0JBQWdCLENBQUM7QUFFeEIsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFHLEdBQUcsRUFBRTtJQUMzQixPQUFPLElBQUksQ0FBQTs7O1VBR0gsR0FBRyxDQUFBOzswQkFFYSxVQUFVLENBQUMsT0FBTyxDQUFDLGVBQWUsRUFBRSxjQUFjLENBQUM7Ozs7Ozs7Ozs7OztxQkFZeEQsVUFBVSxDQUFDLE9BQU8sQ0FBQyxlQUFlLEVBQUUsZUFBZSxDQUFDOzs7Ozs7Ozs7Ozs7Ozs7O3FCQWdCcEQsVUFBVSxDQUFDLE9BQU8sQ0FBQyxlQUFlLEVBQUUsZUFBZSxDQUFDOztTQUVoRTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0EwQk4sQ0FBQztBQUNKLENBQUMsQ0FBQyJ9
|
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
var __esDecorate = (this && this.__esDecorate) || function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
|
|
2
|
+
function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
|
|
3
|
+
var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
|
|
4
|
+
var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
|
|
5
|
+
var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
|
|
6
|
+
var _, done = false;
|
|
7
|
+
for (var i = decorators.length - 1; i >= 0; i--) {
|
|
8
|
+
var context = {};
|
|
9
|
+
for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
|
|
10
|
+
for (var p in contextIn.access) context.access[p] = contextIn.access[p];
|
|
11
|
+
context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
|
|
12
|
+
var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
|
|
13
|
+
if (kind === "accessor") {
|
|
14
|
+
if (result === void 0) continue;
|
|
15
|
+
if (result === null || typeof result !== "object") throw new TypeError("Object expected");
|
|
16
|
+
if (_ = accept(result.get)) descriptor.get = _;
|
|
17
|
+
if (_ = accept(result.set)) descriptor.set = _;
|
|
18
|
+
if (_ = accept(result.init)) initializers.unshift(_);
|
|
19
|
+
}
|
|
20
|
+
else if (_ = accept(result)) {
|
|
21
|
+
if (kind === "field") initializers.unshift(_);
|
|
22
|
+
else descriptor[key] = _;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
if (target) Object.defineProperty(target, contextIn.name, descriptor);
|
|
26
|
+
done = true;
|
|
27
|
+
};
|
|
28
|
+
var __runInitializers = (this && this.__runInitializers) || function (thisArg, initializers, value) {
|
|
29
|
+
var useValue = arguments.length > 2;
|
|
30
|
+
for (var i = 0; i < initializers.length; i++) {
|
|
31
|
+
value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
|
|
32
|
+
}
|
|
33
|
+
return useValue ? value : void 0;
|
|
34
|
+
};
|
|
35
|
+
import { customElement, DeesElement, html, css, cssManager, property, state, } from '@design.estate/dees-element';
|
|
36
|
+
import { demoFunc } from './dees-tile.demo.js';
|
|
37
|
+
import { cssGeistFontFamily } from '../../00fonts.js';
|
|
38
|
+
import { themeDefaultStyles } from '../../00theme.js';
|
|
39
|
+
/**
|
|
40
|
+
* dees-tile — the unified "rounded on rounded" tile frame.
|
|
41
|
+
*
|
|
42
|
+
* RESPONSIBILITIES (what this component owns):
|
|
43
|
+
* 1. Outer card — border, border-radius, background, overflow clipping
|
|
44
|
+
* 2. Flex column layout — stacking header / content / footer vertically
|
|
45
|
+
* 3. Content inset — the rounded inner area with border-top and border-bottom
|
|
46
|
+
* 4. Default heading — styled 32px heading text when no slot="header" is provided
|
|
47
|
+
* 5. Footer visibility — auto-hides footer area when slot="footer" is empty
|
|
48
|
+
*
|
|
49
|
+
* NOT RESPONSIBILITIES (what consumer components own):
|
|
50
|
+
* - Header/footer height, padding, font-size, colors when using custom slots
|
|
51
|
+
* - Content layout (absolute, flex, grid — consumer decides)
|
|
52
|
+
* - Any semantic meaning of header/footer content
|
|
53
|
+
*
|
|
54
|
+
* The header and footer slots are BARE containers (just flex-shrink: 0).
|
|
55
|
+
* The slotted content fully controls its own appearance.
|
|
56
|
+
* Only the default heading fallback (.tile-heading) carries tile-level styling.
|
|
57
|
+
*/
|
|
58
|
+
let DeesTile = (() => {
|
|
59
|
+
let _classDecorators = [customElement('dees-tile')];
|
|
60
|
+
let _classDescriptor;
|
|
61
|
+
let _classExtraInitializers = [];
|
|
62
|
+
let _classThis;
|
|
63
|
+
let _classSuper = DeesElement;
|
|
64
|
+
let _heading_decorators;
|
|
65
|
+
let _heading_initializers = [];
|
|
66
|
+
let _heading_extraInitializers = [];
|
|
67
|
+
let _hasFooter_decorators;
|
|
68
|
+
let _hasFooter_initializers = [];
|
|
69
|
+
let _hasFooter_extraInitializers = [];
|
|
70
|
+
var DeesTile = class extends _classSuper {
|
|
71
|
+
static { _classThis = this; }
|
|
72
|
+
static {
|
|
73
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
74
|
+
_heading_decorators = [property({ type: String })];
|
|
75
|
+
_hasFooter_decorators = [state()];
|
|
76
|
+
__esDecorate(this, null, _heading_decorators, { kind: "accessor", name: "heading", static: false, private: false, access: { has: obj => "heading" in obj, get: obj => obj.heading, set: (obj, value) => { obj.heading = value; } }, metadata: _metadata }, _heading_initializers, _heading_extraInitializers);
|
|
77
|
+
__esDecorate(this, null, _hasFooter_decorators, { kind: "accessor", name: "hasFooter", static: false, private: false, access: { has: obj => "hasFooter" in obj, get: obj => obj.hasFooter, set: (obj, value) => { obj.hasFooter = value; } }, metadata: _metadata }, _hasFooter_initializers, _hasFooter_extraInitializers);
|
|
78
|
+
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
|
|
79
|
+
DeesTile = _classThis = _classDescriptor.value;
|
|
80
|
+
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
81
|
+
}
|
|
82
|
+
static demo = demoFunc;
|
|
83
|
+
static demoGroups = ['Layout'];
|
|
84
|
+
#heading_accessor_storage = __runInitializers(this, _heading_initializers, '');
|
|
85
|
+
get heading() { return this.#heading_accessor_storage; }
|
|
86
|
+
set heading(value) { this.#heading_accessor_storage = value; }
|
|
87
|
+
#hasFooter_accessor_storage = (__runInitializers(this, _heading_extraInitializers), __runInitializers(this, _hasFooter_initializers, false));
|
|
88
|
+
get hasFooter() { return this.#hasFooter_accessor_storage; }
|
|
89
|
+
set hasFooter(value) { this.#hasFooter_accessor_storage = value; }
|
|
90
|
+
static styles = [
|
|
91
|
+
themeDefaultStyles,
|
|
92
|
+
cssManager.defaultStyles,
|
|
93
|
+
css `
|
|
94
|
+
:host {
|
|
95
|
+
display: flex;
|
|
96
|
+
flex-direction: column;
|
|
97
|
+
font-family: ${cssGeistFontFamily};
|
|
98
|
+
color: ${cssManager.bdTheme('hsl(0 0% 3.9%)', 'hsl(0 0% 98%)')};
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
/* --- The frame --- */
|
|
102
|
+
.tile-outer {
|
|
103
|
+
position: relative;
|
|
104
|
+
flex: 1;
|
|
105
|
+
min-height: 0;
|
|
106
|
+
background: ${cssManager.bdTheme('hsl(0 0% 100%)', 'hsl(0 0% 3.9%)')};
|
|
107
|
+
border: 1px solid ${cssManager.bdTheme('hsl(0 0% 89.8%)', 'hsl(0 0% 14.9%)')};
|
|
108
|
+
border-radius: 8px;
|
|
109
|
+
overflow: hidden;
|
|
110
|
+
display: flex;
|
|
111
|
+
flex-direction: column;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
/* --- Header: bare container, only the default heading gets styled --- */
|
|
115
|
+
.tile-header {
|
|
116
|
+
flex-shrink: 0;
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
.tile-heading {
|
|
120
|
+
height: 32px;
|
|
121
|
+
line-height: 32px;
|
|
122
|
+
padding: 0 16px;
|
|
123
|
+
font-size: 14px;
|
|
124
|
+
font-weight: 500;
|
|
125
|
+
letter-spacing: -0.01em;
|
|
126
|
+
color: ${cssManager.bdTheme('hsl(0 0% 20%)', 'hsl(0 0% 63.9%)')};
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
/* --- Content: the rounded inset --- */
|
|
130
|
+
.tile-content {
|
|
131
|
+
flex: 1;
|
|
132
|
+
position: relative;
|
|
133
|
+
border-radius: 8px;
|
|
134
|
+
border-top: 1px solid ${cssManager.bdTheme('hsl(0 0% 93%)', 'hsl(0 0% 11%)')};
|
|
135
|
+
border-bottom: 1px solid ${cssManager.bdTheme('hsl(0 0% 93%)', 'hsl(0 0% 11%)')};
|
|
136
|
+
overflow: hidden;
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
.tile-content.no-footer {
|
|
140
|
+
border-bottom: none;
|
|
141
|
+
border-bottom-left-radius: 0;
|
|
142
|
+
border-bottom-right-radius: 0;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
/* --- Footer: bare container, consumer styles the slotted content --- */
|
|
146
|
+
.tile-footer {
|
|
147
|
+
flex-shrink: 0;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
.tile-footer.hidden {
|
|
151
|
+
display: none;
|
|
152
|
+
}
|
|
153
|
+
`,
|
|
154
|
+
];
|
|
155
|
+
render() {
|
|
156
|
+
return html `
|
|
157
|
+
<div class="tile-outer" part="outer">
|
|
158
|
+
<div class="tile-header" part="header">
|
|
159
|
+
<slot name="header">
|
|
160
|
+
<div class="tile-heading">${this.heading}</div>
|
|
161
|
+
</slot>
|
|
162
|
+
</div>
|
|
163
|
+
<div class="tile-content ${!this.hasFooter ? 'no-footer' : ''}" part="content">
|
|
164
|
+
<slot></slot>
|
|
165
|
+
</div>
|
|
166
|
+
<div class="tile-footer ${!this.hasFooter ? 'hidden' : ''}" part="footer">
|
|
167
|
+
<slot name="footer" @slotchange=${this.onFooterSlotChange}></slot>
|
|
168
|
+
</div>
|
|
169
|
+
</div>
|
|
170
|
+
`;
|
|
171
|
+
}
|
|
172
|
+
onFooterSlotChange(e) {
|
|
173
|
+
const slot = e.target;
|
|
174
|
+
this.hasFooter = slot.assignedNodes({ flatten: true }).length > 0;
|
|
175
|
+
}
|
|
176
|
+
constructor() {
|
|
177
|
+
super(...arguments);
|
|
178
|
+
__runInitializers(this, _hasFooter_extraInitializers);
|
|
179
|
+
}
|
|
180
|
+
static {
|
|
181
|
+
__runInitializers(_classThis, _classExtraInitializers);
|
|
182
|
+
}
|
|
183
|
+
};
|
|
184
|
+
return DeesTile = _classThis;
|
|
185
|
+
})();
|
|
186
|
+
export { DeesTile };
|
|
187
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVlcy10aWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdHNfd2ViL2VsZW1lbnRzLzAwZ3JvdXAtbGF5b3V0L2RlZXMtdGlsZS9kZWVzLXRpbGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLE9BQU8sRUFDTCxhQUFhLEVBQ2IsV0FBVyxFQUNYLElBQUksRUFDSixHQUFHLEVBQ0gsVUFBVSxFQUNWLFFBQVEsRUFDUixLQUFLLEdBRU4sTUFBTSw2QkFBNkIsQ0FBQztBQUNyQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFRdEQ7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQWtCRztJQUVVLFFBQVE7NEJBRHBCLGFBQWEsQ0FBQyxXQUFXLENBQUM7Ozs7c0JBQ0csV0FBVzs7Ozs7Ozt3QkFBbkIsU0FBUSxXQUFXOzs7O21DQUl0QyxRQUFRLENBQUMsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUM7cUNBRzFCLEtBQUssRUFBRTtZQUZSLDBLQUFTLE9BQU8sNkJBQVAsT0FBTyx5RkFBYztZQUc5QixnTEFBUyxTQUFTLDZCQUFULFNBQVMsNkZBQWtCO1lBUnRDLDZLQWtHQzs7OztRQWpHUSxNQUFNLENBQUMsSUFBSSxHQUFHLFFBQVEsQ0FBQztRQUN2QixNQUFNLENBQUMsVUFBVSxHQUFHLENBQUMsUUFBUSxDQUFDLENBQUM7UUFHdEMsMkVBQTJCLEVBQUUsRUFBQztRQUE5QixJQUFTLE9BQU8sNkNBQWM7UUFBOUIsSUFBUyxPQUFPLG1EQUFjO1FBRzlCLHFJQUE4QixLQUFLLEdBQUM7UUFBcEMsSUFBUyxTQUFTLCtDQUFrQjtRQUFwQyxJQUFTLFNBQVMscURBQWtCO1FBRTdCLE1BQU0sQ0FBQyxNQUFNLEdBQUc7WUFDckIsa0JBQWtCO1lBQ2xCLFVBQVUsQ0FBQyxhQUFhO1lBQ3hCLEdBQUcsQ0FBQTs7Ozt1QkFJZ0Isa0JBQWtCO2lCQUN4QixVQUFVLENBQUMsT0FBTyxDQUFDLGdCQUFnQixFQUFFLGVBQWUsQ0FBQzs7Ozs7Ozs7c0JBUWhELFVBQVUsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLEVBQUUsZ0JBQWdCLENBQUM7NEJBQ2hELFVBQVUsQ0FBQyxPQUFPLENBQUMsaUJBQWlCLEVBQUUsaUJBQWlCLENBQUM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7aUJBbUJuRSxVQUFVLENBQUMsT0FBTyxDQUFDLGVBQWUsRUFBRSxpQkFBaUIsQ0FBQzs7Ozs7Ozs7Z0NBUXZDLFVBQVUsQ0FBQyxPQUFPLENBQUMsZUFBZSxFQUFFLGVBQWUsQ0FBQzttQ0FDakQsVUFBVSxDQUFDLE9BQU8sQ0FBQyxlQUFlLEVBQUUsZUFBZSxDQUFDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7S0FrQmxGO1NBQ0YsQ0FBQztRQUVLLE1BQU07WUFDWCxPQUFPLElBQUksQ0FBQTs7Ozt3Q0FJeUIsSUFBSSxDQUFDLE9BQU87OzttQ0FHakIsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLEVBQUU7OztrQ0FHbkMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUU7NENBQ3JCLElBQUksQ0FBQyxrQkFBa0I7OztLQUc5RCxDQUFDO1FBQ0osQ0FBQztRQUVPLGtCQUFrQixDQUFDLENBQVE7WUFDakMsTUFBTSxJQUFJLEdBQUcsQ0FBQyxDQUFDLE1BQXlCLENBQUM7WUFDekMsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztRQUNwRSxDQUFDOzs7Ozs7WUFqR1UsdURBQVE7Ozs7O1NBQVIsUUFBUSJ9
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './dees-tile.js';
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './dees-tile.js';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi90c193ZWIvZWxlbWVudHMvMDBncm91cC1sYXlvdXQvZGVlcy10aWxlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsZ0JBQWdCLENBQUMifQ==
|
|
@@ -6,4 +6,5 @@ export * from './dees-label/index.js';
|
|
|
6
6
|
export * from './dees-pagination/index.js';
|
|
7
7
|
export * from './dees-panel/index.js';
|
|
8
8
|
export * from './dees-stepper/index.js';
|
|
9
|
-
|
|
9
|
+
export * from './dees-tile/index.js';
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi90c193ZWIvZWxlbWVudHMvMDBncm91cC1sYXlvdXQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsb0JBQW9CO0FBQ3BCLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxzQkFBc0IsQ0FBQyJ9
|
package/dist_ts_web/elements/00group-simple/dees-shopping-productcard/dees-shopping-productcard.js
CHANGED
|
@@ -35,6 +35,7 @@ var __runInitializers = (this && this.__runInitializers) || function (thisArg, i
|
|
|
35
35
|
import { customElement, property, html, css, cssManager, DeesElement, } from '@design.estate/dees-element';
|
|
36
36
|
import { demoFunc } from './dees-shopping-productcard.demo.js';
|
|
37
37
|
import { themeDefaultStyles } from '../../00theme.js';
|
|
38
|
+
import '../../00group-layout/dees-tile/dees-tile.js';
|
|
38
39
|
let DeesShoppingProductcard = (() => {
|
|
39
40
|
let _classDecorators = [customElement('dees-shopping-productcard')];
|
|
40
41
|
let _classDescriptor;
|
|
@@ -103,28 +104,20 @@ let DeesShoppingProductcard = (() => {
|
|
|
103
104
|
display: block;
|
|
104
105
|
}
|
|
105
106
|
|
|
106
|
-
|
|
107
|
-
background: ${cssManager.bdTheme('hsl(0 0% 100%)', 'hsl(215 20.2% 11.8%)')};
|
|
108
|
-
border: 1px solid ${cssManager.bdTheme('hsl(0 0% 89.8%)', 'hsl(0 0% 14.9%)')};
|
|
109
|
-
border-radius: 8px;
|
|
110
|
-
overflow: hidden;
|
|
111
|
-
transition: all 0.2s ease;
|
|
112
|
-
display: flex;
|
|
113
|
-
flex-direction: column;
|
|
107
|
+
dees-tile {
|
|
114
108
|
height: 100%;
|
|
115
|
-
position: relative;
|
|
116
109
|
}
|
|
117
110
|
|
|
118
|
-
|
|
111
|
+
dees-tile:hover::part(outer) {
|
|
119
112
|
border-color: ${cssManager.bdTheme('hsl(0 0% 79.8%)', 'hsl(0 0% 20.9%)')};
|
|
120
113
|
box-shadow: 0 4px 6px -1px hsl(0 0% 0% / 0.1), 0 2px 4px -2px hsl(0 0% 0% / 0.1);
|
|
121
114
|
}
|
|
122
115
|
|
|
123
|
-
|
|
116
|
+
dees-tile.selectable {
|
|
124
117
|
cursor: pointer;
|
|
125
118
|
}
|
|
126
119
|
|
|
127
|
-
|
|
120
|
+
dees-tile.selected::part(outer) {
|
|
128
121
|
border-color: ${cssManager.bdTheme('hsl(217.2 91.2% 59.8%)', 'hsl(213.1 93.9% 67.8%)')};
|
|
129
122
|
box-shadow: 0 0 0 3px ${cssManager.bdTheme('hsl(217.2 91.2% 59.8% / 0.1)', 'hsl(213.1 93.9% 67.8% / 0.1)')};
|
|
130
123
|
}
|
|
@@ -185,36 +178,48 @@ let DeesShoppingProductcard = (() => {
|
|
|
185
178
|
transform: scale(1);
|
|
186
179
|
}
|
|
187
180
|
|
|
188
|
-
.product-
|
|
189
|
-
padding: 16px;
|
|
181
|
+
.product-header-bar {
|
|
190
182
|
display: flex;
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
183
|
+
align-items: center;
|
|
184
|
+
justify-content: space-between;
|
|
185
|
+
height: 32px;
|
|
186
|
+
padding: 0 16px;
|
|
187
|
+
gap: 8px;
|
|
194
188
|
}
|
|
195
|
-
|
|
196
|
-
.product-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
189
|
+
|
|
190
|
+
.product-name {
|
|
191
|
+
font-size: 14px;
|
|
192
|
+
font-weight: 500;
|
|
193
|
+
color: ${cssManager.bdTheme('hsl(0 0% 20%)', 'hsl(0 0% 63.9%)')};
|
|
194
|
+
white-space: nowrap;
|
|
195
|
+
overflow: hidden;
|
|
196
|
+
text-overflow: ellipsis;
|
|
200
197
|
}
|
|
201
198
|
|
|
202
199
|
.product-category {
|
|
203
|
-
font-size:
|
|
200
|
+
font-size: 11px;
|
|
204
201
|
font-weight: 500;
|
|
205
202
|
color: ${cssManager.bdTheme('hsl(215.4 16.3% 56.9%)', 'hsl(215 20.2% 55.1%)')};
|
|
206
203
|
text-transform: uppercase;
|
|
207
204
|
letter-spacing: 0.05em;
|
|
208
|
-
|
|
205
|
+
white-space: nowrap;
|
|
206
|
+
flex-shrink: 0;
|
|
209
207
|
}
|
|
210
|
-
|
|
211
|
-
.product-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
line-height: 1.4;
|
|
208
|
+
|
|
209
|
+
.product-body {
|
|
210
|
+
display: flex;
|
|
211
|
+
flex-direction: column;
|
|
212
|
+
height: 100%;
|
|
216
213
|
}
|
|
217
214
|
|
|
215
|
+
.product-content {
|
|
216
|
+
padding: 12px 16px;
|
|
217
|
+
display: flex;
|
|
218
|
+
flex-direction: column;
|
|
219
|
+
gap: 8px;
|
|
220
|
+
flex: 1;
|
|
221
|
+
}
|
|
222
|
+
|
|
218
223
|
.product-description {
|
|
219
224
|
font-size: 13px;
|
|
220
225
|
color: ${cssManager.bdTheme('hsl(215.4 16.3% 46.9%)', 'hsl(215 20.2% 65.1%)')};
|
|
@@ -227,8 +232,9 @@ let DeesShoppingProductcard = (() => {
|
|
|
227
232
|
align-items: center;
|
|
228
233
|
justify-content: space-between;
|
|
229
234
|
gap: 16px;
|
|
230
|
-
padding
|
|
231
|
-
|
|
235
|
+
padding: 12px 16px;
|
|
236
|
+
width: 100%;
|
|
237
|
+
box-sizing: border-box;
|
|
232
238
|
}
|
|
233
239
|
|
|
234
240
|
.product-price {
|
|
@@ -276,51 +282,54 @@ let DeesShoppingProductcard = (() => {
|
|
|
276
282
|
return `${currency}${value.toFixed(2)}`;
|
|
277
283
|
};
|
|
278
284
|
return html `
|
|
279
|
-
<
|
|
280
|
-
class="
|
|
285
|
+
<dees-tile
|
|
286
|
+
class="${this.selectable ? 'selectable' : ''} ${this.selected ? 'selected' : ''}"
|
|
281
287
|
@click=${this.handleCardClick}
|
|
282
288
|
>
|
|
283
|
-
<div class="product-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
289
|
+
<div slot="header" class="product-header-bar">
|
|
290
|
+
<span class="product-name">${name}</span>
|
|
291
|
+
${category ? html `<span class="product-category">${category}</span>` : ''}
|
|
292
|
+
</div>
|
|
293
|
+
<div class="product-body">
|
|
294
|
+
<div class="product-image">
|
|
295
|
+
${imageUrl ? html `
|
|
296
|
+
<img src="${imageUrl}" alt="${name}">
|
|
297
|
+
` : html `
|
|
298
|
+
<dees-icon .icon=${iconName}></dees-icon>
|
|
299
|
+
`}
|
|
300
|
+
${this.selectable ? html `
|
|
301
|
+
<div
|
|
302
|
+
class="selection-checkbox ${this.selected ? 'checked' : ''}"
|
|
303
|
+
@click=${(e) => {
|
|
293
304
|
e.stopPropagation();
|
|
294
305
|
this.handleSelectionToggle();
|
|
295
306
|
}}
|
|
296
|
-
|
|
297
|
-
|
|
307
|
+
>
|
|
308
|
+
<dees-icon .icon=${'lucide:check'}></dees-icon>
|
|
309
|
+
</div>
|
|
310
|
+
` : ''}
|
|
311
|
+
</div>
|
|
312
|
+
<div class="product-content">
|
|
313
|
+
${description ? html `
|
|
314
|
+
<div class="product-description">${description}</div>
|
|
315
|
+
` : ''}
|
|
316
|
+
<div class="stock-status ${inStock ? 'in-stock' : 'out-of-stock'}">
|
|
317
|
+
<dees-icon .icon=${inStock ? 'lucide:check-circle' : 'lucide:x-circle'}></dees-icon>
|
|
318
|
+
${stockText}
|
|
298
319
|
</div>
|
|
299
|
-
` : ''}
|
|
300
|
-
</div>
|
|
301
|
-
<div class="product-content">
|
|
302
|
-
<div class="product-header">
|
|
303
|
-
${category ? html `<div class="product-category">${category}</div>` : ''}
|
|
304
|
-
<div class="product-name">${name}</div>
|
|
305
320
|
</div>
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
321
|
+
</div>
|
|
322
|
+
<div slot="footer" class="product-footer">
|
|
323
|
+
<div class="product-price">
|
|
324
|
+
<span class="price-current">${formatPrice(price)}</span>
|
|
325
|
+
${originalPrice && originalPrice > price ? html `
|
|
326
|
+
<span class="price-original">${formatPrice(originalPrice)}</span>
|
|
327
|
+
` : ''}
|
|
312
328
|
</div>
|
|
313
|
-
|
|
314
|
-
<
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
<span class="price-original">${formatPrice(originalPrice)}</span>
|
|
318
|
-
` : ''}
|
|
319
|
-
</div>
|
|
320
|
-
${this.showQuantitySelector ? html `
|
|
321
|
-
<dees-input-quantityselector
|
|
322
|
-
.value=${this.quantity}
|
|
323
|
-
@changeSubject=${(e) => {
|
|
329
|
+
${this.showQuantitySelector ? html `
|
|
330
|
+
<dees-input-quantityselector
|
|
331
|
+
.value=${this.quantity}
|
|
332
|
+
@changeSubject=${(e) => {
|
|
324
333
|
this.quantity = e.detail.getValue();
|
|
325
334
|
this.dispatchEvent(new CustomEvent('quantityChange', {
|
|
326
335
|
detail: {
|
|
@@ -331,11 +340,10 @@ let DeesShoppingProductcard = (() => {
|
|
|
331
340
|
composed: true
|
|
332
341
|
}));
|
|
333
342
|
}}
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
</div>
|
|
343
|
+
></dees-input-quantityselector>
|
|
344
|
+
` : ''}
|
|
337
345
|
</div>
|
|
338
|
-
</
|
|
346
|
+
</dees-tile>
|
|
339
347
|
`;
|
|
340
348
|
}
|
|
341
349
|
handleCardClick() {
|
|
@@ -373,4 +381,4 @@ let DeesShoppingProductcard = (() => {
|
|
|
373
381
|
return DeesShoppingProductcard = _classThis;
|
|
374
382
|
})();
|
|
375
383
|
export { DeesShoppingProductcard };
|
|
376
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
384
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVlcy1zaG9wcGluZy1wcm9kdWN0Y2FyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3RzX3dlYi9lbGVtZW50cy8wMGdyb3VwLXNpbXBsZS9kZWVzLXNob3BwaW5nLXByb2R1Y3RjYXJkL2RlZXMtc2hvcHBpbmctcHJvZHVjdGNhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLE9BQU8sRUFDTCxhQUFhLEVBQ2IsUUFBUSxFQUNSLElBQUksRUFDSixHQUFHLEVBQ0gsVUFBVSxFQUVWLFdBQVcsR0FDWixNQUFNLDZCQUE2QixDQUFDO0FBQ3JDLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUMvRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUN0RCxPQUFPLDZDQUE2QyxDQUFDO0lBc0J4Qyx1QkFBdUI7NEJBRG5DLGFBQWEsQ0FBQywyQkFBMkIsQ0FBQzs7OztzQkFDRSxXQUFXOzs7Ozs7Ozs7Ozs7Ozs7O3VDQUFuQixTQUFRLFdBQVc7Ozs7dUNBSXJELFFBQVEsQ0FBQyxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsQ0FBQztvQ0FNMUIsUUFBUSxDQUFDLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxDQUFDO2dEQUcxQixRQUFRLENBQUMsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLENBQUM7c0NBRzNCLFFBQVEsQ0FBQyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsQ0FBQztvQ0FHM0IsUUFBUSxDQUFDLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxDQUFDO1lBZDVCLHNMQUFTLFdBQVcsNkJBQVgsV0FBVyxpR0FHbEI7WUFHRiw2S0FBUyxRQUFRLDZCQUFSLFFBQVEsMkZBQWE7WUFHOUIsaU5BQVMsb0JBQW9CLDZCQUFwQixvQkFBb0IsbUhBQWlCO1lBRzlDLG1MQUFTLFVBQVUsNkJBQVYsVUFB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
|