@sbb-esta/lyne-elements-dev 4.9.0-dev.1775144212 → 4.9.0-dev.1775154606

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.
@@ -1 +1 @@
1
- {"version":3,"file":"icon-request.d.ts","sourceRoot":"","sources":["../../../../src/elements/icon/icon-request.ts"],"names":[],"mappings":"AAcA,6FAA6F;AAC7F,eAAO,MAAM,aAAa,GACxB,WAAW,MAAM,EACjB,MAAM,MAAM,EACZ,UAAU,OAAO,KAChB,OAAO,CAAC,MAAM,CA6ChB,CAAC"}
1
+ {"version":3,"file":"icon-request.d.ts","sourceRoot":"","sources":["../../../../src/elements/icon/icon-request.ts"],"names":[],"mappings":"AAcA,6FAA6F;AAC7F,eAAO,MAAM,aAAa,GACxB,WAAW,MAAM,EACjB,MAAM,MAAM,EACZ,UAAU,OAAO,KAChB,OAAO,CAAC,MAAM,CA8ChB,CAAC"}
@@ -21,7 +21,8 @@ var getSvgContent = (namespace, name, sanitize) => {
21
21
  if (!response.ok) throw new Error(`Failed to load icon ${namespace}:${name}`);
22
22
  return validateContent(await response.text(), sanitize);
23
23
  }).catch((error) => {
24
- throw Error(error);
24
+ console.warn(error);
25
+ return "";
25
26
  })
26
27
  });
27
28
  requests.set(url, req);
@@ -31,4 +32,4 @@ var getSvgContent = (namespace, name, sanitize) => {
31
32
  //#endregion
32
33
  export { getSvgContent };
33
34
 
34
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi1yZXF1ZXN0LmpzIiwibmFtZXMiOltdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9pY29uL2ljb24tcmVxdWVzdC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc1NlcnZlciB9IGZyb20gJ2xpdCc7XG5cbmltcG9ydCB0eXBlIHsgU2JiSWNvbkNvbmZpZyB9IGZyb20gJy4uL2NvcmUvY29uZmlnLnRzJztcbmltcG9ydCB7IHJlYWRDb25maWcgfSBmcm9tICcuLi9jb3JlL2NvbmZpZy50cyc7XG5cbmltcG9ydCB7IHZhbGlkYXRlQ29udGVudCB9IGZyb20gJy4vaWNvbi12YWxpZGF0ZS50cyc7XG5cbmNvbnN0IGljb25DZG4gPSAnaHR0cHM6Ly9pY29ucy5hcHAuc2JiLmNoLyc7XG5cbmNvbnN0IGljb25OYW1lc3BhY2VzID0gbmV3IE1hcDxzdHJpbmcsIHN0cmluZz4oKVxuICAuc2V0KCdkZWZhdWx0JywgYCR7aWNvbkNkbn1pY29ucy9gKVxuICAuc2V0KCdwaWN0bycsIGAke2ljb25DZG59cGljdG8vYCk7XG5jb25zdCByZXF1ZXN0cyA9IG5ldyBNYXA8c3RyaW5nLCBQcm9taXNlPGFueT4+KCk7XG5cbi8qKiBGZXRjaGVzIGljb24gc3ZnIGNvbnRlbnQgZnJvbSBwcm92aWRlcnMgYW5kIGFzc2VydHMgb25seSBvbmUgcmVxdWVzdCBwZXIgaWNvbiBpcyBtYWRlLiAqL1xuZXhwb3J0IGNvbnN0IGdldFN2Z0NvbnRlbnQgPSAoXG4gIG5hbWVzcGFjZTogc3RyaW5nLFxuICBuYW1lOiBzdHJpbmcsXG4gIHNhbml0aXplOiBib29sZWFuLFxuKTogUHJvbWlzZTxzdHJpbmc+ID0+IHtcbiAgY29uc3QgY29uZmlnOiBTYmJJY29uQ29uZmlnID0gcmVhZENvbmZpZygpLmljb24gPz8ge307XG5cbiAgY29uc3QgcmVzb2x2ZWROYW1lc3BhY2UgPSBjb25maWcubmFtZXNwYWNlcz8uZ2V0KG5hbWVzcGFjZSkgPz8gaWNvbk5hbWVzcGFjZXMuZ2V0KG5hbWVzcGFjZSk7XG4gIGlmIChyZXNvbHZlZE5hbWVzcGFjZSA9PSBudWxsKSB7XG4gICAgdGhyb3cgRXJyb3IoXG4gICAgICBgVW5hYmxlIHRvIGZpbmQgdGhlIG5hbWVzcGFjZSBcIiR7bmFtZXNwYWNlfVwiLiBQbGVhc2UgcmVnaXN0ZXIgeW91ciBjdXN0b20gbmFtZXNwYWNlLmAsXG4gICAgKTtcbiAgfVxuICBjb25zdCB1cmwgPSBgJHtyZXNvbHZlZE5hbWVzcGFjZX0ke25hbWV9LnN2Z2A7XG5cbiAgLy8gQ2hlY2sgaWYgd2UgYWxyZWFkeSBoYXZlIGEgcmVxdWVzdCBmb3IgdGhpcyB1cmxcbiAgbGV0IHJlcSA9IHJlcXVlc3RzLmdldCh1cmwpO1xuXG4gIGlmICghcmVxKSB7XG4gICAgLy8gV2UgY2Fubm90IHN1cHBvcnQgc2VydmVyIHNpZGUgcmVuZGVyZWQgaWNvbnMgKHlldCksIGFzIHRoZSB2YWxpZGF0aW9uXG4gICAgLy8gaXMgZG9uZSB2aWEgRE9NLCB3aGljaCBpcyBub3QgYXZhaWxhYmxlIGR1cmluZyBTU1IuXG4gICAgaWYgKHR5cGVvZiBmZXRjaCAhPT0gJ3VuZGVmaW5lZCcgJiYgIWlzU2VydmVyKSB7XG4gICAgICBjb25zdCBpbnRlcmNlcHRvciA9IGNvbmZpZy5pbnRlcmNlcHRvciA/PyAoKGkpID0+IGkucmVxdWVzdCgpKTtcblxuICAgICAgcmVxID0gaW50ZXJjZXB0b3Ioe1xuICAgICAgICBuYW1lc3BhY2UsXG4gICAgICAgIG5hbWUsXG4gICAgICAgIHVybCxcbiAgICAgICAgcmVxdWVzdDogKCkgPT5cbiAgICAgICAgICBmZXRjaCh1cmwpXG4gICAgICAgICAgICAudGhlbihhc3luYyAocmVzcG9uc2UpID0+IHtcbiAgICAgICAgICAgICAgaWYgKCFyZXNwb25zZS5vaykge1xuICAgICAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgRmFpbGVkIHRvIGxvYWQgaWNvbiAke25hbWVzcGFjZX06JHtuYW1lfWApO1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIHJldHVybiB2YWxpZGF0ZUNvbnRlbnQoYXdhaXQgcmVzcG9uc2UudGV4dCgpLCBzYW5pdGl6ZSk7XG4gICAgICAgICAgICB9KVxuICAgICAgICAgICAgLmNhdGNoKChlcnJvcikgPT4ge1xuICAgICAgICAgICAgICB0aHJvdyBFcnJvcihlcnJvcik7XG4gICAgICAgICAgICB9KSxcbiAgICAgIH0pO1xuICAgICAgLy8gQ2FjaGUgZm9yIHRoZSBzYW1lIHJlcXVlc3RzXG4gICAgICByZXF1ZXN0cy5zZXQodXJsLCByZXEpO1xuICAgIH0gZWxzZSB7XG4gICAgICAvLyBSZXNvbHZlIHByb21pc2UgZm9yIHNzciBzY2VuYXJpb3NcbiAgICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoJycpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiByZXE7XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7O0FBT0EsSUFBTSxVQUFVO0FBRWhCLElBQU0sa0NBQWlCLElBQUksS0FBcUIsRUFDN0MsSUFBSSxXQUFXLEdBQUcsUUFBTyxRQUFTLENBQ2xDLElBQUksU0FBUyxHQUFHLFFBQU8sUUFBUztBQUNuQyxJQUFNLDJCQUFXLElBQUksS0FBMkI7O0FBR2hELElBQWEsaUJBQ1gsV0FDQSxNQUNBLGFBQ21CO0NBQ25CLE1BQU0sU0FBd0IsWUFBWSxDQUFDLFFBQVEsRUFBRTtDQUVyRCxNQUFNLG9CQUFvQixPQUFPLFlBQVksSUFBSSxVQUFVLElBQUksZUFBZSxJQUFJLFVBQVU7QUFDNUYsS0FBSSxxQkFBcUIsS0FDdkIsT0FBTSxNQUNKLGlDQUFpQyxVQUFTLDJDQUMzQztDQUVILE1BQU0sTUFBTSxHQUFHLG9CQUFvQixLQUFJO0NBR3ZDLElBQUksTUFBTSxTQUFTLElBQUksSUFBSTtBQUUzQixLQUFJLENBQUMsSUFHSCxLQUFJLE9BQU8sVUFBVSxlQUFlLENBQUMsVUFBVTtBQUc3QyxTQUZvQixPQUFPLGlCQUFpQixNQUFNLEVBQUUsU0FBUyxHQUUzQztHQUNoQjtHQUNBO0dBQ0E7R0FDQSxlQUNFLE1BQU0sSUFBSSxDQUNQLEtBQUssT0FBTyxhQUFZO0FBQ3ZCLFFBQUksQ0FBQyxTQUFTLEdBQ1osT0FBTSxJQUFJLE1BQU0sdUJBQXVCLFVBQVMsR0FBSSxPQUFPO0FBRTdELFdBQU8sZ0JBQWdCLE1BQU0sU0FBUyxNQUFNLEVBQUUsU0FBUztLQUN2RCxDQUNELE9BQU8sVUFBUztBQUNmLFVBQU0sTUFBTSxNQUFNOztHQUV6QixDQUFDO0FBRUYsV0FBUyxJQUFJLEtBQUssSUFBSTtPQUd0QixRQUFPLFFBQVEsUUFBUSxHQUFHO0FBSTlCLFFBQU8ifQ==
35
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi1yZXF1ZXN0LmpzIiwibmFtZXMiOltdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9pY29uL2ljb24tcmVxdWVzdC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc1NlcnZlciB9IGZyb20gJ2xpdCc7XG5cbmltcG9ydCB0eXBlIHsgU2JiSWNvbkNvbmZpZyB9IGZyb20gJy4uL2NvcmUvY29uZmlnLnRzJztcbmltcG9ydCB7IHJlYWRDb25maWcgfSBmcm9tICcuLi9jb3JlL2NvbmZpZy50cyc7XG5cbmltcG9ydCB7IHZhbGlkYXRlQ29udGVudCB9IGZyb20gJy4vaWNvbi12YWxpZGF0ZS50cyc7XG5cbmNvbnN0IGljb25DZG4gPSAnaHR0cHM6Ly9pY29ucy5hcHAuc2JiLmNoLyc7XG5cbmNvbnN0IGljb25OYW1lc3BhY2VzID0gbmV3IE1hcDxzdHJpbmcsIHN0cmluZz4oKVxuICAuc2V0KCdkZWZhdWx0JywgYCR7aWNvbkNkbn1pY29ucy9gKVxuICAuc2V0KCdwaWN0bycsIGAke2ljb25DZG59cGljdG8vYCk7XG5jb25zdCByZXF1ZXN0cyA9IG5ldyBNYXA8c3RyaW5nLCBQcm9taXNlPGFueT4+KCk7XG5cbi8qKiBGZXRjaGVzIGljb24gc3ZnIGNvbnRlbnQgZnJvbSBwcm92aWRlcnMgYW5kIGFzc2VydHMgb25seSBvbmUgcmVxdWVzdCBwZXIgaWNvbiBpcyBtYWRlLiAqL1xuZXhwb3J0IGNvbnN0IGdldFN2Z0NvbnRlbnQgPSAoXG4gIG5hbWVzcGFjZTogc3RyaW5nLFxuICBuYW1lOiBzdHJpbmcsXG4gIHNhbml0aXplOiBib29sZWFuLFxuKTogUHJvbWlzZTxzdHJpbmc+ID0+IHtcbiAgY29uc3QgY29uZmlnOiBTYmJJY29uQ29uZmlnID0gcmVhZENvbmZpZygpLmljb24gPz8ge307XG5cbiAgY29uc3QgcmVzb2x2ZWROYW1lc3BhY2UgPSBjb25maWcubmFtZXNwYWNlcz8uZ2V0KG5hbWVzcGFjZSkgPz8gaWNvbk5hbWVzcGFjZXMuZ2V0KG5hbWVzcGFjZSk7XG4gIGlmIChyZXNvbHZlZE5hbWVzcGFjZSA9PSBudWxsKSB7XG4gICAgdGhyb3cgRXJyb3IoXG4gICAgICBgVW5hYmxlIHRvIGZpbmQgdGhlIG5hbWVzcGFjZSBcIiR7bmFtZXNwYWNlfVwiLiBQbGVhc2UgcmVnaXN0ZXIgeW91ciBjdXN0b20gbmFtZXNwYWNlLmAsXG4gICAgKTtcbiAgfVxuICBjb25zdCB1cmwgPSBgJHtyZXNvbHZlZE5hbWVzcGFjZX0ke25hbWV9LnN2Z2A7XG5cbiAgLy8gQ2hlY2sgaWYgd2UgYWxyZWFkeSBoYXZlIGEgcmVxdWVzdCBmb3IgdGhpcyB1cmxcbiAgbGV0IHJlcSA9IHJlcXVlc3RzLmdldCh1cmwpO1xuXG4gIGlmICghcmVxKSB7XG4gICAgLy8gV2UgY2Fubm90IHN1cHBvcnQgc2VydmVyIHNpZGUgcmVuZGVyZWQgaWNvbnMgKHlldCksIGFzIHRoZSB2YWxpZGF0aW9uXG4gICAgLy8gaXMgZG9uZSB2aWEgRE9NLCB3aGljaCBpcyBub3QgYXZhaWxhYmxlIGR1cmluZyBTU1IuXG4gICAgaWYgKHR5cGVvZiBmZXRjaCAhPT0gJ3VuZGVmaW5lZCcgJiYgIWlzU2VydmVyKSB7XG4gICAgICBjb25zdCBpbnRlcmNlcHRvciA9IGNvbmZpZy5pbnRlcmNlcHRvciA/PyAoKGkpID0+IGkucmVxdWVzdCgpKTtcblxuICAgICAgcmVxID0gaW50ZXJjZXB0b3Ioe1xuICAgICAgICBuYW1lc3BhY2UsXG4gICAgICAgIG5hbWUsXG4gICAgICAgIHVybCxcbiAgICAgICAgcmVxdWVzdDogKCkgPT5cbiAgICAgICAgICBmZXRjaCh1cmwpXG4gICAgICAgICAgICAudGhlbihhc3luYyAocmVzcG9uc2UpID0+IHtcbiAgICAgICAgICAgICAgaWYgKCFyZXNwb25zZS5vaykge1xuICAgICAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgRmFpbGVkIHRvIGxvYWQgaWNvbiAke25hbWVzcGFjZX06JHtuYW1lfWApO1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIHJldHVybiB2YWxpZGF0ZUNvbnRlbnQoYXdhaXQgcmVzcG9uc2UudGV4dCgpLCBzYW5pdGl6ZSk7XG4gICAgICAgICAgICB9KVxuICAgICAgICAgICAgLmNhdGNoKChlcnJvcikgPT4ge1xuICAgICAgICAgICAgICBjb25zb2xlLndhcm4oZXJyb3IpO1xuICAgICAgICAgICAgICByZXR1cm4gJyc7XG4gICAgICAgICAgICB9KSxcbiAgICAgIH0pO1xuICAgICAgLy8gQ2FjaGUgZm9yIHRoZSBzYW1lIHJlcXVlc3RzXG4gICAgICByZXF1ZXN0cy5zZXQodXJsLCByZXEpO1xuICAgIH0gZWxzZSB7XG4gICAgICAvLyBSZXNvbHZlIHByb21pc2UgZm9yIHNzciBzY2VuYXJpb3NcbiAgICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoJycpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiByZXE7XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7O0FBT0EsSUFBTSxVQUFVO0FBRWhCLElBQU0sa0NBQWlCLElBQUksS0FBcUIsRUFDN0MsSUFBSSxXQUFXLEdBQUcsUUFBTyxRQUFTLENBQ2xDLElBQUksU0FBUyxHQUFHLFFBQU8sUUFBUztBQUNuQyxJQUFNLDJCQUFXLElBQUksS0FBMkI7O0FBR2hELElBQWEsaUJBQ1gsV0FDQSxNQUNBLGFBQ21CO0NBQ25CLE1BQU0sU0FBd0IsWUFBWSxDQUFDLFFBQVEsRUFBRTtDQUVyRCxNQUFNLG9CQUFvQixPQUFPLFlBQVksSUFBSSxVQUFVLElBQUksZUFBZSxJQUFJLFVBQVU7QUFDNUYsS0FBSSxxQkFBcUIsS0FDdkIsT0FBTSxNQUNKLGlDQUFpQyxVQUFTLDJDQUMzQztDQUVILE1BQU0sTUFBTSxHQUFHLG9CQUFvQixLQUFJO0NBR3ZDLElBQUksTUFBTSxTQUFTLElBQUksSUFBSTtBQUUzQixLQUFJLENBQUMsSUFHSCxLQUFJLE9BQU8sVUFBVSxlQUFlLENBQUMsVUFBVTtBQUc3QyxTQUZvQixPQUFPLGlCQUFpQixNQUFNLEVBQUUsU0FBUyxHQUUzQztHQUNoQjtHQUNBO0dBQ0E7R0FDQSxlQUNFLE1BQU0sSUFBSSxDQUNQLEtBQUssT0FBTyxhQUFZO0FBQ3ZCLFFBQUksQ0FBQyxTQUFTLEdBQ1osT0FBTSxJQUFJLE1BQU0sdUJBQXVCLFVBQVMsR0FBSSxPQUFPO0FBRTdELFdBQU8sZ0JBQWdCLE1BQU0sU0FBUyxNQUFNLEVBQUUsU0FBUztLQUN2RCxDQUNELE9BQU8sVUFBUztBQUNmLFlBQVEsS0FBSyxNQUFNO0FBQ25CLFdBQU87O0dBRWQsQ0FBQztBQUVGLFdBQVMsSUFBSSxLQUFLLElBQUk7T0FHdEIsUUFBTyxRQUFRLFFBQVEsR0FBRztBQUk5QixRQUFPIn0=
@@ -158,7 +158,7 @@ var SbbOverlayBaseElement = (() => {
158
158
  }
159
159
  _close(result, target) {
160
160
  if (this.state === "closing" || this.state === "closed") return;
161
- this.returnValue = result;
161
+ this.returnValue = result ?? null;
162
162
  this.overlayCloseElement = target;
163
163
  if (!this.dispatchBeforeCloseEvent()) return;
164
164
  this.state = "closing";
@@ -244,4 +244,4 @@ var SbbOverlayBaseElement = (() => {
244
244
  //#endregion
245
245
  export { SbbOverlayBaseElement, SbbOverlayCloseEvent, assignOverlayResult, overlayRefs };
246
246
 
247
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"overlay-base-element.js","names":[],"sources":["../../../../src/elements/overlay/overlay-base-element.ts"],"sourcesContent":["import { isServer, type PropertyDeclaration, type PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbFocusTrapController } from '../core/a11y.ts';\nimport { SbbOpenCloseBaseElement } from '../core/base-elements.ts';\nimport {\n  SbbEscapableOverlayController,\n  SbbInertController,\n  SbbLanguageController,\n} from '../core/controllers.ts';\nimport { forceType, idReference } from '../core/decorators.ts';\nimport { SbbScrollHandler } from '../core/dom.ts';\nimport { i18nDialog } from '../core/i18n.ts';\nimport type { SbbOverlayCloseEventDetails } from '../core/interfaces.ts';\nimport { SbbNegativeMixin } from '../core/mixins.ts';\nimport {\n  removeAriaOverlayTriggerAttributes,\n  setAriaOverlayTriggerAttributes,\n} from '../core/overlay.ts';\nimport type { SbbScreenReaderOnlyElement } from '../screen-reader-only.ts';\n\nconst overlayResultMap = new WeakMap<HTMLElement, any>();\n\nexport class SbbOverlayCloseEvent<T = any> extends CustomEvent<SbbOverlayCloseEventDetails> {\n  /**\n   * The result associated with the closed overlay.\n   * This is either the result assigned to the `closeTarget` via\n   * `assignOverlayResult` / `assignDialogResult` or the value of the\n   * corresponding close attribute on the `closeTarget`\n   * (e.g. sbb-overlay-close=\"my-result\" or sbb-dialog-close=\"my-result\").\n   */\n  public readonly result: T | null;\n\n  /**\n   * The element that was used to close the overlay/dialog, i.e. the element that the\n   * user clicked on that had the close attribute.\n   * Empty if closed programmatically or via Escape press.\n   */\n  public readonly closeTarget: HTMLElement | null;\n\n  public constructor(\n    name: string,\n    {\n      cancelable,\n      closeAttribute,\n      closeTarget,\n      result,\n    }: { cancelable?: boolean; closeAttribute: string; closeTarget?: HTMLElement; result?: any },\n  ) {\n    // TODO: Remove detail and change base class to Event\n    super(name, { cancelable, detail: { returnValue: result, closeTarget } });\n\n    this.result =\n      result ??\n      (!closeTarget\n        ? null\n        : (overlayResultMap.get(closeTarget) ??\n          (closeTarget.getAttribute(closeAttribute)?.trim() || null)));\n    this.closeTarget = closeTarget ?? null;\n  }\n}\n\nexport function assignOverlayResult<T>(element: HTMLElement, result: T): void {\n  overlayResultMap.set(element, result);\n}\n\n// A global collection of existing overlays.\nexport const overlayRefs: SbbOverlayBaseElement[] = [];\n\nexport abstract class SbbOverlayBaseElement extends SbbNegativeMixin(SbbOpenCloseBaseElement) {\n  /**\n   * The element that will trigger the menu overlay.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor trigger: HTMLElement | null = null;\n\n  /** This will be forwarded as aria-label to the relevant nested element to describe the purpose of the overlay. */\n  @forceType()\n  @property({ attribute: 'accessibility-label' })\n  public accessor accessibilityLabel: string = '';\n\n  /**\n   * Whether to skip restoring focus to the previously-focused element when the overlay is closed.\n   * Note that automatic focus restoration is an accessibility feature, and it is recommended that\n   * you provide your own equivalent, if you decide to turn it off.\n   */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor skipFocusRestoration: boolean = false;\n\n  // The last element which had focus before the component was opened.\n  protected lastFocusedElement?: HTMLElement;\n  // TODO: rename to lastClosedTarget\n  protected overlayCloseElement?: HTMLElement;\n  protected openOverlayController?: AbortController;\n  protected focusTrapController = new SbbFocusTrapController(this);\n  protected scrollHandler = new SbbScrollHandler();\n  // TODO: rename to lastResult\n  protected returnValue: any;\n  protected language = new SbbLanguageController(this);\n  protected inertController = new SbbInertController(this);\n  protected escapableOverlayController = new SbbEscapableOverlayController(this);\n\n  private _ariaLiveRefToggle = false;\n  private _ariaLiveRef?: SbbScreenReaderOnlyElement;\n  private _triggerElement: HTMLElement | null = null;\n  private _triggerAbortController?: AbortController;\n\n  protected abstract closeAttribute: string;\n  protected closeTag?: string;\n  protected abstract handleOpening(): void;\n  protected abstract handleClosing(): void;\n  protected abstract isZeroAnimationDuration(): boolean;\n  protected abstract override dispatchBeforeCloseEvent(\n    detail?: SbbOverlayCloseEventDetails,\n  ): boolean;\n\n  protected abstract override dispatchCloseEvent(detail?: SbbOverlayCloseEventDetails): boolean;\n\n  /** Opens the component. */\n  public open(): void {\n    if (\n      this.state === 'opening' ||\n      this.state === 'opened' ||\n      this._hasClosedParent() ||\n      !this.dispatchBeforeOpenEvent()\n    ) {\n      return;\n    }\n\n    this.lastFocusedElement = document.activeElement as HTMLElement;\n\n    this.showPopover?.();\n    this.state = 'opening';\n    this._triggerElement?.setAttribute('aria-expanded', 'true');\n\n    // Add this overlay to the global collection\n    overlayRefs.push(this);\n\n    this.scrollHandler.disableScroll();\n    this.escapableOverlayController.connect();\n    this.attachOpenOverlayEvents();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `opened` state.\n    if (this.isZeroAnimationDuration()) {\n      this.handleOpening();\n    }\n  }\n\n  /** Closes the component. */\n  public close(result?: any): void;\n  /** @deprecated */\n  public close(result?: any, target?: HTMLElement): void;\n  public close(result?: any, target?: HTMLElement): void {\n    this._close(result, target);\n  }\n\n  private _close(result: any, target: HTMLElement | undefined): void {\n    if (this.state === 'closing' || this.state === 'closed') {\n      return;\n    }\n\n    this.returnValue = result;\n    this.overlayCloseElement = target;\n    if (!this.dispatchBeforeCloseEvent()) {\n      return;\n    }\n    this.state = 'closing';\n    this._triggerElement?.setAttribute('aria-expanded', 'false');\n    this.removeAriaLiveRefContent();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `closed` state.\n    if (this.isZeroAnimationDuration()) {\n      this.handleClosing();\n    }\n  }\n\n  /**\n   * Check if there is a parent dialog or overlay in the DOM that is closed.\n   * In this case, the overlay should not be opened because it would break the state.\n   * Not nested but stacked overlays are supported so this logic does not apply in this case.\n   */\n  private _hasClosedParent(): boolean {\n    const parentDialog =\n      this.parentElement?.closest<SbbOverlayBaseElement>('sbb-dialog, sbb-overlay');\n\n    return (parentDialog?.state === 'closed' || parentDialog?.state === 'closing') ?? false;\n  }\n\n  public override connectedCallback(): void {\n    this.popover = 'manual';\n    super.connectedCallback();\n    if (this.hasUpdated) {\n      this._configureTrigger();\n    }\n  }\n\n  // Check if the trigger is valid and attach click event listeners.\n  private _configureTrigger(): void {\n    if (this.trigger === this._triggerElement) {\n      return;\n    }\n\n    this._triggerAbortController?.abort();\n    removeAriaOverlayTriggerAttributes(this._triggerElement);\n    this._triggerElement = this.trigger;\n\n    if (!this._triggerElement) {\n      return;\n    }\n\n    setAriaOverlayTriggerAttributes(this._triggerElement, 'dialog', this.id, this.state);\n    this._triggerAbortController = new AbortController();\n    this._triggerElement.addEventListener('click', () => this.open(), {\n      signal: this._triggerAbortController.signal,\n    });\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._ariaLiveRef =\n      this.shadowRoot!.querySelector<SbbScreenReaderOnlyElement>('sbb-screen-reader-only')!;\n    this._configureTrigger();\n\n    // If the component is already open on firstUpdate, fix the focus\n    if (this.isOpen) {\n      // TODO: find better solution\n      // Problem: content's shadow DOM not yet ready, so focusing is impossible.\n      setTimeout(() => {\n        this.focusTrapController.focusInitialElement();\n      }, 0);\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this.openOverlayController?.abort();\n    this.removeInstanceFromGlobalCollection();\n    this.scrollHandler.enableScroll();\n    this._triggerElement = null;\n    this._triggerAbortController?.abort();\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n\n    if (!isServer && (!name || name === 'trigger') && this.hasUpdated) {\n      this._configureTrigger();\n    }\n  }\n\n  protected attachOpenOverlayEvents(): void {\n    this.openOverlayController = new AbortController();\n    // Remove overlay label as soon as it is not needed any more to prevent accessing it with browse mode.\n    window.addEventListener(\n      'keydown',\n      () => {\n        this.removeAriaLiveRefContent();\n      },\n      {\n        signal: this.openOverlayController.signal,\n      },\n    );\n    window.addEventListener('click', () => this.removeAriaLiveRefContent(), {\n      signal: this.openOverlayController.signal,\n    });\n  }\n\n  protected removeInstanceFromGlobalCollection(): void {\n    const indexInOverlayRefs = overlayRefs.indexOf(this as SbbOverlayBaseElement);\n    if (indexInOverlayRefs > -1) {\n      overlayRefs.splice(indexInOverlayRefs, 1);\n    }\n  }\n\n  // Close the component on click of any element that has the `closeAttribute` attribute.\n  protected closeOnSbbOverlayCloseClick(event: Event): void {\n    const overlayCloseElement = event\n      .composedPath()\n      .filter((e): e is HTMLElement => e instanceof window.HTMLElement)\n      .find(\n        (target) =>\n          (target.hasAttribute(this.closeAttribute) || target.localName === this.closeTag) &&\n          !target.hasAttribute('disabled'),\n      );\n\n    if (\n      !overlayCloseElement ||\n      (overlayCloseElement.closest(this.localName) !== this &&\n        !this.shadowRoot?.contains(overlayCloseElement))\n    ) {\n      return;\n    }\n\n    if (overlayRefs.length) {\n      overlayRefs[overlayRefs.length - 1]._close(null, overlayCloseElement);\n    }\n  }\n\n  protected removeAriaLiveRefContent(): void {\n    if (!this._ariaLiveRef) {\n      return;\n    }\n    this._ariaLiveRef.textContent = '';\n  }\n\n  protected setAriaLiveRefContent(label?: string): void {\n    if (!this._ariaLiveRef) {\n      return;\n    }\n\n    this._ariaLiveRefToggle = !this._ariaLiveRefToggle;\n\n    // If the text content remains the same, on VoiceOver the aria-live region is not announced a second time.\n    // In order to support reading on every opening, we toggle an invisible space.\n    this._ariaLiveRef.textContent = `${i18nDialog[this.language.current]}${\n      label ? `, ${label}` : ''\n    }${this._ariaLiveRefToggle ? ' ' : ''}`;\n  }\n\n  // Wait for dialog transition to complete.\n  // In rare cases, it can be that the animationEnd event is triggered twice.\n  // To avoid entering a corrupt state, exit when state is not expected.\n  protected onOverlayAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this.handleOpening();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this.handleClosing();\n    }\n  }\n}\n"],"mappings":"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"}
247
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"overlay-base-element.js","names":[],"sources":["../../../../src/elements/overlay/overlay-base-element.ts"],"sourcesContent":["import { isServer, type PropertyDeclaration, type PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbFocusTrapController } from '../core/a11y.ts';\nimport { SbbOpenCloseBaseElement } from '../core/base-elements.ts';\nimport {\n  SbbEscapableOverlayController,\n  SbbInertController,\n  SbbLanguageController,\n} from '../core/controllers.ts';\nimport { forceType, idReference } from '../core/decorators.ts';\nimport { SbbScrollHandler } from '../core/dom.ts';\nimport { i18nDialog } from '../core/i18n.ts';\nimport type { SbbOverlayCloseEventDetails } from '../core/interfaces.ts';\nimport { SbbNegativeMixin } from '../core/mixins.ts';\nimport {\n  removeAriaOverlayTriggerAttributes,\n  setAriaOverlayTriggerAttributes,\n} from '../core/overlay.ts';\nimport type { SbbScreenReaderOnlyElement } from '../screen-reader-only.ts';\n\nconst overlayResultMap = new WeakMap<HTMLElement, any>();\n\nexport class SbbOverlayCloseEvent<T = any> extends CustomEvent<SbbOverlayCloseEventDetails> {\n  /**\n   * The result associated with the closed overlay.\n   * This is either the result assigned to the `closeTarget` via\n   * `assignOverlayResult` / `assignDialogResult` or the value of the\n   * corresponding close attribute on the `closeTarget`\n   * (e.g. sbb-overlay-close=\"my-result\" or sbb-dialog-close=\"my-result\").\n   */\n  public readonly result: T | null;\n\n  /**\n   * The element that was used to close the overlay/dialog, i.e. the element that the\n   * user clicked on that had the close attribute.\n   * Empty if closed programmatically or via Escape press.\n   */\n  public readonly closeTarget: HTMLElement | null;\n\n  public constructor(\n    name: string,\n    {\n      cancelable,\n      closeAttribute,\n      closeTarget,\n      result,\n    }: { cancelable?: boolean; closeAttribute: string; closeTarget?: HTMLElement; result?: any },\n  ) {\n    // TODO: Remove detail and change base class to Event\n    super(name, { cancelable, detail: { returnValue: result, closeTarget } });\n\n    this.result =\n      result ??\n      (!closeTarget\n        ? null\n        : (overlayResultMap.get(closeTarget) ??\n          (closeTarget.getAttribute(closeAttribute)?.trim() || null)));\n    this.closeTarget = closeTarget ?? null;\n  }\n}\n\nexport function assignOverlayResult<T>(element: HTMLElement, result: T): void {\n  overlayResultMap.set(element, result);\n}\n\n// A global collection of existing overlays.\nexport const overlayRefs: SbbOverlayBaseElement[] = [];\n\nexport abstract class SbbOverlayBaseElement extends SbbNegativeMixin(SbbOpenCloseBaseElement) {\n  /**\n   * The element that will trigger the menu overlay.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor trigger: HTMLElement | null = null;\n\n  /** This will be forwarded as aria-label to the relevant nested element to describe the purpose of the overlay. */\n  @forceType()\n  @property({ attribute: 'accessibility-label' })\n  public accessor accessibilityLabel: string = '';\n\n  /**\n   * Whether to skip restoring focus to the previously-focused element when the overlay is closed.\n   * Note that automatic focus restoration is an accessibility feature, and it is recommended that\n   * you provide your own equivalent, if you decide to turn it off.\n   */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor skipFocusRestoration: boolean = false;\n\n  // The last element which had focus before the component was opened.\n  protected lastFocusedElement?: HTMLElement;\n  // TODO: rename to lastClosedTarget\n  protected overlayCloseElement?: HTMLElement;\n  protected openOverlayController?: AbortController;\n  protected focusTrapController = new SbbFocusTrapController(this);\n  protected scrollHandler = new SbbScrollHandler();\n  // TODO: rename to lastResult\n  protected returnValue: any;\n  protected language = new SbbLanguageController(this);\n  protected inertController = new SbbInertController(this);\n  protected escapableOverlayController = new SbbEscapableOverlayController(this);\n\n  private _ariaLiveRefToggle = false;\n  private _ariaLiveRef?: SbbScreenReaderOnlyElement;\n  private _triggerElement: HTMLElement | null = null;\n  private _triggerAbortController?: AbortController;\n\n  protected abstract closeAttribute: string;\n  protected closeTag?: string;\n  protected abstract handleOpening(): void;\n  protected abstract handleClosing(): void;\n  protected abstract isZeroAnimationDuration(): boolean;\n  protected abstract override dispatchBeforeCloseEvent(\n    detail?: SbbOverlayCloseEventDetails,\n  ): boolean;\n\n  protected abstract override dispatchCloseEvent(detail?: SbbOverlayCloseEventDetails): boolean;\n\n  /** Opens the component. */\n  public open(): void {\n    if (\n      this.state === 'opening' ||\n      this.state === 'opened' ||\n      this._hasClosedParent() ||\n      !this.dispatchBeforeOpenEvent()\n    ) {\n      return;\n    }\n\n    this.lastFocusedElement = document.activeElement as HTMLElement;\n\n    this.showPopover?.();\n    this.state = 'opening';\n    this._triggerElement?.setAttribute('aria-expanded', 'true');\n\n    // Add this overlay to the global collection\n    overlayRefs.push(this);\n\n    this.scrollHandler.disableScroll();\n    this.escapableOverlayController.connect();\n    this.attachOpenOverlayEvents();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `opened` state.\n    if (this.isZeroAnimationDuration()) {\n      this.handleOpening();\n    }\n  }\n\n  /** Closes the component. */\n  public close(result?: any): void;\n  /** @deprecated */\n  public close(result?: any, target?: HTMLElement): void;\n  public close(result?: any, target?: HTMLElement): void {\n    this._close(result, target);\n  }\n\n  private _close(result: any, target: HTMLElement | undefined): void {\n    if (this.state === 'closing' || this.state === 'closed') {\n      return;\n    }\n\n    this.returnValue = result ?? null;\n    this.overlayCloseElement = target;\n    if (!this.dispatchBeforeCloseEvent()) {\n      return;\n    }\n    this.state = 'closing';\n    this._triggerElement?.setAttribute('aria-expanded', 'false');\n    this.removeAriaLiveRefContent();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `closed` state.\n    if (this.isZeroAnimationDuration()) {\n      this.handleClosing();\n    }\n  }\n\n  /**\n   * Check if there is a parent dialog or overlay in the DOM that is closed.\n   * In this case, the overlay should not be opened because it would break the state.\n   * Not nested but stacked overlays are supported so this logic does not apply in this case.\n   */\n  private _hasClosedParent(): boolean {\n    const parentDialog =\n      this.parentElement?.closest<SbbOverlayBaseElement>('sbb-dialog, sbb-overlay');\n\n    return (parentDialog?.state === 'closed' || parentDialog?.state === 'closing') ?? false;\n  }\n\n  public override connectedCallback(): void {\n    this.popover = 'manual';\n    super.connectedCallback();\n    if (this.hasUpdated) {\n      this._configureTrigger();\n    }\n  }\n\n  // Check if the trigger is valid and attach click event listeners.\n  private _configureTrigger(): void {\n    if (this.trigger === this._triggerElement) {\n      return;\n    }\n\n    this._triggerAbortController?.abort();\n    removeAriaOverlayTriggerAttributes(this._triggerElement);\n    this._triggerElement = this.trigger;\n\n    if (!this._triggerElement) {\n      return;\n    }\n\n    setAriaOverlayTriggerAttributes(this._triggerElement, 'dialog', this.id, this.state);\n    this._triggerAbortController = new AbortController();\n    this._triggerElement.addEventListener('click', () => this.open(), {\n      signal: this._triggerAbortController.signal,\n    });\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._ariaLiveRef =\n      this.shadowRoot!.querySelector<SbbScreenReaderOnlyElement>('sbb-screen-reader-only')!;\n    this._configureTrigger();\n\n    // If the component is already open on firstUpdate, fix the focus\n    if (this.isOpen) {\n      // TODO: find better solution\n      // Problem: content's shadow DOM not yet ready, so focusing is impossible.\n      setTimeout(() => {\n        this.focusTrapController.focusInitialElement();\n      }, 0);\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this.openOverlayController?.abort();\n    this.removeInstanceFromGlobalCollection();\n    this.scrollHandler.enableScroll();\n    this._triggerElement = null;\n    this._triggerAbortController?.abort();\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n\n    if (!isServer && (!name || name === 'trigger') && this.hasUpdated) {\n      this._configureTrigger();\n    }\n  }\n\n  protected attachOpenOverlayEvents(): void {\n    this.openOverlayController = new AbortController();\n    // Remove overlay label as soon as it is not needed any more to prevent accessing it with browse mode.\n    window.addEventListener(\n      'keydown',\n      () => {\n        this.removeAriaLiveRefContent();\n      },\n      {\n        signal: this.openOverlayController.signal,\n      },\n    );\n    window.addEventListener('click', () => this.removeAriaLiveRefContent(), {\n      signal: this.openOverlayController.signal,\n    });\n  }\n\n  protected removeInstanceFromGlobalCollection(): void {\n    const indexInOverlayRefs = overlayRefs.indexOf(this as SbbOverlayBaseElement);\n    if (indexInOverlayRefs > -1) {\n      overlayRefs.splice(indexInOverlayRefs, 1);\n    }\n  }\n\n  // Close the component on click of any element that has the `closeAttribute` attribute.\n  protected closeOnSbbOverlayCloseClick(event: Event): void {\n    const overlayCloseElement = event\n      .composedPath()\n      .filter((e): e is HTMLElement => e instanceof window.HTMLElement)\n      .find(\n        (target) =>\n          (target.hasAttribute(this.closeAttribute) || target.localName === this.closeTag) &&\n          !target.hasAttribute('disabled'),\n      );\n\n    if (\n      !overlayCloseElement ||\n      (overlayCloseElement.closest(this.localName) !== this &&\n        !this.shadowRoot?.contains(overlayCloseElement))\n    ) {\n      return;\n    }\n\n    if (overlayRefs.length) {\n      overlayRefs[overlayRefs.length - 1]._close(null, overlayCloseElement);\n    }\n  }\n\n  protected removeAriaLiveRefContent(): void {\n    if (!this._ariaLiveRef) {\n      return;\n    }\n    this._ariaLiveRef.textContent = '';\n  }\n\n  protected setAriaLiveRefContent(label?: string): void {\n    if (!this._ariaLiveRef) {\n      return;\n    }\n\n    this._ariaLiveRefToggle = !this._ariaLiveRefToggle;\n\n    // If the text content remains the same, on VoiceOver the aria-live region is not announced a second time.\n    // In order to support reading on every opening, we toggle an invisible space.\n    this._ariaLiveRef.textContent = `${i18nDialog[this.language.current]}${\n      label ? `, ${label}` : ''\n    }${this._ariaLiveRefToggle ? ' ' : ''}`;\n  }\n\n  // Wait for dialog transition to complete.\n  // In rare cases, it can be that the animationEnd event is triggered twice.\n  // To avoid entering a corrupt state, exit when state is not expected.\n  protected onOverlayAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this.handleOpening();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this.handleClosing();\n    }\n  }\n}\n"],"mappings":"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"}
@@ -13,9 +13,7 @@ var r = "https://icons.app.sbb.ch/", i = (/* @__PURE__ */ new Map()).set("defaul
13
13
  request: () => fetch(u).then(async (t) => {
14
14
  if (!t.ok) throw Error(`Failed to load icon ${r}:${o}`);
15
15
  return e(await t.text(), s);
16
- }).catch((e) => {
17
- throw Error(e);
18
- })
16
+ }).catch((e) => (console.warn(e), ""))
19
17
  }), a.set(u, d);
20
18
  else return Promise.resolve("");
21
19
  return d;
@@ -106,7 +106,7 @@ var y = [], b = (() => {
106
106
  this._close(e, t);
107
107
  }
108
108
  _close(e, t) {
109
- this.state === "closing" || this.state === "closed" || (this.returnValue = e, this.overlayCloseElement = t, this.dispatchBeforeCloseEvent() && (this.state = "closing", this._triggerElement?.setAttribute("aria-expanded", "false"), this.removeAriaLiveRefContent(), this.isZeroAnimationDuration() && this.handleClosing()));
109
+ this.state === "closing" || this.state === "closed" || (this.returnValue = e ?? null, this.overlayCloseElement = t, this.dispatchBeforeCloseEvent() && (this.state = "closing", this._triggerElement?.setAttribute("aria-expanded", "false"), this.removeAriaLiveRefContent(), this.isZeroAnimationDuration() && this.handleClosing()));
110
110
  }
111
111
  _hasClosedParent() {
112
112
  let e = this.parentElement?.closest("sbb-dialog, sbb-overlay");
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-dev",
3
- "version": "4.9.0-dev.1775144212",
3
+ "version": "4.9.0-dev.1775154606",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
7
7
  "web components",
8
8
  "lit",
9
- "https://github.com/sbb-design-systems/lyne-components/commit/59562cd0cb9d5a2c920efc7f62a74fc4963aeb73"
9
+ "https://github.com/sbb-design-systems/lyne-components/commit/4d6617c6a3100388f5572132a76651d0ba55daf9"
10
10
  ],
11
11
  "type": "module",
12
12
  "exports": {