@jsekulowicz/ds-components 0.5.4 → 0.6.0

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 (55) hide show
  1. package/custom-elements.json +122 -187
  2. package/dist/atoms/breadcrumb/breadcrumb-item.styles.d.ts.map +1 -1
  3. package/dist/atoms/breadcrumb/breadcrumb-item.styles.js +5 -1
  4. package/dist/atoms/breadcrumb/breadcrumb-item.styles.js.map +1 -1
  5. package/dist/define.d.ts +1 -1
  6. package/dist/define.d.ts.map +1 -1
  7. package/dist/define.js +1 -1
  8. package/dist/define.js.map +1 -1
  9. package/dist/index.d.ts +1 -1
  10. package/dist/index.d.ts.map +1 -1
  11. package/dist/index.js +1 -1
  12. package/dist/index.js.map +1 -1
  13. package/dist/organisms/footer/footer.styles.d.ts.map +1 -1
  14. package/dist/organisms/footer/footer.styles.js +6 -7
  15. package/dist/organisms/footer/footer.styles.js.map +1 -1
  16. package/dist/organisms/top-bar/define.d.ts +7 -0
  17. package/dist/organisms/top-bar/define.d.ts.map +1 -0
  18. package/dist/organisms/top-bar/define.js +5 -0
  19. package/dist/organisms/top-bar/define.js.map +1 -0
  20. package/dist/organisms/top-bar/index.d.ts +2 -0
  21. package/dist/organisms/top-bar/index.d.ts.map +1 -0
  22. package/dist/organisms/top-bar/index.js +2 -0
  23. package/dist/organisms/top-bar/index.js.map +1 -0
  24. package/dist/organisms/top-bar/top-bar.d.ts +25 -0
  25. package/dist/organisms/top-bar/top-bar.d.ts.map +1 -0
  26. package/dist/organisms/top-bar/top-bar.js +44 -0
  27. package/dist/organisms/top-bar/top-bar.js.map +1 -0
  28. package/dist/organisms/top-bar/top-bar.styles.d.ts +2 -0
  29. package/dist/organisms/top-bar/top-bar.styles.d.ts.map +1 -0
  30. package/dist/organisms/top-bar/top-bar.styles.js +37 -0
  31. package/dist/organisms/top-bar/top-bar.styles.js.map +1 -0
  32. package/dist/templates/page-shell/page-shell.d.ts +1 -0
  33. package/dist/templates/page-shell/page-shell.d.ts.map +1 -1
  34. package/dist/templates/page-shell/page-shell.js +6 -6
  35. package/dist/templates/page-shell/page-shell.js.map +1 -1
  36. package/dist/templates/page-shell/page-shell.styles.d.ts.map +1 -1
  37. package/dist/templates/page-shell/page-shell.styles.js +28 -57
  38. package/dist/templates/page-shell/page-shell.styles.js.map +1 -1
  39. package/package.json +6 -6
  40. package/dist/organisms/navbar/define.d.ts +0 -7
  41. package/dist/organisms/navbar/define.d.ts.map +0 -1
  42. package/dist/organisms/navbar/define.js +0 -5
  43. package/dist/organisms/navbar/define.js.map +0 -1
  44. package/dist/organisms/navbar/index.d.ts +0 -2
  45. package/dist/organisms/navbar/index.d.ts.map +0 -1
  46. package/dist/organisms/navbar/index.js +0 -2
  47. package/dist/organisms/navbar/index.js.map +0 -1
  48. package/dist/organisms/navbar/navbar.d.ts +0 -29
  49. package/dist/organisms/navbar/navbar.d.ts.map +0 -1
  50. package/dist/organisms/navbar/navbar.js +0 -104
  51. package/dist/organisms/navbar/navbar.js.map +0 -1
  52. package/dist/organisms/navbar/navbar.styles.d.ts +0 -2
  53. package/dist/organisms/navbar/navbar.styles.d.ts.map +0 -1
  54. package/dist/organisms/navbar/navbar.styles.js +0 -90
  55. 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,2 +0,0 @@
1
- export declare const navbarStyles: import("lit").CSSResult;
2
- //# sourceMappingURL=navbar.styles.d.ts.map
@@ -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"}