valtech-components 2.0.692 → 2.0.693
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.
|
@@ -110,7 +110,9 @@ export class RefresherComponent {
|
|
|
110
110
|
}
|
|
111
111
|
/** Handler para evento ionPull */
|
|
112
112
|
onIonPull(event) {
|
|
113
|
-
const detail = event
|
|
113
|
+
const detail = event?.detail;
|
|
114
|
+
if (!detail || typeof detail.progress !== 'number')
|
|
115
|
+
return;
|
|
114
116
|
const progress = Math.min(detail.progress, 1);
|
|
115
117
|
this.pullProgress.set(progress);
|
|
116
118
|
this.pullProgressChange.emit({
|
|
@@ -266,4 +268,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
266
268
|
}], stateChange: [{
|
|
267
269
|
type: Output
|
|
268
270
|
}] } });
|
|
269
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"refresher.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/refresher/refresher.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,KAAK,EACL,MAAM,EACN,YAAY,EACZ,MAAM,EACN,SAAS,EAET,YAAY,EACZ,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EACL,YAAY,EACZ,mBAAmB,EACnB,UAAU,EACV,OAAO,GACR,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAKL,0BAA0B,GAC3B,MAAM,SAAS,CAAC;;;AAEjB;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AA8EH,MAAM,OAAO,kBAAkB;IA7E/B;QAqFE,kCAAkC;QACzB,UAAK,GAAsB,EAAE,CAAC;QAEvC,iDAAiD;QACvC,YAAO,GAAG,IAAI,YAAY,EAAgB,CAAC;QAErD,yCAAyC;QAC/B,uBAAkB,GAAG,IAAI,YAAY,EAAoB,CAAC;QAEpE,iCAAiC;QACvB,gBAAW,GAAG,IAAI,YAAY,EAAkB,CAAC;QAEnD,SAAI,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAEnC,kCAAkC;QACzB,UAAK,GAAG,MAAM,CAAiB,MAAM,CAAC,CAAC;QAEhD,qCAAqC;QAC5B,iBAAY,GAAG,MAAM,CAAS,CAAC,CAAC,CAAC;KAiG3C;IA/FC,0CAA0C;IAC1C,cAAc;QACZ,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;IAChE,CAAC;IAED,6CAA6C;IAC7C,iBAAiB;QACf,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IAC7D,CAAC;IAED,oCAAoC;IACpC,IAAI,WAAW;QACb,OAAO;YACL,GAAG,0BAA0B;YAC7B,GAAG,IAAI,CAAC,KAAK;YACb,WAAW,EAAE,IAAI,CAAC,cAAc,EAAE;YAClC,cAAc,EAAE,IAAI,CAAC,iBAAiB,EAAE;SACzC,CAAC;IACJ,CAAC;IAED,wCAAwC;IACxC,IAAI,kBAAkB;QACpB,OAAO,CAAC,CAAC,CACP,IAAI,CAAC,gBAAgB;YACrB,IAAI,CAAC,mBAAmB;YACxB,IAAI,CAAC,mBAAmB;YACxB,IAAI,CAAC,KAAK,CAAC,eAAe,CAC3B,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,cAAc;QACZ,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAC7B,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,QAAQ;QACN,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAC7B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACpC,IAAI,CAAC,YAAY,EAAE,QAAQ,EAAE,CAAC;QAE9B,0CAA0C;QAC1C,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YACvB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAChC,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,aAAa,IAAI,GAAG,CAAC,CAAC;IAC5C,CAAC;IAED;;OAEG;IACH,MAAM;QACJ,IAAI,CAAC,YAAY,EAAE,MAAM,EAAE,CAAC;QAC5B,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACvB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAChC,CAAC;IAED,qCAAqC;IACrC,YAAY,CAAC,KAAkB;QAC7B,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAC7B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACpC,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,kCAAkC;IAClC,SAAS,CAAC,KAAkB;QAC1B,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;QAC9C,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAEhC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC;YAC3B,QAAQ;YACR,gBAAgB,EAAE,QAAQ,IAAI,CAAC;SAChC,CAAC,CAAC;IACL,CAAC;IAED,mCAAmC;IACnC,UAAU;QACR,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC1B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACnC,CAAC;IAEO,gBAAgB;QACtB,MAAM,KAAK,GAAiB;YAC1B,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE;YAC/B,MAAM,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE;YAC3B,SAAS,EAAE,IAAI,IAAI,EAAE;SACtB,CAAC;QACF,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;+GA1HU,kBAAkB;mGAAlB,kBAAkB,moBAzEnB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsDT,6OAvDS,YAAY,sMAAE,YAAY,iKAAE,mBAAmB,iJAAE,UAAU,yGAAE,OAAO;;4FA0EnE,kBAAkB;kBA7E9B,SAAS;+BACE,eAAe,cACb,IAAI,WACP,CAAC,YAAY,EAAE,YAAY,EAAE,mBAAmB,EAAE,UAAU,EAAE,OAAO,CAAC,YACrE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsDT;8BAoBuB,YAAY;sBAAnC,SAAS;uBAAC,WAAW;gBAGY,gBAAgB;sBAAjD,YAAY;uBAAC,kBAAkB;gBACK,mBAAmB;sBAAvD,YAAY;uBAAC,qBAAqB;gBACE,mBAAmB;sBAAvD,YAAY;uBAAC,qBAAqB;gBAG1B,KAAK;sBAAb,KAAK;gBAGI,OAAO;sBAAhB,MAAM;gBAGG,kBAAkB;sBAA3B,MAAM;gBAGG,WAAW;sBAApB,MAAM","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  signal,\n  ViewChild,\n  TemplateRef,\n  ContentChild,\n  inject,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport {\n  IonRefresher,\n  IonRefresherContent,\n  IonSpinner,\n  IonText,\n} from '@ionic/angular/standalone';\nimport { I18nService } from '../../../services/i18n';\nimport {\n  RefresherMetadata,\n  RefresherState,\n  RefreshEvent,\n  RefreshPullEvent,\n  DEFAULT_REFRESHER_METADATA,\n} from './types';\n\n/**\n * Componente de pull-to-refresh para movil y web.\n *\n * @example\n * <!-- Uso basico -->\n * <val-refresher\n *   [props]=\"{\n *     color: 'primary',\n *     pullingText: 'Arrastra para actualizar',\n *     refreshingText: 'Cargando...'\n *   }\"\n *   (refresh)=\"onRefresh($event)\"\n * >\n *   <ion-content>\n *     <!-- Contenido scrolleable -->\n *   </ion-content>\n * </val-refresher>\n *\n * @example\n * <!-- Con indicador personalizado -->\n * <val-refresher [props]=\"{ color: 'primary' }\" (refresh)=\"onRefresh($event)\">\n *   <ng-template #pullingIndicator let-progress=\"progress\">\n *     <div class=\"custom-indicator\">\n *       <ion-icon name=\"arrow-down\" [style.transform]=\"'rotate(' + progress * 180 + 'deg)'\"></ion-icon>\n *     </div>\n *   </ng-template>\n *   <ion-content>...</ion-content>\n * </val-refresher>\n */\n@Component({\n  selector: 'val-refresher',\n  standalone: true,\n  imports: [CommonModule, IonRefresher, IonRefresherContent, IonSpinner, IonText],\n  template: `\n    <ion-refresher\n      #refresher\n      slot=\"fixed\"\n      [disabled]=\"mergedProps.disabled\"\n      [pullMin]=\"mergedProps.pullThreshold\"\n      [pullMax]=\"mergedProps.pullMax\"\n      [pullFactor]=\"mergedProps.pullFactor\"\n      [snapbackDuration]=\"mergedProps.snapbackDuration\"\n      [closeDuration]=\"mergedProps.closeDuration\"\n      (ionRefresh)=\"onIonRefresh($event)\"\n      (ionPull)=\"onIonPull($event)\"\n      (ionStart)=\"onIonStart()\"\n    >\n      @if (hasCustomIndicator) {\n        <!-- Custom indicator templates -->\n        <div class=\"refresher-custom-content\">\n          @switch (state()) {\n            @case ('pulling') {\n              @if (pullingIndicator) {\n                <ng-container\n                  *ngTemplateOutlet=\"pullingIndicator; context: { progress: pullProgress() }\"\n                ></ng-container>\n              }\n            }\n            @case ('refreshing') {\n              @if (refreshingIndicator) {\n                <ng-container *ngTemplateOutlet=\"refreshingIndicator\"></ng-container>\n              } @else {\n                <ion-spinner [name]=\"mergedProps.spinnerType\" [color]=\"mergedProps.color\"></ion-spinner>\n                @if (mergedProps.refreshingText) {\n                  <ion-text [color]=\"mergedProps.color\">{{ mergedProps.refreshingText }}</ion-text>\n                }\n              }\n            }\n            @case ('completing') {\n              @if (completingIndicator) {\n                <ng-container *ngTemplateOutlet=\"completingIndicator\"></ng-container>\n              }\n            }\n          }\n        </div>\n      } @else {\n        <!-- Default Ionic refresher content -->\n        <ion-refresher-content\n          [pullingIcon]=\"mergedProps.spinnerType === 'crescent' ? 'chevron-down-circle-outline' : undefined\"\n          [pullingText]=\"mergedProps.pullingText\"\n          [refreshingSpinner]=\"mergedProps.spinnerType\"\n          [refreshingText]=\"mergedProps.refreshingText\"\n        ></ion-refresher-content>\n      }\n    </ion-refresher>\n\n    <ng-content></ng-content>\n  `,\n  styles: [\n    `\n      :host {\n        display: block;\n        position: relative;\n      }\n\n      .refresher-custom-content {\n        display: flex;\n        flex-direction: column;\n        align-items: center;\n        justify-content: center;\n        gap: 8px;\n        padding: 16px;\n      }\n    `,\n  ],\n})\nexport class RefresherComponent {\n  @ViewChild('refresher') ionRefresher!: IonRefresher;\n\n  /** Templates personalizados via content projection */\n  @ContentChild('pullingIndicator') pullingIndicator?: TemplateRef<{ progress: number }>;\n  @ContentChild('refreshingIndicator') refreshingIndicator?: TemplateRef<void>;\n  @ContentChild('completingIndicator') completingIndicator?: TemplateRef<void>;\n\n  /** Configuracion del refresher */\n  @Input() props: RefresherMetadata = {};\n\n  /** Evento emitido cuando se activa el refresh */\n  @Output() refresh = new EventEmitter<RefreshEvent>();\n\n  /** Evento de progreso durante el pull */\n  @Output() pullProgressChange = new EventEmitter<RefreshPullEvent>();\n\n  /** Evento de cambio de estado */\n  @Output() stateChange = new EventEmitter<RefresherState>();\n\n  private i18n = inject(I18nService);\n\n  /** Estado actual del refresher */\n  readonly state = signal<RefresherState>('idle');\n\n  /** Progreso actual del pull (0-1) */\n  readonly pullProgress = signal<number>(0);\n\n  /** Get pulling text with i18n fallback */\n  getPullingText(): string {\n    return this.props.pullingText || this.i18n.t('pullToRefresh');\n  }\n\n  /** Get refreshing text with i18n fallback */\n  getRefreshingText(): string {\n    return this.props.refreshingText || this.i18n.t('loading');\n  }\n\n  /** Props combinados con defaults */\n  get mergedProps(): RefresherMetadata {\n    return {\n      ...DEFAULT_REFRESHER_METADATA,\n      ...this.props,\n      pullingText: this.getPullingText(),\n      refreshingText: this.getRefreshingText(),\n    };\n  }\n\n  /** Si hay indicadores personalizados */\n  get hasCustomIndicator(): boolean {\n    return !!(\n      this.pullingIndicator ||\n      this.refreshingIndicator ||\n      this.completingIndicator ||\n      this.props.indicatorConfig\n    );\n  }\n\n  /**\n   * Activa programaticamente el refresh.\n   */\n  triggerRefresh(): void {\n    this.state.set('refreshing');\n    this.emitRefreshEvent();\n  }\n\n  /**\n   * Completa la operacion de refresh actual.\n   */\n  complete(): void {\n    this.state.set('completing');\n    this.stateChange.emit('completing');\n    this.ionRefresher?.complete();\n\n    // Resetear a idle despues de la animacion\n    setTimeout(() => {\n      this.state.set('idle');\n      this.stateChange.emit('idle');\n    }, this.mergedProps.closeDuration ?? 280);\n  }\n\n  /**\n   * Cancela la operacion de refresh actual.\n   */\n  cancel(): void {\n    this.ionRefresher?.cancel();\n    this.state.set('idle');\n    this.stateChange.emit('idle');\n  }\n\n  /** Handler para evento ionRefresh */\n  onIonRefresh(event: CustomEvent): void {\n    this.state.set('refreshing');\n    this.stateChange.emit('refreshing');\n    this.emitRefreshEvent();\n  }\n\n  /** Handler para evento ionPull */\n  onIonPull(event: CustomEvent): void {\n    const detail = event.detail;\n    const progress = Math.min(detail.progress, 1);\n    this.pullProgress.set(progress);\n\n    this.pullProgressChange.emit({\n      progress,\n      thresholdReached: progress >= 1,\n    });\n  }\n\n  /** Handler para evento ionStart */\n  onIonStart(): void {\n    this.state.set('pulling');\n    this.stateChange.emit('pulling');\n  }\n\n  private emitRefreshEvent(): void {\n    const event: RefreshEvent = {\n      complete: () => this.complete(),\n      cancel: () => this.cancel(),\n      timestamp: new Date(),\n    };\n    this.refresh.emit(event);\n  }\n}\n"]}
|
|
271
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"refresher.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/refresher/refresher.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  signal,\n  ViewChild,\n  TemplateRef,\n  ContentChild,\n  inject,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport {\n  IonRefresher,\n  IonRefresherContent,\n  IonSpinner,\n  IonText,\n} from '@ionic/angular/standalone';\nimport { I18nService } from '../../../services/i18n';\nimport {\n  RefresherMetadata,\n  RefresherState,\n  RefreshEvent,\n  RefreshPullEvent,\n  DEFAULT_REFRESHER_METADATA,\n} from './types';\n\n/**\n * Componente de pull-to-refresh para movil y web.\n *\n * @example\n * <!-- Uso basico -->\n * <val-refresher\n *   [props]=\"{\n *     color: 'primary',\n *     pullingText: 'Arrastra para actualizar',\n *     refreshingText: 'Cargando...'\n *   }\"\n *   (refresh)=\"onRefresh($event)\"\n * >\n *   <ion-content>\n *     <!-- Contenido scrolleable -->\n *   </ion-content>\n * </val-refresher>\n *\n * @example\n * <!-- Con indicador personalizado -->\n * <val-refresher [props]=\"{ color: 'primary' }\" (refresh)=\"onRefresh($event)\">\n *   <ng-template #pullingIndicator let-progress=\"progress\">\n *     <div class=\"custom-indicator\">\n *       <ion-icon name=\"arrow-down\" [style.transform]=\"'rotate(' + progress * 180 + 'deg)'\"></ion-icon>\n *     </div>\n *   </ng-template>\n *   <ion-content>...</ion-content>\n * </val-refresher>\n */\n@Component({\n  selector: 'val-refresher',\n  standalone: true,\n  imports: [CommonModule, IonRefresher, IonRefresherContent, IonSpinner, IonText],\n  template: `\n    <ion-refresher\n      #refresher\n      slot=\"fixed\"\n      [disabled]=\"mergedProps.disabled\"\n      [pullMin]=\"mergedProps.pullThreshold\"\n      [pullMax]=\"mergedProps.pullMax\"\n      [pullFactor]=\"mergedProps.pullFactor\"\n      [snapbackDuration]=\"mergedProps.snapbackDuration\"\n      [closeDuration]=\"mergedProps.closeDuration\"\n      (ionRefresh)=\"onIonRefresh($event)\"\n      (ionPull)=\"onIonPull($event)\"\n      (ionStart)=\"onIonStart()\"\n    >\n      @if (hasCustomIndicator) {\n        <!-- Custom indicator templates -->\n        <div class=\"refresher-custom-content\">\n          @switch (state()) {\n            @case ('pulling') {\n              @if (pullingIndicator) {\n                <ng-container\n                  *ngTemplateOutlet=\"pullingIndicator; context: { progress: pullProgress() }\"\n                ></ng-container>\n              }\n            }\n            @case ('refreshing') {\n              @if (refreshingIndicator) {\n                <ng-container *ngTemplateOutlet=\"refreshingIndicator\"></ng-container>\n              } @else {\n                <ion-spinner [name]=\"mergedProps.spinnerType\" [color]=\"mergedProps.color\"></ion-spinner>\n                @if (mergedProps.refreshingText) {\n                  <ion-text [color]=\"mergedProps.color\">{{ mergedProps.refreshingText }}</ion-text>\n                }\n              }\n            }\n            @case ('completing') {\n              @if (completingIndicator) {\n                <ng-container *ngTemplateOutlet=\"completingIndicator\"></ng-container>\n              }\n            }\n          }\n        </div>\n      } @else {\n        <!-- Default Ionic refresher content -->\n        <ion-refresher-content\n          [pullingIcon]=\"mergedProps.spinnerType === 'crescent' ? 'chevron-down-circle-outline' : undefined\"\n          [pullingText]=\"mergedProps.pullingText\"\n          [refreshingSpinner]=\"mergedProps.spinnerType\"\n          [refreshingText]=\"mergedProps.refreshingText\"\n        ></ion-refresher-content>\n      }\n    </ion-refresher>\n\n    <ng-content></ng-content>\n  `,\n  styles: [\n    `\n      :host {\n        display: block;\n        position: relative;\n      }\n\n      .refresher-custom-content {\n        display: flex;\n        flex-direction: column;\n        align-items: center;\n        justify-content: center;\n        gap: 8px;\n        padding: 16px;\n      }\n    `,\n  ],\n})\nexport class RefresherComponent {\n  @ViewChild('refresher') ionRefresher!: IonRefresher;\n\n  /** Templates personalizados via content projection */\n  @ContentChild('pullingIndicator') pullingIndicator?: TemplateRef<{ progress: number }>;\n  @ContentChild('refreshingIndicator') refreshingIndicator?: TemplateRef<void>;\n  @ContentChild('completingIndicator') completingIndicator?: TemplateRef<void>;\n\n  /** Configuracion del refresher */\n  @Input() props: RefresherMetadata = {};\n\n  /** Evento emitido cuando se activa el refresh */\n  @Output() refresh = new EventEmitter<RefreshEvent>();\n\n  /** Evento de progreso durante el pull */\n  @Output() pullProgressChange = new EventEmitter<RefreshPullEvent>();\n\n  /** Evento de cambio de estado */\n  @Output() stateChange = new EventEmitter<RefresherState>();\n\n  private i18n = inject(I18nService);\n\n  /** Estado actual del refresher */\n  readonly state = signal<RefresherState>('idle');\n\n  /** Progreso actual del pull (0-1) */\n  readonly pullProgress = signal<number>(0);\n\n  /** Get pulling text with i18n fallback */\n  getPullingText(): string {\n    return this.props.pullingText || this.i18n.t('pullToRefresh');\n  }\n\n  /** Get refreshing text with i18n fallback */\n  getRefreshingText(): string {\n    return this.props.refreshingText || this.i18n.t('loading');\n  }\n\n  /** Props combinados con defaults */\n  get mergedProps(): RefresherMetadata {\n    return {\n      ...DEFAULT_REFRESHER_METADATA,\n      ...this.props,\n      pullingText: this.getPullingText(),\n      refreshingText: this.getRefreshingText(),\n    };\n  }\n\n  /** Si hay indicadores personalizados */\n  get hasCustomIndicator(): boolean {\n    return !!(\n      this.pullingIndicator ||\n      this.refreshingIndicator ||\n      this.completingIndicator ||\n      this.props.indicatorConfig\n    );\n  }\n\n  /**\n   * Activa programaticamente el refresh.\n   */\n  triggerRefresh(): void {\n    this.state.set('refreshing');\n    this.emitRefreshEvent();\n  }\n\n  /**\n   * Completa la operacion de refresh actual.\n   */\n  complete(): void {\n    this.state.set('completing');\n    this.stateChange.emit('completing');\n    this.ionRefresher?.complete();\n\n    // Resetear a idle despues de la animacion\n    setTimeout(() => {\n      this.state.set('idle');\n      this.stateChange.emit('idle');\n    }, this.mergedProps.closeDuration ?? 280);\n  }\n\n  /**\n   * Cancela la operacion de refresh actual.\n   */\n  cancel(): void {\n    this.ionRefresher?.cancel();\n    this.state.set('idle');\n    this.stateChange.emit('idle');\n  }\n\n  /** Handler para evento ionRefresh */\n  onIonRefresh(event: CustomEvent): void {\n    this.state.set('refreshing');\n    this.stateChange.emit('refreshing');\n    this.emitRefreshEvent();\n  }\n\n  /** Handler para evento ionPull */\n  onIonPull(event: CustomEvent): void {\n    const detail = event?.detail;\n    if (!detail || typeof detail.progress !== 'number') return;\n\n    const progress = Math.min(detail.progress, 1);\n    this.pullProgress.set(progress);\n\n    this.pullProgressChange.emit({\n      progress,\n      thresholdReached: progress >= 1,\n    });\n  }\n\n  /** Handler para evento ionStart */\n  onIonStart(): void {\n    this.state.set('pulling');\n    this.stateChange.emit('pulling');\n  }\n\n  private emitRefreshEvent(): void {\n    const event: RefreshEvent = {\n      complete: () => this.complete(),\n      cancel: () => this.cancel(),\n      timestamp: new Date(),\n    };\n    this.refresh.emit(event);\n  }\n}\n"]}
|
package/esm2022/lib/version.mjs
CHANGED
|
@@ -2,5 +2,5 @@
|
|
|
2
2
|
* Current version of valtech-components.
|
|
3
3
|
* This is automatically updated during the publish process.
|
|
4
4
|
*/
|
|
5
|
-
export const VERSION = '2.0.
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
export const VERSION = '2.0.693';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7O0dBR0c7QUFDSCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDdXJyZW50IHZlcnNpb24gb2YgdmFsdGVjaC1jb21wb25lbnRzLlxuICogVGhpcyBpcyBhdXRvbWF0aWNhbGx5IHVwZGF0ZWQgZHVyaW5nIHRoZSBwdWJsaXNoIHByb2Nlc3MuXG4gKi9cbmV4cG9ydCBjb25zdCBWRVJTSU9OID0gJzIuMC42OTMnO1xuIl19
|
|
@@ -50,7 +50,7 @@ import 'prismjs/components/prism-json';
|
|
|
50
50
|
* Current version of valtech-components.
|
|
51
51
|
* This is automatically updated during the publish process.
|
|
52
52
|
*/
|
|
53
|
-
const VERSION = '2.0.
|
|
53
|
+
const VERSION = '2.0.693';
|
|
54
54
|
|
|
55
55
|
/**
|
|
56
56
|
* Servicio para gestionar presets de componentes.
|
|
@@ -18138,7 +18138,9 @@ class RefresherComponent {
|
|
|
18138
18138
|
}
|
|
18139
18139
|
/** Handler para evento ionPull */
|
|
18140
18140
|
onIonPull(event) {
|
|
18141
|
-
const detail = event
|
|
18141
|
+
const detail = event?.detail;
|
|
18142
|
+
if (!detail || typeof detail.progress !== 'number')
|
|
18143
|
+
return;
|
|
18142
18144
|
const progress = Math.min(detail.progress, 1);
|
|
18143
18145
|
this.pullProgress.set(progress);
|
|
18144
18146
|
this.pullProgressChange.emit({
|