oasys-lib 1.85.0-rc.0 → 1.85.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -72,11 +72,11 @@ export class TextInputComponent {
72
72
  }
73
73
  // Get preface content if available
74
74
  if (this.prefaceContent?.nativeElement?.textContent?.trim()) {
75
- prefaceText = this.prefaceContent.nativeElement.textContent.trim() + ' ';
75
+ prefaceText = ' ' + this.prefaceContent.nativeElement.textContent.trim();
76
76
  }
77
77
  const textValue = this.textValue?.trim() ?? '';
78
78
  const telephoneToText = prefaceText + ' ' + textValue.split('').join(' ');
79
- return this.label + ' ' + telephoneToText;
79
+ return this.label + telephoneToText;
80
80
  }
81
81
  getInputMode() {
82
82
  // For telephone inputs, use tel input mode
@@ -155,4 +155,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
155
155
  type: ViewChild,
156
156
  args: ['prefaceContent', { read: ElementRef, static: false }]
157
157
  }] } });
158
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/oasys-lib/src/lib/components/form/text-input/text-input.component.ts","../../../../../../../projects/oasys-lib/src/lib/components/form/text-input/text-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  forwardRef,\n  ElementRef,\n  Inject,\n  AfterViewInit,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { AutocompleteType, TextInputType } from './text-input';\nimport { ValidationErrorTypes } from '../forms';\n\n@Component({\n  selector: 'ui-text-input',\n  templateUrl: './text-input.component.html',\n  styleUrls: ['./text-input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(\n        (): typeof TextInputComponent => TextInputComponent\n      ),\n      multi: true\n    }\n  ]\n})\nexport class TextInputComponent\n  implements ControlValueAccessor, OnInit, AfterViewInit\n{\n  @Input() label!: string;\n  @Input() hint?: string;\n  @Input() optional: boolean = true;\n  @Input() type: TextInputType = 'text';\n  @Input() autocomplete: AutocompleteType = 'on';\n  @Input() autofocus: boolean = false;\n  @Input() minlength: number;\n  @Input() maxlength: number = 255;\n  @Input() pattern: string;\n  @Input() autocorrect: boolean = this.type === 'text'; // do not spell check emails and passwords\n  @Input() disabled: boolean = false;\n  @Input() aria_label: string | undefined;\n\n  @Input() show_password_string: string = 'Show'; // Pass in translated string\n  @Input() hide_password_string: string = 'Hide'; // Pass in translated string\n\n  @Input() validation_messages: ValidationErrorTypes; // Pass in translated string\n\n  @Output() didChange = new EventEmitter<string>();\n\n  @ViewChild('textinput', { read: ElementRef })\n  textInput: ElementRef<HTMLElement>;\n\n  @ViewChild('prefaceContent', { read: ElementRef, static: false })\n  prefaceContent: ElementRef<HTMLElement>;\n\n  textValue: string = '';\n  showPassword: boolean = false;\n  inputDidChange: boolean = false; // only show valdiation after a change event (ie. blur)\n  textInputType: TextInputType = 'text';\n\n  id: string | number;\n\n  safariAutocorrect: 'on' | 'off' = 'on';\n\n  constructor(@Inject(DOCUMENT) private document: Document) {}\n\n  onChange: any = (): void => {};\n  onTouched: any = (): void => {};\n\n  writeValue(textValue: string): void {\n    this.textValue = textValue;\n  }\n\n  registerOnChange(fn: unknown): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: unknown): void {\n    this.onTouched = fn;\n  }\n\n  onModelChange(textValue: string): void {\n    this.textValue = textValue;\n    this.onChange(textValue);\n    this.didChange.emit(textValue);\n    this.onTouched();\n  }\n\n  toggleShowPassword(): void {\n    this.showPassword = !this.showPassword;\n    this.textInputType = this.showPassword ? 'text' : 'password';\n  }\n\n  handleEvent(): void {\n    this.inputDidChange = true;\n\n    const inputElement = this.document.getElementById(this.id.toString());\n    inputElement?.removeEventListener('change', this);\n  }\n\n  setupValidationListener(): void {\n    const inputElement = this.document.getElementById(this.id.toString());\n    inputElement?.addEventListener('change', this);\n  }\n\n  ngAfterViewInit(): void {\n    this.setupValidationListener();\n  }\n\n  ngOnInit(): void {\n    this.id = Math.random();\n    this.textInputType = this.type;\n    this.safariAutocorrect = this.autocorrect ? 'on' : 'off';\n  }\n\n  accessibleAriaLabel(): string {\n    let prefaceText = '';\n\n    if (this.aria_label || this.textInputType !== 'tel') {\n      return this.aria_label;\n    }\n\n    // Get preface content if available\n    if (this.prefaceContent?.nativeElement?.textContent?.trim()) {\n      prefaceText = this.prefaceContent.nativeElement.textContent.trim() + ' ';\n    }\n\n    const textValue = this.textValue?.trim() ?? '';\n    const telephoneToText = prefaceText + ' ' + textValue.split('').join(' ');\n\n    return this.label + ' ' + telephoneToText;\n  }\n\n  getInputMode(): string | undefined {\n    // For telephone inputs, use tel input mode\n    if (this.textInputType === 'tel') {\n      return 'tel';\n    }\n\n    return undefined;\n  }\n\n  getAriaDescribedBy(): string {\n    const describedBy = [];\n\n    // Add error if it exists\n    describedBy.push('error_' + this.id);\n\n    // Add hint if it exists\n    if (this.hint) {\n      describedBy.push('hint_' + this.id);\n    }\n\n    return describedBy.length > 0 ? describedBy.join(' ') : undefined;\n  }\n}\n","<ui-stack class=\"ui-text-input-container\" stack_gap=\"tight\">\n  <div class=\"ui-text-input\">\n    <ui-stack stack_direction=\"x\">\n      <div class=\"input-preface\" [attr.id]=\"'preface_' + id\" #prefaceContent>\n        <ng-content select=\"[preface]\"></ng-content>\n      </div>\n      <input\n        #textinput\n        [id]=\"id\"\n        [name]=\"id\"\n        [ngModel]=\"textValue\"\n        (ngModelChange)=\"onModelChange($event)\"\n        [ngClass]=\"\n          inputDidChange ? 'ng-input-did-change' : 'ng-input-did-not-change'\n        \"\n        [attr.autocorrect]=\"safariAutocorrect\"\n        [attr.disabled]=\"disabled || null\"\n        [autofocus]=\"autofocus\"\n        [autocomplete]=\"autocomplete || null\"\n        [minlength]=\"minlength || null\"\n        [maxlength]=\"maxlength\"\n        [pattern]=\"pattern || null\"\n        [required]=\"!optional\"\n        [spellcheck]=\"autocorrect\"\n        [type]=\"textInputType\"\n        [value]=\"textValue\"\n        [attr.inputmode]=\"getInputMode()\"\n        [attr.aria-describedby]=\"getAriaDescribedBy()\"\n        [attr.aria-label]=\"accessibleAriaLabel()\"\n        class=\"text-body--default text-body--regular\"\n      />\n    </ui-stack>\n    <ui-stack\n      class=\"label-container\"\n      stack_direction=\"x\"\n      [stack_distribute]=\"type === 'password' ? 'space-between' : 'start'\"\n    >\n      <label class=\"text-body--supporting text-body--regular\" [for]=\"id\">{{\n        label\n      }}</label>\n      @if (type === \"password\") {\n        <a\n          (click)=\"toggleShowPassword()\"\n          class=\"text-body--supporting text-color--supporting\"\n        >\n          @if (!showPassword) {\n            <span>{{ show_password_string }}</span>\n          } @else if (showPassword) {\n            <span>{{ hide_password_string }}</span>\n          }\n        </a>\n      }\n    </ui-stack>\n  </div>\n  <ui-stack stack_gap=\"none\">\n    <div class=\"input-errors\">\n      <div class=\"input-errors-content\" [attr.id]=\"'error_' + id\">\n        <ng-content select=\"ui-form-errors\"></ng-content>\n      </div>\n    </div>\n    @if (hint) {\n      <ui-box\n        class=\"hint-container\"\n        box_background=\"none\"\n        box_space=\"none\"\n        box_space_left=\"near\"\n        box_space_right=\"near\"\n        box_space_bottom=\"near\"\n      >\n        <div\n          class=\"ui-text-input-hint text-body--supporting text-color--supporting\"\n          [attr.id]=\"'hint_' + id\"\n        >\n          {{ hint }}\n        </div>\n      </ui-box>\n    }\n  </ui-stack>\n</ui-stack>\n"]}
158
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/oasys-lib/src/lib/components/form/text-input/text-input.component.ts","../../../../../../../projects/oasys-lib/src/lib/components/form/text-input/text-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  forwardRef,\n  ElementRef,\n  Inject,\n  AfterViewInit,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { AutocompleteType, TextInputType } from './text-input';\nimport { ValidationErrorTypes } from '../forms';\n\n@Component({\n  selector: 'ui-text-input',\n  templateUrl: './text-input.component.html',\n  styleUrls: ['./text-input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(\n        (): typeof TextInputComponent => TextInputComponent\n      ),\n      multi: true\n    }\n  ]\n})\nexport class TextInputComponent\n  implements ControlValueAccessor, OnInit, AfterViewInit\n{\n  @Input() label!: string;\n  @Input() hint?: string;\n  @Input() optional: boolean = true;\n  @Input() type: TextInputType = 'text';\n  @Input() autocomplete: AutocompleteType = 'on';\n  @Input() autofocus: boolean = false;\n  @Input() minlength: number;\n  @Input() maxlength: number = 255;\n  @Input() pattern: string;\n  @Input() autocorrect: boolean = this.type === 'text'; // do not spell check emails and passwords\n  @Input() disabled: boolean = false;\n  @Input() aria_label: string | undefined;\n\n  @Input() show_password_string: string = 'Show'; // Pass in translated string\n  @Input() hide_password_string: string = 'Hide'; // Pass in translated string\n\n  @Input() validation_messages: ValidationErrorTypes; // Pass in translated string\n\n  @Output() didChange = new EventEmitter<string>();\n\n  @ViewChild('textinput', { read: ElementRef })\n  textInput: ElementRef<HTMLElement>;\n\n  @ViewChild('prefaceContent', { read: ElementRef, static: false })\n  prefaceContent: ElementRef<HTMLElement>;\n\n  textValue: string = '';\n  showPassword: boolean = false;\n  inputDidChange: boolean = false; // only show valdiation after a change event (ie. blur)\n  textInputType: TextInputType = 'text';\n\n  id: string | number;\n\n  safariAutocorrect: 'on' | 'off' = 'on';\n\n  constructor(@Inject(DOCUMENT) private document: Document) {}\n\n  onChange: any = (): void => {};\n  onTouched: any = (): void => {};\n\n  writeValue(textValue: string): void {\n    this.textValue = textValue;\n  }\n\n  registerOnChange(fn: unknown): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: unknown): void {\n    this.onTouched = fn;\n  }\n\n  onModelChange(textValue: string): void {\n    this.textValue = textValue;\n    this.onChange(textValue);\n    this.didChange.emit(textValue);\n    this.onTouched();\n  }\n\n  toggleShowPassword(): void {\n    this.showPassword = !this.showPassword;\n    this.textInputType = this.showPassword ? 'text' : 'password';\n  }\n\n  handleEvent(): void {\n    this.inputDidChange = true;\n\n    const inputElement = this.document.getElementById(this.id.toString());\n    inputElement?.removeEventListener('change', this);\n  }\n\n  setupValidationListener(): void {\n    const inputElement = this.document.getElementById(this.id.toString());\n    inputElement?.addEventListener('change', this);\n  }\n\n  ngAfterViewInit(): void {\n    this.setupValidationListener();\n  }\n\n  ngOnInit(): void {\n    this.id = Math.random();\n    this.textInputType = this.type;\n    this.safariAutocorrect = this.autocorrect ? 'on' : 'off';\n  }\n\n  accessibleAriaLabel(): string | undefined {\n    let prefaceText = '';\n\n    if (this.aria_label || this.textInputType !== 'tel') {\n      return this.aria_label;\n    }\n\n    // Get preface content if available\n    if (this.prefaceContent?.nativeElement?.textContent?.trim()) {\n      prefaceText = ' ' + this.prefaceContent.nativeElement.textContent.trim();\n    }\n\n    const textValue = this.textValue?.trim() ?? '';\n    const telephoneToText = prefaceText + ' ' + textValue.split('').join(' ');\n\n    return this.label + telephoneToText;\n  }\n\n  getInputMode(): string | undefined {\n    // For telephone inputs, use tel input mode\n    if (this.textInputType === 'tel') {\n      return 'tel';\n    }\n\n    return undefined;\n  }\n\n  getAriaDescribedBy(): string | undefined {\n    const describedBy = [];\n\n    // Add error if it exists\n    describedBy.push('error_' + this.id);\n\n    // Add hint if it exists\n    if (this.hint) {\n      describedBy.push('hint_' + this.id);\n    }\n\n    return describedBy.length > 0 ? describedBy.join(' ') : undefined;\n  }\n}\n","<ui-stack class=\"ui-text-input-container\" stack_gap=\"tight\">\n  <div class=\"ui-text-input\">\n    <ui-stack stack_direction=\"x\">\n      <div class=\"input-preface\" [attr.id]=\"'preface_' + id\" #prefaceContent>\n        <ng-content select=\"[preface]\"></ng-content>\n      </div>\n      <input\n        #textinput\n        [id]=\"id\"\n        [name]=\"id\"\n        [ngModel]=\"textValue\"\n        (ngModelChange)=\"onModelChange($event)\"\n        [ngClass]=\"\n          inputDidChange ? 'ng-input-did-change' : 'ng-input-did-not-change'\n        \"\n        [attr.autocorrect]=\"safariAutocorrect\"\n        [attr.disabled]=\"disabled || null\"\n        [autofocus]=\"autofocus\"\n        [autocomplete]=\"autocomplete || null\"\n        [minlength]=\"minlength || null\"\n        [maxlength]=\"maxlength\"\n        [pattern]=\"pattern || null\"\n        [required]=\"!optional\"\n        [spellcheck]=\"autocorrect\"\n        [type]=\"textInputType\"\n        [value]=\"textValue\"\n        [attr.inputmode]=\"getInputMode()\"\n        [attr.aria-describedby]=\"getAriaDescribedBy()\"\n        [attr.aria-label]=\"accessibleAriaLabel()\"\n        class=\"text-body--default text-body--regular\"\n      />\n    </ui-stack>\n    <ui-stack\n      class=\"label-container\"\n      stack_direction=\"x\"\n      [stack_distribute]=\"type === 'password' ? 'space-between' : 'start'\"\n    >\n      <label class=\"text-body--supporting text-body--regular\" [for]=\"id\">{{\n        label\n      }}</label>\n      @if (type === \"password\") {\n        <a\n          (click)=\"toggleShowPassword()\"\n          class=\"text-body--supporting text-color--supporting\"\n        >\n          @if (!showPassword) {\n            <span>{{ show_password_string }}</span>\n          } @else if (showPassword) {\n            <span>{{ hide_password_string }}</span>\n          }\n        </a>\n      }\n    </ui-stack>\n  </div>\n  <ui-stack stack_gap=\"none\">\n    <div class=\"input-errors\">\n      <div class=\"input-errors-content\" [attr.id]=\"'error_' + id\">\n        <ng-content select=\"ui-form-errors\"></ng-content>\n      </div>\n    </div>\n    @if (hint) {\n      <ui-box\n        class=\"hint-container\"\n        box_background=\"none\"\n        box_space=\"none\"\n        box_space_left=\"near\"\n        box_space_right=\"near\"\n        box_space_bottom=\"near\"\n      >\n        <div\n          class=\"ui-text-input-hint text-body--supporting text-color--supporting\"\n          [attr.id]=\"'hint_' + id\"\n        >\n          {{ hint }}\n        </div>\n      </ui-box>\n    }\n  </ui-stack>\n</ui-stack>\n"]}
@@ -1714,11 +1714,11 @@ class TextInputComponent {
1714
1714
  }
1715
1715
  // Get preface content if available
1716
1716
  if (this.prefaceContent?.nativeElement?.textContent?.trim()) {
1717
- prefaceText = this.prefaceContent.nativeElement.textContent.trim() + ' ';
1717
+ prefaceText = ' ' + this.prefaceContent.nativeElement.textContent.trim();
1718
1718
  }
1719
1719
  const textValue = this.textValue?.trim() ?? '';
1720
1720
  const telephoneToText = prefaceText + ' ' + textValue.split('').join(' ');
1721
- return this.label + ' ' + telephoneToText;
1721
+ return this.label + telephoneToText;
1722
1722
  }
1723
1723
  getInputMode() {
1724
1724
  // For telephone inputs, use tel input mode