@testgorilla/tgo-ui 2.31.0 → 2.31.2
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.
|
@@ -92,6 +92,7 @@ export declare class SliderComponent implements Validator {
|
|
|
92
92
|
sliderValueChange: EventEmitter<SliderValue>;
|
|
93
93
|
cdr: ChangeDetectorRef;
|
|
94
94
|
decimalPipe: DecimalPipe;
|
|
95
|
+
private control?;
|
|
95
96
|
constructor(defaultAppTheme: ApplicationTheme);
|
|
96
97
|
private value;
|
|
97
98
|
protected translationContext: string;
|
|
@@ -133,6 +133,9 @@ export class SliderComponent {
|
|
|
133
133
|
setTimeout(() => {
|
|
134
134
|
this.sliderStart = value.start;
|
|
135
135
|
this.cdr.markForCheck();
|
|
136
|
+
if (this.control) {
|
|
137
|
+
this.control.updateValueAndValidity();
|
|
138
|
+
}
|
|
136
139
|
});
|
|
137
140
|
}
|
|
138
141
|
onValueChange(ev) {
|
|
@@ -175,6 +178,7 @@ export class SliderComponent {
|
|
|
175
178
|
return this.useDecimal() ? this.decimalPipe.transform(value, '1.0-0') || value.toString() : value.toString();
|
|
176
179
|
}
|
|
177
180
|
validate(control) {
|
|
181
|
+
this.control = control;
|
|
178
182
|
return this.hasError && this.touchedControlName ? { invalidSlider: true } : null;
|
|
179
183
|
}
|
|
180
184
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SliderComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
@@ -249,4 +253,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
249
253
|
}], sliderValueChange: [{
|
|
250
254
|
type: Output
|
|
251
255
|
}] } });
|
|
252
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/slider/slider.component.ts","../../../../../projects/tgo-canopy-ui/components/slider/slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DecimalPipe } from '@angular/common';\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  forwardRef,\r\n  inject,\r\n  Inject,\r\n  input,\r\n  Input,\r\n  Optional,\r\n  Output,\r\n} from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  FormsModule,\r\n  NG_VALIDATORS,\r\n  NG_VALUE_ACCESSOR,\r\n  ValidationErrors,\r\n  Validator,\r\n} from '@angular/forms';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MatSliderModule } from '@angular/material/slider';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { NgxMaskDirective, provideNgxMask } from 'ngx-mask';\r\nimport { DigitsOnlyDirective } from '../../directives/digits-only.directive';\r\nimport { ApplicationTheme } from '../../models/application-theme.model';\r\nimport { UiTranslatePipe } from '../../pipes/ui-translate.pipe';\r\nimport { IconComponentModule } from '../icon/icon.component.module';\r\nimport { SliderValue, SliderVariant } from './slider.model';\r\n\r\n@Component({\r\n  selector: 'ui-slider',\r\n  templateUrl: './slider.component.html',\r\n  styleUrls: ['./slider.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => SliderComponent),\r\n      multi: true,\r\n    },\r\n    {\r\n      provide: NG_VALIDATORS,\r\n      useExisting: forwardRef(() => SliderComponent),\r\n      multi: true,\r\n    },\r\n    provideNgxMask(),\r\n    DecimalPipe,\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    MatSliderModule,\r\n    FormsModule,\r\n    MatInputModule,\r\n    MatTooltipModule,\r\n    IconComponentModule,\r\n    UiTranslatePipe,\r\n    DigitsOnlyDirective,\r\n    NgxMaskDirective,\r\n  ],\r\n})\r\nexport class SliderComponent implements Validator {\r\n  /**\r\n   * The maximum value of the slider.\r\n   *\r\n   * @type {number}\r\n   * @default 100\r\n   */\r\n  @Input() max = 100;\r\n\r\n  /**\r\n   * The minimum value of the slider.\r\n   *\r\n   * @type {number}\r\n   * @default 0\r\n   */\r\n  @Input() min = 0;\r\n\r\n  /**\r\n   * A flag indicating whether the slider displays values as percentages.\r\n   *\r\n   * @type {boolean}\r\n   * @default true\r\n   */\r\n  @Input() percentage = false;\r\n\r\n  /**\r\n   * A flag indicating whether the slider is disabled.\r\n   *\r\n   * @type {boolean}\r\n   * @default true\r\n   */\r\n  @Input() disabled = false;\r\n\r\n  /**\r\n   * The starting value of the slider.\r\n   *\r\n   * @type {number}\r\n   * @default 0\r\n   */\r\n  @Input() sliderStart = 0;\r\n\r\n  /**\r\n   * The ending value of the slider.\r\n   *\r\n   * @type {number}\r\n   * @default 100\r\n   */\r\n  @Input() sliderEnd = 100;\r\n\r\n  /**\r\n   * The label for the slider.\r\n   *\r\n   * @type {string}\r\n   * @default ''\r\n   */\r\n  @Input() label = '';\r\n\r\n  /**\r\n   * Show slider inputs.\r\n   *\r\n   * @type {boolean}\r\n   * @default true\r\n   */\r\n  @Input() showInputs = true;\r\n\r\n  /**\r\n   * Step number.\r\n   *\r\n   * @type {number}\r\n   * @default 1\r\n   */\r\n  @Input() step = 1;\r\n\r\n  /**\r\n   *\r\n   * Defines the application theme\r\n   *\r\n   * @type {ApplicationTheme}\r\n   * @memberof SliderComponent\r\n   */\r\n  @Input() applicationTheme: ApplicationTheme = 'light';\r\n\r\n  /**\r\n   *\r\n   * Defines the variant slider\r\n   *\r\n   * @type {SliderVariant}\r\n   * @memberof SliderComponent\r\n   */\r\n  @Input() variant: SliderVariant = 'range';\r\n\r\n  useDecimal = input<boolean>(false);\r\n\r\n  minLabel = input<string>();\r\n\r\n  maxLabel = input<string>();\r\n\r\n  inputWidth = input(80);\r\n\r\n  @Output() sliderValueChange = new EventEmitter<SliderValue>();\r\n\r\n  cdr = inject(ChangeDetectorRef);\r\n  decimalPipe = inject(DecimalPipe);\r\n\r\n  constructor(\r\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme\r\n  ) {\r\n    if (defaultAppTheme) {\r\n      this.applicationTheme = defaultAppTheme;\r\n      this.cdr.markForCheck();\r\n    }\r\n    this.formatLabel = this.formatLabel.bind(this);\r\n  }\r\n\r\n  private value: SliderValue = { start: 0, end: 100 };\r\n  protected translationContext = 'SLIDER.';\r\n  protected touchedControlName = '';\r\n\r\n  onChange: (value: SliderValue) => void = () => {};\r\n  onTouch: () => void = () => {};\r\n\r\n  registerOnChange(fn: (value: SliderValue) => void): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: () => void): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  writeValue(value: SliderValue): void {\r\n    this.value = value;\r\n    this.sliderEnd = value.end;\r\n    this.cdr.markForCheck();\r\n    // Update sliderStart in a separate detection cycle to ensure proper rendering o mat-slider\r\n    setTimeout(() => {\r\n      this.sliderStart = value.start;\r\n      this.cdr.markForCheck();\r\n    });\r\n  }\r\n\r\n  protected onValueChange(ev?: number): void {\r\n    const value: SliderValue = { start: +this.sliderStart, end: +this.sliderEnd };\r\n\r\n    if (ev) {\r\n      value.start = ev;\r\n      value.end = 0;\r\n    }\r\n\r\n    this.value = value;\r\n    this.onChange(value);\r\n    this.sliderValueChange.emit(value);\r\n    this.cdr.markForCheck();\r\n    this.onTouch();\r\n  }\r\n\r\n  protected onInputBlur(inputName: string): void {\r\n    this.touchedControlName = inputName;\r\n    const value: SliderValue = { start: +this.sliderStart, end: +this.sliderEnd };\r\n\r\n    if (this.isValueChanged(value)) {\r\n      this.onValueChange();\r\n    }\r\n  }\r\n\r\n  protected onInputFocus(): void {\r\n    this.touchedControlName = '';\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  private isValueChanged(value: SliderValue): boolean {\r\n    return this.value.start !== value.start || this.value.end !== value.end;\r\n  }\r\n\r\n  get hasError(): boolean {\r\n    return (\r\n      this.max < +this.sliderEnd ||\r\n      this.min > +this.sliderStart ||\r\n      this.min > +this.sliderEnd ||\r\n      this.max < +this.sliderStart ||\r\n      +this.sliderEnd < +this.sliderStart\r\n    );\r\n  }\r\n\r\n  get isBasicSlider(): boolean {\r\n    return this.variant === 'basic';\r\n  }\r\n\r\n  formatLabel(value: number): string {\r\n    return this.useDecimal() ? this.decimalPipe.transform(value, '1.0-0') || value.toString() : value.toString();\r\n  }\r\n\r\n  validate(control: AbstractControl): ValidationErrors | null {\r\n    return this.hasError && this.touchedControlName ? { invalidSlider: true } : null;\r\n  }\r\n}\r\n","<ng-container>\r\n  <div\r\n    class=\"slider-container\"\r\n    [attr.theme]=\"applicationTheme\"\r\n    [ngClass]=\"{ disabled: disabled, error: hasError && touchedControlName }\"\r\n  >\r\n    @if (label) {\r\n      <div class=\"slider-label\">{{ label }}</div>\r\n    }\r\n\r\n    <div class=\"slider\">\r\n      @if (!isBasicSlider) {\r\n        <div class=\"min-value\">\r\n          <span>\r\n            @if (useDecimal()) {\r\n              {{ min | number }}\r\n            } @else {\r\n              {{ min }}\r\n            }\r\n            @if (percentage) {\r\n              %\r\n            }\r\n          </span>\r\n        </div>\r\n      }\r\n      <mat-slider\r\n        [disableRipple]=\"applicationTheme !== 'classic'\"\r\n        #sliderElement\r\n        discrete\r\n        [disabled]=\"disabled\"\r\n        [max]=\"max\"\r\n        [min]=\"min\"\r\n        [step]=\"step\"\r\n        (mouseenter)=\"sliderElement.discrete = true\"\r\n        (mouseleave)=\"sliderElement.discrete = false\"\r\n        [displayWith]=\"formatLabel\"\r\n      >\r\n        @if (isBasicSlider) {\r\n          <input [disabled]=\"disabled\" (valueChange)=\"onValueChange($event)\" [(ngModel)]=\"sliderStart\" matSliderThumb />\r\n        } @else {\r\n          <input [disabled]=\"disabled\" (valueChange)=\"onValueChange()\" [(ngModel)]=\"sliderStart\" matSliderStartThumb />\r\n          <input [disabled]=\"disabled\" (valueChange)=\"onValueChange()\" [(ngModel)]=\"sliderEnd\" matSliderEndThumb />\r\n        }\r\n      </mat-slider>\r\n      @if (!isBasicSlider) {\r\n        <div class=\"max-value\">\r\n          <span>\r\n            @if (useDecimal()) {\r\n              {{ max | number }}\r\n            } @else {\r\n              {{ max }}\r\n            }\r\n            @if (percentage) {\r\n              %\r\n            }\r\n          </span>\r\n        </div>\r\n      }\r\n    </div>\r\n\r\n    @if (showInputs && !this.isBasicSlider) {\r\n      <div class=\"slider-input\">\r\n        <mat-form-field [appearance]=\"'outline'\" [ngStyle]=\"{ width: inputWidth() + 'px' }\">\r\n          @if (minLabel()) {\r\n            <mat-label>\r\n              {{ minLabel() }}\r\n              @if (percentage) {\r\n                <span>%</span>\r\n              }\r\n            </mat-label>\r\n          } @else {\r\n            <mat-label>\r\n              {{ 'COMMON.MIN' | uiTranslate | async }}\r\n              @if (percentage) {\r\n                <span>%</span>\r\n              }\r\n            </mat-label>\r\n          }\r\n          @if (useDecimal()) {\r\n            <input\r\n              matInput\r\n              [type]=\"'text'\"\r\n              [(ngModel)]=\"sliderStart\"\r\n              [disabled]=\"disabled\"\r\n              (focus)=\"onInputFocus()\"\r\n              (blur)=\"onInputBlur('start')\"\r\n              (keydown.enter)=\"onInputBlur('start')\"\r\n              mask=\"separator.2\"\r\n              thousandSeparator=\",\"\r\n            />\r\n          } @else {\r\n            <input\r\n              matInput\r\n              [type]=\"'number'\"\r\n              [(ngModel)]=\"sliderStart\"\r\n              [disabled]=\"disabled\"\r\n              (focus)=\"onInputFocus()\"\r\n              (blur)=\"onInputBlur('start')\"\r\n              (keydown.enter)=\"onInputBlur('start')\"\r\n              [allowOnlyDigits]=\"true\"\r\n              digitsOnly\r\n            />\r\n          }\r\n        </mat-form-field>\r\n        <mat-form-field [appearance]=\"'outline'\" [ngStyle]=\"{ width: inputWidth() + 'px' }\">\r\n          @if (maxLabel()) {\r\n            <mat-label>\r\n              {{ maxLabel() }}\r\n              @if (percentage) {\r\n                <span>%</span>\r\n              }\r\n            </mat-label>\r\n          } @else {\r\n            <mat-label>\r\n              {{ 'COMMON.MAX' | uiTranslate | async }}\r\n              @if (percentage) {\r\n                <span>%</span>\r\n              }\r\n            </mat-label>\r\n          }\r\n          @if (useDecimal()) {\r\n            <input\r\n              matInput\r\n              [disabled]=\"disabled\"\r\n              [type]=\"'text'\"\r\n              [(ngModel)]=\"sliderEnd\"\r\n              (focus)=\"onInputFocus()\"\r\n              (blur)=\"onInputBlur('end')\"\r\n              (keydown.enter)=\"onInputBlur('end')\"\r\n              data-testid=\"slider.input-end\"\r\n              mask=\"separator.2\"\r\n              thousandSeparator=\",\"\r\n            />\r\n          } @else {\r\n            <input\r\n              matInput\r\n              [disabled]=\"disabled\"\r\n              [type]=\"'number'\"\r\n              [(ngModel)]=\"sliderEnd\"\r\n              (focus)=\"onInputFocus()\"\r\n              (blur)=\"onInputBlur('end')\"\r\n              (keydown.enter)=\"onInputBlur('end')\"\r\n              [allowOnlyDigits]=\"true\"\r\n              digitsOnly\r\n              data-testid=\"slider.input-end\"\r\n            />\r\n          }\r\n        </mat-form-field>\r\n      </div>\r\n    }\r\n\r\n    @if (hasError && touchedControlName) {\r\n      <mat-error class=\"slider-errors\">\r\n        @if (touchedControlName === 'start' && sliderStart > sliderEnd) {\r\n          <div class=\"validation-error\">\r\n            <ui-icon [name]=\"'Info'\"></ui-icon>\r\n            <span>{{\r\n              translationContext + 'MIN_MORE_THAN_MAX' | uiTranslate: { min: sliderStart, max: sliderEnd } | async\r\n            }}</span>\r\n          </div>\r\n        }\r\n        @if (touchedControlName === 'end' && sliderStart > sliderEnd) {\r\n          <div class=\"validation-error\">\r\n            <ui-icon [name]=\"'Info'\"></ui-icon>\r\n            <span>{{\r\n              translationContext + 'MAX_LESS_THAN_MIN' | uiTranslate: { min: sliderStart, max: sliderEnd } | async\r\n            }}</span>\r\n          </div>\r\n        }\r\n        @if (sliderStart < min) {\r\n          <div class=\"validation-error\">\r\n            <ui-icon [name]=\"'Info'\"></ui-icon>\r\n            <span>{{ 'COMMON.MIN' | uiTranslate | async }} {{ min }}</span>\r\n          </div>\r\n        }\r\n        @if (sliderEnd > max) {\r\n          <div class=\"validation-error\">\r\n            <ui-icon [name]=\"'Info'\"></ui-icon>\r\n            <span>{{ 'COMMON.MAX' | uiTranslate | async }} {{ max }}</span>\r\n          </div>\r\n        }\r\n      </mat-error>\r\n    }\r\n  </div>\r\n</ng-container>\r\n"]}
|
|
256
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/slider/slider.component.ts","../../../../../projects/tgo-canopy-ui/components/slider/slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DecimalPipe } from '@angular/common';\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  forwardRef,\r\n  inject,\r\n  Inject,\r\n  input,\r\n  Input,\r\n  Optional,\r\n  Output,\r\n} from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  FormsModule,\r\n  NG_VALIDATORS,\r\n  NG_VALUE_ACCESSOR,\r\n  ValidationErrors,\r\n  Validator,\r\n} from '@angular/forms';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MatSliderModule } from '@angular/material/slider';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { NgxMaskDirective, provideNgxMask } from 'ngx-mask';\r\nimport { DigitsOnlyDirective } from '../../directives/digits-only.directive';\r\nimport { ApplicationTheme } from '../../models/application-theme.model';\r\nimport { UiTranslatePipe } from '../../pipes/ui-translate.pipe';\r\nimport { IconComponentModule } from '../icon/icon.component.module';\r\nimport { SliderValue, SliderVariant } from './slider.model';\r\n\r\n@Component({\r\n  selector: 'ui-slider',\r\n  templateUrl: './slider.component.html',\r\n  styleUrls: ['./slider.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => SliderComponent),\r\n      multi: true,\r\n    },\r\n    {\r\n      provide: NG_VALIDATORS,\r\n      useExisting: forwardRef(() => SliderComponent),\r\n      multi: true,\r\n    },\r\n    provideNgxMask(),\r\n    DecimalPipe,\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    MatSliderModule,\r\n    FormsModule,\r\n    MatInputModule,\r\n    MatTooltipModule,\r\n    IconComponentModule,\r\n    UiTranslatePipe,\r\n    DigitsOnlyDirective,\r\n    NgxMaskDirective,\r\n  ],\r\n})\r\nexport class SliderComponent implements Validator {\r\n  /**\r\n   * The maximum value of the slider.\r\n   *\r\n   * @type {number}\r\n   * @default 100\r\n   */\r\n  @Input() max = 100;\r\n\r\n  /**\r\n   * The minimum value of the slider.\r\n   *\r\n   * @type {number}\r\n   * @default 0\r\n   */\r\n  @Input() min = 0;\r\n\r\n  /**\r\n   * A flag indicating whether the slider displays values as percentages.\r\n   *\r\n   * @type {boolean}\r\n   * @default true\r\n   */\r\n  @Input() percentage = false;\r\n\r\n  /**\r\n   * A flag indicating whether the slider is disabled.\r\n   *\r\n   * @type {boolean}\r\n   * @default true\r\n   */\r\n  @Input() disabled = false;\r\n\r\n  /**\r\n   * The starting value of the slider.\r\n   *\r\n   * @type {number}\r\n   * @default 0\r\n   */\r\n  @Input() sliderStart = 0;\r\n\r\n  /**\r\n   * The ending value of the slider.\r\n   *\r\n   * @type {number}\r\n   * @default 100\r\n   */\r\n  @Input() sliderEnd = 100;\r\n\r\n  /**\r\n   * The label for the slider.\r\n   *\r\n   * @type {string}\r\n   * @default ''\r\n   */\r\n  @Input() label = '';\r\n\r\n  /**\r\n   * Show slider inputs.\r\n   *\r\n   * @type {boolean}\r\n   * @default true\r\n   */\r\n  @Input() showInputs = true;\r\n\r\n  /**\r\n   * Step number.\r\n   *\r\n   * @type {number}\r\n   * @default 1\r\n   */\r\n  @Input() step = 1;\r\n\r\n  /**\r\n   *\r\n   * Defines the application theme\r\n   *\r\n   * @type {ApplicationTheme}\r\n   * @memberof SliderComponent\r\n   */\r\n  @Input() applicationTheme: ApplicationTheme = 'light';\r\n\r\n  /**\r\n   *\r\n   * Defines the variant slider\r\n   *\r\n   * @type {SliderVariant}\r\n   * @memberof SliderComponent\r\n   */\r\n  @Input() variant: SliderVariant = 'range';\r\n\r\n  useDecimal = input<boolean>(false);\r\n\r\n  minLabel = input<string>();\r\n\r\n  maxLabel = input<string>();\r\n\r\n  inputWidth = input(80);\r\n\r\n  @Output() sliderValueChange = new EventEmitter<SliderValue>();\r\n\r\n  cdr = inject(ChangeDetectorRef);\r\n  decimalPipe = inject(DecimalPipe);\r\n  private control?: AbstractControl;\r\n\r\n  constructor(\r\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme\r\n  ) {\r\n    if (defaultAppTheme) {\r\n      this.applicationTheme = defaultAppTheme;\r\n      this.cdr.markForCheck();\r\n    }\r\n    this.formatLabel = this.formatLabel.bind(this);\r\n  }\r\n\r\n  private value: SliderValue = { start: 0, end: 100 };\r\n  protected translationContext = 'SLIDER.';\r\n  protected touchedControlName = '';\r\n\r\n  onChange: (value: SliderValue) => void = () => {};\r\n  onTouch: () => void = () => {};\r\n\r\n  registerOnChange(fn: (value: SliderValue) => void): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: () => void): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  writeValue(value: SliderValue): void {\r\n    this.value = value;\r\n    this.sliderEnd = value.end;\r\n    this.cdr.markForCheck();\r\n    // Update sliderStart in a separate detection cycle to ensure proper rendering o mat-slider\r\n    setTimeout(() => {\r\n      this.sliderStart = value.start;\r\n      this.cdr.markForCheck();\r\n      if (this.control) {\r\n        this.control.updateValueAndValidity();\r\n      }\r\n    });\r\n  }\r\n\r\n  protected onValueChange(ev?: number): void {\r\n    const value: SliderValue = { start: +this.sliderStart, end: +this.sliderEnd };\r\n\r\n    if (ev) {\r\n      value.start = ev;\r\n      value.end = 0;\r\n    }\r\n\r\n    this.value = value;\r\n    this.onChange(value);\r\n    this.sliderValueChange.emit(value);\r\n    this.cdr.markForCheck();\r\n    this.onTouch();\r\n  }\r\n\r\n  protected onInputBlur(inputName: string): void {\r\n    this.touchedControlName = inputName;\r\n    const value: SliderValue = { start: +this.sliderStart, end: +this.sliderEnd };\r\n\r\n    if (this.isValueChanged(value)) {\r\n      this.onValueChange();\r\n    }\r\n  }\r\n\r\n  protected onInputFocus(): void {\r\n    this.touchedControlName = '';\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  private isValueChanged(value: SliderValue): boolean {\r\n    return this.value.start !== value.start || this.value.end !== value.end;\r\n  }\r\n\r\n  get hasError(): boolean {\r\n    return (\r\n      this.max < +this.sliderEnd ||\r\n      this.min > +this.sliderStart ||\r\n      this.min > +this.sliderEnd ||\r\n      this.max < +this.sliderStart ||\r\n      +this.sliderEnd < +this.sliderStart\r\n    );\r\n  }\r\n\r\n  get isBasicSlider(): boolean {\r\n    return this.variant === 'basic';\r\n  }\r\n\r\n  formatLabel(value: number): string {\r\n    return this.useDecimal() ? this.decimalPipe.transform(value, '1.0-0') || value.toString() : value.toString();\r\n  }\r\n\r\n  validate(control: AbstractControl): ValidationErrors | null {\r\n    this.control = control;\r\n    return this.hasError && this.touchedControlName ? { invalidSlider: true } : null;\r\n  }\r\n}\r\n","<ng-container>\r\n  <div\r\n    class=\"slider-container\"\r\n    [attr.theme]=\"applicationTheme\"\r\n    [ngClass]=\"{ disabled: disabled, error: hasError && touchedControlName }\"\r\n  >\r\n    @if (label) {\r\n      <div class=\"slider-label\">{{ label }}</div>\r\n    }\r\n\r\n    <div class=\"slider\">\r\n      @if (!isBasicSlider) {\r\n        <div class=\"min-value\">\r\n          <span>\r\n            @if (useDecimal()) {\r\n              {{ min | number }}\r\n            } @else {\r\n              {{ min }}\r\n            }\r\n            @if (percentage) {\r\n              %\r\n            }\r\n          </span>\r\n        </div>\r\n      }\r\n      <mat-slider\r\n        [disableRipple]=\"applicationTheme !== 'classic'\"\r\n        #sliderElement\r\n        discrete\r\n        [disabled]=\"disabled\"\r\n        [max]=\"max\"\r\n        [min]=\"min\"\r\n        [step]=\"step\"\r\n        (mouseenter)=\"sliderElement.discrete = true\"\r\n        (mouseleave)=\"sliderElement.discrete = false\"\r\n        [displayWith]=\"formatLabel\"\r\n      >\r\n        @if (isBasicSlider) {\r\n          <input [disabled]=\"disabled\" (valueChange)=\"onValueChange($event)\" [(ngModel)]=\"sliderStart\" matSliderThumb />\r\n        } @else {\r\n          <input [disabled]=\"disabled\" (valueChange)=\"onValueChange()\" [(ngModel)]=\"sliderStart\" matSliderStartThumb />\r\n          <input [disabled]=\"disabled\" (valueChange)=\"onValueChange()\" [(ngModel)]=\"sliderEnd\" matSliderEndThumb />\r\n        }\r\n      </mat-slider>\r\n      @if (!isBasicSlider) {\r\n        <div class=\"max-value\">\r\n          <span>\r\n            @if (useDecimal()) {\r\n              {{ max | number }}\r\n            } @else {\r\n              {{ max }}\r\n            }\r\n            @if (percentage) {\r\n              %\r\n            }\r\n          </span>\r\n        </div>\r\n      }\r\n    </div>\r\n\r\n    @if (showInputs && !this.isBasicSlider) {\r\n      <div class=\"slider-input\">\r\n        <mat-form-field [appearance]=\"'outline'\" [ngStyle]=\"{ width: inputWidth() + 'px' }\">\r\n          @if (minLabel()) {\r\n            <mat-label>\r\n              {{ minLabel() }}\r\n              @if (percentage) {\r\n                <span>%</span>\r\n              }\r\n            </mat-label>\r\n          } @else {\r\n            <mat-label>\r\n              {{ 'COMMON.MIN' | uiTranslate | async }}\r\n              @if (percentage) {\r\n                <span>%</span>\r\n              }\r\n            </mat-label>\r\n          }\r\n          @if (useDecimal()) {\r\n            <input\r\n              matInput\r\n              [type]=\"'text'\"\r\n              [(ngModel)]=\"sliderStart\"\r\n              [disabled]=\"disabled\"\r\n              (focus)=\"onInputFocus()\"\r\n              (blur)=\"onInputBlur('start')\"\r\n              (keydown.enter)=\"onInputBlur('start')\"\r\n              mask=\"separator.2\"\r\n              thousandSeparator=\",\"\r\n            />\r\n          } @else {\r\n            <input\r\n              matInput\r\n              [type]=\"'number'\"\r\n              [(ngModel)]=\"sliderStart\"\r\n              [disabled]=\"disabled\"\r\n              (focus)=\"onInputFocus()\"\r\n              (blur)=\"onInputBlur('start')\"\r\n              (keydown.enter)=\"onInputBlur('start')\"\r\n              [allowOnlyDigits]=\"true\"\r\n              digitsOnly\r\n            />\r\n          }\r\n        </mat-form-field>\r\n        <mat-form-field [appearance]=\"'outline'\" [ngStyle]=\"{ width: inputWidth() + 'px' }\">\r\n          @if (maxLabel()) {\r\n            <mat-label>\r\n              {{ maxLabel() }}\r\n              @if (percentage) {\r\n                <span>%</span>\r\n              }\r\n            </mat-label>\r\n          } @else {\r\n            <mat-label>\r\n              {{ 'COMMON.MAX' | uiTranslate | async }}\r\n              @if (percentage) {\r\n                <span>%</span>\r\n              }\r\n            </mat-label>\r\n          }\r\n          @if (useDecimal()) {\r\n            <input\r\n              matInput\r\n              [disabled]=\"disabled\"\r\n              [type]=\"'text'\"\r\n              [(ngModel)]=\"sliderEnd\"\r\n              (focus)=\"onInputFocus()\"\r\n              (blur)=\"onInputBlur('end')\"\r\n              (keydown.enter)=\"onInputBlur('end')\"\r\n              data-testid=\"slider.input-end\"\r\n              mask=\"separator.2\"\r\n              thousandSeparator=\",\"\r\n            />\r\n          } @else {\r\n            <input\r\n              matInput\r\n              [disabled]=\"disabled\"\r\n              [type]=\"'number'\"\r\n              [(ngModel)]=\"sliderEnd\"\r\n              (focus)=\"onInputFocus()\"\r\n              (blur)=\"onInputBlur('end')\"\r\n              (keydown.enter)=\"onInputBlur('end')\"\r\n              [allowOnlyDigits]=\"true\"\r\n              digitsOnly\r\n              data-testid=\"slider.input-end\"\r\n            />\r\n          }\r\n        </mat-form-field>\r\n      </div>\r\n    }\r\n\r\n    @if (hasError && touchedControlName) {\r\n      <mat-error class=\"slider-errors\">\r\n        @if (touchedControlName === 'start' && sliderStart > sliderEnd) {\r\n          <div class=\"validation-error\">\r\n            <ui-icon [name]=\"'Info'\"></ui-icon>\r\n            <span>{{\r\n              translationContext + 'MIN_MORE_THAN_MAX' | uiTranslate: { min: sliderStart, max: sliderEnd } | async\r\n            }}</span>\r\n          </div>\r\n        }\r\n        @if (touchedControlName === 'end' && sliderStart > sliderEnd) {\r\n          <div class=\"validation-error\">\r\n            <ui-icon [name]=\"'Info'\"></ui-icon>\r\n            <span>{{\r\n              translationContext + 'MAX_LESS_THAN_MIN' | uiTranslate: { min: sliderStart, max: sliderEnd } | async\r\n            }}</span>\r\n          </div>\r\n        }\r\n        @if (sliderStart < min) {\r\n          <div class=\"validation-error\">\r\n            <ui-icon [name]=\"'Info'\"></ui-icon>\r\n            <span>{{ 'COMMON.MIN' | uiTranslate | async }} {{ min }}</span>\r\n          </div>\r\n        }\r\n        @if (sliderEnd > max) {\r\n          <div class=\"validation-error\">\r\n            <ui-icon [name]=\"'Info'\"></ui-icon>\r\n            <span>{{ 'COMMON.MAX' | uiTranslate | async }} {{ max }}</span>\r\n          </div>\r\n        }\r\n      </mat-error>\r\n    }\r\n  </div>\r\n</ng-container>\r\n"]}
|
|
@@ -13906,6 +13906,9 @@ class SliderComponent {
|
|
|
13906
13906
|
setTimeout(() => {
|
|
13907
13907
|
this.sliderStart = value.start;
|
|
13908
13908
|
this.cdr.markForCheck();
|
|
13909
|
+
if (this.control) {
|
|
13910
|
+
this.control.updateValueAndValidity();
|
|
13911
|
+
}
|
|
13909
13912
|
});
|
|
13910
13913
|
}
|
|
13911
13914
|
onValueChange(ev) {
|
|
@@ -13948,6 +13951,7 @@ class SliderComponent {
|
|
|
13948
13951
|
return this.useDecimal() ? this.decimalPipe.transform(value, '1.0-0') || value.toString() : value.toString();
|
|
13949
13952
|
}
|
|
13950
13953
|
validate(control) {
|
|
13954
|
+
this.control = control;
|
|
13951
13955
|
return this.hasError && this.touchedControlName ? { invalidSlider: true } : null;
|
|
13952
13956
|
}
|
|
13953
13957
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SliderComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|