diff --git a/projects/demo/src/pages/documentation/plugins/examples/4-change-event/component.ts b/projects/demo/src/pages/documentation/plugins/examples/4-change-event/component.ts new file mode 100644 index 000000000..5ee28e2d1 --- /dev/null +++ b/projects/demo/src/pages/documentation/plugins/examples/4-change-event/component.ts @@ -0,0 +1,31 @@ +import {ChangeDetectionStrategy, Component} from '@angular/core'; +import {FormsModule} from '@angular/forms'; +import {MaskitoDirective} from '@maskito/angular'; +import {TuiInputModule} from '@taiga-ui/kit'; + +import mask from './mask'; + +@Component({ + standalone: true, + selector: 'plugins-change-event-doc-example-4', + imports: [FormsModule, MaskitoDirective, TuiInputModule], + template: ` + + Enter number + + + + `, + changeDetection: ChangeDetectionStrategy.OnPush, +}) +export class PluginsDocExample4 { + protected readonly maskitoOptions = mask; + protected value = ''; +} diff --git a/projects/demo/src/pages/documentation/plugins/examples/4-change-event/mask.ts b/projects/demo/src/pages/documentation/plugins/examples/4-change-event/mask.ts new file mode 100644 index 000000000..e577b5d1f --- /dev/null +++ b/projects/demo/src/pages/documentation/plugins/examples/4-change-event/mask.ts @@ -0,0 +1,15 @@ +import type {MaskitoOptions} from '@maskito/core'; +import {maskitoChangeEventPlugin} from '@maskito/core'; +import {maskitoNumberOptionsGenerator} from '@maskito/kit'; + +const numberOptions = maskitoNumberOptionsGenerator({ + precision: 2, +}); + +export default { + ...numberOptions, + plugins: [ + ...numberOptions.plugins, + maskitoChangeEventPlugin(), // <--- Enable it + ], +} as MaskitoOptions; diff --git a/projects/demo/src/pages/documentation/plugins/plugins.component.ts b/projects/demo/src/pages/documentation/plugins/plugins.component.ts index a989b4f0d..16ac384ca 100644 --- a/projects/demo/src/pages/documentation/plugins/plugins.component.ts +++ b/projects/demo/src/pages/documentation/plugins/plugins.component.ts @@ -9,6 +9,7 @@ import {NextStepsComponent} from '../next-steps/next-steps.component'; import {PluginsDocExample1} from './examples/1-reject/component'; import {PluginsDocExample2} from './examples/2-initial-calibration/component'; import {PluginsDocExample3} from './examples/3-strict-composition/component'; +import {PluginsDocExample4} from './examples/4-change-event/component'; @Component({ standalone: true, @@ -22,6 +23,7 @@ import {PluginsDocExample3} from './examples/3-strict-composition/component'; PluginsDocExample1, PluginsDocExample2, PluginsDocExample3, + PluginsDocExample4, ], templateUrl: './plugins.template.html', changeDetection: ChangeDetectionStrategy.OnPush, @@ -47,4 +49,10 @@ export default class PluginsDocPageComponent { './examples/3-strict-composition/mask.ts?raw' ), }; + + protected readonly changeEventExample: TuiDocExample = { + [DocExamplePrimaryTab.MaskitoOptions]: import( + './examples/4-change-event/mask.ts?raw' + ), + }; } diff --git a/projects/demo/src/pages/documentation/plugins/plugins.template.html b/projects/demo/src/pages/documentation/plugins/plugins.template.html index c812da449..2a2de4e66 100644 --- a/projects/demo/src/pages/documentation/plugins/plugins.template.html +++ b/projects/demo/src/pages/documentation/plugins/plugins.template.html @@ -82,5 +82,44 @@ + + + Native + + beforeinput + + event default behavior is cancelled to process user entered invalid value. This causes native + + change + + event to + NOT + be dispatched by browser. A + change + event, as opposed to + input + , is triggered only when user left the field and value was changed during interaction. If you rely on this + behavior, add + maskitoChangeEventPlugin + to your mask configuration. It will dispatch synthetic + change + event using the same logic. + + + +