@muibook/components 10.0.0 → 11.0.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 (150) hide show
  1. package/LICENSE +27 -11
  2. package/README.md +7 -7
  3. package/dist/esm/components/mui-accordion/block/index.js +9 -5
  4. package/dist/esm/components/mui-alert/index.js +88 -52
  5. package/dist/esm/components/mui-badge/index.js +61 -16
  6. package/dist/esm/components/mui-body/index.js +76 -10
  7. package/dist/esm/components/mui-button/index.js +152 -32
  8. package/dist/esm/components/mui-card/card/index.js +13 -8
  9. package/dist/esm/components/mui-checkbox/index.js +64 -30
  10. package/dist/esm/components/mui-chip/index.js +153 -33
  11. package/dist/esm/components/mui-chip-input/index.js +407 -0
  12. package/dist/esm/components/mui-code/index.js +11 -9
  13. package/dist/esm/components/mui-dialog/index.js +17 -8
  14. package/dist/esm/components/mui-dropdown/index.js +44 -44
  15. package/dist/esm/components/mui-field/index.js +56 -21
  16. package/dist/esm/components/mui-form-group/index.js +88 -0
  17. package/dist/esm/components/mui-form-hint/index.js +1 -0
  18. package/dist/esm/components/mui-form-message/index.js +72 -0
  19. package/dist/esm/components/mui-form-section/index.js +108 -0
  20. package/dist/esm/components/mui-form-section-footer/index.js +46 -0
  21. package/dist/esm/components/mui-hint/index.js +146 -0
  22. package/dist/esm/components/mui-icons/accessibility/index.js +5 -4
  23. package/dist/esm/components/mui-icons/add/index.js +1 -0
  24. package/dist/esm/components/mui-icons/ai/index.js +9 -14
  25. package/dist/esm/components/mui-icons/attention/index.js +1 -0
  26. package/dist/esm/components/mui-icons/calendar/index.js +5 -4
  27. package/dist/esm/components/mui-icons/check/index.js +6 -5
  28. package/dist/esm/components/mui-icons/checkmark/index.js +9 -8
  29. package/dist/esm/components/mui-icons/close/index.js +6 -5
  30. package/dist/esm/components/mui-icons/down-arrow-circle/index.js +9 -8
  31. package/dist/esm/components/mui-icons/down-chevron/index.js +8 -7
  32. package/dist/esm/components/mui-icons/ellipsis/index.js +1 -0
  33. package/dist/esm/components/mui-icons/exclamationmark/index.js +49 -0
  34. package/dist/esm/components/mui-icons/game-controller/index.js +8 -7
  35. package/dist/esm/components/mui-icons/gear/index.js +5 -4
  36. package/dist/esm/components/mui-icons/globe/index.js +8 -7
  37. package/dist/esm/components/mui-icons/grid/index.js +1 -0
  38. package/dist/esm/components/mui-icons/home/index.js +9 -8
  39. package/dist/esm/components/mui-icons/index.js +3 -0
  40. package/dist/esm/components/mui-icons/info/index.js +3 -2
  41. package/dist/esm/components/mui-icons/left-arrow/index.js +1 -0
  42. package/dist/esm/components/mui-icons/left-chevron/index.js +6 -5
  43. package/dist/esm/components/mui-icons/left-sidebar/index.js +6 -5
  44. package/dist/esm/components/mui-icons/list-and-film/index.js +1 -0
  45. package/dist/esm/components/mui-icons/menu/index.js +8 -7
  46. package/dist/esm/components/mui-icons/message/index.js +5 -4
  47. package/dist/esm/components/mui-icons/moon/index.js +3 -2
  48. package/dist/esm/components/mui-icons/movie-clapper/index.js +5 -4
  49. package/dist/esm/components/mui-icons/music-microphone/index.js +6 -5
  50. package/dist/esm/components/mui-icons/music-quarter-note/index.js +1 -0
  51. package/dist/esm/components/mui-icons/notification/index.js +5 -4
  52. package/dist/esm/components/mui-icons/pin/index.js +3 -2
  53. package/dist/esm/components/mui-icons/pin-slash/index.js +6 -5
  54. package/dist/esm/components/mui-icons/play-rectangle/index.js +9 -8
  55. package/dist/esm/components/mui-icons/play-stack/index.js +5 -4
  56. package/dist/esm/components/mui-icons/rectangle/index.js +6 -5
  57. package/dist/esm/components/mui-icons/rectangle-bottom-panel/index.js +1 -0
  58. package/dist/esm/components/mui-icons/rectangle-dashed/index.js +1 -0
  59. package/dist/esm/components/mui-icons/rectangle-left-drawer/index.js +1 -0
  60. package/dist/esm/components/mui-icons/rectangle-media-text/index.js +6 -5
  61. package/dist/esm/components/mui-icons/right-chevron/index.js +1 -0
  62. package/dist/esm/components/mui-icons/search/index.js +6 -5
  63. package/dist/esm/components/mui-icons/spinner/index.js +56 -0
  64. package/dist/esm/components/mui-icons/stop/index.js +3 -2
  65. package/dist/esm/components/mui-icons/subtract/index.js +1 -0
  66. package/dist/esm/components/mui-icons/sun/index.js +1 -0
  67. package/dist/esm/components/mui-icons/text-below-folder/index.js +55 -0
  68. package/dist/esm/components/mui-icons/toggle/index.js +8 -6
  69. package/dist/esm/components/mui-icons/translate/index.js +5 -4
  70. package/dist/esm/components/mui-icons/up-arrow/index.js +5 -4
  71. package/dist/esm/components/mui-icons/up-chevron/index.js +6 -5
  72. package/dist/esm/components/mui-icons/warning/index.js +7 -6
  73. package/dist/esm/components/mui-input/index.js +298 -47
  74. package/dist/esm/components/mui-link/index.js +187 -59
  75. package/dist/esm/components/mui-list/item/index.js +3 -0
  76. package/dist/esm/components/mui-markdown/index.js +149 -0
  77. package/dist/esm/components/mui-media-player/index.js +184 -0
  78. package/dist/esm/components/mui-message/index.js +50 -20
  79. package/dist/esm/components/mui-progress/index.js +15 -15
  80. package/dist/esm/components/mui-prompt/index.js +1461 -0
  81. package/dist/esm/components/mui-prompt-message/index.js +114 -0
  82. package/dist/esm/components/mui-prompt-preview/index.js +497 -0
  83. package/dist/esm/components/mui-prompt-toggle/index.js +48 -0
  84. package/dist/esm/components/mui-radio/index.js +155 -0
  85. package/dist/esm/components/mui-radio-group/index.js +104 -0
  86. package/dist/esm/components/mui-range-input/index.js +122 -0
  87. package/dist/esm/components/mui-rule/index.js +11 -3
  88. package/dist/esm/components/mui-select/index.js +89 -30
  89. package/dist/esm/components/mui-spinner/index.js +70 -0
  90. package/dist/esm/components/mui-stepper/step/index.js +255 -18
  91. package/dist/esm/components/mui-stepper/stepper/index.js +68 -72
  92. package/dist/esm/components/mui-table/row/index.js +16 -3
  93. package/dist/esm/components/mui-tabs/controller/index.js +21 -14
  94. package/dist/esm/components/mui-tabs/item/index.js +285 -29
  95. package/dist/esm/components/mui-tabs/panel/index.js +3 -0
  96. package/dist/esm/components/mui-tabs/tab-bar/index.js +85 -34
  97. package/dist/esm/components/mui-textarea/index.js +257 -0
  98. package/dist/esm/css/mui-base.css +27 -0
  99. package/dist/esm/css/mui-brand.css +3 -1
  100. package/dist/esm/css/mui-tokens.css +234 -7
  101. package/dist/esm/custom-elements.json +5450 -2039
  102. package/dist/esm/index.js +24 -4
  103. package/dist/esm/tokens/js/index.js +107 -105
  104. package/dist/types/components/mui-agent-bubble/doc.d.ts +2 -0
  105. package/dist/types/components/mui-agent-bubble/index.d.ts +1 -0
  106. package/dist/types/components/mui-agent-prompt/doc.d.ts +2 -0
  107. package/dist/types/components/mui-agent-prompt/index.d.ts +1 -0
  108. package/dist/types/components/mui-chip-input/doc.d.ts +2 -0
  109. package/dist/types/components/mui-chip-input/index.d.ts +3 -0
  110. package/dist/types/components/mui-form-group/doc.d.ts +2 -0
  111. package/dist/types/components/mui-form-group/index.d.ts +2 -0
  112. package/dist/types/components/mui-form-group-horizontal/index.d.ts +1 -0
  113. package/dist/types/components/mui-form-hint/doc.d.ts +2 -0
  114. package/dist/types/components/mui-form-hint/index.d.ts +1 -0
  115. package/dist/types/components/mui-form-message/index.d.ts +2 -0
  116. package/dist/types/components/mui-form-section/doc.d.ts +2 -0
  117. package/dist/types/components/mui-form-section/index.d.ts +1 -0
  118. package/dist/types/components/mui-form-section-footer/doc.d.ts +2 -0
  119. package/dist/types/components/mui-form-section-footer/index.d.ts +1 -0
  120. package/dist/types/components/mui-hint/doc.d.ts +2 -0
  121. package/dist/types/components/mui-hint/index.d.ts +1 -0
  122. package/dist/types/components/mui-icons/exclamationmark.d.ts +1 -0
  123. package/dist/types/components/mui-icons/index.d.ts +3 -0
  124. package/dist/types/components/mui-icons/spinner.d.ts +1 -0
  125. package/dist/types/components/mui-icons/text-below-folder.d.ts +1 -0
  126. package/dist/types/components/mui-markdown/doc.d.ts +2 -0
  127. package/dist/types/components/mui-markdown/index.d.ts +1 -0
  128. package/dist/types/components/mui-media-player/doc.d.ts +2 -0
  129. package/dist/types/components/mui-media-player/index.d.ts +8 -0
  130. package/dist/types/components/mui-prompt/doc.d.ts +2 -0
  131. package/dist/types/components/mui-prompt/index.d.ts +18 -0
  132. package/dist/types/components/mui-prompt-chip/index.d.ts +1 -0
  133. package/dist/types/components/mui-prompt-message/doc.d.ts +2 -0
  134. package/dist/types/components/mui-prompt-message/index.d.ts +1 -0
  135. package/dist/types/components/mui-prompt-preview/doc.d.ts +2 -0
  136. package/dist/types/components/mui-prompt-preview/index.d.ts +7 -0
  137. package/dist/types/components/mui-prompt-toggle/index.d.ts +1 -0
  138. package/dist/types/components/mui-radio/doc.d.ts +2 -0
  139. package/dist/types/components/mui-radio/index.d.ts +1 -0
  140. package/dist/types/components/mui-radio-group/index.d.ts +1 -0
  141. package/dist/types/components/mui-range-input/doc.d.ts +2 -0
  142. package/dist/types/components/mui-range-input/index.d.ts +1 -0
  143. package/dist/types/components/mui-spinner/doc.d.ts +2 -0
  144. package/dist/types/components/mui-spinner/index.d.ts +1 -0
  145. package/dist/types/components/mui-stepper/step/index.d.ts +4 -1
  146. package/dist/types/components/mui-textarea/doc.d.ts +2 -0
  147. package/dist/types/components/mui-textarea/index.d.ts +1 -0
  148. package/dist/types/index.d.ts +21 -0
  149. package/dist/types/tokens/js/index.d.ts +2 -0
  150. package/package.json +88 -1
@@ -0,0 +1,184 @@
1
+ import "../mui-button/index.js";
2
+ import "../mui-body/index.js";
3
+ import "../mui-hint/index.js";
4
+ import "../mui-range-input/index.js";
5
+ import "../mui-icons/play-rectangle/index.js";
6
+ import "../mui-icons/stop/index.js";
7
+ import "../mui-icons/music-microphone/index.js";
8
+ import "../mui-icons/movie-clapper/index.js";
9
+ class m extends HTMLElement {
10
+ constructor() {
11
+ super(), this.countdownMode = !1, this.attachShadow({ mode: "open" });
12
+ }
13
+ static get observedAttributes() {
14
+ return ["src", "type", "autoplay", "muted", "loop", "poster", "prefer-native-controls"];
15
+ }
16
+ connectedCallback() {
17
+ this.render(), this.bindControls();
18
+ }
19
+ attributeChangedCallback(e, t) {
20
+ e !== t && (this.render(), this.bindControls());
21
+ }
22
+ resolveType(e) {
23
+ const t = (this.getAttribute("type") || "").toLowerCase();
24
+ if (t === "video" || t === "audio" || t === "youtube" || t === "soundcloud")
25
+ return t;
26
+ try {
27
+ const i = new URL(e), o = i.hostname.toLowerCase(), a = i.pathname.toLowerCase();
28
+ if (o === "youtu.be" || o.endsWith("youtube.com") || o.endsWith("youtube-nocookie.com"))
29
+ return "youtube";
30
+ if (o.endsWith("soundcloud.com")) return "soundcloud";
31
+ if (/\.(mp4|webm|mov|m4v|ogv)$/.test(a)) return "video";
32
+ if (/\.(mp3|wav|m4a|aac|flac|ogg|oga)$/.test(a)) return "audio";
33
+ } catch {
34
+ return "audio";
35
+ }
36
+ return "audio";
37
+ }
38
+ getYouTubeEmbed(e) {
39
+ try {
40
+ const t = new URL(e);
41
+ if (t.hostname.toLowerCase() === "youtu.be") return `https://www.youtube.com/embed/${t.pathname.replace("/", "")}?rel=0`;
42
+ const o = t.searchParams.get("v");
43
+ if (o) return `https://www.youtube.com/embed/${o}?rel=0`;
44
+ } catch {
45
+ return "";
46
+ }
47
+ return "";
48
+ }
49
+ getSoundcloudEmbed(e) {
50
+ return `https://w.soundcloud.com/player/?url=${encodeURIComponent(e)}&auto_play=false&show_comments=false&show_teaser=false&visual=false`;
51
+ }
52
+ formatTime(e) {
53
+ const t = Number.isFinite(e) ? Math.max(0, Math.floor(e)) : 0, i = Math.floor(t / 60), o = t % 60;
54
+ return `${i}:${String(o).padStart(2, "0")}`;
55
+ }
56
+ bindControls() {
57
+ if (!this.shadowRoot) return;
58
+ const e = this.shadowRoot.querySelector("video, audio");
59
+ if (!e) return;
60
+ const t = this.shadowRoot.querySelector('[data-action="play"]'), i = this.shadowRoot.querySelector('[data-action="mute"]'), o = this.shadowRoot.querySelector('[data-action="seek"]'), a = this.shadowRoot.querySelector('[data-action="time-mode"]');
61
+ if (!!!(t || i || o || a)) return;
62
+ let d = null, l = null;
63
+ const r = () => {
64
+ const s = e.paused;
65
+ if (t == null || t.setAttribute("aria-label", s ? "Play media" : "Pause media"), t && s !== d && (t.innerHTML = s ? '<mui-icon-play-rectangle size="x-small"></mui-icon-play-rectangle>' : '<mui-icon-stop size="x-small"></mui-icon-stop>', d = s), i && e.muted !== l && (i.setAttribute("aria-label", e.muted ? "Unmute media" : "Mute media"), l = e.muted), o) {
66
+ const n = o, c = Number.isFinite(e.duration) ? e.duration : 0;
67
+ o.setAttribute("max", String(c || 0)), n.value = e.currentTime || 0;
68
+ }
69
+ if (a) {
70
+ const n = Number.isFinite(e.duration) ? e.duration : 0, c = Math.max(0, n - e.currentTime);
71
+ a.textContent = this.countdownMode ? `-${this.formatTime(c)} / ${this.formatTime(n)}` : `${this.formatTime(e.currentTime)} / ${this.formatTime(n)}`, a.setAttribute("aria-pressed", String(this.countdownMode));
72
+ }
73
+ };
74
+ t == null || t.addEventListener("click", () => {
75
+ e.paused ? e.play().catch(() => {
76
+ }) : e.pause();
77
+ }), i == null || i.addEventListener("click", () => {
78
+ e.muted = !e.muted, r();
79
+ }), o == null || o.addEventListener("input", (s) => {
80
+ const n = s.detail || {};
81
+ e.currentTime = Number(n.value || 0), r();
82
+ }), a == null || a.addEventListener("click", () => {
83
+ this.countdownMode = !this.countdownMode, r();
84
+ }), e.addEventListener("timeupdate", r), e.addEventListener("loadedmetadata", r), e.addEventListener("play", r), e.addEventListener("pause", r), r();
85
+ }
86
+ render() {
87
+ if (!this.shadowRoot) return;
88
+ const e = this.getAttribute("src") || "", t = this.getAttribute("poster") || "", i = this.hasAttribute("muted"), o = this.hasAttribute("autoplay"), a = this.hasAttribute("loop"), u = this.resolveType(e), d = this.getAttribute("prefer-native-controls") !== "false", l = u === "youtube" ? `<div class="media-shell video-shell">
89
+ <iframe class="embed" src="${this.getYouTubeEmbed(e)}" title="Video preview" loading="lazy" allow="autoplay; encrypted-media; picture-in-picture" allowfullscreen></iframe>
90
+ </div>` : u === "soundcloud" ? `<div class="media-shell soundcloud-shell">
91
+ <iframe class="embed soundcloud" src="${this.getSoundcloudEmbed(e)}" title="Audio preview" loading="lazy"></iframe>
92
+ </div>` : u === "video" ? `<div class="media-shell video-shell">
93
+ <video ${o ? "autoplay" : ""} ${i ? "muted" : ""} ${a ? "loop" : ""} ${d ? "controls" : ""} ${t ? `poster="${t.replace(/"/g, "&quot;")}"` : ""} playsinline src="${e.replace(/"/g, "&quot;")}"></video>
94
+ </div>` : `<audio ${o ? "autoplay" : ""} ${i ? "muted" : ""} ${a ? "loop" : ""} ${d ? "controls" : ""} src="${e.replace(/"/g, "&quot;")}"></audio>`, s = (u === "video" || u === "audio") && !d;
95
+ this.shadowRoot.innerHTML = /*html*/
96
+ `
97
+ <style>
98
+ :host {
99
+ display: block;
100
+ width: 100%;
101
+ }
102
+ .frame {
103
+ width: 100%;
104
+ display: grid;
105
+ }
106
+ .media-shell {
107
+ position: relative;
108
+ width: 100%;
109
+ border-radius: var(--radius-100);
110
+ overflow: hidden;
111
+ background: var(--surface-elevated-200);
112
+ }
113
+ .video-shell {
114
+ aspect-ratio: var(--media-player-video-ratio, 16 / 9);
115
+ }
116
+ .soundcloud-shell {
117
+ aspect-ratio: var(--media-player-soundcloud-ratio, 16 / 5);
118
+ min-height: 16rem;
119
+ }
120
+ .media-shell > video,
121
+ .media-shell > .embed {
122
+ position: absolute;
123
+ inset: 0;
124
+ width: 100%;
125
+ height: 100%;
126
+ }
127
+ video,
128
+ audio {
129
+ width: 100%;
130
+ background: var(--surface-elevated-100);
131
+ }
132
+ video {
133
+ object-fit: cover;
134
+ }
135
+ .embed {
136
+ border: 0;
137
+ background: var(--surface-elevated-100);
138
+ }
139
+ .controls {
140
+ display: inline-flex;
141
+ width: 100%;
142
+ align-items: center;
143
+ padding: var(--space-100);
144
+ box-sizing: border-box;
145
+ }
146
+ .controls mui-range-input {
147
+ flex: 1 1 auto;
148
+ min-width: 0;
149
+ --range-input-accent-color: var(--media-player-seek-color, var(--grey-1200));
150
+ --range-input-bubble-background: var(--media-player-seek-time-background, var(--surface-elevated-100));
151
+ --range-input-bubble-border-color: var(--media-player-seek-time-border-color, var(--border-color));
152
+ }
153
+ [data-action="time-mode"] {
154
+ white-space: nowrap;
155
+ flex: 0 0 auto;
156
+ }
157
+
158
+ </style>
159
+ <div class="frame">
160
+ ${l}
161
+ ${s ? `<div class="controls">
162
+ <mui-hint placement="top">
163
+ <mui-button slot="trigger" data-action="play" size="x-small" icon-only variant="tertiary" aria-label="Play media">
164
+ <mui-icon-play-rectangle size="x-small"></mui-icon-play-rectangle>
165
+ </mui-button>
166
+ Play/Stop
167
+ </mui-hint>
168
+ <mui-range-input data-action="seek" min="0" max="0" value="0" step="0.1" bubble bubble-format="time" label="Media seek"></mui-range-input>
169
+ <mui-hint placement="top">
170
+ <mui-button slot="trigger" data-action="mute" size="x-small" icon-only variant="tertiary" aria-label="Mute media">
171
+ <mui-icon-music-microphone size="x-small"></mui-icon-music-microphone>
172
+ </mui-button>
173
+ Mute
174
+ </mui-hint>
175
+ <mui-hint placement="top">
176
+ <mui-button slot="trigger" data-action="time-mode" size="x-small" variant="tertiary" aria-pressed="false">0:00 / 0:00</mui-button>
177
+ Time
178
+ </mui-hint>
179
+ </div>` : ""}
180
+ </div>
181
+ `;
182
+ }
183
+ }
184
+ customElements.get("mui-media-player") || customElements.define("mui-media-player", m);
@@ -5,49 +5,79 @@ import "../mui-icons/check/index.js";
5
5
  import "../mui-icons/info/index.js";
6
6
  import "../mui-icons/warning/index.js";
7
7
  import "../mui-icons/attention/index.js";
8
- const l = ["neutral", "positive", "info", "warning", "attention"], g = {
8
+ const f = ["neutral", "positive", "info", "warning", "attention"], h = {
9
9
  neutral: "background-color: var(--feedback-neutral-background); border: var(--feedback-neutral-border);",
10
10
  positive: "background-color: var(--feedback-positive-background); border: var(--feedback-positive-border);",
11
11
  info: "background-color: var(--feedback-info-background); border: var(--feedback-info-border);",
12
12
  warning: "background-color: var(--feedback-warning-background); border: var(--feedback-warning-border);",
13
13
  attention: "background-color: var(--feedback-attention-background); border: var(--feedback-attention-border);"
14
- }, b = {
14
+ }, p = {
15
15
  neutral: "polite",
16
16
  positive: "polite",
17
17
  info: "polite",
18
18
  warning: "assertive",
19
19
  attention: "assertive"
20
- }, u = {
20
+ }, k = {
21
21
  neutral: "status",
22
22
  positive: "status",
23
23
  info: "status",
24
24
  warning: "alert",
25
25
  attention: "alert"
26
- }, v = {
26
+ }, S = {
27
27
  neutral: "--feedback-neutral-icon",
28
28
  positive: "--feedback-positive-icon",
29
29
  info: "--feedback-info-icon",
30
30
  warning: "--feedback-warning-icon",
31
31
  attention: "--feedback-attention-icon"
32
- }, f = {
32
+ }, w = {
33
33
  neutral: "color: var(--feedback-neutral-text);",
34
34
  positive: "color: var(--feedback-positive-text);",
35
35
  info: "color: var(--feedback-info-text);",
36
36
  warning: "color: var(--feedback-warning-text);",
37
37
  attention: "color: var(--feedback-attention-text);"
38
- }, m = {
38
+ }, z = {
39
39
  neutral: "mui-icon-message",
40
40
  positive: "mui-icon-check",
41
41
  info: "mui-icon-info",
42
42
  warning: "mui-icon-warning",
43
43
  attention: "mui-icon-attention"
44
44
  };
45
- class k extends HTMLElement {
45
+ class C extends HTMLElement {
46
46
  constructor() {
47
- super(), this.attachShadow({ mode: "open" });
47
+ super(), this.contentSlotListener = null, this.attachShadow({ mode: "open" });
48
+ }
49
+ static get observedAttributes() {
50
+ return ["variant", "heading", "icon", "size"];
48
51
  }
49
52
  connectedCallback() {
50
- const t = this.getAttribute("variant") || "neutral", e = l.includes(t) ? t : "neutral", a = this.getAttribute("heading") || "Heading...", o = this.getAttribute("icon") || m[e], i = v[e], n = f[e], r = g[e], s = b[e], c = u[e], d = (
53
+ this.render();
54
+ }
55
+ attributeChangedCallback(e, t, n) {
56
+ t !== n && (e === "variant" || e === "heading" || e === "icon" || e === "size") && this.render();
57
+ }
58
+ getMessageSize() {
59
+ const e = this.getAttribute("size");
60
+ return e === "small" || e === "medium" ? e : "large";
61
+ }
62
+ getInlineContentSize(e) {
63
+ return e === "small" ? "x-small" : e === "medium" ? "small" : "medium";
64
+ }
65
+ setupContentSlot(e) {
66
+ var i;
67
+ const t = (i = this.shadowRoot) == null ? void 0 : i.querySelector("slot:not([name])");
68
+ if (!t) return;
69
+ this.contentSlotListener && t.removeEventListener("slotchange", this.contentSlotListener);
70
+ const n = () => {
71
+ const s = this.getInlineContentSize(e);
72
+ t.assignedElements({ flatten: !0 }).forEach((o) => {
73
+ const a = o.tagName.toLowerCase();
74
+ (a === "mui-body" || a === "mui-link") && o.setAttribute("size", s);
75
+ });
76
+ };
77
+ this.contentSlotListener = n, t.addEventListener("slotchange", this.contentSlotListener), requestAnimationFrame(n);
78
+ }
79
+ render() {
80
+ const e = this.getAttribute("variant") || "neutral", t = f.includes(e) ? e : "neutral", n = this.getMessageSize(), i = this.getAttribute("heading") || "Heading...", r = this.getAttribute("icon") || z[t], o = S[t], a = w[t], c = h[t], l = p[t], d = k[t], g = n === "large" ? "var(--message-gap-horizontal)" : n === "medium" ? "var(--space-200)" : "var(--space-100)", u = n === "large" ? "var(--message-gap-vertical)" : n === "medium" ? "var(--space-100)" : "var(--space-050)", v = n === "large" ? "var(--font-size-200)" : "var(--font-size-100)", b = n === "large" ? "medium" : "small", m = (
51
81
  /*css*/
52
82
  `
53
83
  :host {
@@ -59,7 +89,7 @@ class k extends HTMLElement {
59
89
  section {
60
90
  padding: var(--message-padding);
61
91
  border-radius: var(--message-radius);
62
- ${r}
92
+ ${c}
63
93
  }
64
94
 
65
95
  .icon {
@@ -69,27 +99,27 @@ class k extends HTMLElement {
69
99
 
70
100
  .heading {
71
101
  font-weight: var(--font-weight-bold);
72
- font-size: var(--font-size-200);
73
- ${n}
102
+ font-size: ${v};
103
+ ${a}
74
104
  }
75
105
  `
76
106
  );
77
107
  this.shadowRoot && (this.shadowRoot.innerHTML = /*html*/
78
108
  `
79
- <style>${d}</style>
109
+ <style>${m}</style>
80
110
 
81
- <section aria-labelledby="message-heading" aria-live="${s}" role="${c}">
82
- <mui-h-stack space="var(--message-gap-horizontal)">
111
+ <section aria-labelledby="message-heading" aria-live="${l}" role="${d}">
112
+ <mui-h-stack space="${g}">
83
113
  <div class="icon">
84
- <${o} size="medium" color="var(${i})"></${o}>
114
+ <${r} size="${b}" color="var(${o})"></${r}>
85
115
  </div>
86
- <mui-v-stack space="var(--message-gap-vertical)">
87
- <div class="heading" id="message-heading">${a}</div>
116
+ <mui-v-stack space="${u}">
117
+ <div class="heading" id="message-heading">${i}</div>
88
118
  <slot></slot>
89
119
  </mui-v-stack>
90
120
  </mui-h-stack>
91
121
  </section>
92
- `);
122
+ `, this.setupContentSlot(n));
93
123
  }
94
124
  }
95
- customElements.get("mui-message") || customElements.define("mui-message", k);
125
+ customElements.get("mui-message") || customElements.define("mui-message", C);
@@ -12,19 +12,19 @@ class o extends HTMLElement {
12
12
  this.render();
13
13
  }
14
14
  render() {
15
- const a = Math.min(Math.max(Number(this.getAttribute("progress") || 0), 0), 100), e = this.getAttribute("state");
16
- let r = `${a}%`, s = "none", t = "";
17
- e === "syncing" ? (r = "30%", s = "slideAnim calc(var(--speed-400) * 4) linear infinite") : e === "pending" && (r = "100%", s = "zebraAnim calc(var(--speed-300) * 4) linear infinite", t = `
15
+ const t = Math.min(Math.max(Number(this.getAttribute("progress") || 0), 0), 100), r = this.getAttribute("state");
16
+ let e = `${t}%`, s = "none", i = "", a = "var(--progress-radius) 0 0 var(--progress-radius)";
17
+ r === "syncing" ? (e = "var(--progress-syncing-width)", s = "slideAnim calc(var(--speed-400) * 4) linear infinite", a = "var(--progress-radius)") : r === "pending" && (e = "100%", s = "zebraAnim calc(var(--speed-300) * 4) linear infinite", a = "var(--progress-radius)", i = `
18
18
  background-image: repeating-linear-gradient(
19
19
  45deg,
20
20
  var(--progress-loading-bar-100) 0,
21
- var(--progress-loading-bar-100) 10px,
22
- var(--progress-loading-bar-200) 10px,
23
- var(--progress-loading-bar-200) 20px
21
+ var(--progress-loading-bar-100) var(--progress-pending-stripe-size),
22
+ var(--progress-loading-bar-200) var(--progress-pending-stripe-size),
23
+ var(--progress-loading-bar-200) calc(var(--progress-pending-stripe-size) * 2)
24
24
  );
25
25
  background-size: 200% 100%;
26
26
  `);
27
- const i = (
27
+ const n = (
28
28
  /*css*/
29
29
  `
30
30
  :host {
@@ -35,21 +35,21 @@ class o extends HTMLElement {
35
35
  width: 100%;
36
36
  height: var(--space-300);
37
37
  background-color: var(--progress-track-background);
38
- border-radius: var(--space-300);
38
+ border-radius: var(--progress-radius);
39
39
  overflow: hidden;
40
40
  position: relative;
41
41
  }
42
42
  .progress-bar {
43
43
  height: 100%;
44
- width: ${r};
45
- background-color: var(--progress-bar-background);
46
- border-radius: var(--space-300) 0 0 var(--space-300);
44
+ width: ${e};
45
+ background-color: ${r === "syncing" ? "var(--progress-syncing-bar-background)" : "var(--progress-bar-background)"};
46
+ border-radius: ${a};
47
47
  position: absolute;
48
48
  left: 0;
49
49
  top: 0;
50
- transition: ${e ? "none" : "width var(--speed-300) ease"};
50
+ transition: ${r ? "none" : "width var(--speed-300) ease"};
51
51
  animation: ${s};
52
- ${t}
52
+ ${i}
53
53
  }
54
54
 
55
55
  @keyframes slideAnim {
@@ -59,13 +59,13 @@ class o extends HTMLElement {
59
59
 
60
60
  @keyframes zebraAnim {
61
61
  0% { background-position: 0 0; }
62
- 100% { background-position: 40px 0; }
62
+ 100% { background-position: calc(var(--progress-pending-stripe-size) * 4) 0; }
63
63
  }
64
64
  `
65
65
  );
66
66
  this.shadowRoot.innerHTML = /*html*/
67
67
  `
68
- <style>${i}</style>
68
+ <style>${n}</style>
69
69
  <div class="progress-container">
70
70
  <div class="progress-bar"></div>
71
71
  </div>