diff --git a/src/material/paginator/paginator.ts b/src/material/paginator/paginator.ts index 914da7564f27..4ee738dc9ed1 100644 --- a/src/material/paginator/paginator.ts +++ b/src/material/paginator/paginator.ts @@ -22,12 +22,12 @@ import { booleanAttribute, numberAttribute, } from '@angular/core'; -import {MatFormField, MatFormFieldAppearance} from '@angular/material/form-field'; -import {HasInitialized, MatOption, mixinInitialized, ThemePalette} from '@angular/material/core'; +import {MatOption, ThemePalette} from '@angular/material/core'; import {MatSelect} from '@angular/material/select'; import {MatIconButton} from '@angular/material/button'; import {MatTooltip} from '@angular/material/tooltip'; -import {Subscription} from 'rxjs'; +import {MatFormField, MatFormFieldAppearance} from '@angular/material/form-field'; +import {Observable, ReplaySubject, Subscription} from 'rxjs'; import {MatPaginatorIntl} from './paginator-intl'; /** The default page size if there is no page size and there are no provided page size options. */ @@ -90,10 +90,6 @@ export const MAT_PAGINATOR_DEFAULT_OPTIONS = new InjectionToken(1); /** Theme color to be used for the underlying form controls. */ @Input() color: ThemePalette; @@ -196,12 +190,14 @@ export class MatPaginator /** Displayed set of page size options. Will be sorted and include current page size. */ _displayedPageSizeOptions: number[]; + /** Emits when the paginator is initialized. */ + initialized: Observable = this._initializedStream; + constructor( public _intl: MatPaginatorIntl, private _changeDetectorRef: ChangeDetectorRef, @Optional() @Inject(MAT_PAGINATOR_DEFAULT_OPTIONS) defaults?: MatPaginatorDefaultOptions, ) { - super(); this._intlChanges = _intl.changes.subscribe(() => this._changeDetectorRef.markForCheck()); if (defaults) { @@ -228,12 +224,13 @@ export class MatPaginator } ngOnInit() { - this._initialized = true; + this._isInitialized = true; this._updateDisplayedPageSizeOptions(); - this._markInitialized(); + this._initializedStream.next(); } ngOnDestroy() { + this._initializedStream.complete(); this._intlChanges.unsubscribe(); } @@ -337,7 +334,7 @@ export class MatPaginator * the page size is an option and that the list is sorted. */ private _updateDisplayedPageSizeOptions() { - if (!this._initialized) { + if (!this._isInitialized) { return; } diff --git a/tools/public_api_guard/material/paginator.md b/tools/public_api_guard/material/paginator.md index 41d346f2fce4..7fb1f2751433 100644 --- a/tools/public_api_guard/material/paginator.md +++ b/tools/public_api_guard/material/paginator.md @@ -6,13 +6,13 @@ import { ChangeDetectorRef } from '@angular/core'; import { EventEmitter } from '@angular/core'; -import { HasInitialized } from '@angular/material/core'; import * as i0 from '@angular/core'; import * as i1 from '@angular/material/button'; import * as i2 from '@angular/material/select'; import * as i3 from '@angular/material/tooltip'; import { InjectionToken } from '@angular/core'; import { MatFormFieldAppearance } from '@angular/material/form-field'; +import { Observable } from 'rxjs'; import { OnDestroy } from '@angular/core'; import { OnInit } from '@angular/core'; import { Optional } from '@angular/core'; @@ -33,7 +33,7 @@ export const MAT_PAGINATOR_INTL_PROVIDER: { export function MAT_PAGINATOR_INTL_PROVIDER_FACTORY(parentIntl: MatPaginatorIntl): MatPaginatorIntl; // @public -export class MatPaginator extends _MatPaginatorMixinBase implements OnInit, OnDestroy, HasInitialized { +export class MatPaginator implements OnInit, OnDestroy { constructor(_intl: MatPaginatorIntl, _changeDetectorRef: ChangeDetectorRef, defaults?: MatPaginatorDefaultOptions); _changePageSize(pageSize: number): void; color: ThemePalette; @@ -45,6 +45,7 @@ export class MatPaginator extends _MatPaginatorMixinBase implements OnInit, OnDe hasNextPage(): boolean; hasPreviousPage(): boolean; hidePageSize: boolean; + initialized: Observable; // (undocumented) _intl: MatPaginatorIntl; lastPage(): void;