@flywheel-io/vision 2.0.0-beta.6 → 2.0.0-beta.7

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.
@@ -26,6 +26,7 @@ export declare class FwButtonToggleComponent implements ControlValueAccessor, On
26
26
  ngOnChanges(changes: SimpleChanges): void;
27
27
  ngOnDestroy(): void;
28
28
  ngAfterContentInit(): void;
29
+ valueChange(value: string): void;
29
30
  updateValue(value: string): void;
30
31
  formatToggles(): void;
31
32
  static ɵfac: i0.ɵɵFactoryDeclaration<FwButtonToggleComponent, never>;
@@ -50,6 +50,11 @@ export class FwButtonToggleComponent {
50
50
  this.formatToggles();
51
51
  }
52
52
  }
53
+ // Inputs need an `${inputName}Change` event to support two-way binding to [(value)]
54
+ // https://angular.dev/guide/templates/two-way-binding
55
+ valueChange(value) {
56
+ this.updateValue(value);
57
+ }
53
58
  updateValue(value) {
54
59
  this._value = value;
55
60
  if (this.onChange) {
@@ -129,4 +134,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
129
134
  }], value: [{
130
135
  type: Input
131
136
  }] } });
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-toggle.component.js","sourceRoot":"","sources":["../../../../../src/components/button-toggle/button-toggle.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\nimport { FwButtonToggleItemComponent } from './button-toggle-item/button-toggle-item.component';\n\n@Component({\n  selector: 'fw-button-toggle',\n  styleUrls: ['./button-toggle.component.scss'],\n  template: '<ng-content select=\"fw-button-toggle-item,fw-tooltip\"></ng-content>',\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FwButtonToggleComponent),\n      multi: true,\n    },\n  ],\n})\nexport class FwButtonToggleComponent implements ControlValueAccessor, OnChanges, OnDestroy, AfterContentInit {\n  @HostBinding('attr.class') get classes(): string {\n    return ['fw-button-toggle', this.size, this.layout].filter(Boolean).join(' ');\n  };\n\n  @Input() layout?: 'basic' | 'compact' = 'basic';\n  @Input() size?: 'small' | 'medium' | 'large' = 'medium';\n  @Input() disabled?: boolean = false;\n  @Input() color?: 'primary' | 'secondary' | 'danger' | 'slate' | 'skeleton' | 'warning' | 'success';\n  @Input() selectedColor?: 'primary' | 'secondary' | 'danger' | 'slate' | 'skeleton' | 'warning' | 'success';\n  @ContentChildren(FwButtonToggleItemComponent, { descendants: true }) toggleButtons: QueryList<FwButtonToggleItemComponent>;\n  private subscriptions: Subscription[] = [];\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() change = new EventEmitter<string>();\n  private _value: string;\n  @Input()\n  get value(): string {\n    return this._value;\n  }\n\n  set value(newValue: string) {\n    this.updateValue(newValue);\n  }\n\n  constructor(private cdref: ChangeDetectorRef) {\n  }\n\n  onChange: (value: string) => void;\n  onTouched = (): void => {\n  };\n\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  writeValue(value: string): void {\n    this.value = value;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  ngOnChanges(changes: SimpleChanges): void {\n    this.formatToggles();\n  }\n\n  ngOnDestroy(): void {\n    for (const subscription of this.subscriptions) {\n      subscription.unsubscribe();\n    }\n  }\n\n  ngAfterContentInit(): void {\n    if (this.toggleButtons.length > 0) {\n      this.formatToggles();\n    }\n  }\n\n  updateValue(value: string): void {\n    this._value = value;\n    if (this.onChange) {\n      this.onChange(value);\n    }\n    this.change.emit(value);\n  }\n\n  formatToggles(): void {\n    if (this.toggleButtons) {\n      this.toggleButtons.forEach(toggle => {\n        if (toggle.value === this.value) {\n          toggle.selected = true;\n        }\n        toggle.size = this.size;\n        if (this.color) {\n          toggle.color = this.color;\n        }\n        if (this.selectedColor) {\n          toggle.selectedColor = this.selectedColor;\n        }\n        if (this.disabled) {\n          toggle.disabled = this.disabled;\n        }\n        const sub = toggle.click.subscribe(() => {\n          if (this.toggleButtons.length === 1) {\n            toggle.selected = !toggle.selected;\n          } else {\n            this.toggleButtons.forEach(t => {\n              t.selected = false;\n            });\n            toggle.selected = true;\n          }\n          const val = this.toggleButtons.find(t => t.selected)?.value;\n          this.writeValue(val);\n        });\n        this.subscriptions.push(sub);\n      });\n    }\n  }\n}\n"]}
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-toggle.component.js","sourceRoot":"","sources":["../../../../../src/components/button-toggle/button-toggle.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\nimport { FwButtonToggleItemComponent } from './button-toggle-item/button-toggle-item.component';\n\n@Component({\n  selector: 'fw-button-toggle',\n  styleUrls: ['./button-toggle.component.scss'],\n  template: '<ng-content select=\"fw-button-toggle-item,fw-tooltip\"></ng-content>',\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FwButtonToggleComponent),\n      multi: true,\n    },\n  ],\n})\nexport class FwButtonToggleComponent implements ControlValueAccessor, OnChanges, OnDestroy, AfterContentInit {\n  @HostBinding('attr.class') get classes(): string {\n    return ['fw-button-toggle', this.size, this.layout].filter(Boolean).join(' ');\n  };\n\n  @Input() layout?: 'basic' | 'compact' = 'basic';\n  @Input() size?: 'small' | 'medium' | 'large' = 'medium';\n  @Input() disabled?: boolean = false;\n  @Input() color?: 'primary' | 'secondary' | 'danger' | 'slate' | 'skeleton' | 'warning' | 'success';\n  @Input() selectedColor?: 'primary' | 'secondary' | 'danger' | 'slate' | 'skeleton' | 'warning' | 'success';\n  @ContentChildren(FwButtonToggleItemComponent, { descendants: true }) toggleButtons: QueryList<FwButtonToggleItemComponent>;\n  private subscriptions: Subscription[] = [];\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() change = new EventEmitter<string>();\n  private _value: string;\n  @Input()\n  get value(): string {\n    return this._value;\n  }\n\n  set value(newValue: string) {\n    this.updateValue(newValue);\n  }\n\n  constructor(private cdref: ChangeDetectorRef) {\n  }\n\n  onChange: (value: string) => void;\n  onTouched = (): void => {\n  };\n\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  writeValue(value: string): void {\n    this.value = value;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  ngOnChanges(changes: SimpleChanges): void {\n    this.formatToggles();\n  }\n\n  ngOnDestroy(): void {\n    for (const subscription of this.subscriptions) {\n      subscription.unsubscribe();\n    }\n  }\n\n  ngAfterContentInit(): void {\n    if (this.toggleButtons.length > 0) {\n      this.formatToggles();\n    }\n  }\n\n  // Inputs need an `${inputName}Change` event to support two-way binding to [(value)]\n  // https://angular.dev/guide/templates/two-way-binding\n  valueChange(value: string): void {\n    this.updateValue(value);\n  }\n\n  updateValue(value: string): void {\n    this._value = value;\n    if (this.onChange) {\n      this.onChange(value);\n    }\n    this.change.emit(value);\n  }\n\n  formatToggles(): void {\n    if (this.toggleButtons) {\n      this.toggleButtons.forEach(toggle => {\n        if (toggle.value === this.value) {\n          toggle.selected = true;\n        }\n        toggle.size = this.size;\n        if (this.color) {\n          toggle.color = this.color;\n        }\n        if (this.selectedColor) {\n          toggle.selectedColor = this.selectedColor;\n        }\n        if (this.disabled) {\n          toggle.disabled = this.disabled;\n        }\n        const sub = toggle.click.subscribe(() => {\n          if (this.toggleButtons.length === 1) {\n            toggle.selected = !toggle.selected;\n          } else {\n            this.toggleButtons.forEach(t => {\n              t.selected = false;\n            });\n            toggle.selected = true;\n          }\n          const val = this.toggleButtons.find(t => t.selected)?.value;\n          this.writeValue(val);\n        });\n        this.subscriptions.push(sub);\n      });\n    }\n  }\n}\n"]}
@@ -1160,6 +1160,11 @@ class FwButtonToggleComponent {
1160
1160
  this.formatToggles();
1161
1161
  }
1162
1162
  }
1163
+ // Inputs need an `${inputName}Change` event to support two-way binding to [(value)]
1164
+ // https://angular.dev/guide/templates/two-way-binding
1165
+ valueChange(value) {
1166
+ this.updateValue(value);
1167
+ }
1163
1168
  updateValue(value) {
1164
1169
  this._value = value;
1165
1170
  if (this.onChange) {