@progressio_resources/gravity-design-system 2.6.15 → 2.6.16

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.
@@ -107,7 +107,8 @@ export class GravityTextFieldComponent {
107
107
  ($event.key === 'a' && $event.metaKey === true) || // Allow: Cmd+A (Mac)
108
108
  ($event.key === 'c' && $event.metaKey === true) || // Allow: Cmd+C (Mac)
109
109
  ($event.key === 'v' && $event.metaKey === true) || // Allow: Cmd+V (Mac)
110
- ($event.key === 'x' && $event.metaKey === true) // Allow: Cmd+X (Mac)
110
+ ($event.key === 'x' && $event.metaKey === true) || // Allow: Cmd+X (Mac)
111
+ ($event.key === '.') || ($event.key === ',') // Allow: dot and comma for decimal
111
112
  ) {
112
113
  // let it happen, don't do anything
113
114
  return;
@@ -179,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
179
180
  }], width: [{
180
181
  type: Input
181
182
  }] } });
182
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gravity-text-field.component.js","sourceRoot":"","sources":["../../../../../../projects/gravity-design-system/src/lib/components/gravity-text-field/gravity-text-field.component.ts","../../../../../../projects/gravity-design-system/src/lib/components/gravity-text-field/gravity-text-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild} from '@angular/core';\nimport {GravityIconComponent} from \"../gravity-icon/gravity-icon.component\";\n\n@Component({\n  selector: 'gravity-text-field',\n  templateUrl: './gravity-text-field.component.html',\n  styleUrls: ['./gravity-text-field.component.scss']\n})\nexport class GravityTextFieldComponent implements OnInit, OnChanges {\n  @Output('clickIconLeft') public leftIconResponse: EventEmitter<void> = new EventEmitter();\n  @Output('clickIconRight') public rightIconResponse: EventEmitter<void> = new EventEmitter();\n  @Output('response') public textFieldValueResponse: EventEmitter<string> = new EventEmitter();\n\n  @ViewChild('inputElement', {static: false}) private inputElement: any;\n  @ViewChild('textAreaElement', {static: false}) private textAreaElement: any;\n\n  // Component\n  @Input() public currentLang: string = 'en';\n  @Input() public customInputValue: string;\n  @Input() public customState: 'default' | 'active' | 'hover' | 'typing' | 'typed' | 'typed-error' | 'typed-positive' | 'disabled' | 'readonly' | 'autofill' = 'default';\n  @Input() public cypressTag: string;\n  @Input() public label: string;\n  @Input() public prefix: string = \"\";\n  @Input() public required: boolean;\n  @Input() public supportText: string;\n  @Input() public textFieldType: 'input' | 'textarea' = \"input\";\n\n  // Icons\n  @Input() public clickOnLeftIcon: boolean = false;\n  @Input() public clickOnRightIcon: boolean = false;\n  @Input() public iconLeft: string;\n  @Input() public iconRight: string;\n\n  // Input | Textarea\n  @Input() public autocomplete: string = 'off';\n  @Input() public inputContentType: 'email' | 'number' | 'password' | 'tel' | 'text' = \"text\";\n  @Input() public placeholder: string;\n  @Input() public validations: { maxLength?: number; minLength?: number };\n\n  // Sizes\n  @Input() public size: 'sm' | 'md' = 'md';\n  @Input() public width: 'short' | 'medium' | 'full' | 'fit' = 'short';\n\n  public focusInput: boolean = false;\n  public inputValue: string = '';\n\n  ngOnInit(): void {\n    this.inputValue = this.customInputValue ? this.customInputValue : '';\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['customInputValue']) {\n      this.inputValue = changes['customInputValue'].currentValue ? changes['customInputValue'].currentValue : '';\n    }\n  }\n\n  public getPlaceholder(): string {\n    if (this.placeholder && this.placeholder != '') {\n      return this.placeholder;\n    } else {\n      return this.label;\n    }\n  }\n\n  public clearInput(): void {\n    this.changeInputValue(true);\n  }\n\n  public changeInputValue(clearInput: boolean = false): void {\n    if (clearInput) {\n      this.inputValue = '';\n    } else if (this.textFieldType == 'input') {\n      this.inputValue = this.inputElement.nativeElement.value;\n    } else {\n      this.inputValue = this.textAreaElement.nativeElement.value;\n    }\n\n    if (this.inputValue == '') {\n      this.textFieldValueResponse.emit('');\n    } else {\n      this.textFieldValueResponse.emit(this.prefix + this.inputValue);\n    }\n  }\n\n  public handleIconClick(iconPosition: 'left' | 'right'): void {\n    if (iconPosition == 'left' && this.clickOnLeftIcon) {\n      this.leftIconResponse.emit();\n    }\n\n    if (iconPosition == 'right' && this.clickOnRightIcon) {\n      this.rightIconResponse.emit();\n    }\n  }\n\n  public getTextFieldStatus(): string {\n    if (this.customState == 'default') {\n      if (!this.focusInput && !this.inputValue) {\n        return 'active';\n      } else if (!this.focusInput && this.inputValue) {\n        return 'typed';\n      } else {\n        return 'typing';\n      }\n    } else {\n      return this.customState;\n    }\n  }\n\n  public getTextFieldInputFontSize(): string {\n    return 'hr-label ' + this.size + '-regular';\n  }\n\n  public isNewIcon(iconPosition: 'left' | 'right'): boolean {\n    if (iconPosition == 'left') {\n      return GravityIconComponent.isNewIcon(this.iconLeft);\n    } else {\n      return GravityIconComponent.isNewIcon(this.iconRight);\n    }\n  }\n\n  public onKeyDownEvent($event: KeyboardEvent): void {\n    if (this.inputContentType == 'number') {\n      let navigationKeys = ['Backspace', 'Delete', 'Tab', 'Escape', 'Enter', 'Home', 'End', 'ArrowLeft', 'ArrowRight', 'Clear', 'Copy', 'Paste'];\n\n      if (\n        navigationKeys.indexOf($event.key) > -1 || // Allow: navigation keys: backspace, delete, arrows etc.\n        ($event.key === 'a' && $event.ctrlKey === true) || // Allow: Ctrl+A\n        ($event.key === 'c' && $event.ctrlKey === true) || // Allow: Ctrl+C\n        ($event.key === 'v' && $event.ctrlKey === true) || // Allow: Ctrl+V\n        ($event.key === 'x' && $event.ctrlKey === true) || // Allow: Ctrl+X\n        ($event.key === 'a' && $event.metaKey === true) || // Allow: Cmd+A (Mac)\n        ($event.key === 'c' && $event.metaKey === true) || // Allow: Cmd+C (Mac)\n        ($event.key === 'v' && $event.metaKey === true) || // Allow: Cmd+V (Mac)\n        ($event.key === 'x' && $event.metaKey === true) // Allow: Cmd+X (Mac)\n      ) {\n        // let it happen, don't do anything\n        return;\n      }\n\n      // Ensure that it is a number and stop the keypress\n      if (\n        ($event.shiftKey || ($event.keyCode < 48 || $event.keyCode > 57)) &&\n        ($event.keyCode < 96 || $event.keyCode > 105)\n      ) {\n        $event.preventDefault();\n      }\n    }\n  }\n}\n","<label class=\"hr-label sm-bold {{getTextFieldStatus()}}\" [class.custom-label-size]=\"size == 'sm'\" *ngIf=\"label\">\n  {{label}} <span *ngIf=\"required || getTextFieldStatus() == 'typed-error'\">*</span>\n</label>\n<div class=\"gravity-input-field {{size}} {{width}}-width {{getTextFieldStatus()}}\">\n  <ng-container *ngIf=\"iconLeft\">\n    <ng-container [ngTemplateOutlet]=\"icons\" [ngTemplateOutletContext]=\"{iconPosition: 'left'}\"></ng-container>\n  </ng-container>\n  <span class=\"{{getTextFieldInputFontSize()}} prefix\">{{prefix}}</span>\n  <input [attr.data-cy]=\"cypressTag\"\n         [attr.disabled]=\"customState == 'disabled' ? true : null\"\n         [attr.readonly]=\"customState == 'readonly' ? true : null\"\n         [autocomplete]=\"autocomplete\"\n         [maxLength]=\"validations?.maxLength ? validations?.maxLength : 100\"\n         [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n         [placeholder]=\"getPlaceholder()\"\n         [type]=\"inputContentType != 'number' ? inputContentType : 'text'\"\n         [value]=\"inputValue\"\n\n         (blur)=\"focusInput = false\"\n         (change)=\"changeInputValue()\"\n         (focus)=\"focusInput = true\"\n         (keydown)=\"onKeyDownEvent($event)\"\n         (keyup)=\"changeInputValue()\"\n\n         class=\"{{getTextFieldInputFontSize()}}\"\n\n         #inputElement\n\n         *ngIf=\"textFieldType == 'input'\">\n  <textarea [attr.data-cy]=\"cypressTag\"\n            [attr.disabled]=\"customState == 'disabled' ? true : null\"\n            [attr.readonly]=\"customState == 'readonly' ? true : null\"\n            [maxLength]=\"validations?.maxLength ? validations?.maxLength : 200\"\n            [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n            [placeholder]=\"getPlaceholder()\"\n            [value]=\"inputValue\"\n\n            (blur)=\"focusInput = false\"\n            (change)=\"changeInputValue()\"\n            (focus)=\"focusInput = true\"\n            (keydown)=\"onKeyDownEvent($event)\"\n            (keyup)=\"changeInputValue()\"\n\n            class=\"{{getTextFieldInputFontSize()}}\"\n            rows=\"1\"\n\n            #textAreaElement\n\n            *ngIf=\"textFieldType == 'textarea'\"></textarea>\n  <ng-container *ngIf=\"iconRight\">\n    <ng-container [ngTemplateOutlet]=\"icons\" [ngTemplateOutletContext]=\"{iconPosition: 'right'}\"></ng-container>\n  </ng-container>\n</div>\n<p class=\"hr-label sm-regular supporting-text {{getTextFieldStatus()}} {{size}}\"\n   [class.custom-label-size]=\"size == 'sm'\" *ngIf=\"supportText\">\n  <gravity-icon [iconName]=\"'question-circle'\" *ngIf=\"getTextFieldStatus() == 'typed-error'\"\n                [iconSize]=\"'md-16'\"></gravity-icon>\n  {{supportText}}\n</p>\n<p class=\"hr-label sm-regular supporting-text {{getTextFieldStatus()}} {{size}}\"\n   [class.custom-label-size]=\"size == 'sm'\"\n   *ngIf=\"!supportText && getTextFieldStatus() == 'active' && inputValue == '' && required\">\n  {{currentLang == 'es' ? 'Requerido' : 'Required'}}\n</p>\n\n<ng-template #icons let-iconPosition=\"iconPosition\">\n  <gravity-icon (click)=\"$event.stopPropagation(); handleIconClick(iconPosition)\" class=\"{{iconPosition}}\"\n                [class.pointer]=\"(iconPosition == 'left' && clickOnLeftIcon) || (iconPosition == 'right' && clickOnRightIcon)\"\n                [iconName]=\"iconPosition == 'left' ? iconLeft : iconRight\"\n                [iconSize]=\"isNewIcon(iconPosition) ? 'md-16' : null\"></gravity-icon>\n</ng-template>\n"]}
183
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gravity-text-field.component.js","sourceRoot":"","sources":["../../../../../../projects/gravity-design-system/src/lib/components/gravity-text-field/gravity-text-field.component.ts","../../../../../../projects/gravity-design-system/src/lib/components/gravity-text-field/gravity-text-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild} from '@angular/core';\nimport {GravityIconComponent} from \"../gravity-icon/gravity-icon.component\";\n\n@Component({\n  selector: 'gravity-text-field',\n  templateUrl: './gravity-text-field.component.html',\n  styleUrls: ['./gravity-text-field.component.scss']\n})\nexport class GravityTextFieldComponent implements OnInit, OnChanges {\n  @Output('clickIconLeft') public leftIconResponse: EventEmitter<void> = new EventEmitter();\n  @Output('clickIconRight') public rightIconResponse: EventEmitter<void> = new EventEmitter();\n  @Output('response') public textFieldValueResponse: EventEmitter<string> = new EventEmitter();\n\n  @ViewChild('inputElement', {static: false}) private inputElement: any;\n  @ViewChild('textAreaElement', {static: false}) private textAreaElement: any;\n\n  // Component\n  @Input() public currentLang: string = 'en';\n  @Input() public customInputValue: string;\n  @Input() public customState: 'default' | 'active' | 'hover' | 'typing' | 'typed' | 'typed-error' | 'typed-positive' | 'disabled' | 'readonly' | 'autofill' = 'default';\n  @Input() public cypressTag: string;\n  @Input() public label: string;\n  @Input() public prefix: string = \"\";\n  @Input() public required: boolean;\n  @Input() public supportText: string;\n  @Input() public textFieldType: 'input' | 'textarea' = \"input\";\n\n  // Icons\n  @Input() public clickOnLeftIcon: boolean = false;\n  @Input() public clickOnRightIcon: boolean = false;\n  @Input() public iconLeft: string;\n  @Input() public iconRight: string;\n\n  // Input | Textarea\n  @Input() public autocomplete: string = 'off';\n  @Input() public inputContentType: 'email' | 'number' | 'password' | 'tel' | 'text' = \"text\";\n  @Input() public placeholder: string;\n  @Input() public validations: { maxLength?: number; minLength?: number };\n\n  // Sizes\n  @Input() public size: 'sm' | 'md' = 'md';\n  @Input() public width: 'short' | 'medium' | 'full' | 'fit' = 'short';\n\n  public focusInput: boolean = false;\n  public inputValue: string = '';\n\n  ngOnInit(): void {\n    this.inputValue = this.customInputValue ? this.customInputValue : '';\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['customInputValue']) {\n      this.inputValue = changes['customInputValue'].currentValue ? changes['customInputValue'].currentValue : '';\n    }\n  }\n\n  public getPlaceholder(): string {\n    if (this.placeholder && this.placeholder != '') {\n      return this.placeholder;\n    } else {\n      return this.label;\n    }\n  }\n\n  public clearInput(): void {\n    this.changeInputValue(true);\n  }\n\n  public changeInputValue(clearInput: boolean = false): void {\n    if (clearInput) {\n      this.inputValue = '';\n    } else if (this.textFieldType == 'input') {\n      this.inputValue = this.inputElement.nativeElement.value;\n    } else {\n      this.inputValue = this.textAreaElement.nativeElement.value;\n    }\n\n    if (this.inputValue == '') {\n      this.textFieldValueResponse.emit('');\n    } else {\n      this.textFieldValueResponse.emit(this.prefix + this.inputValue);\n    }\n  }\n\n  public handleIconClick(iconPosition: 'left' | 'right'): void {\n    if (iconPosition == 'left' && this.clickOnLeftIcon) {\n      this.leftIconResponse.emit();\n    }\n\n    if (iconPosition == 'right' && this.clickOnRightIcon) {\n      this.rightIconResponse.emit();\n    }\n  }\n\n  public getTextFieldStatus(): string {\n    if (this.customState == 'default') {\n      if (!this.focusInput && !this.inputValue) {\n        return 'active';\n      } else if (!this.focusInput && this.inputValue) {\n        return 'typed';\n      } else {\n        return 'typing';\n      }\n    } else {\n      return this.customState;\n    }\n  }\n\n  public getTextFieldInputFontSize(): string {\n    return 'hr-label ' + this.size + '-regular';\n  }\n\n  public isNewIcon(iconPosition: 'left' | 'right'): boolean {\n    if (iconPosition == 'left') {\n      return GravityIconComponent.isNewIcon(this.iconLeft);\n    } else {\n      return GravityIconComponent.isNewIcon(this.iconRight);\n    }\n  }\n\n  public onKeyDownEvent($event: KeyboardEvent): void {\n    if (this.inputContentType == 'number') {\n      let navigationKeys = ['Backspace', 'Delete', 'Tab', 'Escape', 'Enter', 'Home', 'End', 'ArrowLeft', 'ArrowRight', 'Clear', 'Copy', 'Paste'];\n\n      if (\n        navigationKeys.indexOf($event.key) > -1 || // Allow: navigation keys: backspace, delete, arrows etc.\n        ($event.key === 'a' && $event.ctrlKey === true) || // Allow: Ctrl+A\n        ($event.key === 'c' && $event.ctrlKey === true) || // Allow: Ctrl+C\n        ($event.key === 'v' && $event.ctrlKey === true) || // Allow: Ctrl+V\n        ($event.key === 'x' && $event.ctrlKey === true) || // Allow: Ctrl+X\n        ($event.key === 'a' && $event.metaKey === true) || // Allow: Cmd+A (Mac)\n        ($event.key === 'c' && $event.metaKey === true) || // Allow: Cmd+C (Mac)\n        ($event.key === 'v' && $event.metaKey === true) || // Allow: Cmd+V (Mac)\n        ($event.key === 'x' && $event.metaKey === true) ||// Allow: Cmd+X (Mac)\n        ($event.key === '.') || ($event.key === ',') // Allow: dot and comma for decimal\n      ) {\n        // let it happen, don't do anything\n        return;\n      }\n\n      // Ensure that it is a number and stop the keypress\n      if (\n        ($event.shiftKey || ($event.keyCode < 48 || $event.keyCode > 57)) &&\n        ($event.keyCode < 96 || $event.keyCode > 105)\n      ) {\n        $event.preventDefault();\n      }\n    }\n  }\n}\n","<label class=\"hr-label sm-bold {{getTextFieldStatus()}}\" [class.custom-label-size]=\"size == 'sm'\" *ngIf=\"label\">\n  {{label}} <span *ngIf=\"required || getTextFieldStatus() == 'typed-error'\">*</span>\n</label>\n<div class=\"gravity-input-field {{size}} {{width}}-width {{getTextFieldStatus()}}\">\n  <ng-container *ngIf=\"iconLeft\">\n    <ng-container [ngTemplateOutlet]=\"icons\" [ngTemplateOutletContext]=\"{iconPosition: 'left'}\"></ng-container>\n  </ng-container>\n  <span class=\"{{getTextFieldInputFontSize()}} prefix\">{{prefix}}</span>\n  <input [attr.data-cy]=\"cypressTag\"\n         [attr.disabled]=\"customState == 'disabled' ? true : null\"\n         [attr.readonly]=\"customState == 'readonly' ? true : null\"\n         [autocomplete]=\"autocomplete\"\n         [maxLength]=\"validations?.maxLength ? validations?.maxLength : 100\"\n         [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n         [placeholder]=\"getPlaceholder()\"\n         [type]=\"inputContentType != 'number' ? inputContentType : 'text'\"\n         [value]=\"inputValue\"\n\n         (blur)=\"focusInput = false\"\n         (change)=\"changeInputValue()\"\n         (focus)=\"focusInput = true\"\n         (keydown)=\"onKeyDownEvent($event)\"\n         (keyup)=\"changeInputValue()\"\n\n         class=\"{{getTextFieldInputFontSize()}}\"\n\n         #inputElement\n\n         *ngIf=\"textFieldType == 'input'\">\n  <textarea [attr.data-cy]=\"cypressTag\"\n            [attr.disabled]=\"customState == 'disabled' ? true : null\"\n            [attr.readonly]=\"customState == 'readonly' ? true : null\"\n            [maxLength]=\"validations?.maxLength ? validations?.maxLength : 200\"\n            [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n            [placeholder]=\"getPlaceholder()\"\n            [value]=\"inputValue\"\n\n            (blur)=\"focusInput = false\"\n            (change)=\"changeInputValue()\"\n            (focus)=\"focusInput = true\"\n            (keydown)=\"onKeyDownEvent($event)\"\n            (keyup)=\"changeInputValue()\"\n\n            class=\"{{getTextFieldInputFontSize()}}\"\n            rows=\"1\"\n\n            #textAreaElement\n\n            *ngIf=\"textFieldType == 'textarea'\"></textarea>\n  <ng-container *ngIf=\"iconRight\">\n    <ng-container [ngTemplateOutlet]=\"icons\" [ngTemplateOutletContext]=\"{iconPosition: 'right'}\"></ng-container>\n  </ng-container>\n</div>\n<p class=\"hr-label sm-regular supporting-text {{getTextFieldStatus()}} {{size}}\"\n   [class.custom-label-size]=\"size == 'sm'\" *ngIf=\"supportText\">\n  <gravity-icon [iconName]=\"'question-circle'\" *ngIf=\"getTextFieldStatus() == 'typed-error'\"\n                [iconSize]=\"'md-16'\"></gravity-icon>\n  {{supportText}}\n</p>\n<p class=\"hr-label sm-regular supporting-text {{getTextFieldStatus()}} {{size}}\"\n   [class.custom-label-size]=\"size == 'sm'\"\n   *ngIf=\"!supportText && getTextFieldStatus() == 'active' && inputValue == '' && required\">\n  {{currentLang == 'es' ? 'Requerido' : 'Required'}}\n</p>\n\n<ng-template #icons let-iconPosition=\"iconPosition\">\n  <gravity-icon (click)=\"$event.stopPropagation(); handleIconClick(iconPosition)\" class=\"{{iconPosition}}\"\n                [class.pointer]=\"(iconPosition == 'left' && clickOnLeftIcon) || (iconPosition == 'right' && clickOnRightIcon)\"\n                [iconName]=\"iconPosition == 'left' ? iconLeft : iconRight\"\n                [iconSize]=\"isNewIcon(iconPosition) ? 'md-16' : null\"></gravity-icon>\n</ng-template>\n"]}
@@ -508,7 +508,8 @@ class GravityTextFieldComponent {
508
508
  ($event.key === 'a' && $event.metaKey === true) || // Allow: Cmd+A (Mac)
509
509
  ($event.key === 'c' && $event.metaKey === true) || // Allow: Cmd+C (Mac)
510
510
  ($event.key === 'v' && $event.metaKey === true) || // Allow: Cmd+V (Mac)
511
- ($event.key === 'x' && $event.metaKey === true) // Allow: Cmd+X (Mac)
511
+ ($event.key === 'x' && $event.metaKey === true) || // Allow: Cmd+X (Mac)
512
+ ($event.key === '.') || ($event.key === ',') // Allow: dot and comma for decimal
512
513
  ) {
513
514
  // let it happen, don't do anything
514
515
  return;