UNPKG

@engie-group/fluid-design-system-angular

Version:

Fluid Design System Angular

227 lines 31.6 kB
import { CommonModule } from '@angular/common'; import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, Output, ViewEncapsulation, } from '@angular/core'; import { FormFieldDirective } from '../form-field/form-field.directive'; import { IconButtonComponent } from '../icon-button/icon-button.component'; import { IconComponent } from '../icon/icon.component'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; export class FormItemComponent { constructor() { this.formItemClassName = 'nj-form-item'; /** * @ignore */ this.isVisible = false; /** * @ignore */ this.passwordNotice = ''; /** * @ignore */ this.passwordButtonLabel = ''; /** * @ignore */ this.isMultiline = false; /** * Form item size */ this.size = 'medium'; /** * Whether the form-item label is floating */ this.isFloatingLabel = true; /** * Whether the form-item's icon (or custom icon) is clickable */ this.isIconClickable = true; /** * Additional form-item css classes */ this.additionalClass = ''; /** * Outputs icon click */ this.iconClick = new EventEmitter(); /** * Outputs icon keydown */ this.iconKeydown = new EventEmitter(); /** * Outputs icon click */ this.wrapperClick = new EventEmitter(); } /** * Whether form-item is in success state */ set hasSuccess(value) { this._hasSuccess = value; this.setAriaAttributes(); } get hasSuccess() { return this._hasSuccess; } /** * Whether form-item is in error state */ set hasError(value) { this._hasError = value; this.setAriaAttributes(); } get hasError() { return this._hasError; } /** * Whether the form-item has a hint substring */ set hasHint(value) { this._hasHint = value; this.setAriaAttributes(); } get hasHint() { return this._hasHint; } ngAfterContentInit() { const tagName = this.formField?.tagName?.toLowerCase(); this.isPassword = this.formField?.type === 'password'; this.isMultiline = tagName === 'textarea'; this.passwordButtonLabel = this.passwordButtonLabelShow; this.setAriaAttributes(); if (this.isRequired) { this.formField.element.setAttribute('required', 'required'); } } /** * @ignore */ iconClickHandler(event) { if (!this.isIconClickable) { return; } this.iconClick.emit(event); } /** * @ignore */ iconKeydownHandler(event) { event?.preventDefault(); if (!this.isIconClickable) { return; } this.iconKeydown.emit(event); } /** * @ignore */ toggleVisibility() { if (this.isVisible) { this.formField.type = 'password'; this.passwordNotice = this.passwordNoticeIsHidden; this.passwordButtonLabel = this.passwordButtonLabelShow; } else { this.formField.type = 'text'; this.passwordNotice = this.passwordNoticeIsVisible; this.passwordButtonLabel = this.passwordButtonLabelHide; } this.isVisible = !this.isVisible; } /** * @ignore */ getSubscriptId() { return `${this.inputId}-subscript`; } /** * @ignore */ setAriaAttributes() { if (this.formField?.element) { if (this.hasError) { this.formField.element.setAttribute('aria-invalid', 'true'); } if (this.hasError || this.hasSuccess || this.hasHint) { this.formField.element.setAttribute('aria-describedby', this.getSubscriptId()); } } } /** * @ignore */ isCustomSelect() { const type = this.formField?.type; return this.isSelect && type === 'text'; } /** * @ignore */ getFormItemSizeClass() { let sizeModifier; switch (this.size) { case 'small': sizeModifier = 'sm'; break; case 'large': sizeModifier = 'lg'; break; case 'xlarge': sizeModifier = 'xl'; break; default: break; } return sizeModifier ? `${this.formItemClassName}--${sizeModifier}` : ''; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FormItemComponent, isStandalone: true, selector: "nj-form-item", inputs: { inputId: "inputId", size: "size", isFloatingLabel: "isFloatingLabel", isDisabled: "isDisabled", isRequired: "isRequired", hasSuccess: "hasSuccess", hasError: "hasError", hasHint: "hasHint", hasCustomIcon: "hasCustomIcon", isIconClickable: "isIconClickable", iconName: "iconName", additionalClass: "additionalClass", passwordButtonLabelShow: "passwordButtonLabelShow", passwordButtonLabelHide: "passwordButtonLabelHide", passwordNoticeIsVisible: "passwordNoticeIsVisible", passwordNoticeIsHidden: "passwordNoticeIsHidden", isSelect: "isSelect" }, outputs: { iconClick: "iconClick", iconKeydown: "iconKeydown", wrapperClick: "wrapperClick" }, queries: [{ propertyName: "formField", first: true, predicate: FormFieldDirective, descendants: true }], ngImport: i0, template: "<div class=\"nj-form-item\"\n [class.nj-form-item--static]=\"!isFloatingLabel\"\n [class.nj-form-item--disabled]=\"isDisabled\"\n [class.nj-form-item--error]=\"hasError\"\n [class.nj-form-item--success]=\"hasSuccess\"\n [class.nj-form-item--password]=\"isPassword\"\n [class.nj-form-item--select]=\"isSelect\"\n [class.nj-form-item--visible]=\"isVisible\"\n [class.nj-form-item--textarea]=\"isMultiline\"\n [ngClass]=\"[getFormItemSizeClass(), additionalClass]\">\n <div class=\"nj-form-item__field-wrapper\" (click)=\"wrapperClick.emit($event)\">\n <ng-content select=\"[njFormField]\"></ng-content>\n <label class=\"nj-form-item__label\" [attr.for]=\"inputId\" [attr.aria-hidden]=\"isCustomSelect() ? 'true' : null\">\n <ng-content select=\"[njFormLabel]\"></ng-content>\n <span *ngIf=\"isRequired\" class=\"nj-form-item__required-asterisk\">*</span>\n </label>\n <nj-icon-button\n *ngIf=\"isPassword\"\n size=\"sm\"\n variant=\"tertiary\"\n [label]=\"passwordButtonLabel\"\n [icon]=\"iconName || 'visibility'\"\n (click)=\"toggleVisibility()\"\n [ariaPressed]=\"isVisible\"\n additionalClass=\"nj-form-item__password-button\"\n >\n </nj-icon-button>\n <nj-icon class=\"nj-form-item__icon\"\n *ngIf=\"!isPassword && !isMultiline && !hasCustomIcon && iconName\"\n [name]=\"iconName\"\n variant=\"inherit\"\n (click)=\"iconClickHandler($event)\"\n (keydown)=\"iconKeydownHandler($event)\">\n </nj-icon>\n <div class=\"nj-form-item__icon\" *ngIf=\"!isPassword && !isMultiline && hasCustomIcon\" [attr.tabindex]=\"isIconClickable ? 0 : null\"\n (click)=\"iconClickHandler($event)\" (keydown)=\"iconKeydownHandler($event)\">\n <ng-content select=\"[njFormCustomIcon]\"></ng-content>\n </div>\n <p *ngIf=\"isPassword\" class=\"nj-sr-only\" aria-live=\"polite\" aria-atomic=\"true\">{{ passwordNotice }}</p>\n <ng-content select=\"[njFormAdditionalContent]\"></ng-content>\n </div>\n <div class=\"nj-form-item__subscript\" *ngIf=\"hasError || hasSuccess || hasHint\" [attr.id]=\"getSubscriptId()\">\n <nj-icon *ngIf=\"hasError\" class=\"nj-form-item__subscript-icon\" name=\"warning\" size=\"inherit\" variant=\"inherit\"></nj-icon>\n <nj-icon *ngIf=\"hasSuccess && !hasError\" class=\"nj-form-item__subscript-icon\" name=\"check\" size=\"inherit\" variant=\"inherit\"></nj-icon>\n <ng-content select=\"[njFormSubscript]\"></ng-content>\n </div>\n</div>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "component", type: IconComponent, selector: "nj-icon", inputs: ["size", "variant"] }, { kind: "component", type: IconButtonComponent, selector: "nj-icon-button", inputs: ["type", "ariaPressed", "ariaDescribedby", "isDisabled", "tabIndex", "variant", "size", "hasCustomIcon", "icon", "label", "additionalClass"], outputs: ["buttonClick"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormItemComponent, decorators: [{ type: Component, args: [{ selector: 'nj-form-item', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [IconComponent, IconButtonComponent, FormFieldDirective, CommonModule], template: "<div class=\"nj-form-item\"\n [class.nj-form-item--static]=\"!isFloatingLabel\"\n [class.nj-form-item--disabled]=\"isDisabled\"\n [class.nj-form-item--error]=\"hasError\"\n [class.nj-form-item--success]=\"hasSuccess\"\n [class.nj-form-item--password]=\"isPassword\"\n [class.nj-form-item--select]=\"isSelect\"\n [class.nj-form-item--visible]=\"isVisible\"\n [class.nj-form-item--textarea]=\"isMultiline\"\n [ngClass]=\"[getFormItemSizeClass(), additionalClass]\">\n <div class=\"nj-form-item__field-wrapper\" (click)=\"wrapperClick.emit($event)\">\n <ng-content select=\"[njFormField]\"></ng-content>\n <label class=\"nj-form-item__label\" [attr.for]=\"inputId\" [attr.aria-hidden]=\"isCustomSelect() ? 'true' : null\">\n <ng-content select=\"[njFormLabel]\"></ng-content>\n <span *ngIf=\"isRequired\" class=\"nj-form-item__required-asterisk\">*</span>\n </label>\n <nj-icon-button\n *ngIf=\"isPassword\"\n size=\"sm\"\n variant=\"tertiary\"\n [label]=\"passwordButtonLabel\"\n [icon]=\"iconName || 'visibility'\"\n (click)=\"toggleVisibility()\"\n [ariaPressed]=\"isVisible\"\n additionalClass=\"nj-form-item__password-button\"\n >\n </nj-icon-button>\n <nj-icon class=\"nj-form-item__icon\"\n *ngIf=\"!isPassword && !isMultiline && !hasCustomIcon && iconName\"\n [name]=\"iconName\"\n variant=\"inherit\"\n (click)=\"iconClickHandler($event)\"\n (keydown)=\"iconKeydownHandler($event)\">\n </nj-icon>\n <div class=\"nj-form-item__icon\" *ngIf=\"!isPassword && !isMultiline && hasCustomIcon\" [attr.tabindex]=\"isIconClickable ? 0 : null\"\n (click)=\"iconClickHandler($event)\" (keydown)=\"iconKeydownHandler($event)\">\n <ng-content select=\"[njFormCustomIcon]\"></ng-content>\n </div>\n <p *ngIf=\"isPassword\" class=\"nj-sr-only\" aria-live=\"polite\" aria-atomic=\"true\">{{ passwordNotice }}</p>\n <ng-content select=\"[njFormAdditionalContent]\"></ng-content>\n </div>\n <div class=\"nj-form-item__subscript\" *ngIf=\"hasError || hasSuccess || hasHint\" [attr.id]=\"getSubscriptId()\">\n <nj-icon *ngIf=\"hasError\" class=\"nj-form-item__subscript-icon\" name=\"warning\" size=\"inherit\" variant=\"inherit\"></nj-icon>\n <nj-icon *ngIf=\"hasSuccess && !hasError\" class=\"nj-form-item__subscript-icon\" name=\"check\" size=\"inherit\" variant=\"inherit\"></nj-icon>\n <ng-content select=\"[njFormSubscript]\"></ng-content>\n </div>\n</div>\n", styles: [":host{display:block}\n"] }] }], propDecorators: { inputId: [{ type: Input }], size: [{ type: Input }], isFloatingLabel: [{ type: Input }], isDisabled: [{ type: Input }], isRequired: [{ type: Input }], hasSuccess: [{ type: Input }], hasError: [{ type: Input }], hasHint: [{ type: Input }], hasCustomIcon: [{ type: Input }], isIconClickable: [{ type: Input }], iconName: [{ type: Input }], additionalClass: [{ type: Input }], passwordButtonLabelShow: [{ type: Input }], passwordButtonLabelHide: [{ type: Input }], passwordNoticeIsVisible: [{ type: Input }], passwordNoticeIsHidden: [{ type: Input }], isSelect: [{ type: Input }], iconClick: [{ type: Output }], iconKeydown: [{ type: Output }], wrapperClick: [{ type: Output }], formField: [{ type: ContentChild, args: [FormFieldDirective] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-item.component.js","sourceRoot":"","sources":["../../../../src/components/form-item/form-item.component.ts","../../../../src/components/form-item/form-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {CommonModule} from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {FormFieldDirective} from '../form-field/form-field.directive';\nimport {IconButtonComponent} from '../icon-button/icon-button.component';\nimport {IconComponent} from '../icon/icon.component';\nimport {FormItemSize} from './form-item.model';\n\n@Component({\n  selector: 'nj-form-item',\n  templateUrl: './form-item.component.html',\n  styleUrls: ['./form-item.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [IconComponent, IconButtonComponent, FormFieldDirective, CommonModule]\n})\nexport class FormItemComponent implements AfterContentInit {\n\n  private readonly formItemClassName = 'nj-form-item';\n\n  /**\n   * @ignore\n   */\n  private _hasError: boolean;\n\n  /**\n   * @ignore\n   */\n  private _hasSuccess: boolean;\n\n  /**\n   * @ignore\n   */\n  private _hasHint: boolean;\n\n  /**\n   * @ignore\n   */\n  isPassword: boolean;\n\n  /**\n   * @ignore\n   */\n  isVisible = false;\n\n  /**\n   * @ignore\n   */\n  passwordNotice = '';\n\n  /**\n   * @ignore\n   */\n  passwordButtonLabel = '';\n\n  /**\n   * @ignore\n   */\n  isMultiline = false;\n\n  /**\n   * Input id and label for attribute, needed for focus to work properly\n   */\n  @Input() inputId: string;\n\n  /**\n   * Form item size\n   */\n  @Input() size: FormItemSize = 'medium';\n\n  /**\n   * Whether the form-item label is floating\n   */\n  @Input() isFloatingLabel = true;\n\n  /**\n   * Whether form-item is disabled or not\n   */\n  @Input() isDisabled: boolean;\n\n  /**\n   * Whether form-item is required or not\n   */\n  @Input() isRequired: boolean;\n\n  /**\n   * Whether form-item is in success state\n   */\n  @Input()\n  set hasSuccess(value: boolean) {\n    this._hasSuccess = value;\n    this.setAriaAttributes();\n  }\n\n  get hasSuccess(): boolean {\n    return this._hasSuccess;\n  }\n\n  /**\n   * Whether form-item is in error state\n   */\n  @Input()\n  set hasError(value: boolean) {\n    this._hasError = value;\n    this.setAriaAttributes();\n  }\n\n  get hasError(): boolean {\n    return this._hasError;\n  }\n\n  /**\n   * Whether the form-item has a hint substring\n   */\n  @Input()\n  set hasHint(value: boolean) {\n    this._hasHint = value;\n    this.setAriaAttributes();\n  }\n\n  get hasHint(): boolean {\n    return this._hasHint;\n  }\n\n  /**\n   * Whether the form-item has a custom icon\n   */\n  @Input() hasCustomIcon: boolean;\n\n  /**\n   * Whether the form-item's icon (or custom icon) is clickable\n   */\n  @Input() isIconClickable = true;\n\n  /**\n   * Material icon name\n   */\n  @Input() iconName: string;\n\n  /**\n   * Additional form-item css classes\n   */\n  @Input() additionalClass: string = '';\n\n  /**\n   * Label for the button to toggle password visibility when password is hidden.\n   * @example \"Show password\"\n   */\n  @Input() passwordButtonLabelShow?: string;\n\n  /**\n   * Label for the button to toggle password visibility when password is visible.\n   * @example \"Hide password\"\n   */\n  @Input() passwordButtonLabelHide?: string;\n  /**\n   * Label to announce when password becomes visible.\n   * @example \"Password is visible\"\n   */\n  @Input() passwordNoticeIsVisible?: string;\n\n  /**\n   * Label to announce when password becomes hidden.\n   * @example \"Password is hidden\"\n   */\n  @Input() passwordNoticeIsHidden?: string;\n\n  /**\n   * Whether form-item is a select or not\n   */\n  @Input() isSelect: boolean;\n\n  /**\n   * Outputs icon click\n   */\n  @Output() iconClick: EventEmitter<MouseEvent> = new EventEmitter<\n    MouseEvent\n  >();\n\n  /**\n   * Outputs icon keydown\n   */\n  @Output() iconKeydown: EventEmitter<KeyboardEvent> = new EventEmitter<\n    KeyboardEvent\n  >();\n\n  /**\n   * Outputs icon click\n   */\n  @Output() wrapperClick: EventEmitter<MouseEvent> = new EventEmitter<\n    MouseEvent\n  >();\n\n  /**\n   * @ignore\n   */\n  @ContentChild(FormFieldDirective) formField: FormFieldDirective;\n\n  ngAfterContentInit() {\n    const tagName = this.formField?.tagName?.toLowerCase();\n    this.isPassword = this.formField?.type === 'password';\n    this.isMultiline = tagName === 'textarea';\n    this.passwordButtonLabel = this.passwordButtonLabelShow;\n    this.setAriaAttributes();\n    if (this.isRequired) {\n      this.formField.element.setAttribute('required', 'required');\n    }\n  }\n\n  /**\n   * @ignore\n   */\n  iconClickHandler(event: MouseEvent) {\n    if (!this.isIconClickable) {\n      return;\n    }\n    this.iconClick.emit(event);\n  }\n\n  /**\n   * @ignore\n   */\n  iconKeydownHandler(event: KeyboardEvent) {\n    event?.preventDefault();\n    if (!this.isIconClickable) {\n      return;\n    }\n    this.iconKeydown.emit(event);\n  }\n\n  /**\n   * @ignore\n   */\n  toggleVisibility() {\n    if (this.isVisible) {\n      this.formField.type = 'password';\n      this.passwordNotice = this.passwordNoticeIsHidden;\n      this.passwordButtonLabel = this.passwordButtonLabelShow;\n    } else {\n      this.formField.type = 'text';\n      this.passwordNotice = this.passwordNoticeIsVisible;\n      this.passwordButtonLabel = this.passwordButtonLabelHide;\n    }\n    this.isVisible = !this.isVisible;\n  }\n\n  /**\n   * @ignore\n   */\n  getSubscriptId(): string {\n    return `${this.inputId}-subscript`;\n  }\n\n  /**\n   * @ignore\n   */\n  setAriaAttributes() {\n    if (this.formField?.element) {\n      if (this.hasError) {\n        this.formField.element.setAttribute('aria-invalid', 'true');\n      }\n\n      if (this.hasError || this.hasSuccess || this.hasHint) {\n        this.formField.element.setAttribute('aria-describedby', this.getSubscriptId());\n      }\n    }\n  }\n\n  /**\n   * @ignore\n   */\n  isCustomSelect(): boolean {\n    const type = this.formField?.type;\n    return this.isSelect && type === 'text';\n  }\n\n  /**\n   * @ignore\n   */\n  getFormItemSizeClass(): string {\n    let sizeModifier: string;\n    switch (this.size) {\n      case 'small':\n        sizeModifier = 'sm';\n        break;\n      case 'large':\n        sizeModifier = 'lg';\n        break;\n      case 'xlarge':\n        sizeModifier = 'xl';\n        break;\n      default:\n        break;\n    }\n    return sizeModifier ? `${this.formItemClassName}--${sizeModifier}` : '';\n  }\n}\n","<div class=\"nj-form-item\"\n     [class.nj-form-item--static]=\"!isFloatingLabel\"\n     [class.nj-form-item--disabled]=\"isDisabled\"\n     [class.nj-form-item--error]=\"hasError\"\n     [class.nj-form-item--success]=\"hasSuccess\"\n     [class.nj-form-item--password]=\"isPassword\"\n     [class.nj-form-item--select]=\"isSelect\"\n     [class.nj-form-item--visible]=\"isVisible\"\n     [class.nj-form-item--textarea]=\"isMultiline\"\n     [ngClass]=\"[getFormItemSizeClass(), additionalClass]\">\n  <div class=\"nj-form-item__field-wrapper\" (click)=\"wrapperClick.emit($event)\">\n    <ng-content select=\"[njFormField]\"></ng-content>\n    <label class=\"nj-form-item__label\" [attr.for]=\"inputId\" [attr.aria-hidden]=\"isCustomSelect() ? 'true' : null\">\n      <ng-content select=\"[njFormLabel]\"></ng-content>\n      <span *ngIf=\"isRequired\" class=\"nj-form-item__required-asterisk\">*</span>\n    </label>\n    <nj-icon-button\n      *ngIf=\"isPassword\"\n      size=\"sm\"\n      variant=\"tertiary\"\n      [label]=\"passwordButtonLabel\"\n      [icon]=\"iconName || 'visibility'\"\n      (click)=\"toggleVisibility()\"\n      [ariaPressed]=\"isVisible\"\n      additionalClass=\"nj-form-item__password-button\"\n    >\n    </nj-icon-button>\n    <nj-icon class=\"nj-form-item__icon\"\n             *ngIf=\"!isPassword && !isMultiline && !hasCustomIcon && iconName\"\n             [name]=\"iconName\"\n             variant=\"inherit\"\n             (click)=\"iconClickHandler($event)\"\n             (keydown)=\"iconKeydownHandler($event)\">\n    </nj-icon>\n    <div class=\"nj-form-item__icon\" *ngIf=\"!isPassword && !isMultiline && hasCustomIcon\" [attr.tabindex]=\"isIconClickable ? 0 : null\"\n         (click)=\"iconClickHandler($event)\" (keydown)=\"iconKeydownHandler($event)\">\n      <ng-content select=\"[njFormCustomIcon]\"></ng-content>\n    </div>\n    <p *ngIf=\"isPassword\" class=\"nj-sr-only\" aria-live=\"polite\" aria-atomic=\"true\">{{ passwordNotice }}</p>\n    <ng-content select=\"[njFormAdditionalContent]\"></ng-content>\n  </div>\n  <div class=\"nj-form-item__subscript\" *ngIf=\"hasError || hasSuccess || hasHint\" [attr.id]=\"getSubscriptId()\">\n    <nj-icon *ngIf=\"hasError\" class=\"nj-form-item__subscript-icon\" name=\"warning\" size=\"inherit\" variant=\"inherit\"></nj-icon>\n    <nj-icon *ngIf=\"hasSuccess && !hasError\" class=\"nj-form-item__subscript-icon\" name=\"check\" size=\"inherit\" variant=\"inherit\"></nj-icon>\n    <ng-content select=\"[njFormSubscript]\"></ng-content>\n  </div>\n</div>\n"]}