File

src/modules/input-mask-directives/directives/text-mask.directive.ts

Description

Directive to display a mask in input elements. This directive internally uses the text-mask-core library to provide the input mask functionality.

IMPORTANT: Currently the Text Mask supports only input of type text, tel, url, password, and search. Due to a limitation in browser API, other input types, such as email or number, cannot be supported.

Disabling the mask

Passing an undefined value as config or a config object with mask: false will disable the mask.

Example :
<input type="text" [starkTextMask]="yourMaskConfig">
<!-- or -->
<input type="text" [(ngModel)]="yourModelValue" [starkTextMask]="yourMaskConfig">
<!-- or -->
<input type="text" [formControl]="yourFormControl" [starkTextMask]="yourMaskConfig">

Extends

MaskedInputDirective

Implements

OnChanges

Metadata

Index

Properties
Methods
Inputs

Constructor

Public constructor(_renderer: Renderer2, _elementRef: ElementRef, _compositionMode: boolean)

Class constructor

Parameters :
Name Type Optional Description
_renderer Renderer2 No
  • Angular Renderer2 wrapper for DOM manipulations.
_elementRef ElementRef No
  • Reference to the DOM element where this directive is applied to.
_compositionMode boolean No
  • Injected token to control if form directives buffer IME input until the "compositionend" event occurs.

Inputs

starkTextMask
Type : StarkTextMaskConfig
Default value : { mask: false }

Configuration object for the mask to be displayed in the input field.

Methods

Public ngOnChanges
ngOnChanges(changes: SimpleChanges)

Component lifecycle hook

Parameters :
Name Type Optional Description
changes SimpleChanges No
  • Contains the changed properties
Returns : void
Public normalizeMaskConfig
normalizeMaskConfig(maskConfig: StarkTextMaskConfig)

Create a valid configuration to be passed to the MaskedInputDirective

Parameters :
Name Type Optional Description
maskConfig StarkTextMaskConfig No
  • The provided configuration via the directive's input
Returns : Ng2TextMaskConfig

Properties

Private Readonly defaultTextMaskConfig
Type : StarkTextMaskConfig
Default value : { mask: false, // by default the mask is disabled guide: true, placeholderChar: "_", keepCharPositions: true }

Default configuration. It will be merged with the configuration passed to the directive.

import { Directive, ElementRef, forwardRef, Inject, Input, OnChanges, Optional, Provider, Renderer2, SimpleChanges } from "@angular/core";
import { COMPOSITION_BUFFER_MODE, NG_VALUE_ACCESSOR } from "@angular/forms";
import { MaskedInputDirective, TextMaskConfig as Ng2TextMaskConfig } from "angular2-text-mask";
import { StarkTextMaskConfig } from "./text-mask-config.intf";

/**
 * @ignore
 */
const directiveName = "[starkTextMask]";

/**
 * @ignore
 */
export const STARK_TEXT_MASK_VALUE_ACCESSOR: Provider = {
	provide: NG_VALUE_ACCESSOR,
	// eslint-disable-next-line @angular-eslint/no-forward-ref
	useExisting: forwardRef(() => StarkTextMaskDirective),
	multi: true
};

/**
 * Directive to display a mask in input elements. This directive internally uses the {@link https://github.com/text-mask/text-mask/tree/master/core|text-mask-core} library
 * to provide the input mask functionality.
 *
 * **`IMPORTANT:`** Currently the Text Mask supports only input of type text, tel, url, password, and search.
 * Due to a limitation in browser API, other input types, such as email or number, cannot be supported.
 *
 * ### Disabling the mask
 * Passing an `undefined` value as config or a config object with `mask: false` will disable the mask.
 *
 * @example
 * <input type="text" [starkTextMask]="yourMaskConfig">
 * <!-- or -->
 * <input type="text" [(ngModel)]="yourModelValue" [starkTextMask]="yourMaskConfig">
 * <!-- or -->
 * <input type="text" [formControl]="yourFormControl" [starkTextMask]="yourMaskConfig">
 *
 */
@Directive({
	host: {
		"(input)": "_handleInput($event.target.value)",
		"(blur)": "onTouched()",
		"(compositionstart)": "_compositionStart()",
		"(compositionend)": "_compositionEnd($event.target.value)"
	},
	selector: directiveName,
	exportAs: "starkTextMask",
	providers: [STARK_TEXT_MASK_VALUE_ACCESSOR]
})
export class StarkTextMaskDirective extends MaskedInputDirective implements OnChanges {
	/**
	 * Configuration object for the mask to be displayed in the input field.
	 */
	/* eslint-disable @angular-eslint/no-input-rename */
	@Input("starkTextMask")
	public maskConfig: StarkTextMaskConfig = { mask: false };

	/**
	 * @ignore
	 */
	private elementRef: ElementRef;

	/**
	 * Default configuration.
	 * It will be merged with the configuration passed to the directive.
	 */
	private readonly defaultTextMaskConfig: StarkTextMaskConfig = {
		mask: false, // by default the mask is disabled
		guide: true,
		placeholderChar: "_",
		keepCharPositions: true
	};

	/**
	 * Class constructor
	 * @param _renderer - Angular `Renderer2` wrapper for DOM manipulations.
	 * @param _elementRef - Reference to the DOM element where this directive is applied to.
	 * @param _compositionMode - Injected token to control if form directives buffer IME input until the "compositionend" event occurs.
	 */
	public constructor(
		_renderer: Renderer2,
		_elementRef: ElementRef,
		@Optional() @Inject(COMPOSITION_BUFFER_MODE) _compositionMode: boolean
	) {
		super(_renderer, _elementRef, _compositionMode);
		this.elementRef = _elementRef;
	}

	/**
	 * Component lifecycle hook
	 * @param changes - Contains the changed properties
	 */
	public override ngOnChanges(changes: SimpleChanges): void {
		this.textMaskConfig = this.normalizeMaskConfig(this.maskConfig);

		super.ngOnChanges(changes);

		// TODO: temporary workaround to update the model when the maskConfig changes since this is not yet implemented in text-mask and still being discussed
		// see: https://github.com/text-mask/text-mask/issues/657
		if (changes["maskConfig"] && !changes["maskConfig"].isFirstChange() && this.textMaskConfig.mask !== false) {
			// trigger a dummy "input" event in the input to trigger the changes in the model (only if the mask was not disabled!)
			const ev: Event = document.createEvent("Event");
			ev.initEvent("input", true, true);
			(<HTMLInputElement>this.elementRef.nativeElement).dispatchEvent(ev);
		}
	}

	/**
	 * Create a valid configuration to be passed to the MaskedInputDirective
	 * @param maskConfig - The provided configuration via the directive's input
	 */
	public normalizeMaskConfig(maskConfig: StarkTextMaskConfig): Ng2TextMaskConfig {
		// TODO: Ng2TextMaskConfig is not the same as Core TextMaskConfig
		return { ...this.defaultTextMaskConfig, ...(<any>maskConfig) };
	}
}

results matching ""

    No results matching ""