/** * @license * Copyright Google LLC All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://angular.io/license */ import { BooleanInput, NumberInput } from '@angular/cdk/coercion'; import { ElementRef, AfterViewInit, DoCheck, OnDestroy, NgZone } from '@angular/core'; import { Platform } from '@angular/cdk/platform'; /** Directive to automatically resize a textarea to fit its content. */ export declare class CdkTextareaAutosize implements AfterViewInit, DoCheck, OnDestroy { private _elementRef; private _platform; private _ngZone; /** Keep track of the previous textarea value to avoid resizing when the value hasn't changed. */ private _previousValue?; private _initialHeight; private readonly _destroyed; private _minRows; private _maxRows; private _enabled; /** * Value of minRows as of last resize. If the minRows has decreased, the * height of the textarea needs to be recomputed to reflect the new minimum. The maxHeight * does not have the same problem because it does not affect the textarea's scrollHeight. */ private _previousMinRows; private _textareaElement; /** Minimum amount of rows in the textarea. */ get minRows(): number; set minRows(value: number); /** Maximum amount of rows in the textarea. */ get maxRows(): number; set maxRows(value: number); /** Whether autosizing is enabled or not */ get enabled(): boolean; set enabled(value: boolean); get placeholder(): string; set placeholder(value: string); /** Cached height of a textarea with a single row. */ private _cachedLineHeight; /** Cached height of a textarea with only the placeholder. */ private _cachedPlaceholderHeight?; /** Used to reference correct document/window */ protected _document?: Document; private _hasFocus; private _isViewInited; constructor(_elementRef: ElementRef, _platform: Platform, _ngZone: NgZone, /** @breaking-change 11.0.0 make document required */ document?: any); /** Sets the minimum height of the textarea as determined by minRows. */ _setMinHeight(): void; /** Sets the maximum height of the textarea as determined by maxRows. */ _setMaxHeight(): void; ngAfterViewInit(): void; ngOnDestroy(): void; /** * Cache the height of a single-row textarea if it has not already been cached. * * We need to know how large a single "row" of a textarea is in order to apply minRows and * maxRows. For the initial version, we will assume that the height of a single line in the * textarea does not ever change. */ private _cacheTextareaLineHeight; private _measureScrollHeight; private _cacheTextareaPlaceholderHeight; /** Handles `focus` and `blur` events. */ private _handleFocusEvent; ngDoCheck(): void; /** * Resize the textarea to fit its content. * @param force Whether to force a height recalculation. By default the height will be * recalculated only if the value changed since the last call. */ resizeToFitContent(force?: boolean): void; /** * Resets the textarea to its original size */ reset(): void; _noopInputHandler(): void; /** Access injected document if available or fallback to global document reference */ private _getDocument; /** Use defaultView of injected document if available or fallback to global window reference */ private _getWindow; /** * Scrolls a textarea to the caret position. On Firefox resizing the textarea will * prevent it from scrolling to the caret position. We need to re-set the selection * in order for it to scroll to the proper position. */ private _scrollToCaretPosition; static ngAcceptInputType_minRows: NumberInput; static ngAcceptInputType_maxRows: NumberInput; static ngAcceptInputType_enabled: BooleanInput; }