@db-ux/ngx-core-components 1.1.0 → 1.1.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/README.md +6 -1
- package/components/navigation-item/model.d.ts +3 -2
- package/components/navigation-item/navigation-item.d.ts +2 -0
- package/esm2022/components/checkbox/checkbox.mjs +1 -1
- package/esm2022/components/input/input.mjs +1 -1
- package/esm2022/components/navigation-item/model.mjs +1 -1
- package/esm2022/components/navigation-item/navigation-item.mjs +24 -5
- package/esm2022/components/radio/radio.mjs +7 -5
- package/esm2022/components/select/select.mjs +1 -1
- package/esm2022/components/switch/switch.mjs +1 -1
- package/esm2022/components/tab-item/tab-item.mjs +1 -1
- package/esm2022/components/textarea/textarea.mjs +1 -1
- package/fesm2022/db-ux-ngx-core-components.mjs +27 -6
- package/fesm2022/db-ux-ngx-core-components.mjs.map +1 -1
- package/package.json +3 -3
package/README.md
CHANGED
|
@@ -53,6 +53,10 @@ The current default development config in `angular.json` doesn't use output hash
|
|
|
53
53
|
As a solution add `
|
|
54
54
|
"outputHashing": "media"` to `configurations/development` in`angular.json`.
|
|
55
55
|
|
|
56
|
+
### DB Theme
|
|
57
|
+
|
|
58
|
+
In case that you're building a website or application for Deutsche Bahn, you'll additionally have to install the DB Theme via the [`@db-ux/db-theme`](https://www.npmjs.com/package/@db-ux/db-theme) node package (even also available as an inner source node package, as described within that packages README).
|
|
59
|
+
|
|
56
60
|
## Usage
|
|
57
61
|
|
|
58
62
|
```ts app.component.ts
|
|
@@ -114,7 +118,8 @@ There are 3 ways to use Events in Angular:
|
|
|
114
118
|
As we'd like to perfectly support our users and customers on their digital journey, the usage of Deutsche Bahn brand and trademarks are bound of clear guidelines and restrictions even when being used with the code that we're provide with this product; Deutsche Bahn fully reserves all rights regarding the Deutsche Bahn brand, even though that we're providing the code of DB UX Design System products free to use and release it under the Apache 2.0 license.
|
|
115
119
|
Please have a look at our brand portal at <https://marketingportal.extranet.deutschebahn.com/> for any further questions and whom to contact on any brand issues.
|
|
116
120
|
|
|
117
|
-
|
|
121
|
+
For any usage outside of Deutsche Bahn websites and applications you aren't allowed to use any Deutsche Bahn brand and
|
|
122
|
+
design assets as well as protected characteristics and trademarks, that for not including the DB Theme.
|
|
118
123
|
|
|
119
124
|
## Contributions
|
|
120
125
|
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ClickEvent, ClickEventProps, ClickEventState, GlobalProps, GlobalState, IconProps, InitializedState, NavigationBackButtonProps, ShowIconProps, TextProps, WidthProps } from '../../shared/model';
|
|
1
|
+
import { ClickEvent, ClickEventProps, ClickEventState, GlobalProps, GlobalState, IconProps, InitializedState, NavigationBackButtonProps, NavigationBehaviorState, ShowIconProps, TextProps, WidthProps } from '../../shared/model';
|
|
2
2
|
import { NavigationItemSafeTriangle } from '../../utils/navigation';
|
|
3
3
|
export type DBNavigationItemDefaultProps = {
|
|
4
4
|
/**
|
|
@@ -30,5 +30,6 @@ export type DBNavigationItemDefaultState = {
|
|
|
30
30
|
hasSubNavigation?: boolean;
|
|
31
31
|
updateSubNavigationState: () => void;
|
|
32
32
|
navigationItemSafeTriangle?: NavigationItemSafeTriangle;
|
|
33
|
+
autoClose?: boolean;
|
|
33
34
|
};
|
|
34
|
-
export type DBNavigationItemState = DBNavigationItemDefaultState & ClickEventState<HTMLButtonElement> & GlobalState & InitializedState;
|
|
35
|
+
export type DBNavigationItemState = DBNavigationItemDefaultState & ClickEventState<HTMLButtonElement> & GlobalState & InitializedState & NavigationBehaviorState;
|
|
@@ -25,8 +25,10 @@ export declare class DBNavigationItem {
|
|
|
25
25
|
hasAreaPopup: DBNavigationItemState["hasAreaPopup"];
|
|
26
26
|
hasSubNavigation: DBNavigationItemState["hasSubNavigation"];
|
|
27
27
|
isSubNavigationExpanded: DBNavigationItemState["isSubNavigationExpanded"];
|
|
28
|
+
autoClose: DBNavigationItemState["autoClose"];
|
|
28
29
|
subNavigationId: DBNavigationItemState["subNavigationId"];
|
|
29
30
|
navigationItemSafeTriangle: DBNavigationItemState["navigationItemSafeTriangle"];
|
|
31
|
+
handleNavigationItemClick(event: unknown): ReturnType<DBNavigationItemState["handleNavigationItemClick"]>;
|
|
30
32
|
handleClick(event: ClickEvent<HTMLButtonElement>): ReturnType<DBNavigationItemState["handleClick"]>;
|
|
31
33
|
handleBackClick(event: ClickEvent<HTMLButtonElement>): ReturnType<DBNavigationItemState["handleBackClick"]>;
|
|
32
34
|
updateSubNavigationState(): ReturnType<DBNavigationItemState["updateSubNavigationState"]>;
|
|
@@ -324,4 +324,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
324
324
|
type: ViewChild,
|
|
325
325
|
args: ["_ref"]
|
|
326
326
|
}] } });
|
|
327
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/checkbox/checkbox.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Output,\n  EventEmitter,\n  Component,\n  ViewChild,\n  ElementRef,\n  Input,\n  SimpleChanges,\nRenderer2 } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n\nimport { CommonModule } from \"@angular/common\";\n\nconst defaultProps = {};\n\nimport { DBCheckboxProps, DBCheckboxState } from \"./model\";\nimport {\n  DEFAULT_INVALID_MESSAGE,\n  DEFAULT_INVALID_MESSAGE_ID_SUFFIX,\n  DEFAULT_MESSAGE_ID_SUFFIX,\n  DEFAULT_VALID_MESSAGE,\n  DEFAULT_VALID_MESSAGE_ID_SUFFIX,\n} from \"../../shared/constants\";\nimport { ChangeEvent, InteractionEvent } from \"../../shared/model\";\nimport {\n  handleFrameworkEventAngular,\n  handleFrameworkEventVue,\n} from \"../../utils/form-components\";\nimport { DBInfotext } from \"../infotext/infotext\";\nimport {\n  cls,\n  delay,\n  getHideProp,\n  hasVoiceOver,\n  stringPropVisible,\n  uuid,\n} from \"../../utils\";\n\n@Component({\n\t\tproviders: [{\n\t\t\tprovide: NG_VALUE_ACCESSOR,\n\t\t\tuseExisting: DBCheckbox,\n\t\t\tmulti: true\n\t\t}],\t\n  selector: \"db-checkbox\",\n  template: `\n    <div\n      [class]=\"cls('db-checkbox', className)\"\n      [attr.data-size]=\"size\"\n      [attr.data-hide-label]=\"getHideProp(showLabel)\"\n    >\n      <label [attr.for]=\"_id\">\n        <input\n          type=\"checkbox\"\n          [attr.aria-invalid]=\"validation === 'invalid'\"\n          [attr.data-custom-validity]=\"validation\"\n          #_ref\n          [attr.id]=\"_id\"\n          [attr.name]=\"name\"\n          [checked]=\"checked\"\n          [disabled]=\"disabled\"\n          [attr.value]=\"value\"\n          [required]=\"required\"\n          (change)=\"handleChange($event)\"\n          (blur)=\"handleBlur($event)\"\n          (focus)=\"handleFocus($event)\"\n          [attr.aria-describedby]=\"_descByIds\"\n        />\n        <ng-container *ngIf=\"label\">{{label}}</ng-container>\n        <ng-container *ngIf=\"!(label)\"><ng-content></ng-content></ng-container>\n      </label>\n      <ng-container *ngIf=\"stringPropVisible(message, showMessage)\">\n        <db-infotext size=\"small\" [icon]=\"messageIcon\" [id]=\"_messageId\">\n          {{message}}\n        </db-infotext>\n      </ng-container>\n      <db-infotext size=\"small\" semantic=\"successful\" [id]=\"_validMessageId\">\n        {{validMessage ?? DEFAULT_VALID_MESSAGE}}\n      </db-infotext>\n      <db-infotext size=\"small\" semantic=\"critical\" [id]=\"_invalidMessageId\">\n        {{invalidMessage ?? this._ref?.validationMessage ??\n            DEFAULT_INVALID_MESSAGE}}\n      </db-infotext>\n      <span data-visually-hidden=\"true\" role=\"status\">\n        {{_voiceOverFallback}}\n      </span>\n    </div>\n  `,\n  standalone: true,\n  imports: [CommonModule, DBInfotext],\n})\nexport class DBCheckbox implements ControlValueAccessor {\n\t\tconstructor(private renderer: Renderer2) { }\n  DEFAULT_INVALID_MESSAGE = DEFAULT_INVALID_MESSAGE;\n  DEFAULT_VALID_MESSAGE = DEFAULT_VALID_MESSAGE;\n  cls = cls;\n  getHideProp = getHideProp;\n  stringPropVisible = stringPropVisible;\n\n  @Input() id!: DBCheckboxProps[\"id\"];\n  @Input() message!: DBCheckboxProps[\"message\"];\n  @Input() showMessage!: DBCheckboxProps[\"showMessage\"];\n  @Input() indeterminate!: DBCheckboxProps[\"indeterminate\"];\n  @Input() checked!: DBCheckboxProps[\"checked\"];\n  @Input() validation!: DBCheckboxProps[\"validation\"];\n  @Input() invalidMessage!: DBCheckboxProps[\"invalidMessage\"];\n  @Input() required!: DBCheckboxProps[\"required\"];\n  @Input() validMessage!: DBCheckboxProps[\"validMessage\"];\n  @Input() className!: DBCheckboxProps[\"className\"];\n  @Input() size!: DBCheckboxProps[\"size\"];\n  @Input() showLabel!: DBCheckboxProps[\"showLabel\"];\n  @Input() name!: DBCheckboxProps[\"name\"];\n  @Input() disabled!: DBCheckboxProps[\"disabled\"];\n  @Input() value!: DBCheckboxProps[\"value\"];\n  @Input() label!: DBCheckboxProps[\"label\"];\n  @Input() messageIcon!: DBCheckboxProps[\"messageIcon\"];\n\n  @Output() onChange = new EventEmitter();\n  @Output() change = new EventEmitter();\n  @Output() onBlur = new EventEmitter();\n  @Output() blur = new EventEmitter();\n  @Output() onFocus = new EventEmitter();\n  @Output() focus = new EventEmitter();\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  initialized: DBCheckboxState[\"initialized\"] = false;\n  _id: DBCheckboxState[\"_id\"] = undefined;\n  _messageId: DBCheckboxState[\"_messageId\"] = undefined;\n  _validMessageId: DBCheckboxState[\"_validMessageId\"] = undefined;\n  _invalidMessageId: DBCheckboxState[\"_invalidMessageId\"] = undefined;\n  _descByIds: DBCheckboxState[\"_descByIds\"] = \"\";\n  _voiceOverFallback: DBCheckboxState[\"_voiceOverFallback\"] = \"\";\n  handleChange(\n    event: ChangeEvent<HTMLInputElement>\n  ): ReturnType<DBCheckboxState[\"handleChange\"]> {\n    if (this.onChange) {\n      this.onChange.emit(event);\n    }\n    if (this.change) {\n      this.change.emit(event);\n    }\n    handleFrameworkEventAngular(this, event, \"checked\");\n\n    /* For a11y reasons we need to map the correct message with the checkbox */\n    if (\n      !this._ref?.nativeElement?.validity.valid ||\n      this.validation === \"invalid\"\n    ) {\n      this._descByIds = this._invalidMessageId;\n      if (hasVoiceOver()) {\n        this._voiceOverFallback =\n          this.invalidMessage ??\n          this._ref?.nativeElement?.validationMessage ??\n          DEFAULT_INVALID_MESSAGE;\n        delay(() => (this._voiceOverFallback = \"\"), 1000);\n      }\n    } else if (\n      this.validation === \"valid\" ||\n      (this._ref?.nativeElement?.validity.valid && this.required)\n    ) {\n      this._descByIds = this._validMessageId;\n      if (hasVoiceOver()) {\n        this._voiceOverFallback = this.validMessage ?? DEFAULT_VALID_MESSAGE;\n        delay(() => (this._voiceOverFallback = \"\"), 1000);\n      }\n    } else if (stringPropVisible(this.message, this.showMessage)) {\n      this._descByIds = this._messageId;\n    } else {\n      this._descByIds = \"\";\n    }\n  }\n  handleBlur(\n    event: InteractionEvent<HTMLInputElement>\n  ): ReturnType<DBCheckboxState[\"handleBlur\"]> {\n    if (this.onBlur) {\n      this.onBlur.emit(event);\n    }\n    if (this.blur) {\n      this.blur.emit(event);\n    }\n  }\n  handleFocus(\n    event: InteractionEvent<HTMLInputElement>\n  ): ReturnType<DBCheckboxState[\"handleFocus\"]> {\n    if (this.onFocus) {\n      this.onFocus.emit(event);\n    }\n    if (this.focus) {\n      this.focus.emit(event);\n    }\n  }\n\n  /**\n   * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n   * @param element  the ref for the component\n   * @param customElementSelector  the custom element like `my-component`\n   */\n  private enableAttributePassing(\n    element: HTMLElement | null,\n    customElementSelector: string\n  ) {\n    const parent = element?.closest(customElementSelector);\n    if (element && parent) {\n      const attributes = parent.attributes;\n      for (let i = 0; i < attributes.length; i++) {\n        const attr = attributes.item(i);\n        if (\n          attr &&\n          (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n        ) {\n          element.setAttribute(attr.name, attr.value);\n          parent.removeAttribute(attr.name);\n        }\n        if (attr && attr.name === \"class\") {\n          const isWebComponent = attr.value.includes(\"hydrated\");\n          const value = attr.value.replace(\"hydrated\", \"\").trim();\n          const currentClass = element.getAttribute(\"class\");\n          element.setAttribute(\n            attr.name,\n            `${currentClass ? `${currentClass} ` : \"\"}${value}`\n          );\n          if (isWebComponent) {\n            // Stencil is using this class for lazy loading component\n            parent.setAttribute(\"class\", \"hydrated\");\n          } else {\n            parent.removeAttribute(attr.name);\n          }\n        }\n      }\n    }\n  }\n\n  \n\t\twriteValue(value: any) {\n\t\t  this.checked = !!value;\n\n\t\t  if (this._ref?.nativeElement) {\n\t\t\t this.renderer.setProperty(this._ref?.nativeElement, 'checked', !!value);\n\t\t  }\n\t\t}\n\n\t\tpropagateChange(_: any) {}\n\n\t\tregisterOnChange(onChange: any) {\n\t\t  this.propagateChange = onChange;\n\t\t}\n\n\t\tregisterOnTouched(onTouched: any) {\n\t\t //this.onTouched = onTouched;\n\t\t}\n\n\t\tsetDisabledState(disabled: boolean) {\n\t\t  this.disabled = disabled;\n\t\t}\n\n\t\tngOnInit() {\n    if (typeof window !== \"undefined\") {\n      this.initialized = true;\n      const mId = this.id ?? `checkbox-${uuid()}`;\n      this._id = mId;\n      this._messageId = mId + DEFAULT_MESSAGE_ID_SUFFIX;\n      this._validMessageId = mId + DEFAULT_VALID_MESSAGE_ID_SUFFIX;\n      this._invalidMessageId = mId + DEFAULT_INVALID_MESSAGE_ID_SUFFIX;\n    }\n  }\n\n  ngAfterViewInit() {\n    const element: HTMLElement | null = this._ref?.nativeElement;\n    this.enableAttributePassing(element, \"db-checkbox\");\n  }\n\n  ngAfterContentChecked(changes: SimpleChanges) {\n    if (typeof window !== \"undefined\") {\n      if (this._id) {\n        const messageId = this._id + DEFAULT_MESSAGE_ID_SUFFIX;\n        this._messageId = messageId;\n        this._validMessageId = this._id + DEFAULT_VALID_MESSAGE_ID_SUFFIX;\n        this._invalidMessageId = this._id + DEFAULT_INVALID_MESSAGE_ID_SUFFIX;\n        if (stringPropVisible(this.message, this.showMessage)) {\n          this._descByIds = messageId;\n        }\n      }\n      if (this._ref?.nativeElement) {\n        if (this.initialized && this.indeterminate !== undefined) {\n          // When indeterminate is set, the value of the checked prop only impacts the form submitted values.\n          // It has no accessibility or UX implications. (https://mui.com/material-ui/react-checkbox/)\n          this._ref.nativeElement.indeterminate = this.indeterminate;\n        }\n      }\n      if (this.initialized && this._ref?.nativeElement) {\n        // in angular this must be set via native element\n        if (this.checked != undefined) {\n          this._ref.nativeElement.checked = this.checked;\n        }\n        this.initialized = false;\n      }\n    }\n  }\n}\n"]}
|
|
327
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/checkbox/checkbox.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Output,\n  EventEmitter,\n  Component,\n  ViewChild,\n  ElementRef,\n  Input,\n  SimpleChanges,\nRenderer2 } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n\nimport { CommonModule } from \"@angular/common\";\n\nconst defaultProps = {};\n\nimport { DBCheckboxProps, DBCheckboxState } from \"./model\";\nimport {\n  DEFAULT_INVALID_MESSAGE,\n  DEFAULT_INVALID_MESSAGE_ID_SUFFIX,\n  DEFAULT_MESSAGE_ID_SUFFIX,\n  DEFAULT_VALID_MESSAGE,\n  DEFAULT_VALID_MESSAGE_ID_SUFFIX,\n} from \"../../shared/constants\";\nimport { ChangeEvent, InteractionEvent } from \"../../shared/model\";\nimport {\n  handleFrameworkEventAngular,\n  handleFrameworkEventVue,\n} from \"../../utils/form-components\";\nimport { DBInfotext } from \"../infotext/infotext\";\nimport {\n  cls,\n  delay,\n  getHideProp,\n  hasVoiceOver,\n  stringPropVisible,\n  uuid,\n} from \"../../utils\";\n\n@Component({\n\t\tproviders: [{\n\t\t\tprovide: NG_VALUE_ACCESSOR,\n\t\t\tuseExisting: DBCheckbox,\n\t\t\tmulti: true\n\t\t}],\t\n  selector: \"db-checkbox\",\n  template: `\n    <div\n      [class]=\"cls('db-checkbox', className)\"\n      [attr.data-size]=\"size\"\n      [attr.data-hide-label]=\"getHideProp(showLabel)\"\n    >\n      <label [attr.for]=\"_id\">\n        <input\n          type=\"checkbox\"\n          [attr.aria-invalid]=\"validation === 'invalid'\"\n          [attr.data-custom-validity]=\"validation\"\n          #_ref\n          [attr.id]=\"_id\"\n          [attr.name]=\"name\"\n          [checked]=\"checked\"\n          [disabled]=\"disabled\"\n          [attr.value]=\"value\"\n          [required]=\"required\"\n          (change)=\"handleChange($event)\"\n          (blur)=\"handleBlur($event)\"\n          (focus)=\"handleFocus($event)\"\n          [attr.aria-describedby]=\"_descByIds\"\n        />\n        <ng-container *ngIf=\"label\">{{label}}</ng-container>\n        <ng-container *ngIf=\"!(label)\"><ng-content></ng-content></ng-container>\n      </label>\n      <ng-container *ngIf=\"stringPropVisible(message, showMessage)\">\n        <db-infotext size=\"small\" [icon]=\"messageIcon\" [id]=\"_messageId\">\n          {{message}}\n        </db-infotext>\n      </ng-container>\n      <db-infotext size=\"small\" semantic=\"successful\" [id]=\"_validMessageId\">\n        {{validMessage ?? DEFAULT_VALID_MESSAGE}}\n      </db-infotext>\n      <db-infotext size=\"small\" semantic=\"critical\" [id]=\"_invalidMessageId\">\n        {{invalidMessage ?? this._ref?.validationMessage ??\n            DEFAULT_INVALID_MESSAGE}}\n      </db-infotext>\n      <span data-visually-hidden=\"true\" role=\"status\">\n        {{_voiceOverFallback}}\n      </span>\n    </div>\n  `,\n  standalone: true,\n  imports: [CommonModule, DBInfotext],\n})\nexport class DBCheckbox implements ControlValueAccessor {\n\t\tconstructor(private renderer: Renderer2) { }\n  DEFAULT_INVALID_MESSAGE = DEFAULT_INVALID_MESSAGE;\n  DEFAULT_VALID_MESSAGE = DEFAULT_VALID_MESSAGE;\n  cls = cls;\n  getHideProp = getHideProp;\n  stringPropVisible = stringPropVisible;\n\n  @Input() id!: DBCheckboxProps[\"id\"];\n  @Input() message!: DBCheckboxProps[\"message\"];\n  @Input() showMessage!: DBCheckboxProps[\"showMessage\"];\n  @Input() indeterminate!: DBCheckboxProps[\"indeterminate\"];\n  @Input() checked!: DBCheckboxProps[\"checked\"];\n  @Input() validation!: DBCheckboxProps[\"validation\"];\n  @Input() invalidMessage!: DBCheckboxProps[\"invalidMessage\"];\n  @Input() required!: DBCheckboxProps[\"required\"];\n  @Input() validMessage!: DBCheckboxProps[\"validMessage\"];\n  @Input() className!: DBCheckboxProps[\"className\"];\n  @Input() size!: DBCheckboxProps[\"size\"];\n  @Input() showLabel!: DBCheckboxProps[\"showLabel\"];\n  @Input() name!: DBCheckboxProps[\"name\"];\n  @Input() disabled!: DBCheckboxProps[\"disabled\"];\n  @Input() value!: DBCheckboxProps[\"value\"];\n  @Input() label!: DBCheckboxProps[\"label\"];\n  @Input() messageIcon!: DBCheckboxProps[\"messageIcon\"];\n\n  @Output() onChange = new EventEmitter();\n  @Output() change = new EventEmitter();\n  @Output() onBlur = new EventEmitter();\n  @Output() blur = new EventEmitter();\n  @Output() onFocus = new EventEmitter();\n  @Output() focus = new EventEmitter();\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  initialized: DBCheckboxState[\"initialized\"] = false;\n  _id: DBCheckboxState[\"_id\"] = undefined;\n  _messageId: DBCheckboxState[\"_messageId\"] = undefined;\n  _validMessageId: DBCheckboxState[\"_validMessageId\"] = undefined;\n  _invalidMessageId: DBCheckboxState[\"_invalidMessageId\"] = undefined;\n  _descByIds: DBCheckboxState[\"_descByIds\"] = \"\";\n  _voiceOverFallback: DBCheckboxState[\"_voiceOverFallback\"] = \"\";\n  handleChange(\n    event: ChangeEvent<HTMLInputElement>\n  ): ReturnType<DBCheckboxState[\"handleChange\"]> {\n    if (this.onChange) {\n      this.onChange.emit(event);\n    }\n    if (this.change) {\n      this.change.emit(event);\n    }\n    handleFrameworkEventAngular(this, event, \"checked\");\n\n    /* For a11y reasons we need to map the correct message with the checkbox */\n    if (\n      !this._ref?.nativeElement?.validity.valid ||\n      this.validation === \"invalid\"\n    ) {\n      this._descByIds = this._invalidMessageId;\n      if (hasVoiceOver()) {\n        this._voiceOverFallback =\n          this.invalidMessage ??\n          this._ref?.nativeElement?.validationMessage ??\n          DEFAULT_INVALID_MESSAGE;\n        delay(() => (this._voiceOverFallback = \"\"), 1000);\n      }\n    } else if (\n      this.validation === \"valid\" ||\n      (this._ref?.nativeElement?.validity.valid && this.required)\n    ) {\n      this._descByIds = this._validMessageId;\n      if (hasVoiceOver()) {\n        this._voiceOverFallback = this.validMessage ?? DEFAULT_VALID_MESSAGE;\n        delay(() => (this._voiceOverFallback = \"\"), 1000);\n      }\n    } else if (stringPropVisible(this.message, this.showMessage)) {\n      this._descByIds = this._messageId;\n    } else {\n      this._descByIds = \"\";\n    }\n  }\n  handleBlur(\n    event: InteractionEvent<HTMLInputElement>\n  ): ReturnType<DBCheckboxState[\"handleBlur\"]> {\n    if (this.onBlur) {\n      this.onBlur.emit(event);\n    }\n    if (this.blur) {\n      this.blur.emit(event);\n    }\n  }\n  handleFocus(\n    event: InteractionEvent<HTMLInputElement>\n  ): ReturnType<DBCheckboxState[\"handleFocus\"]> {\n    if (this.onFocus) {\n      this.onFocus.emit(event);\n    }\n    if (this.focus) {\n      this.focus.emit(event);\n    }\n  }\n\n  /**\n   * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n   * @param element  the ref for the component\n   * @param customElementSelector  the custom element like `my-component`\n   */\n  private enableAttributePassing(\n    element: HTMLElement | null,\n    customElementSelector: string\n  ) {\n    const parent = element?.closest(customElementSelector);\n    if (element && parent) {\n      const attributes = parent.attributes;\n      for (let i = 0; i < attributes.length; i++) {\n        const attr = attributes.item(i);\n        if (\n          attr &&\n          (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n        ) {\n          element.setAttribute(attr.name, attr.value);\n          parent.removeAttribute(attr.name);\n        }\n        if (attr && attr.name === \"class\") {\n          const isWebComponent = attr.value.includes(\"hydrated\");\n          const value = attr.value.replace(\"hydrated\", \"\").trim();\n          const currentClass = element.getAttribute(\"class\");\n          element.setAttribute(\n            attr.name,\n            `${currentClass ? `${currentClass} ` : \"\"}${value}`\n          );\n          if (isWebComponent) {\n            // Stencil is using this class for lazy loading component\n            parent.setAttribute(\"class\", \"hydrated\");\n          } else {\n            parent.removeAttribute(attr.name);\n          }\n        }\n      }\n    }\n  }\n\n  \n\t\twriteValue(value: any) {\n\t\t\t\n\t\t  this.checked = !!value;\n\n\t\t  if (this._ref?.nativeElement) {\n\t\t\t this.renderer.setProperty(this._ref?.nativeElement, 'checked', !!value);\n\t\t  }\n\t\t\t\n\t\t}\n\n\t\tpropagateChange(_: any) {}\n\n\t\tregisterOnChange(onChange: any) {\n\t\t  this.propagateChange = onChange;\n\t\t}\n\n\t\tregisterOnTouched(onTouched: any) {\n\t\t //this.onTouched = onTouched;\n\t\t}\n\n\t\tsetDisabledState(disabled: boolean) {\n\t\t  this.disabled = disabled;\n\t\t}\n\n\t\tngOnInit() {\n    if (typeof window !== \"undefined\") {\n      this.initialized = true;\n      const mId = this.id ?? `checkbox-${uuid()}`;\n      this._id = mId;\n      this._messageId = mId + DEFAULT_MESSAGE_ID_SUFFIX;\n      this._validMessageId = mId + DEFAULT_VALID_MESSAGE_ID_SUFFIX;\n      this._invalidMessageId = mId + DEFAULT_INVALID_MESSAGE_ID_SUFFIX;\n    }\n  }\n\n  ngAfterViewInit() {\n    const element: HTMLElement | null = this._ref?.nativeElement;\n    this.enableAttributePassing(element, \"db-checkbox\");\n  }\n\n  ngAfterContentChecked(changes: SimpleChanges) {\n    if (typeof window !== \"undefined\") {\n      if (this._id) {\n        const messageId = this._id + DEFAULT_MESSAGE_ID_SUFFIX;\n        this._messageId = messageId;\n        this._validMessageId = this._id + DEFAULT_VALID_MESSAGE_ID_SUFFIX;\n        this._invalidMessageId = this._id + DEFAULT_INVALID_MESSAGE_ID_SUFFIX;\n        if (stringPropVisible(this.message, this.showMessage)) {\n          this._descByIds = messageId;\n        }\n      }\n      if (this._ref?.nativeElement) {\n        if (this.initialized && this.indeterminate !== undefined) {\n          // When indeterminate is set, the value of the checked prop only impacts the form submitted values.\n          // It has no accessibility or UX implications. (https://mui.com/material-ui/react-checkbox/)\n          this._ref.nativeElement.indeterminate = this.indeterminate;\n        }\n      }\n      if (this.initialized && this._ref?.nativeElement) {\n        // in angular this must be set via native element\n        if (this.checked != undefined) {\n          this._ref.nativeElement.checked = this.checked;\n        }\n        this.initialized = false;\n      }\n    }\n  }\n}\n"]}
|
|
@@ -428,4 +428,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
428
428
|
type: ViewChild,
|
|
429
429
|
args: ["_ref"]
|
|
430
430
|
}] } });
|
|
431
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/input/input.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Output,\n  EventEmitter,\n  Component,\n  ViewChild,\n  ElementRef,\n  Input,\n  SimpleChanges,\nRenderer2 } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n\nimport { CommonModule } from \"@angular/common\";\n\nconst defaultProps = {};\n\nimport {\n  cls,\n  delay,\n  getHideProp,\n  hasVoiceOver,\n  isArrayOfStrings,\n  stringPropVisible,\n  uuid,\n} from \"../../utils\";\nimport { DBInputProps, DBInputState } from \"./model\";\nimport {\n  DEFAULT_DATALIST_ID_SUFFIX,\n  DEFAULT_INVALID_MESSAGE,\n  DEFAULT_INVALID_MESSAGE_ID_SUFFIX,\n  DEFAULT_LABEL,\n  DEFAULT_MESSAGE_ID_SUFFIX,\n  DEFAULT_PLACEHOLDER,\n  DEFAULT_VALID_MESSAGE,\n  DEFAULT_VALID_MESSAGE_ID_SUFFIX,\n} from \"../../shared/constants\";\nimport {\n  ChangeEvent,\n  InputEvent,\n  InteractionEvent,\n  ValueLabelType,\n} from \"../../shared/model\";\nimport { DBInfotext } from \"../infotext/infotext\";\nimport {\n  handleFrameworkEventVue,\n  handleFrameworkEventAngular,\n} from \"../../utils/form-components\";\n\n@Component({\n\t\tproviders: [{\n\t\t\tprovide: NG_VALUE_ACCESSOR,\n\t\t\tuseExisting: DBInput,\n\t\t\tmulti: true\n\t\t}],\t\n  selector: \"db-input\",\n  template: `\n    <div\n      [class]=\"cls('db-input', className)\"\n      [attr.data-variant]=\"variant\"\n      [attr.data-hide-label]=\"getHideProp(showLabel)\"\n      [attr.data-hide-icon]=\"getHideProp(showIcon)\"\n      [attr.data-icon]=\"icon\"\n      [attr.data-icon-after]=\"iconAfter\"\n      [attr.data-hide-icon-after]=\"getHideProp(showIcon)\"\n    >\n      <label [attr.for]=\"_id\">{{label ?? DEFAULT_LABEL}}</label>\n      <input\n        [attr.aria-invalid]=\"validation === 'invalid'\"\n        [attr.data-custom-validity]=\"validation\"\n        #_ref\n        [attr.id]=\"_id\"\n        [attr.name]=\"name\"\n        [attr.type]=\"type || 'text'\"\n        [attr.placeholder]=\"placeholder ?? DEFAULT_PLACEHOLDER\"\n        [disabled]=\"disabled\"\n        [required]=\"required\"\n        [attr.step]=\"step\"\n        [attr.value]=\"value ?? _value\"\n        [attr.maxLength]=\"maxLength\"\n        [attr.minLength]=\"minLength\"\n        [attr.max]=\"max\"\n        [attr.min]=\"min\"\n        [attr.readOnly]=\"readOnly\"\n        [attr.form]=\"form\"\n        [attr.pattern]=\"pattern\"\n        [attr.size]=\"size\"\n        [attr.autoComplete]=\"autocomplete\"\n        [attr.autoFocus]=\"autofocus\"\n        (input)=\"handleInput($event)\"\n        (change)=\"handleChange($event)\"\n        (blur)=\"handleBlur($event)\"\n        (focus)=\"handleFocus($event)\"\n        [attr.list]=\"dataList && _dataListId\"\n        [attr.aria-describedby]=\"_descByIds\"\n      />\n      <ng-container *ngIf=\"dataList\">\n        <datalist [attr.id]=\"_dataListId\">\n          <ng-container\n            *ngFor=\"let option of getDataList(dataList); trackBy: trackByOption0\"\n          >\n            <option [attr.value]=\"option.value\">{{option.label}}</option>\n          </ng-container>\n        </datalist>\n      </ng-container>\n      <ng-content></ng-content>\n      <ng-container *ngIf=\"stringPropVisible(message, showMessage)\">\n        <db-infotext size=\"small\" [icon]=\"messageIcon\" [id]=\"_messageId\">\n          {{message}}\n        </db-infotext>\n      </ng-container>\n      <db-infotext size=\"small\" semantic=\"successful\" [id]=\"_validMessageId\">\n        {{validMessage ?? DEFAULT_VALID_MESSAGE}}\n      </db-infotext>\n      <db-infotext size=\"small\" semantic=\"critical\" [id]=\"_invalidMessageId\">\n        {{invalidMessage ?? this._ref?.validationMessage ??\n            DEFAULT_INVALID_MESSAGE}}\n      </db-infotext>\n      <span data-visually-hidden=\"true\" role=\"status\">\n        {{_voiceOverFallback}}\n      </span>\n    </div>\n  `,\n  standalone: true,\n  imports: [CommonModule, DBInfotext],\n})\nexport class DBInput implements ControlValueAccessor {\n\t\tconstructor(private renderer: Renderer2) { }\n  cls = cls;\n  getHideProp = getHideProp;\n  stringPropVisible = stringPropVisible;\n  DEFAULT_INVALID_MESSAGE = DEFAULT_INVALID_MESSAGE;\n  DEFAULT_LABEL = DEFAULT_LABEL;\n  DEFAULT_PLACEHOLDER = DEFAULT_PLACEHOLDER;\n  DEFAULT_VALID_MESSAGE = DEFAULT_VALID_MESSAGE;\n\n  @Input() id!: DBInputProps[\"id\"];\n  @Input() dataListId!: DBInputProps[\"dataListId\"];\n  @Input() message!: DBInputProps[\"message\"];\n  @Input() showMessage!: DBInputProps[\"showMessage\"];\n  @Input() value!: DBInputProps[\"value\"];\n  @Input() validation!: DBInputProps[\"validation\"];\n  @Input() invalidMessage!: DBInputProps[\"invalidMessage\"];\n  @Input() required!: DBInputProps[\"required\"];\n  @Input() minLength!: DBInputProps[\"minLength\"];\n  @Input() maxLength!: DBInputProps[\"maxLength\"];\n  @Input() pattern!: DBInputProps[\"pattern\"];\n  @Input() validMessage!: DBInputProps[\"validMessage\"];\n  @Input() className!: DBInputProps[\"className\"];\n  @Input() variant!: DBInputProps[\"variant\"];\n  @Input() showLabel!: DBInputProps[\"showLabel\"];\n  @Input() showIcon!: DBInputProps[\"showIcon\"];\n  @Input() icon!: DBInputProps[\"icon\"];\n  @Input() iconAfter!: DBInputProps[\"iconAfter\"];\n  @Input() label!: DBInputProps[\"label\"];\n  @Input() name!: DBInputProps[\"name\"];\n  @Input() type!: DBInputProps[\"type\"];\n  @Input() placeholder!: DBInputProps[\"placeholder\"];\n  @Input() disabled!: DBInputProps[\"disabled\"];\n  @Input() step!: DBInputProps[\"step\"];\n  @Input() max!: DBInputProps[\"max\"];\n  @Input() min!: DBInputProps[\"min\"];\n  @Input() readOnly!: DBInputProps[\"readOnly\"];\n  @Input() form!: DBInputProps[\"form\"];\n  @Input() size!: DBInputProps[\"size\"];\n  @Input() autocomplete!: DBInputProps[\"autocomplete\"];\n  @Input() autofocus!: DBInputProps[\"autofocus\"];\n  @Input() dataList!: DBInputProps[\"dataList\"];\n  @Input() messageIcon!: DBInputProps[\"messageIcon\"];\n\n  @Output() onInput = new EventEmitter();\n  @Output() input = new EventEmitter();\n  @Output() onChange = new EventEmitter();\n  @Output() change = new EventEmitter();\n  @Output() onBlur = new EventEmitter();\n  @Output() blur = new EventEmitter();\n  @Output() onFocus = new EventEmitter();\n  @Output() focus = new EventEmitter();\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  _id: DBInputState[\"_id\"] = undefined;\n  _messageId: DBInputState[\"_messageId\"] = undefined;\n  _validMessageId: DBInputState[\"_validMessageId\"] = undefined;\n  _invalidMessageId: DBInputState[\"_invalidMessageId\"] = undefined;\n  _dataListId: DBInputState[\"_dataListId\"] = undefined;\n  _descByIds: DBInputState[\"_descByIds\"] = \"\";\n  _value: DBInputState[\"_value\"] = \"\";\n  _voiceOverFallback: DBInputState[\"_voiceOverFallback\"] = \"\";\n  handleInput(\n    event: InputEvent<HTMLInputElement>\n  ): ReturnType<DBInputState[\"handleInput\"]> {\n    if (this.onInput) {\n      this.onInput.emit(event);\n    }\n    if (this.input) {\n      this.input.emit(event);\n    }\n  }\n  handleChange(\n    event: ChangeEvent<HTMLInputElement>\n  ): ReturnType<DBInputState[\"handleChange\"]> {\n    if (this.onChange) {\n      this.onChange.emit(event);\n    }\n    if (this.change) {\n      this.change.emit(event);\n    }\n    handleFrameworkEventAngular(this, event);\n\n    /* For a11y reasons we need to map the correct message with the input */\n    if (\n      !this._ref?.nativeElement?.validity.valid ||\n      this.validation === \"invalid\"\n    ) {\n      this._descByIds = this._invalidMessageId;\n      if (hasVoiceOver()) {\n        this._voiceOverFallback =\n          this.invalidMessage ??\n          this._ref?.nativeElement?.validationMessage ??\n          DEFAULT_INVALID_MESSAGE;\n        delay(() => (this._voiceOverFallback = \"\"), 1000);\n      }\n    } else if (\n      this.validation === \"valid\" ||\n      (this._ref?.nativeElement?.validity.valid &&\n        (this.required || this.minLength || this.maxLength || this.pattern))\n    ) {\n      this._descByIds = this._validMessageId;\n      if (hasVoiceOver()) {\n        this._voiceOverFallback = this.validMessage ?? DEFAULT_VALID_MESSAGE;\n        delay(() => (this._voiceOverFallback = \"\"), 1000);\n      }\n    } else if (stringPropVisible(this.message, this.showMessage)) {\n      this._descByIds = this._messageId;\n    } else {\n      this._descByIds = \"\";\n    }\n  }\n  handleBlur(\n    event: InteractionEvent<HTMLInputElement>\n  ): ReturnType<DBInputState[\"handleBlur\"]> {\n    if (this.onBlur) {\n      this.onBlur.emit(event);\n    }\n    if (this.blur) {\n      this.blur.emit(event);\n    }\n  }\n  handleFocus(\n    event: InteractionEvent<HTMLInputElement>\n  ): ReturnType<DBInputState[\"handleFocus\"]> {\n    if (this.onFocus) {\n      this.onFocus.emit(event);\n    }\n    if (this.focus) {\n      this.focus.emit(event);\n    }\n  }\n  getDataList(\n    _list?: string[] | ValueLabelType[]\n  ): ReturnType<DBInputState[\"getDataList\"]> {\n    return Array.from(\n      (isArrayOfStrings(_list)\n        ? _list.map((val: string) => ({\n            value: val,\n            label: undefined,\n          }))\n        : _list) || []\n    );\n  }\n  trackByOption0(_, option) {\n    return this._dataListId + \"-option-\" + option.value;\n  }\n\n  /**\n   * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n   * @param element  the ref for the component\n   * @param customElementSelector  the custom element like `my-component`\n   */\n  private enableAttributePassing(\n    element: HTMLElement | null,\n    customElementSelector: string\n  ) {\n    const parent = element?.closest(customElementSelector);\n    if (element && parent) {\n      const attributes = parent.attributes;\n      for (let i = 0; i < attributes.length; i++) {\n        const attr = attributes.item(i);\n        if (\n          attr &&\n          (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n        ) {\n          element.setAttribute(attr.name, attr.value);\n          parent.removeAttribute(attr.name);\n        }\n        if (attr && attr.name === \"class\") {\n          const isWebComponent = attr.value.includes(\"hydrated\");\n          const value = attr.value.replace(\"hydrated\", \"\").trim();\n          const currentClass = element.getAttribute(\"class\");\n          element.setAttribute(\n            attr.name,\n            `${currentClass ? `${currentClass} ` : \"\"}${value}`\n          );\n          if (isWebComponent) {\n            // Stencil is using this class for lazy loading component\n            parent.setAttribute(\"class\", \"hydrated\");\n          } else {\n            parent.removeAttribute(attr.name);\n          }\n        }\n      }\n    }\n  }\n\n  \n\t\twriteValue(value: any) {\nif (!value && (this.type === \"date\" ||\n\t\t\tthis.type === \"time\" ||\n\t\t\tthis.type === \"week\" ||\n\t\t\tthis.type === \"month\" ||\n\t\t\tthis.type === \"datetime-local\"\n\t\t\t)) return;\n\t\t  this.value = value;\n\n\t\t  if (this._ref?.nativeElement) {\n\t\t\t this.renderer.setProperty(this._ref?.nativeElement, 'value', value);\n\t\t  }\n\t\t}\n\n\t\tpropagateChange(_: any) {}\n\n\t\tregisterOnChange(onChange: any) {\n\t\t  this.propagateChange = onChange;\n\t\t}\n\n\t\tregisterOnTouched(onTouched: any) {\n\t\t //this.onTouched = onTouched;\n\t\t}\n\n\t\tsetDisabledState(disabled: boolean) {\n\t\t  this.disabled = disabled;\n\t\t}\n\n\t\tngOnInit() {\n    if (typeof window !== \"undefined\") {\n      const mId = this.id ?? `input-${uuid()}`;\n      this._id = mId;\n      this._messageId = mId + DEFAULT_MESSAGE_ID_SUFFIX;\n      this._validMessageId = mId + DEFAULT_VALID_MESSAGE_ID_SUFFIX;\n      this._invalidMessageId = mId + DEFAULT_INVALID_MESSAGE_ID_SUFFIX;\n      this._dataListId = mId + DEFAULT_DATALIST_ID_SUFFIX;\n    }\n  }\n\n  ngAfterViewInit() {\n    const element: HTMLElement | null = this._ref?.nativeElement;\n    this.enableAttributePassing(element, \"db-input\");\n  }\n\n  ngAfterContentChecked(changes: SimpleChanges) {\n    if (typeof window !== \"undefined\") {\n      if (this._id) {\n        const messageId = this._id + DEFAULT_MESSAGE_ID_SUFFIX;\n        this._messageId = messageId;\n        this._validMessageId = this._id + DEFAULT_VALID_MESSAGE_ID_SUFFIX;\n        this._invalidMessageId = this._id + DEFAULT_INVALID_MESSAGE_ID_SUFFIX;\n        this._dataListId =\n          this.dataListId ?? this._id + DEFAULT_DATALIST_ID_SUFFIX;\n        if (stringPropVisible(this.message, this.showMessage)) {\n          this._descByIds = messageId;\n        }\n      }\n      this._value = this.value;\n    }\n  }\n}\n"]}
|
|
431
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/input/input.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Output,\n  EventEmitter,\n  Component,\n  ViewChild,\n  ElementRef,\n  Input,\n  SimpleChanges,\nRenderer2 } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n\nimport { CommonModule } from \"@angular/common\";\n\nconst defaultProps = {};\n\nimport {\n  cls,\n  delay,\n  getHideProp,\n  hasVoiceOver,\n  isArrayOfStrings,\n  stringPropVisible,\n  uuid,\n} from \"../../utils\";\nimport { DBInputProps, DBInputState } from \"./model\";\nimport {\n  DEFAULT_DATALIST_ID_SUFFIX,\n  DEFAULT_INVALID_MESSAGE,\n  DEFAULT_INVALID_MESSAGE_ID_SUFFIX,\n  DEFAULT_LABEL,\n  DEFAULT_MESSAGE_ID_SUFFIX,\n  DEFAULT_PLACEHOLDER,\n  DEFAULT_VALID_MESSAGE,\n  DEFAULT_VALID_MESSAGE_ID_SUFFIX,\n} from \"../../shared/constants\";\nimport {\n  ChangeEvent,\n  InputEvent,\n  InteractionEvent,\n  ValueLabelType,\n} from \"../../shared/model\";\nimport { DBInfotext } from \"../infotext/infotext\";\nimport {\n  handleFrameworkEventVue,\n  handleFrameworkEventAngular,\n} from \"../../utils/form-components\";\n\n@Component({\n\t\tproviders: [{\n\t\t\tprovide: NG_VALUE_ACCESSOR,\n\t\t\tuseExisting: DBInput,\n\t\t\tmulti: true\n\t\t}],\t\n  selector: \"db-input\",\n  template: `\n    <div\n      [class]=\"cls('db-input', className)\"\n      [attr.data-variant]=\"variant\"\n      [attr.data-hide-label]=\"getHideProp(showLabel)\"\n      [attr.data-hide-icon]=\"getHideProp(showIcon)\"\n      [attr.data-icon]=\"icon\"\n      [attr.data-icon-after]=\"iconAfter\"\n      [attr.data-hide-icon-after]=\"getHideProp(showIcon)\"\n    >\n      <label [attr.for]=\"_id\">{{label ?? DEFAULT_LABEL}}</label>\n      <input\n        [attr.aria-invalid]=\"validation === 'invalid'\"\n        [attr.data-custom-validity]=\"validation\"\n        #_ref\n        [attr.id]=\"_id\"\n        [attr.name]=\"name\"\n        [attr.type]=\"type || 'text'\"\n        [attr.placeholder]=\"placeholder ?? DEFAULT_PLACEHOLDER\"\n        [disabled]=\"disabled\"\n        [required]=\"required\"\n        [attr.step]=\"step\"\n        [attr.value]=\"value ?? _value\"\n        [attr.maxLength]=\"maxLength\"\n        [attr.minLength]=\"minLength\"\n        [attr.max]=\"max\"\n        [attr.min]=\"min\"\n        [attr.readOnly]=\"readOnly\"\n        [attr.form]=\"form\"\n        [attr.pattern]=\"pattern\"\n        [attr.size]=\"size\"\n        [attr.autoComplete]=\"autocomplete\"\n        [attr.autoFocus]=\"autofocus\"\n        (input)=\"handleInput($event)\"\n        (change)=\"handleChange($event)\"\n        (blur)=\"handleBlur($event)\"\n        (focus)=\"handleFocus($event)\"\n        [attr.list]=\"dataList && _dataListId\"\n        [attr.aria-describedby]=\"_descByIds\"\n      />\n      <ng-container *ngIf=\"dataList\">\n        <datalist [attr.id]=\"_dataListId\">\n          <ng-container\n            *ngFor=\"let option of getDataList(dataList); trackBy: trackByOption0\"\n          >\n            <option [attr.value]=\"option.value\">{{option.label}}</option>\n          </ng-container>\n        </datalist>\n      </ng-container>\n      <ng-content></ng-content>\n      <ng-container *ngIf=\"stringPropVisible(message, showMessage)\">\n        <db-infotext size=\"small\" [icon]=\"messageIcon\" [id]=\"_messageId\">\n          {{message}}\n        </db-infotext>\n      </ng-container>\n      <db-infotext size=\"small\" semantic=\"successful\" [id]=\"_validMessageId\">\n        {{validMessage ?? DEFAULT_VALID_MESSAGE}}\n      </db-infotext>\n      <db-infotext size=\"small\" semantic=\"critical\" [id]=\"_invalidMessageId\">\n        {{invalidMessage ?? this._ref?.validationMessage ??\n            DEFAULT_INVALID_MESSAGE}}\n      </db-infotext>\n      <span data-visually-hidden=\"true\" role=\"status\">\n        {{_voiceOverFallback}}\n      </span>\n    </div>\n  `,\n  standalone: true,\n  imports: [CommonModule, DBInfotext],\n})\nexport class DBInput implements ControlValueAccessor {\n\t\tconstructor(private renderer: Renderer2) { }\n  cls = cls;\n  getHideProp = getHideProp;\n  stringPropVisible = stringPropVisible;\n  DEFAULT_INVALID_MESSAGE = DEFAULT_INVALID_MESSAGE;\n  DEFAULT_LABEL = DEFAULT_LABEL;\n  DEFAULT_PLACEHOLDER = DEFAULT_PLACEHOLDER;\n  DEFAULT_VALID_MESSAGE = DEFAULT_VALID_MESSAGE;\n\n  @Input() id!: DBInputProps[\"id\"];\n  @Input() dataListId!: DBInputProps[\"dataListId\"];\n  @Input() message!: DBInputProps[\"message\"];\n  @Input() showMessage!: DBInputProps[\"showMessage\"];\n  @Input() value!: DBInputProps[\"value\"];\n  @Input() validation!: DBInputProps[\"validation\"];\n  @Input() invalidMessage!: DBInputProps[\"invalidMessage\"];\n  @Input() required!: DBInputProps[\"required\"];\n  @Input() minLength!: DBInputProps[\"minLength\"];\n  @Input() maxLength!: DBInputProps[\"maxLength\"];\n  @Input() pattern!: DBInputProps[\"pattern\"];\n  @Input() validMessage!: DBInputProps[\"validMessage\"];\n  @Input() className!: DBInputProps[\"className\"];\n  @Input() variant!: DBInputProps[\"variant\"];\n  @Input() showLabel!: DBInputProps[\"showLabel\"];\n  @Input() showIcon!: DBInputProps[\"showIcon\"];\n  @Input() icon!: DBInputProps[\"icon\"];\n  @Input() iconAfter!: DBInputProps[\"iconAfter\"];\n  @Input() label!: DBInputProps[\"label\"];\n  @Input() name!: DBInputProps[\"name\"];\n  @Input() type!: DBInputProps[\"type\"];\n  @Input() placeholder!: DBInputProps[\"placeholder\"];\n  @Input() disabled!: DBInputProps[\"disabled\"];\n  @Input() step!: DBInputProps[\"step\"];\n  @Input() max!: DBInputProps[\"max\"];\n  @Input() min!: DBInputProps[\"min\"];\n  @Input() readOnly!: DBInputProps[\"readOnly\"];\n  @Input() form!: DBInputProps[\"form\"];\n  @Input() size!: DBInputProps[\"size\"];\n  @Input() autocomplete!: DBInputProps[\"autocomplete\"];\n  @Input() autofocus!: DBInputProps[\"autofocus\"];\n  @Input() dataList!: DBInputProps[\"dataList\"];\n  @Input() messageIcon!: DBInputProps[\"messageIcon\"];\n\n  @Output() onInput = new EventEmitter();\n  @Output() input = new EventEmitter();\n  @Output() onChange = new EventEmitter();\n  @Output() change = new EventEmitter();\n  @Output() onBlur = new EventEmitter();\n  @Output() blur = new EventEmitter();\n  @Output() onFocus = new EventEmitter();\n  @Output() focus = new EventEmitter();\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  _id: DBInputState[\"_id\"] = undefined;\n  _messageId: DBInputState[\"_messageId\"] = undefined;\n  _validMessageId: DBInputState[\"_validMessageId\"] = undefined;\n  _invalidMessageId: DBInputState[\"_invalidMessageId\"] = undefined;\n  _dataListId: DBInputState[\"_dataListId\"] = undefined;\n  _descByIds: DBInputState[\"_descByIds\"] = \"\";\n  _value: DBInputState[\"_value\"] = \"\";\n  _voiceOverFallback: DBInputState[\"_voiceOverFallback\"] = \"\";\n  handleInput(\n    event: InputEvent<HTMLInputElement>\n  ): ReturnType<DBInputState[\"handleInput\"]> {\n    if (this.onInput) {\n      this.onInput.emit(event);\n    }\n    if (this.input) {\n      this.input.emit(event);\n    }\n  }\n  handleChange(\n    event: ChangeEvent<HTMLInputElement>\n  ): ReturnType<DBInputState[\"handleChange\"]> {\n    if (this.onChange) {\n      this.onChange.emit(event);\n    }\n    if (this.change) {\n      this.change.emit(event);\n    }\n    handleFrameworkEventAngular(this, event);\n\n    /* For a11y reasons we need to map the correct message with the input */\n    if (\n      !this._ref?.nativeElement?.validity.valid ||\n      this.validation === \"invalid\"\n    ) {\n      this._descByIds = this._invalidMessageId;\n      if (hasVoiceOver()) {\n        this._voiceOverFallback =\n          this.invalidMessage ??\n          this._ref?.nativeElement?.validationMessage ??\n          DEFAULT_INVALID_MESSAGE;\n        delay(() => (this._voiceOverFallback = \"\"), 1000);\n      }\n    } else if (\n      this.validation === \"valid\" ||\n      (this._ref?.nativeElement?.validity.valid &&\n        (this.required || this.minLength || this.maxLength || this.pattern))\n    ) {\n      this._descByIds = this._validMessageId;\n      if (hasVoiceOver()) {\n        this._voiceOverFallback = this.validMessage ?? DEFAULT_VALID_MESSAGE;\n        delay(() => (this._voiceOverFallback = \"\"), 1000);\n      }\n    } else if (stringPropVisible(this.message, this.showMessage)) {\n      this._descByIds = this._messageId;\n    } else {\n      this._descByIds = \"\";\n    }\n  }\n  handleBlur(\n    event: InteractionEvent<HTMLInputElement>\n  ): ReturnType<DBInputState[\"handleBlur\"]> {\n    if (this.onBlur) {\n      this.onBlur.emit(event);\n    }\n    if (this.blur) {\n      this.blur.emit(event);\n    }\n  }\n  handleFocus(\n    event: InteractionEvent<HTMLInputElement>\n  ): ReturnType<DBInputState[\"handleFocus\"]> {\n    if (this.onFocus) {\n      this.onFocus.emit(event);\n    }\n    if (this.focus) {\n      this.focus.emit(event);\n    }\n  }\n  getDataList(\n    _list?: string[] | ValueLabelType[]\n  ): ReturnType<DBInputState[\"getDataList\"]> {\n    return Array.from(\n      (isArrayOfStrings(_list)\n        ? _list.map((val: string) => ({\n            value: val,\n            label: undefined,\n          }))\n        : _list) || []\n    );\n  }\n  trackByOption0(_, option) {\n    return this._dataListId + \"-option-\" + option.value;\n  }\n\n  /**\n   * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n   * @param element  the ref for the component\n   * @param customElementSelector  the custom element like `my-component`\n   */\n  private enableAttributePassing(\n    element: HTMLElement | null,\n    customElementSelector: string\n  ) {\n    const parent = element?.closest(customElementSelector);\n    if (element && parent) {\n      const attributes = parent.attributes;\n      for (let i = 0; i < attributes.length; i++) {\n        const attr = attributes.item(i);\n        if (\n          attr &&\n          (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n        ) {\n          element.setAttribute(attr.name, attr.value);\n          parent.removeAttribute(attr.name);\n        }\n        if (attr && attr.name === \"class\") {\n          const isWebComponent = attr.value.includes(\"hydrated\");\n          const value = attr.value.replace(\"hydrated\", \"\").trim();\n          const currentClass = element.getAttribute(\"class\");\n          element.setAttribute(\n            attr.name,\n            `${currentClass ? `${currentClass} ` : \"\"}${value}`\n          );\n          if (isWebComponent) {\n            // Stencil is using this class for lazy loading component\n            parent.setAttribute(\"class\", \"hydrated\");\n          } else {\n            parent.removeAttribute(attr.name);\n          }\n        }\n      }\n    }\n  }\n\n  \n\t\twriteValue(value: any) {\nif (!value && (this.type === \"date\" ||\n\t\t\tthis.type === \"time\" ||\n\t\t\tthis.type === \"week\" ||\n\t\t\tthis.type === \"month\" ||\n\t\t\tthis.type === \"datetime-local\"\n\t\t\t)) return;\n\t\t\t\n\t\t  this.value = value;\n\n\t\t  if (this._ref?.nativeElement) {\n\t\t\t this.renderer.setProperty(this._ref?.nativeElement, 'value', value);\n\t\t  }\n\t\t\t\n\t\t}\n\n\t\tpropagateChange(_: any) {}\n\n\t\tregisterOnChange(onChange: any) {\n\t\t  this.propagateChange = onChange;\n\t\t}\n\n\t\tregisterOnTouched(onTouched: any) {\n\t\t //this.onTouched = onTouched;\n\t\t}\n\n\t\tsetDisabledState(disabled: boolean) {\n\t\t  this.disabled = disabled;\n\t\t}\n\n\t\tngOnInit() {\n    if (typeof window !== \"undefined\") {\n      const mId = this.id ?? `input-${uuid()}`;\n      this._id = mId;\n      this._messageId = mId + DEFAULT_MESSAGE_ID_SUFFIX;\n      this._validMessageId = mId + DEFAULT_VALID_MESSAGE_ID_SUFFIX;\n      this._invalidMessageId = mId + DEFAULT_INVALID_MESSAGE_ID_SUFFIX;\n      this._dataListId = mId + DEFAULT_DATALIST_ID_SUFFIX;\n    }\n  }\n\n  ngAfterViewInit() {\n    const element: HTMLElement | null = this._ref?.nativeElement;\n    this.enableAttributePassing(element, \"db-input\");\n  }\n\n  ngAfterContentChecked(changes: SimpleChanges) {\n    if (typeof window !== \"undefined\") {\n      if (this._id) {\n        const messageId = this._id + DEFAULT_MESSAGE_ID_SUFFIX;\n        this._messageId = messageId;\n        this._validMessageId = this._id + DEFAULT_VALID_MESSAGE_ID_SUFFIX;\n        this._invalidMessageId = this._id + DEFAULT_INVALID_MESSAGE_ID_SUFFIX;\n        this._dataListId =\n          this.dataListId ?? this._id + DEFAULT_DATALIST_ID_SUFFIX;\n        if (stringPropVisible(this.message, this.showMessage)) {\n          this._descByIds = messageId;\n        }\n      }\n      this._value = this.value;\n    }\n  }\n}\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9uYXZpZ2F0aW9uLWl0ZW0vbW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsaWNrRXZlbnQsIENsaWNrRXZlbnRQcm9wcywgQ2xpY2tFdmVudFN0YXRlLCBHbG9iYWxQcm9wcywgR2xvYmFsU3RhdGUsIEljb25Qcm9wcywgSW5pdGlhbGl6ZWRTdGF0ZSwgTmF2aWdhdGlvbkJhY2tCdXR0b25Qcm9wcywgTmF2aWdhdGlvbkJlaGF2aW9yU3RhdGUsIFNob3dJY29uUHJvcHMsIFRleHRQcm9wcywgV2lkdGhQcm9wcyB9IGZyb20gJy4uLy4uL3NoYXJlZC9tb2RlbCc7XG5pbXBvcnQgeyBOYXZpZ2F0aW9uSXRlbVNhZmVUcmlhbmdsZSB9IGZyb20gJy4uLy4uL3V0aWxzL25hdmlnYXRpb24nO1xuZXhwb3J0IHR5cGUgREJOYXZpZ2F0aW9uSXRlbURlZmF1bHRQcm9wcyA9IHtcbiAgLyoqXG4gICAqIEFsdGVybmF0aXZlIGluZGljYXRvciBmb3IgYWN0aXZlIG5hdmlnYXRpb24gaXRlbSAoYm9sZCBmb250KS4gSW4gY29udHJhc3QgdG8gdGhlIHVzZSBvZiBhcmlhLWN1cnJlbnQ9XCJwYWdlXCIgb24gdGhlIGNvbnRhaW5lZCBhbmNob3IsIHRoaXMgZG9lcyBub3QgZ3VhcmFudGVlIGNvcnJlY3QgYTExeS5cbiAgICovXG4gIGFjdGl2ZT86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRoZSBkaXNhYmxlZCBhdHRyaWJ1dGUgY2FuIGJlIHNldCB0byBba2VlcCBhIHVzZXIgZnJvbSBjbGlja2luZyBvbiB0aGUgaXRlbV0oaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvSFRNTC9FbGVtZW50L2J1dHRvbiNkaXNhYmxlZCkuXG4gICAqL1xuICBkaXNhYmxlZD86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFJlYWN0LXNwZWNpZmljIHByb3BlcnR5IHRvIHBhc3MgaW4gYSBzbG90IGZvciBzdWItbmF2aWdhdGlvblxuICAgKi9cbiAgc3ViTmF2aWdhdGlvbj86IGFueTtcblxuICAvKipcbiAgICogVGhpcyBpcyBmb3IgbW9iaWxlIG5hdmlnYXRpb24gb25seSwgaWYgaXQgaXMgc2V0IHRoZSBzdWItbmF2aWdhdGlvbiBpcyBhIHN0YXRpYyBvdmVybGF5XG4gICAqL1xuICBzdWJOYXZpZ2F0aW9uRXhwYW5kZWQ/OiBib29sZWFuO1xufTtcbmV4cG9ydCB0eXBlIERCTmF2aWdhdGlvbkl0ZW1Qcm9wcyA9IERCTmF2aWdhdGlvbkl0ZW1EZWZhdWx0UHJvcHMgJiBHbG9iYWxQcm9wcyAmIENsaWNrRXZlbnRQcm9wczxIVE1MQnV0dG9uRWxlbWVudD4gJiBJY29uUHJvcHMgJiBXaWR0aFByb3BzICYgTmF2aWdhdGlvbkJhY2tCdXR0b25Qcm9wcyAmIFNob3dJY29uUHJvcHMgJiBUZXh0UHJvcHM7XG5leHBvcnQgdHlwZSBEQk5hdmlnYXRpb25JdGVtRGVmYXVsdFN0YXRlID0ge1xuICBoYW5kbGVCYWNrQ2xpY2s6IChldmVudDogQ2xpY2tFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4pID0+IHZvaWQ7XG4gIGhhc0FyZWFQb3B1cDogYm9vbGVhbjtcbiAgaXNTdWJOYXZpZ2F0aW9uRXhwYW5kZWQ6IGJvb2xlYW47XG4gIHN1Yk5hdmlnYXRpb25JZDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBJbnRlcm5hbCBzdGF0ZSBwcm9wZXJ0eSB0byBzaG93L2hpZGUgc3ViLW5hdmlnYXRpb24gYnV0dG9uXG4gICAqL1xuICBoYXNTdWJOYXZpZ2F0aW9uPzogYm9vbGVhbjtcbiAgdXBkYXRlU3ViTmF2aWdhdGlvblN0YXRlOiAoKSA9PiB2b2lkO1xuICBuYXZpZ2F0aW9uSXRlbVNhZmVUcmlhbmdsZT86IE5hdmlnYXRpb25JdGVtU2FmZVRyaWFuZ2xlO1xuICBhdXRvQ2xvc2U/OiBib29sZWFuO1xufTtcbmV4cG9ydCB0eXBlIERCTmF2aWdhdGlvbkl0ZW1TdGF0ZSA9IERCTmF2aWdhdGlvbkl0ZW1EZWZhdWx0U3RhdGUgJiBDbGlja0V2ZW50U3RhdGU8SFRNTEJ1dHRvbkVsZW1lbnQ+ICYgR2xvYmFsU3RhdGUgJiBJbml0aWFsaXplZFN0YXRlICYgTmF2aWdhdGlvbkJlaGF2aW9yU3RhdGUiXX0=
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { Output, EventEmitter, Component, ViewChild, Input, ContentChild, TemplateRef } from "@angular/core";
|
|
2
2
|
import { CommonModule } from "@angular/common";
|
|
3
3
|
import { DBButton } from "../button/button";
|
|
4
|
-
import { cls, getBooleanAsString, getHideProp, uuid } from "../../utils";
|
|
5
|
-
import { NavigationItemSafeTriangle } from "../../utils/navigation";
|
|
4
|
+
import { cls, delay, getBooleanAsString, getHideProp, uuid } from "../../utils";
|
|
5
|
+
import { isEventTargetNavigationItem, NavigationItemSafeTriangle, } from "../../utils/navigation";
|
|
6
6
|
import { DEFAULT_BACK } from "../../shared/constants";
|
|
7
7
|
import { NavigationContentDirective } from './NavigationContent.directive';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
@@ -19,9 +19,18 @@ export class DBNavigationItem {
|
|
|
19
19
|
this.hasAreaPopup = false;
|
|
20
20
|
this.hasSubNavigation = true;
|
|
21
21
|
this.isSubNavigationExpanded = false;
|
|
22
|
+
this.autoClose = false;
|
|
22
23
|
this.subNavigationId = "sub-navigation-" + uuid();
|
|
23
24
|
this.navigationItemSafeTriangle = undefined;
|
|
24
25
|
}
|
|
26
|
+
handleNavigationItemClick(event) {
|
|
27
|
+
if (isEventTargetNavigationItem(event)) {
|
|
28
|
+
this.autoClose = true;
|
|
29
|
+
delay(() => {
|
|
30
|
+
this.autoClose = false;
|
|
31
|
+
}, 300);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
25
34
|
handleClick(event) {
|
|
26
35
|
if (this.onClick) {
|
|
27
36
|
this.onClick.emit(event);
|
|
@@ -129,7 +138,12 @@ export class DBNavigationItem {
|
|
|
129
138
|
<ng-container *ngIf="text">{{text}}</ng-container>
|
|
130
139
|
<ng-container *ngIf="!(text)"><ng-content *ngTemplateOutlet="dbNavigationContent"></ng-content></ng-container>
|
|
131
140
|
</button>
|
|
132
|
-
<menu
|
|
141
|
+
<menu
|
|
142
|
+
class="db-sub-navigation"
|
|
143
|
+
[attr.data-auto-close]="autoClose"
|
|
144
|
+
[attr.id]="subNavigationId"
|
|
145
|
+
(click)="handleNavigationItemClick($event)"
|
|
146
|
+
>
|
|
133
147
|
<ng-container *ngIf="hasAreaPopup">
|
|
134
148
|
<div class="db-mobile-navigation-back">
|
|
135
149
|
<db-button
|
|
@@ -181,7 +195,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
181
195
|
<ng-container *ngIf="text">{{text}}</ng-container>
|
|
182
196
|
<ng-container *ngIf="!(text)"><ng-content *ngTemplateOutlet="dbNavigationContent"></ng-content></ng-container>
|
|
183
197
|
</button>
|
|
184
|
-
<menu
|
|
198
|
+
<menu
|
|
199
|
+
class="db-sub-navigation"
|
|
200
|
+
[attr.data-auto-close]="autoClose"
|
|
201
|
+
[attr.id]="subNavigationId"
|
|
202
|
+
(click)="handleNavigationItemClick($event)"
|
|
203
|
+
>
|
|
185
204
|
<ng-container *ngIf="hasAreaPopup">
|
|
186
205
|
<div class="db-mobile-navigation-back">
|
|
187
206
|
<db-button
|
|
@@ -233,4 +252,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
233
252
|
type: ViewChild,
|
|
234
253
|
args: ["_ref"]
|
|
235
254
|
}] } });
|
|
236
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation-item.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/navigation-item/navigation-item.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Output,\n  EventEmitter,\n  Component,\n  ViewChild,\n  ElementRef,\n  Input,\n  SimpleChanges,\nContentChild, TemplateRef } from  \"@angular/core\";\n\nimport { CommonModule } from \"@angular/common\";\n\nconst defaultProps = {};\n\nimport { DBNavigationItemProps, DBNavigationItemState } from \"./model\";\nimport { DBButton } from \"../button/button\";\nimport { cls, getBooleanAsString, getHideProp, uuid } from \"../../utils\";\nimport { NavigationItemSafeTriangle } from \"../../utils/navigation\";\nimport { DEFAULT_BACK } from \"../../shared/constants\";\nimport { ClickEvent } from \"../../shared/model\";\n\nimport { NavigationContentDirective } from './NavigationContent.directive';\n\n@Component({\n  selector: \"db-navigation-item\",\n  template: `\n    <li\n      #_ref\n      [attr.id]=\"id\"\n      (mouseover)=\"navigationItemSafeTriangle?.enableFollow()\"\n      (mouseleave)=\"navigationItemSafeTriangle?.disableFollow()\"\n      (mousemove)=\"navigationItemSafeTriangle?.followByMouseEvent($event)\"\n      [class]=\"cls('db-navigation-item', className)\"\n      [attr.data-width]=\"width\"\n      [attr.data-icon]=\"icon\"\n      [attr.data-hide-icon]=\"getHideProp(showIcon)\"\n      [attr.data-active]=\"active\"\n      [attr.aria-disabled]=\"getBooleanAsString(disabled)\"\n    >\n      <ng-container *ngIf=\"!hasSubNavigation\">\n        <ng-container *ngIf=\"text\">{{text}}</ng-container>\n        <ng-container *ngIf=\"!(text)\"><ng-content *ngTemplateOutlet=\"dbNavigationContent\"></ng-content></ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"hasSubNavigation\">\n        <button\n          class=\"db-navigation-item-expand-button\"\n          [attr.aria-haspopup]=\"hasAreaPopup\"\n          [attr.aria-expanded]=\"isSubNavigationExpanded\"\n          [attr.disabled]=\"disabled\"\n          (click)=\"handleClick($event)\"\n        >\n          <ng-container *ngIf=\"text\">{{text}}</ng-container>\n          <ng-container *ngIf=\"!(text)\"><ng-content *ngTemplateOutlet=\"dbNavigationContent\"></ng-content></ng-container>\n        </button>\n        <menu class=\"db-sub-navigation\" [attr.id]=\"subNavigationId\">\n          <ng-container *ngIf=\"hasAreaPopup\">\n            <div class=\"db-mobile-navigation-back\">\n              <db-button\n                icon=\"arrow_left\"\n                variant=\"ghost\"\n                [id]=\"backButtonId\"\n                (click)=\"handleBackClick($event)\"\n              >\n                {{backButtonText ?? DEFAULT_BACK}}\n              </db-button>\n            </div>\n          </ng-container>\n          <ng-content select=\"[sub-navigation]\"></ng-content>\n        </menu>\n      </ng-container>\n    </li>\n  `,\n  standalone: true,\n  imports: [CommonModule, DBButton],\n})\nexport class DBNavigationItem {\n\t@ContentChild(NavigationContentDirective, { read: TemplateRef }) dbNavigationContent: any;\n  cls = cls;\n  getBooleanAsString = getBooleanAsString;\n  getHideProp = getHideProp;\n  DEFAULT_BACK = DEFAULT_BACK;\n\n  @Input()\n  subNavigationExpanded!: DBNavigationItemProps[\"subNavigationExpanded\"];\n  @Input() id!: DBNavigationItemProps[\"id\"];\n  @Input() className!: DBNavigationItemProps[\"className\"];\n  @Input() width!: DBNavigationItemProps[\"width\"];\n  @Input() icon!: DBNavigationItemProps[\"icon\"];\n  @Input() showIcon!: DBNavigationItemProps[\"showIcon\"];\n  @Input() active!: DBNavigationItemProps[\"active\"];\n  @Input() disabled!: DBNavigationItemProps[\"disabled\"];\n  @Input() text!: DBNavigationItemProps[\"text\"];\n  @Input() backButtonId!: DBNavigationItemProps[\"backButtonId\"];\n  @Input() backButtonText!: DBNavigationItemProps[\"backButtonText\"];\n\n  @Output() onClick = new EventEmitter();\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  initialized: DBNavigationItemState[\"initialized\"] = false;\n  hasAreaPopup: DBNavigationItemState[\"hasAreaPopup\"] = false;\n  hasSubNavigation: DBNavigationItemState[\"hasSubNavigation\"] = true;\n  isSubNavigationExpanded: DBNavigationItemState[\"isSubNavigationExpanded\"] =\n    false;\n  subNavigationId: DBNavigationItemState[\"subNavigationId\"] =\n    \"sub-navigation-\" + uuid();\n  navigationItemSafeTriangle: DBNavigationItemState[\"navigationItemSafeTriangle\"] =\n    undefined;\n  handleClick(\n    event: ClickEvent<HTMLButtonElement>\n  ): ReturnType<DBNavigationItemState[\"handleClick\"]> {\n    if (this.onClick) {\n      this.onClick.emit(event);\n    }\n    if (this.hasAreaPopup) {\n      this.isSubNavigationExpanded = true;\n    }\n  }\n  handleBackClick(\n    event: ClickEvent<HTMLButtonElement>\n  ): ReturnType<DBNavigationItemState[\"handleBackClick\"]> {\n    event.stopPropagation();\n    this.isSubNavigationExpanded = false;\n  }\n  updateSubNavigationState(): ReturnType<\n    DBNavigationItemState[\"updateSubNavigationState\"]\n  > {\n    if (this.initialized && document && this.subNavigationId) {\n      const subNavigationSlot = document?.getElementById(\n        this.subNavigationId\n      ) as HTMLMenuElement;\n      if (subNavigationSlot) {\n        if (subNavigationSlot.children?.length > 0) {\n          this.hasAreaPopup = true;\n          if (!this.navigationItemSafeTriangle) {\n            this.navigationItemSafeTriangle = new NavigationItemSafeTriangle(\n              this._ref?.nativeElement,\n              subNavigationSlot\n            );\n          }\n        } else {\n          this.hasSubNavigation = false;\n        }\n      }\n    }\n  }\n\n  /**\n   * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n   * @param element  the ref for the component\n   * @param customElementSelector  the custom element like `my-component`\n   */\n  private enableAttributePassing(\n    element: HTMLElement | null,\n    customElementSelector: string\n  ) {\n    const parent = element?.closest(customElementSelector);\n    if (element && parent) {\n      const attributes = parent.attributes;\n      for (let i = 0; i < attributes.length; i++) {\n        const attr = attributes.item(i);\n        if (\n          attr &&\n          (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n        ) {\n          element.setAttribute(attr.name, attr.value);\n          parent.removeAttribute(attr.name);\n        }\n        if (attr && attr.name === \"class\") {\n          const isWebComponent = attr.value.includes(\"hydrated\");\n          const value = attr.value.replace(\"hydrated\", \"\").trim();\n          const currentClass = element.getAttribute(\"class\");\n          element.setAttribute(\n            attr.name,\n            `${currentClass ? `${currentClass} ` : \"\"}${value}`\n          );\n          if (isWebComponent) {\n            // Stencil is using this class for lazy loading component\n            parent.setAttribute(\"class\", \"hydrated\");\n          } else {\n            parent.removeAttribute(attr.name);\n          }\n        }\n      }\n    }\n  }\n\n  ngOnInit() {\n    if (typeof window !== \"undefined\") {\n      this.initialized = true;\n    }\n  }\n\n  ngAfterViewInit() {\n    const element: HTMLElement | null = this._ref?.nativeElement;\n    this.enableAttributePassing(element, \"db-navigation-item\");\n  }\n\n  ngAfterContentChecked(changes: SimpleChanges) {\n    if (typeof window !== \"undefined\") {\n      if (this.subNavigationExpanded !== undefined) {\n        this.isSubNavigationExpanded = !!this.subNavigationExpanded;\n      }\n      this.updateSubNavigationState();\n    }\n  }\n}\n"]}
|
|
255
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation-item.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/navigation-item/navigation-item.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Output,\n  EventEmitter,\n  Component,\n  ViewChild,\n  ElementRef,\n  Input,\n  SimpleChanges,\nContentChild, TemplateRef } from  \"@angular/core\";\n\nimport { CommonModule } from \"@angular/common\";\n\nconst defaultProps = {};\n\nimport { DBNavigationItemProps, DBNavigationItemState } from \"./model\";\nimport { DBButton } from \"../button/button\";\nimport { cls, delay, getBooleanAsString, getHideProp, uuid } from \"../../utils\";\nimport {\n  isEventTargetNavigationItem,\n  NavigationItemSafeTriangle,\n} from \"../../utils/navigation\";\nimport { DEFAULT_BACK } from \"../../shared/constants\";\nimport { ClickEvent } from \"../../shared/model\";\n\nimport { NavigationContentDirective } from './NavigationContent.directive';\n\n@Component({\n  selector: \"db-navigation-item\",\n  template: `\n    <li\n      #_ref\n      [attr.id]=\"id\"\n      (mouseover)=\"navigationItemSafeTriangle?.enableFollow()\"\n      (mouseleave)=\"navigationItemSafeTriangle?.disableFollow()\"\n      (mousemove)=\"navigationItemSafeTriangle?.followByMouseEvent($event)\"\n      [class]=\"cls('db-navigation-item', className)\"\n      [attr.data-width]=\"width\"\n      [attr.data-icon]=\"icon\"\n      [attr.data-hide-icon]=\"getHideProp(showIcon)\"\n      [attr.data-active]=\"active\"\n      [attr.aria-disabled]=\"getBooleanAsString(disabled)\"\n    >\n      <ng-container *ngIf=\"!hasSubNavigation\">\n        <ng-container *ngIf=\"text\">{{text}}</ng-container>\n        <ng-container *ngIf=\"!(text)\"><ng-content *ngTemplateOutlet=\"dbNavigationContent\"></ng-content></ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"hasSubNavigation\">\n        <button\n          class=\"db-navigation-item-expand-button\"\n          [attr.aria-haspopup]=\"hasAreaPopup\"\n          [attr.aria-expanded]=\"isSubNavigationExpanded\"\n          [attr.disabled]=\"disabled\"\n          (click)=\"handleClick($event)\"\n        >\n          <ng-container *ngIf=\"text\">{{text}}</ng-container>\n          <ng-container *ngIf=\"!(text)\"><ng-content *ngTemplateOutlet=\"dbNavigationContent\"></ng-content></ng-container>\n        </button>\n        <menu\n          class=\"db-sub-navigation\"\n          [attr.data-auto-close]=\"autoClose\"\n          [attr.id]=\"subNavigationId\"\n          (click)=\"handleNavigationItemClick($event)\"\n        >\n          <ng-container *ngIf=\"hasAreaPopup\">\n            <div class=\"db-mobile-navigation-back\">\n              <db-button\n                icon=\"arrow_left\"\n                variant=\"ghost\"\n                [id]=\"backButtonId\"\n                (click)=\"handleBackClick($event)\"\n              >\n                {{backButtonText ?? DEFAULT_BACK}}\n              </db-button>\n            </div>\n          </ng-container>\n          <ng-content select=\"[sub-navigation]\"></ng-content>\n        </menu>\n      </ng-container>\n    </li>\n  `,\n  standalone: true,\n  imports: [CommonModule, DBButton],\n})\nexport class DBNavigationItem {\n\t@ContentChild(NavigationContentDirective, { read: TemplateRef }) dbNavigationContent: any;\n  cls = cls;\n  getBooleanAsString = getBooleanAsString;\n  getHideProp = getHideProp;\n  DEFAULT_BACK = DEFAULT_BACK;\n\n  @Input()\n  subNavigationExpanded!: DBNavigationItemProps[\"subNavigationExpanded\"];\n  @Input() id!: DBNavigationItemProps[\"id\"];\n  @Input() className!: DBNavigationItemProps[\"className\"];\n  @Input() width!: DBNavigationItemProps[\"width\"];\n  @Input() icon!: DBNavigationItemProps[\"icon\"];\n  @Input() showIcon!: DBNavigationItemProps[\"showIcon\"];\n  @Input() active!: DBNavigationItemProps[\"active\"];\n  @Input() disabled!: DBNavigationItemProps[\"disabled\"];\n  @Input() text!: DBNavigationItemProps[\"text\"];\n  @Input() backButtonId!: DBNavigationItemProps[\"backButtonId\"];\n  @Input() backButtonText!: DBNavigationItemProps[\"backButtonText\"];\n\n  @Output() onClick = new EventEmitter();\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  initialized: DBNavigationItemState[\"initialized\"] = false;\n  hasAreaPopup: DBNavigationItemState[\"hasAreaPopup\"] = false;\n  hasSubNavigation: DBNavigationItemState[\"hasSubNavigation\"] = true;\n  isSubNavigationExpanded: DBNavigationItemState[\"isSubNavigationExpanded\"] =\n    false;\n  autoClose: DBNavigationItemState[\"autoClose\"] = false;\n  subNavigationId: DBNavigationItemState[\"subNavigationId\"] =\n    \"sub-navigation-\" + uuid();\n  navigationItemSafeTriangle: DBNavigationItemState[\"navigationItemSafeTriangle\"] =\n    undefined;\n  handleNavigationItemClick(\n    event: unknown\n  ): ReturnType<DBNavigationItemState[\"handleNavigationItemClick\"]> {\n    if (isEventTargetNavigationItem(event)) {\n      this.autoClose = true;\n      delay(() => {\n        this.autoClose = false;\n      }, 300);\n    }\n  }\n  handleClick(\n    event: ClickEvent<HTMLButtonElement>\n  ): ReturnType<DBNavigationItemState[\"handleClick\"]> {\n    if (this.onClick) {\n      this.onClick.emit(event);\n    }\n    if (this.hasAreaPopup) {\n      this.isSubNavigationExpanded = true;\n    }\n  }\n  handleBackClick(\n    event: ClickEvent<HTMLButtonElement>\n  ): ReturnType<DBNavigationItemState[\"handleBackClick\"]> {\n    event.stopPropagation();\n    this.isSubNavigationExpanded = false;\n  }\n  updateSubNavigationState(): ReturnType<\n    DBNavigationItemState[\"updateSubNavigationState\"]\n  > {\n    if (this.initialized && document && this.subNavigationId) {\n      const subNavigationSlot = document?.getElementById(\n        this.subNavigationId\n      ) as HTMLMenuElement;\n      if (subNavigationSlot) {\n        if (subNavigationSlot.children?.length > 0) {\n          this.hasAreaPopup = true;\n          if (!this.navigationItemSafeTriangle) {\n            this.navigationItemSafeTriangle = new NavigationItemSafeTriangle(\n              this._ref?.nativeElement,\n              subNavigationSlot\n            );\n          }\n        } else {\n          this.hasSubNavigation = false;\n        }\n      }\n    }\n  }\n\n  /**\n   * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n   * @param element  the ref for the component\n   * @param customElementSelector  the custom element like `my-component`\n   */\n  private enableAttributePassing(\n    element: HTMLElement | null,\n    customElementSelector: string\n  ) {\n    const parent = element?.closest(customElementSelector);\n    if (element && parent) {\n      const attributes = parent.attributes;\n      for (let i = 0; i < attributes.length; i++) {\n        const attr = attributes.item(i);\n        if (\n          attr &&\n          (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n        ) {\n          element.setAttribute(attr.name, attr.value);\n          parent.removeAttribute(attr.name);\n        }\n        if (attr && attr.name === \"class\") {\n          const isWebComponent = attr.value.includes(\"hydrated\");\n          const value = attr.value.replace(\"hydrated\", \"\").trim();\n          const currentClass = element.getAttribute(\"class\");\n          element.setAttribute(\n            attr.name,\n            `${currentClass ? `${currentClass} ` : \"\"}${value}`\n          );\n          if (isWebComponent) {\n            // Stencil is using this class for lazy loading component\n            parent.setAttribute(\"class\", \"hydrated\");\n          } else {\n            parent.removeAttribute(attr.name);\n          }\n        }\n      }\n    }\n  }\n\n  ngOnInit() {\n    if (typeof window !== \"undefined\") {\n      this.initialized = true;\n    }\n  }\n\n  ngAfterViewInit() {\n    const element: HTMLElement | null = this._ref?.nativeElement;\n    this.enableAttributePassing(element, \"db-navigation-item\");\n  }\n\n  ngAfterContentChecked(changes: SimpleChanges) {\n    if (typeof window !== \"undefined\") {\n      if (this.subNavigationExpanded !== undefined) {\n        this.isSubNavigationExpanded = !!this.subNavigationExpanded;\n      }\n      this.updateSubNavigationState();\n    }\n  }\n}\n"]}
|
|
@@ -27,7 +27,7 @@ export class DBRadio {
|
|
|
27
27
|
if (this.change) {
|
|
28
28
|
this.change.emit(event);
|
|
29
29
|
}
|
|
30
|
-
handleFrameworkEventAngular(this, event
|
|
30
|
+
handleFrameworkEventAngular(this, event);
|
|
31
31
|
}
|
|
32
32
|
handleBlur(event) {
|
|
33
33
|
if (this.onBlur) {
|
|
@@ -78,9 +78,11 @@ export class DBRadio {
|
|
|
78
78
|
}
|
|
79
79
|
}
|
|
80
80
|
writeValue(value) {
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
81
|
+
if (value) {
|
|
82
|
+
this.value = value;
|
|
83
|
+
if (this._ref?.nativeElement) {
|
|
84
|
+
this.renderer.setProperty(this._ref?.nativeElement, 'value', value);
|
|
85
|
+
}
|
|
84
86
|
}
|
|
85
87
|
}
|
|
86
88
|
propagateChange(_) { }
|
|
@@ -222,4 +224,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
222
224
|
type: ViewChild,
|
|
223
225
|
args: ["_ref"]
|
|
224
226
|
}] } });
|
|
225
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/radio/radio.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Output,\n  EventEmitter,\n  Component,\n  ViewChild,\n  ElementRef,\n  Input,\n  SimpleChanges,\nRenderer2 } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n\nimport { CommonModule } from \"@angular/common\";\n\nconst defaultProps = {};\n\nimport { DBRadioProps, DBRadioState } from \"./model\";\nimport { cls, getHideProp, uuid } from \"../../utils\";\nimport { ChangeEvent, InteractionEvent } from \"../../shared/model\";\nimport {\n  handleFrameworkEventAngular,\n  handleFrameworkEventVue,\n} from \"../../utils/form-components\";\n\n@Component({\n\t\tproviders: [{\n\t\t\tprovide: NG_VALUE_ACCESSOR,\n\t\t\tuseExisting: DBRadio,\n\t\t\tmulti: true\n\t\t}],\t\n  selector: \"db-radio\",\n  template: `\n    <label\n      [attr.data-size]=\"size\"\n      [attr.data-hide-label]=\"getHideProp(showLabel)\"\n      [class]=\"cls('db-radio', className)\"\n      [attr.for]=\"_id\"\n    >\n      <input\n        type=\"radio\"\n        [attr.aria-invalid]=\"validation === 'invalid'\"\n        [attr.data-custom-validity]=\"validation\"\n        #_ref\n        [attr.id]=\"_id\"\n        [attr.name]=\"name\"\n        [checked]=\"checked\"\n        [disabled]=\"disabled\"\n        [attr.aria-describedby]=\"describedbyid\"\n        [attr.value]=\"value\"\n        [required]=\"required\"\n        (change)=\"handleChange($event)\"\n        (blur)=\"handleBlur($event)\"\n        (focus)=\"handleFocus($event)\"\n      />\n      <ng-container *ngIf=\"label\">{{label}}</ng-container>\n      <ng-container *ngIf=\"!(label)\"><ng-content></ng-content></ng-container>\n    </label>\n  `,\n  standalone: true,\n  imports: [CommonModule],\n})\nexport class DBRadio implements ControlValueAccessor {\n\t\tconstructor(private renderer: Renderer2) { }\n  cls = cls;\n  getHideProp = getHideProp;\n\n  @Input() id!: DBRadioProps[\"id\"];\n  @Input() checked!: DBRadioProps[\"checked\"];\n  @Input() size!: DBRadioProps[\"size\"];\n  @Input() showLabel!: DBRadioProps[\"showLabel\"];\n  @Input() className!: DBRadioProps[\"className\"];\n  @Input() validation!: DBRadioProps[\"validation\"];\n  @Input() name!: DBRadioProps[\"name\"];\n  @Input() disabled!: DBRadioProps[\"disabled\"];\n  @Input() describedbyid!: DBRadioProps[\"describedbyid\"];\n  @Input() value!: DBRadioProps[\"value\"];\n  @Input() required!: DBRadioProps[\"required\"];\n  @Input() label!: DBRadioProps[\"label\"];\n\n  @Output() onChange = new EventEmitter();\n  @Output() change = new EventEmitter();\n  @Output() onBlur = new EventEmitter();\n  @Output() blur = new EventEmitter();\n  @Output() onFocus = new EventEmitter();\n  @Output() focus = new EventEmitter();\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  initialized: DBRadioState[\"initialized\"] = false;\n  _id: DBRadioState[\"_id\"] = undefined;\n  handleChange(\n    event: ChangeEvent<HTMLInputElement>\n  ): ReturnType<DBRadioState[\"handleChange\"]> {\n    if (this.onChange) {\n      this.onChange.emit(event);\n    }\n    if (this.change) {\n      this.change.emit(event);\n    }\n    handleFrameworkEventAngular(this, event, \"checked\");\n  }\n  handleBlur(\n    event: InteractionEvent<HTMLInputElement>\n  ): ReturnType<DBRadioState[\"handleBlur\"]> {\n    if (this.onBlur) {\n      this.onBlur.emit(event);\n    }\n    if (this.blur) {\n      this.blur.emit(event);\n    }\n  }\n  handleFocus(\n    event: InteractionEvent<HTMLInputElement>\n  ): ReturnType<DBRadioState[\"handleFocus\"]> {\n    if (this.onFocus) {\n      this.onFocus.emit(event);\n    }\n    if (this.focus) {\n      this.focus.emit(event);\n    }\n  }\n\n  /**\n   * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n   * @param element  the ref for the component\n   * @param customElementSelector  the custom element like `my-component`\n   */\n  private enableAttributePassing(\n    element: HTMLElement | null,\n    customElementSelector: string\n  ) {\n    const parent = element?.closest(customElementSelector);\n    if (element && parent) {\n      const attributes = parent.attributes;\n      for (let i = 0; i < attributes.length; i++) {\n        const attr = attributes.item(i);\n        if (\n          attr &&\n          (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n        ) {\n          element.setAttribute(attr.name, attr.value);\n          parent.removeAttribute(attr.name);\n        }\n        if (attr && attr.name === \"class\") {\n          const isWebComponent = attr.value.includes(\"hydrated\");\n          const value = attr.value.replace(\"hydrated\", \"\").trim();\n          const currentClass = element.getAttribute(\"class\");\n          element.setAttribute(\n            attr.name,\n            `${currentClass ? `${currentClass} ` : \"\"}${value}`\n          );\n          if (isWebComponent) {\n            // Stencil is using this class for lazy loading component\n            parent.setAttribute(\"class\", \"hydrated\");\n          } else {\n            parent.removeAttribute(attr.name);\n          }\n        }\n      }\n    }\n  }\n\n  \n\t\twriteValue(value: any) {\n\t\t  this.checked = !!value;\n\n\t\t  if (this._ref?.nativeElement) {\n\t\t\t this.renderer.setProperty(this._ref?.nativeElement, 'checked', !!value);\n\t\t  }\n\t\t}\n\n\t\tpropagateChange(_: any) {}\n\n\t\tregisterOnChange(onChange: any) {\n\t\t  this.propagateChange = onChange;\n\t\t}\n\n\t\tregisterOnTouched(onTouched: any) {\n\t\t //this.onTouched = onTouched;\n\t\t}\n\n\t\tsetDisabledState(disabled: boolean) {\n\t\t  this.disabled = disabled;\n\t\t}\n\n\t\tngOnInit() {\n    if (typeof window !== \"undefined\") {\n      this.initialized = true;\n      this._id = this.id ?? `radio-${uuid()}`;\n    }\n  }\n\n  ngAfterViewInit() {\n    const element: HTMLElement | null = this._ref?.nativeElement;\n    this.enableAttributePassing(element, \"db-radio\");\n  }\n\n  ngAfterContentChecked(changes: SimpleChanges) {\n    if (typeof window !== \"undefined\") {\n      if (this.checked && this.initialized && this._ref?.nativeElement) {\n        this._ref.nativeElement.checked = true;\n      }\n    }\n  }\n}\n"]}
|
|
227
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/radio/radio.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Output,\n  EventEmitter,\n  Component,\n  ViewChild,\n  ElementRef,\n  Input,\n  SimpleChanges,\nRenderer2 } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n\nimport { CommonModule } from \"@angular/common\";\n\nconst defaultProps = {};\n\nimport { DBRadioProps, DBRadioState } from \"./model\";\nimport { cls, getHideProp, uuid } from \"../../utils\";\nimport { ChangeEvent, InteractionEvent } from \"../../shared/model\";\nimport {\n  handleFrameworkEventAngular,\n  handleFrameworkEventVue,\n} from \"../../utils/form-components\";\n\n@Component({\n\t\tproviders: [{\n\t\t\tprovide: NG_VALUE_ACCESSOR,\n\t\t\tuseExisting: DBRadio,\n\t\t\tmulti: true\n\t\t}],\t\n  selector: \"db-radio\",\n  template: `\n    <label\n      [attr.data-size]=\"size\"\n      [attr.data-hide-label]=\"getHideProp(showLabel)\"\n      [class]=\"cls('db-radio', className)\"\n      [attr.for]=\"_id\"\n    >\n      <input\n        type=\"radio\"\n        [attr.aria-invalid]=\"validation === 'invalid'\"\n        [attr.data-custom-validity]=\"validation\"\n        #_ref\n        [attr.id]=\"_id\"\n        [attr.name]=\"name\"\n        [checked]=\"checked\"\n        [disabled]=\"disabled\"\n        [attr.aria-describedby]=\"describedbyid\"\n        [attr.value]=\"value\"\n        [required]=\"required\"\n        (change)=\"handleChange($event)\"\n        (blur)=\"handleBlur($event)\"\n        (focus)=\"handleFocus($event)\"\n      />\n      <ng-container *ngIf=\"label\">{{label}}</ng-container>\n      <ng-container *ngIf=\"!(label)\"><ng-content></ng-content></ng-container>\n    </label>\n  `,\n  standalone: true,\n  imports: [CommonModule],\n})\nexport class DBRadio implements ControlValueAccessor {\n\t\tconstructor(private renderer: Renderer2) { }\n  cls = cls;\n  getHideProp = getHideProp;\n\n  @Input() id!: DBRadioProps[\"id\"];\n  @Input() checked!: DBRadioProps[\"checked\"];\n  @Input() size!: DBRadioProps[\"size\"];\n  @Input() showLabel!: DBRadioProps[\"showLabel\"];\n  @Input() className!: DBRadioProps[\"className\"];\n  @Input() validation!: DBRadioProps[\"validation\"];\n  @Input() name!: DBRadioProps[\"name\"];\n  @Input() disabled!: DBRadioProps[\"disabled\"];\n  @Input() describedbyid!: DBRadioProps[\"describedbyid\"];\n  @Input() value!: DBRadioProps[\"value\"];\n  @Input() required!: DBRadioProps[\"required\"];\n  @Input() label!: DBRadioProps[\"label\"];\n\n  @Output() onChange = new EventEmitter();\n  @Output() change = new EventEmitter();\n  @Output() onBlur = new EventEmitter();\n  @Output() blur = new EventEmitter();\n  @Output() onFocus = new EventEmitter();\n  @Output() focus = new EventEmitter();\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  initialized: DBRadioState[\"initialized\"] = false;\n  _id: DBRadioState[\"_id\"] = undefined;\n  handleChange(\n    event: ChangeEvent<HTMLInputElement>\n  ): ReturnType<DBRadioState[\"handleChange\"]> {\n    if (this.onChange) {\n      this.onChange.emit(event);\n    }\n    if (this.change) {\n      this.change.emit(event);\n    }\n    handleFrameworkEventAngular(this, event);\n  }\n  handleBlur(\n    event: InteractionEvent<HTMLInputElement>\n  ): ReturnType<DBRadioState[\"handleBlur\"]> {\n    if (this.onBlur) {\n      this.onBlur.emit(event);\n    }\n    if (this.blur) {\n      this.blur.emit(event);\n    }\n  }\n  handleFocus(\n    event: InteractionEvent<HTMLInputElement>\n  ): ReturnType<DBRadioState[\"handleFocus\"]> {\n    if (this.onFocus) {\n      this.onFocus.emit(event);\n    }\n    if (this.focus) {\n      this.focus.emit(event);\n    }\n  }\n\n  /**\n   * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n   * @param element  the ref for the component\n   * @param customElementSelector  the custom element like `my-component`\n   */\n  private enableAttributePassing(\n    element: HTMLElement | null,\n    customElementSelector: string\n  ) {\n    const parent = element?.closest(customElementSelector);\n    if (element && parent) {\n      const attributes = parent.attributes;\n      for (let i = 0; i < attributes.length; i++) {\n        const attr = attributes.item(i);\n        if (\n          attr &&\n          (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n        ) {\n          element.setAttribute(attr.name, attr.value);\n          parent.removeAttribute(attr.name);\n        }\n        if (attr && attr.name === \"class\") {\n          const isWebComponent = attr.value.includes(\"hydrated\");\n          const value = attr.value.replace(\"hydrated\", \"\").trim();\n          const currentClass = element.getAttribute(\"class\");\n          element.setAttribute(\n            attr.name,\n            `${currentClass ? `${currentClass} ` : \"\"}${value}`\n          );\n          if (isWebComponent) {\n            // Stencil is using this class for lazy loading component\n            parent.setAttribute(\"class\", \"hydrated\");\n          } else {\n            parent.removeAttribute(attr.name);\n          }\n        }\n      }\n    }\n  }\n\n  \n\t\twriteValue(value: any) {\n\t\t\tif(value){\n\t\t  this.value = value;\n\n\t\t  if (this._ref?.nativeElement) {\n\t\t\t this.renderer.setProperty(this._ref?.nativeElement, 'value', value);\n\t\t  }\n\t\t\t}\n\t\t}\n\n\t\tpropagateChange(_: any) {}\n\n\t\tregisterOnChange(onChange: any) {\n\t\t  this.propagateChange = onChange;\n\t\t}\n\n\t\tregisterOnTouched(onTouched: any) {\n\t\t //this.onTouched = onTouched;\n\t\t}\n\n\t\tsetDisabledState(disabled: boolean) {\n\t\t  this.disabled = disabled;\n\t\t}\n\n\t\tngOnInit() {\n    if (typeof window !== \"undefined\") {\n      this.initialized = true;\n      this._id = this.id ?? `radio-${uuid()}`;\n    }\n  }\n\n  ngAfterViewInit() {\n    const element: HTMLElement | null = this._ref?.nativeElement;\n    this.enableAttributePassing(element, \"db-radio\");\n  }\n\n  ngAfterContentChecked(changes: SimpleChanges) {\n    if (typeof window !== \"undefined\") {\n      if (this.checked && this.initialized && this._ref?.nativeElement) {\n        this._ref.nativeElement.checked = true;\n      }\n    }\n  }\n}\n"]}
|