@jsekulowicz/ds-components 0.5.4 → 0.6.1
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/custom-elements.json +122 -187
- package/dist/atoms/breadcrumb/breadcrumb-item.styles.d.ts.map +1 -1
- package/dist/atoms/breadcrumb/breadcrumb-item.styles.js +5 -1
- package/dist/atoms/breadcrumb/breadcrumb-item.styles.js.map +1 -1
- package/dist/define.d.ts +1 -1
- package/dist/define.d.ts.map +1 -1
- package/dist/define.js +1 -1
- package/dist/define.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/organisms/footer/footer.styles.d.ts.map +1 -1
- package/dist/organisms/footer/footer.styles.js +6 -7
- package/dist/organisms/footer/footer.styles.js.map +1 -1
- package/dist/organisms/top-bar/define.d.ts +7 -0
- package/dist/organisms/top-bar/define.d.ts.map +1 -0
- package/dist/organisms/top-bar/define.js +5 -0
- package/dist/organisms/top-bar/define.js.map +1 -0
- package/dist/organisms/top-bar/index.d.ts +2 -0
- package/dist/organisms/top-bar/index.d.ts.map +1 -0
- package/dist/organisms/top-bar/index.js +2 -0
- package/dist/organisms/top-bar/index.js.map +1 -0
- package/dist/organisms/top-bar/top-bar.d.ts +25 -0
- package/dist/organisms/top-bar/top-bar.d.ts.map +1 -0
- package/dist/organisms/top-bar/top-bar.js +44 -0
- package/dist/organisms/top-bar/top-bar.js.map +1 -0
- package/dist/organisms/top-bar/top-bar.styles.d.ts +2 -0
- package/dist/organisms/top-bar/top-bar.styles.d.ts.map +1 -0
- package/dist/organisms/top-bar/top-bar.styles.js +37 -0
- package/dist/organisms/top-bar/top-bar.styles.js.map +1 -0
- package/dist/templates/page-shell/page-shell.d.ts +1 -0
- package/dist/templates/page-shell/page-shell.d.ts.map +1 -1
- package/dist/templates/page-shell/page-shell.js +6 -6
- package/dist/templates/page-shell/page-shell.js.map +1 -1
- package/dist/templates/page-shell/page-shell.styles.d.ts.map +1 -1
- package/dist/templates/page-shell/page-shell.styles.js +21 -58
- package/dist/templates/page-shell/page-shell.styles.js.map +1 -1
- package/package.json +8 -8
- package/dist/organisms/navbar/define.d.ts +0 -7
- package/dist/organisms/navbar/define.d.ts.map +0 -1
- package/dist/organisms/navbar/define.js +0 -5
- package/dist/organisms/navbar/define.js.map +0 -1
- package/dist/organisms/navbar/index.d.ts +0 -2
- package/dist/organisms/navbar/index.d.ts.map +0 -1
- package/dist/organisms/navbar/index.js +0 -2
- package/dist/organisms/navbar/index.js.map +0 -1
- package/dist/organisms/navbar/navbar.d.ts +0 -29
- package/dist/organisms/navbar/navbar.d.ts.map +0 -1
- package/dist/organisms/navbar/navbar.js +0 -104
- package/dist/organisms/navbar/navbar.js.map +0 -1
- package/dist/organisms/navbar/navbar.styles.d.ts +0 -2
- package/dist/organisms/navbar/navbar.styles.d.ts.map +0 -1
- package/dist/organisms/navbar/navbar.styles.js +0 -90
- package/dist/organisms/navbar/navbar.styles.js.map +0 -1
|
@@ -1,104 +0,0 @@
|
|
|
1
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
-
};
|
|
7
|
-
import { html } from 'lit';
|
|
8
|
-
import { property, state } from 'lit/decorators.js';
|
|
9
|
-
import { DsElement } from '@jsekulowicz/ds-core';
|
|
10
|
-
import { navbarStyles } from './navbar.styles.js';
|
|
11
|
-
import '../../atoms/icon/define.js';
|
|
12
|
-
import '../../atoms/icon/icons/bars-3.js';
|
|
13
|
-
/**
|
|
14
|
-
* @tag ds-navbar
|
|
15
|
-
* @summary Top-bar navigation shell. Collapses to a hamburger menu below the configured breakpoint.
|
|
16
|
-
* @slot brand - Logo or wordmark (left).
|
|
17
|
-
* @slot default - ds-nav-item children (center, collapses on mobile).
|
|
18
|
-
* @slot actions - Buttons / user menu (right).
|
|
19
|
-
* @csspart bar - The internal `<nav>` element.
|
|
20
|
-
* @csspart brand - The brand wrapper.
|
|
21
|
-
* @csspart links - The collapsible links wrapper (mobile menu when expanded).
|
|
22
|
-
* @csspart actions - The actions wrapper.
|
|
23
|
-
* @csspart toggle - The hamburger toggle button.
|
|
24
|
-
* @csspart menu - The expandable links container.
|
|
25
|
-
*/
|
|
26
|
-
export class DsNavbar extends DsElement {
|
|
27
|
-
constructor() {
|
|
28
|
-
super(...arguments);
|
|
29
|
-
this.label = 'Primary';
|
|
30
|
-
this.menuLabel = 'Menu';
|
|
31
|
-
this._open = false;
|
|
32
|
-
this._hasLinks = false;
|
|
33
|
-
this.#syncLinksPresence = () => {
|
|
34
|
-
const slot = this.shadowRoot?.querySelector('.menu slot:not([name])');
|
|
35
|
-
this._hasLinks = Boolean(slot?.assignedNodes({ flatten: true }).some(isContentNode));
|
|
36
|
-
};
|
|
37
|
-
this.#onLinksSlotChange = () => {
|
|
38
|
-
this.#syncLinksPresence();
|
|
39
|
-
};
|
|
40
|
-
this.#onDocumentKeydown = (event) => {
|
|
41
|
-
if (event.key === 'Escape' && this._open) {
|
|
42
|
-
this._open = false;
|
|
43
|
-
this.removeAttribute('data-open');
|
|
44
|
-
this.shadowRoot?.querySelector('.toggle')?.focus();
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
|
-
this.#onToggle = () => {
|
|
48
|
-
this._open = !this._open;
|
|
49
|
-
this.toggleAttribute('data-open', this._open);
|
|
50
|
-
};
|
|
51
|
-
}
|
|
52
|
-
static { this.styles = [...DsElement.styles, navbarStyles]; }
|
|
53
|
-
connectedCallback() {
|
|
54
|
-
super.connectedCallback();
|
|
55
|
-
document.addEventListener('keydown', this.#onDocumentKeydown);
|
|
56
|
-
}
|
|
57
|
-
disconnectedCallback() {
|
|
58
|
-
super.disconnectedCallback();
|
|
59
|
-
document.removeEventListener('keydown', this.#onDocumentKeydown);
|
|
60
|
-
}
|
|
61
|
-
#syncLinksPresence;
|
|
62
|
-
#onLinksSlotChange;
|
|
63
|
-
#onDocumentKeydown;
|
|
64
|
-
#onToggle;
|
|
65
|
-
render() {
|
|
66
|
-
const menuId = `${this.uid}-menu`;
|
|
67
|
-
return html `<nav part="bar" aria-label=${this.label}>
|
|
68
|
-
<div class="brand" part="brand"><slot name="brand"></slot></div>
|
|
69
|
-
<div class="links" part="links" ?hidden=${!this._hasLinks}>
|
|
70
|
-
<button
|
|
71
|
-
class="toggle"
|
|
72
|
-
part="toggle"
|
|
73
|
-
type="button"
|
|
74
|
-
aria-label=${this.menuLabel}
|
|
75
|
-
aria-expanded=${this._open ? 'true' : 'false'}
|
|
76
|
-
aria-controls=${menuId}
|
|
77
|
-
@click=${this.#onToggle}
|
|
78
|
-
>
|
|
79
|
-
<ds-icon name="bars-3" size="3xl"></ds-icon>
|
|
80
|
-
</button>
|
|
81
|
-
<div class="menu" part="menu" id=${menuId} role="list">
|
|
82
|
-
<slot @slotchange=${this.#onLinksSlotChange}></slot>
|
|
83
|
-
</div>
|
|
84
|
-
</div>
|
|
85
|
-
<div class="actions" part="actions"><slot name="actions"></slot></div>
|
|
86
|
-
</nav>`;
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
__decorate([
|
|
90
|
-
property()
|
|
91
|
-
], DsNavbar.prototype, "label", void 0);
|
|
92
|
-
__decorate([
|
|
93
|
-
property({ attribute: 'menu-label' })
|
|
94
|
-
], DsNavbar.prototype, "menuLabel", void 0);
|
|
95
|
-
__decorate([
|
|
96
|
-
state()
|
|
97
|
-
], DsNavbar.prototype, "_open", void 0);
|
|
98
|
-
__decorate([
|
|
99
|
-
state()
|
|
100
|
-
], DsNavbar.prototype, "_hasLinks", void 0);
|
|
101
|
-
function isContentNode(node) {
|
|
102
|
-
return node.nodeType !== Node.TEXT_NODE || Boolean(node.textContent?.trim());
|
|
103
|
-
}
|
|
104
|
-
//# sourceMappingURL=navbar.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"navbar.js","sourceRoot":"","sources":["../../../src/organisms/navbar/navbar.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"navbar.styles.d.ts","sourceRoot":"","sources":["../../../src/organisms/navbar/navbar.styles.ts"],"names":[],"mappings":"AAMA,eAAO,MAAM,YAAY,yBAoFxB,CAAC"}
|
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
import { css, unsafeCSS } from 'lit';
|
|
2
|
-
import { breakpoint } from '@jsekulowicz/ds-tokens';
|
|
3
|
-
const tabletBreakpoint = unsafeCSS(breakpoint.md);
|
|
4
|
-
const belowDesktopBreakpoint = unsafeCSS(`calc(${breakpoint.lg} - 0.02px)`);
|
|
5
|
-
export const navbarStyles = css `
|
|
6
|
-
:host {
|
|
7
|
-
display: block;
|
|
8
|
-
container-type: inline-size;
|
|
9
|
-
}
|
|
10
|
-
nav {
|
|
11
|
-
position: relative;
|
|
12
|
-
display: flex;
|
|
13
|
-
align-items: center;
|
|
14
|
-
gap: var(--ds-space-4);
|
|
15
|
-
padding: var(--ds-space-3) var(--ds-space-5);
|
|
16
|
-
background: var(--ds-color-bg);
|
|
17
|
-
border-bottom: 1px solid var(--ds-color-border);
|
|
18
|
-
font-family: var(--ds-font-body);
|
|
19
|
-
}
|
|
20
|
-
.brand {
|
|
21
|
-
display: flex;
|
|
22
|
-
align-items: center;
|
|
23
|
-
gap: var(--ds-space-2);
|
|
24
|
-
font-family: var(--ds-font-display);
|
|
25
|
-
font-size: var(--ds-font-size-lg);
|
|
26
|
-
color: var(--ds-color-fg);
|
|
27
|
-
}
|
|
28
|
-
.links {
|
|
29
|
-
display: flex;
|
|
30
|
-
align-items: center;
|
|
31
|
-
gap: var(--ds-space-3);
|
|
32
|
-
flex: 1;
|
|
33
|
-
}
|
|
34
|
-
.actions {
|
|
35
|
-
display: flex;
|
|
36
|
-
align-items: center;
|
|
37
|
-
gap: var(--ds-space-2);
|
|
38
|
-
}
|
|
39
|
-
.toggle {
|
|
40
|
-
display: none;
|
|
41
|
-
align-items: center;
|
|
42
|
-
justify-content: center;
|
|
43
|
-
border: 1px solid var(--ds-color-border);
|
|
44
|
-
background: transparent;
|
|
45
|
-
border-radius: var(--ds-radius-sm);
|
|
46
|
-
color: var(--ds-color-fg);
|
|
47
|
-
cursor: pointer;
|
|
48
|
-
padding: var(--ds-space-2);
|
|
49
|
-
}
|
|
50
|
-
.toggle:focus-visible {
|
|
51
|
-
box-shadow: var(--ds-shadow-focus);
|
|
52
|
-
}
|
|
53
|
-
.menu {
|
|
54
|
-
display: contents;
|
|
55
|
-
}
|
|
56
|
-
@container (max-width: ${tabletBreakpoint}) {
|
|
57
|
-
.links {
|
|
58
|
-
justify-content: flex-end;
|
|
59
|
-
flex: 0 0 auto;
|
|
60
|
-
margin-left: auto;
|
|
61
|
-
}
|
|
62
|
-
.toggle {
|
|
63
|
-
display: inline-flex;
|
|
64
|
-
}
|
|
65
|
-
.menu {
|
|
66
|
-
display: none;
|
|
67
|
-
position: absolute;
|
|
68
|
-
top: 100%;
|
|
69
|
-
left: 0;
|
|
70
|
-
right: 0;
|
|
71
|
-
flex-direction: column;
|
|
72
|
-
align-items: stretch;
|
|
73
|
-
gap: var(--ds-space-1);
|
|
74
|
-
padding: var(--ds-space-3);
|
|
75
|
-
background: var(--ds-color-bg);
|
|
76
|
-
border-bottom: 1px solid var(--ds-color-border);
|
|
77
|
-
box-shadow: var(--ds-shadow-md);
|
|
78
|
-
z-index: 10;
|
|
79
|
-
}
|
|
80
|
-
:host([data-open]) .menu {
|
|
81
|
-
display: flex;
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
@media (max-width: ${belowDesktopBreakpoint}) {
|
|
85
|
-
nav {
|
|
86
|
-
padding-inline: var(--ds-space-4);
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
`;
|
|
90
|
-
//# sourceMappingURL=navbar.styles.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"navbar.styles.js","sourceRoot":"","sources":["../../../src/organisms/navbar/navbar.styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,KAAK,CAAC;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAEpD,MAAM,gBAAgB,GAAG,SAAS,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;AAClD,MAAM,sBAAsB,GAAG,SAAS,CAAC,QAAQ,UAAU,CAAC,EAAE,YAAY,CAAC,CAAC;AAE5E,MAAM,CAAC,MAAM,YAAY,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2BAmDJ,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;uBA4BpB,sBAAsB;;;;;CAK5C,CAAC"}
|