1 | import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
2 | import { BACKSPACE, DELETE, SPACE } from '@angular/cdk/keycodes';
|
3 | import { Platform } from '@angular/cdk/platform';
|
4 | import { DOCUMENT } from '@angular/common';
|
5 | import { Attribute, ChangeDetectorRef, ContentChild, Directive, ElementRef, EventEmitter, Inject, InjectionToken, Input, NgZone, Optional, Output, } from '@angular/core';
|
6 | import { MAT_RIPPLE_GLOBAL_OPTIONS, mixinColor, mixinDisableRipple, mixinTabIndex, RippleRenderer, } from '@angular/material/core';
|
7 | import { ANIMATION_MODULE_TYPE } from '@angular/platform-browser/animations';
|
8 | import { Subject } from 'rxjs';
|
9 | import { take } from 'rxjs/operators';
|
10 | import * as i0 from "@angular/core";
|
11 | import * as i1 from "@angular/cdk/platform";
|
12 | /** Event object emitted by MatChip when selected or deselected. */
|
13 | export class MatChipSelectionChange {
|
14 | constructor(
|
15 | /** Reference to the chip that emitted the event. */
|
16 | source,
|
17 | /** Whether the chip that emitted the event is selected. */
|
18 | selected,
|
19 | /** Whether the selection change was a result of a user interaction. */
|
20 | isUserInput = false) {
|
21 | this.source = source;
|
22 | this.selected = selected;
|
23 | this.isUserInput = isUserInput;
|
24 | }
|
25 | }
|
26 | /**
|
27 | * Injection token that can be used to reference instances of `MatChipRemove`. It serves as
|
28 | * alternative token to the actual `MatChipRemove` class which could cause unnecessary
|
29 | * retention of the class and its directive metadata.
|
30 | */
|
31 | export const MAT_CHIP_REMOVE = new InjectionToken('MatChipRemove');
|
32 | /**
|
33 | * Injection token that can be used to reference instances of `MatChipAvatar`. It serves as
|
34 | * alternative token to the actual `MatChipAvatar` class which could cause unnecessary
|
35 | * retention of the class and its directive metadata.
|
36 | */
|
37 | export const MAT_CHIP_AVATAR = new InjectionToken('MatChipAvatar');
|
38 | /**
|
39 | * Injection token that can be used to reference instances of `MatChipTrailingIcon`. It serves as
|
40 | * alternative token to the actual `MatChipTrailingIcon` class which could cause unnecessary
|
41 | * retention of the class and its directive metadata.
|
42 | */
|
43 | export const MAT_CHIP_TRAILING_ICON = new InjectionToken('MatChipTrailingIcon');
|
44 | // Boilerplate for applying mixins to MatChip.
|
45 | /** @docs-private */
|
46 | class MatChipBase {
|
47 | constructor(_elementRef) {
|
48 | this._elementRef = _elementRef;
|
49 | }
|
50 | }
|
51 | const _MatChipMixinBase = mixinTabIndex(mixinColor(mixinDisableRipple(MatChipBase), 'primary'), -1);
|
52 | /**
|
53 | * Dummy directive to add CSS class to chip avatar.
|
54 | * @docs-private
|
55 | */
|
56 | export class MatChipAvatar {
|
57 | }
|
58 | MatChipAvatar.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: MatChipAvatar, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
59 | MatChipAvatar.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: MatChipAvatar, selector: "mat-chip-avatar, [matChipAvatar]", host: { classAttribute: "mat-chip-avatar" }, providers: [{ provide: MAT_CHIP_AVATAR, useExisting: MatChipAvatar }], ngImport: i0 });
|
60 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: MatChipAvatar, decorators: [{
|
61 | type: Directive,
|
62 | args: [{
|
63 | selector: 'mat-chip-avatar, [matChipAvatar]',
|
64 | host: { 'class': 'mat-chip-avatar' },
|
65 | providers: [{ provide: MAT_CHIP_AVATAR, useExisting: MatChipAvatar }],
|
66 | }]
|
67 | }] });
|
68 | /**
|
69 | * Dummy directive to add CSS class to chip trailing icon.
|
70 | * @docs-private
|
71 | */
|
72 | export class MatChipTrailingIcon {
|
73 | }
|
74 | MatChipTrailingIcon.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: MatChipTrailingIcon, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
75 | MatChipTrailingIcon.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: MatChipTrailingIcon, selector: "mat-chip-trailing-icon, [matChipTrailingIcon]", host: { classAttribute: "mat-chip-trailing-icon" }, providers: [{ provide: MAT_CHIP_TRAILING_ICON, useExisting: MatChipTrailingIcon }], ngImport: i0 });
|
76 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: MatChipTrailingIcon, decorators: [{
|
77 | type: Directive,
|
78 | args: [{
|
79 | selector: 'mat-chip-trailing-icon, [matChipTrailingIcon]',
|
80 | host: { 'class': 'mat-chip-trailing-icon' },
|
81 | providers: [{ provide: MAT_CHIP_TRAILING_ICON, useExisting: MatChipTrailingIcon }],
|
82 | }]
|
83 | }] });
|
84 | /** Material Design styled chip directive. Used inside the MatChipList component. */
|
85 | export class MatChip extends _MatChipMixinBase {
|
86 | constructor(elementRef, _ngZone, platform, globalRippleOptions, _changeDetectorRef, _document, animationMode, tabIndex) {
|
87 | super(elementRef);
|
88 | this._ngZone = _ngZone;
|
89 | this._changeDetectorRef = _changeDetectorRef;
|
90 | /** Whether the chip has focus. */
|
91 | this._hasFocus = false;
|
92 | /** Whether the chip list is selectable */
|
93 | this.chipListSelectable = true;
|
94 | /** Whether the chip list is in multi-selection mode. */
|
95 | this._chipListMultiple = false;
|
96 | /** Whether the chip list as a whole is disabled. */
|
97 | this._chipListDisabled = false;
|
98 | /** ARIA role that should be applied to the chip. */
|
99 | this.role = 'option';
|
100 | this._selected = false;
|
101 | this._selectable = true;
|
102 | this._disabled = false;
|
103 | this._removable = true;
|
104 | /** Emits when the chip is focused. */
|
105 | this._onFocus = new Subject();
|
106 | /** Emits when the chip is blured. */
|
107 | this._onBlur = new Subject();
|
108 | /** Emitted when the chip is selected or deselected. */
|
109 | this.selectionChange = new EventEmitter();
|
110 | /** Emitted when the chip is destroyed. */
|
111 | this.destroyed = new EventEmitter();
|
112 | /** Emitted when a chip is to be removed. */
|
113 | this.removed = new EventEmitter();
|
114 | this._addHostClassName();
|
115 | // Dynamically create the ripple target, append it within the chip, and use it as the
|
116 | // chip's ripple target. Adding the class '.mat-chip-ripple' ensures that it will have
|
117 | // the proper styles.
|
118 | this._chipRippleTarget = _document.createElement('div');
|
119 | this._chipRippleTarget.classList.add('mat-chip-ripple');
|
120 | this._elementRef.nativeElement.appendChild(this._chipRippleTarget);
|
121 | this._chipRipple = new RippleRenderer(this, _ngZone, this._chipRippleTarget, platform);
|
122 | this._chipRipple.setupTriggerEvents(elementRef);
|
123 | this.rippleConfig = globalRippleOptions || {};
|
124 | this._animationsDisabled = animationMode === 'NoopAnimations';
|
125 | this.tabIndex = tabIndex != null ? parseInt(tabIndex) || -1 : -1;
|
126 | }
|
127 | /**
|
128 | * Whether ripples are disabled on interaction
|
129 | * @docs-private
|
130 | */
|
131 | get rippleDisabled() {
|
132 | return (this.disabled ||
|
133 | this.disableRipple ||
|
134 | this._animationsDisabled ||
|
135 | !!this.rippleConfig.disabled);
|
136 | }
|
137 | /** Whether the chip is selected. */
|
138 | get selected() {
|
139 | return this._selected;
|
140 | }
|
141 | set selected(value) {
|
142 | const coercedValue = coerceBooleanProperty(value);
|
143 | if (coercedValue !== this._selected) {
|
144 | this._selected = coercedValue;
|
145 | this._dispatchSelectionChange();
|
146 | }
|
147 | }
|
148 | /** The value of the chip. Defaults to the content inside `<mat-chip>` tags. */
|
149 | get value() {
|
150 | return this._value !== undefined ? this._value : this._elementRef.nativeElement.textContent;
|
151 | }
|
152 | set value(value) {
|
153 | this._value = value;
|
154 | }
|
155 | /**
|
156 | * Whether or not the chip is selectable. When a chip is not selectable,
|
157 | * changes to its selected state are always ignored. By default a chip is
|
158 | * selectable, and it becomes non-selectable if its parent chip list is
|
159 | * not selectable.
|
160 | */
|
161 | get selectable() {
|
162 | return this._selectable && this.chipListSelectable;
|
163 | }
|
164 | set selectable(value) {
|
165 | this._selectable = coerceBooleanProperty(value);
|
166 | }
|
167 | /** Whether the chip is disabled. */
|
168 | get disabled() {
|
169 | return this._chipListDisabled || this._disabled;
|
170 | }
|
171 | set disabled(value) {
|
172 | this._disabled = coerceBooleanProperty(value);
|
173 | }
|
174 | /**
|
175 | * Determines whether or not the chip displays the remove styling and emits (removed) events.
|
176 | */
|
177 | get removable() {
|
178 | return this._removable;
|
179 | }
|
180 | set removable(value) {
|
181 | this._removable = coerceBooleanProperty(value);
|
182 | }
|
183 | /** The ARIA selected applied to the chip. */
|
184 | get ariaSelected() {
|
185 | // Remove the `aria-selected` when the chip is deselected in single-selection mode, because
|
186 | // it adds noise to NVDA users where "not selected" will be read out for each chip.
|
187 | return this.selectable && (this._chipListMultiple || this.selected)
|
188 | ? this.selected.toString()
|
189 | : null;
|
190 | }
|
191 | _addHostClassName() {
|
192 | const basicChipAttrName = 'mat-basic-chip';
|
193 | const element = this._elementRef.nativeElement;
|
194 | if (element.hasAttribute(basicChipAttrName) ||
|
195 | element.tagName.toLowerCase() === basicChipAttrName) {
|
196 | element.classList.add(basicChipAttrName);
|
197 | return;
|
198 | }
|
199 | else {
|
200 | element.classList.add('mat-standard-chip');
|
201 | }
|
202 | }
|
203 | ngOnDestroy() {
|
204 | this.destroyed.emit({ chip: this });
|
205 | this._chipRipple._removeTriggerEvents();
|
206 | }
|
207 | /** Selects the chip. */
|
208 | select() {
|
209 | if (!this._selected) {
|
210 | this._selected = true;
|
211 | this._dispatchSelectionChange();
|
212 | this._changeDetectorRef.markForCheck();
|
213 | }
|
214 | }
|
215 | /** Deselects the chip. */
|
216 | deselect() {
|
217 | if (this._selected) {
|
218 | this._selected = false;
|
219 | this._dispatchSelectionChange();
|
220 | this._changeDetectorRef.markForCheck();
|
221 | }
|
222 | }
|
223 | /** Select this chip and emit selected event */
|
224 | selectViaInteraction() {
|
225 | if (!this._selected) {
|
226 | this._selected = true;
|
227 | this._dispatchSelectionChange(true);
|
228 | this._changeDetectorRef.markForCheck();
|
229 | }
|
230 | }
|
231 | /** Toggles the current selected state of this chip. */
|
232 | toggleSelected(isUserInput = false) {
|
233 | this._selected = !this.selected;
|
234 | this._dispatchSelectionChange(isUserInput);
|
235 | this._changeDetectorRef.markForCheck();
|
236 | return this.selected;
|
237 | }
|
238 | /** Allows for programmatic focusing of the chip. */
|
239 | focus() {
|
240 | if (!this._hasFocus) {
|
241 | this._elementRef.nativeElement.focus();
|
242 | this._onFocus.next({ chip: this });
|
243 | }
|
244 | this._hasFocus = true;
|
245 | }
|
246 | /**
|
247 | * Allows for programmatic removal of the chip. Called by the MatChipList when the DELETE or
|
248 | * BACKSPACE keys are pressed.
|
249 | *
|
250 | * Informs any listeners of the removal request. Does not remove the chip from the DOM.
|
251 | */
|
252 | remove() {
|
253 | if (this.removable) {
|
254 | this.removed.emit({ chip: this });
|
255 | }
|
256 | }
|
257 | /** Handles click events on the chip. */
|
258 | _handleClick(event) {
|
259 | if (this.disabled) {
|
260 | event.preventDefault();
|
261 | }
|
262 | }
|
263 | /** Handle custom key presses. */
|
264 | _handleKeydown(event) {
|
265 | if (this.disabled) {
|
266 | return;
|
267 | }
|
268 | switch (event.keyCode) {
|
269 | case DELETE:
|
270 | case BACKSPACE:
|
271 | // If we are removable, remove the focused chip
|
272 | this.remove();
|
273 | // Always prevent so page navigation does not occur
|
274 | event.preventDefault();
|
275 | break;
|
276 | case SPACE:
|
277 | // If we are selectable, toggle the focused chip
|
278 | if (this.selectable) {
|
279 | this.toggleSelected(true);
|
280 | }
|
281 | // Always prevent space from scrolling the page since the list has focus
|
282 | event.preventDefault();
|
283 | break;
|
284 | }
|
285 | }
|
286 | _blur() {
|
287 | // When animations are enabled, Angular may end up removing the chip from the DOM a little
|
288 | // earlier than usual, causing it to be blurred and throwing off the logic in the chip list
|
289 | // that moves focus not the next item. To work around the issue, we defer marking the chip
|
290 | // as not focused until the next time the zone stabilizes.
|
291 | this._ngZone.onStable.pipe(take(1)).subscribe(() => {
|
292 | this._ngZone.run(() => {
|
293 | this._hasFocus = false;
|
294 | this._onBlur.next({ chip: this });
|
295 | });
|
296 | });
|
297 | }
|
298 | _dispatchSelectionChange(isUserInput = false) {
|
299 | this.selectionChange.emit({
|
300 | source: this,
|
301 | isUserInput,
|
302 | selected: this._selected,
|
303 | });
|
304 | }
|
305 | }
|
306 | MatChip.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: MatChip, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i1.Platform }, { token: MAT_RIPPLE_GLOBAL_OPTIONS, optional: true }, { token: i0.ChangeDetectorRef }, { token: DOCUMENT }, { token: ANIMATION_MODULE_TYPE, optional: true }, { token: 'tabindex', attribute: true }], target: i0.ɵɵFactoryTarget.Directive });
|
307 | MatChip.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: { color: "color", disableRipple: "disableRipple", tabIndex: "tabIndex", role: "role", selected: "selected", value: "value", selectable: "selectable", disabled: "disabled", removable: "removable" }, outputs: { selectionChange: "selectionChange", destroyed: "destroyed", removed: "removed" }, host: { listeners: { "click": "_handleClick($event)", "keydown": "_handleKeydown($event)", "focus": "focus()", "blur": "_blur()" }, properties: { "attr.tabindex": "disabled ? null : tabIndex", "attr.role": "role", "class.mat-chip-selected": "selected", "class.mat-chip-with-avatar": "avatar", "class.mat-chip-with-trailing-icon": "trailingIcon || removeIcon", "class.mat-chip-disabled": "disabled", "class._mat-animation-noopable": "_animationsDisabled", "attr.disabled": "disabled || null", "attr.aria-disabled": "disabled.toString()", "attr.aria-selected": "ariaSelected" }, classAttribute: "mat-chip mat-focus-indicator" }, queries: [{ propertyName: "avatar", first: true, predicate: MAT_CHIP_AVATAR, descendants: true }, { propertyName: "trailingIcon", first: true, predicate: MAT_CHIP_TRAILING_ICON, descendants: true }, { propertyName: "removeIcon", first: true, predicate: MAT_CHIP_REMOVE, descendants: true }], exportAs: ["matChip"], usesInheritance: true, ngImport: i0 });
|
308 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: MatChip, decorators: [{
|
309 | type: Directive,
|
310 | args: [{
|
311 | selector: `mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]`,
|
312 | inputs: ['color', 'disableRipple', 'tabIndex'],
|
313 | exportAs: 'matChip',
|
314 | host: {
|
315 | 'class': 'mat-chip mat-focus-indicator',
|
316 | '[attr.tabindex]': 'disabled ? null : tabIndex',
|
317 | '[attr.role]': 'role',
|
318 | '[class.mat-chip-selected]': 'selected',
|
319 | '[class.mat-chip-with-avatar]': 'avatar',
|
320 | '[class.mat-chip-with-trailing-icon]': 'trailingIcon || removeIcon',
|
321 | '[class.mat-chip-disabled]': 'disabled',
|
322 | '[class._mat-animation-noopable]': '_animationsDisabled',
|
323 | '[attr.disabled]': 'disabled || null',
|
324 | '[attr.aria-disabled]': 'disabled.toString()',
|
325 | '[attr.aria-selected]': 'ariaSelected',
|
326 | '(click)': '_handleClick($event)',
|
327 | '(keydown)': '_handleKeydown($event)',
|
328 | '(focus)': 'focus()',
|
329 | '(blur)': '_blur()',
|
330 | },
|
331 | }]
|
332 | }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i1.Platform }, { type: undefined, decorators: [{
|
333 | type: Optional
|
334 | }, {
|
335 | type: Inject,
|
336 | args: [MAT_RIPPLE_GLOBAL_OPTIONS]
|
337 | }] }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
|
338 | type: Inject,
|
339 | args: [DOCUMENT]
|
340 | }] }, { type: undefined, decorators: [{
|
341 | type: Optional
|
342 | }, {
|
343 | type: Inject,
|
344 | args: [ANIMATION_MODULE_TYPE]
|
345 | }] }, { type: undefined, decorators: [{
|
346 | type: Attribute,
|
347 | args: ['tabindex']
|
348 | }] }]; }, propDecorators: { avatar: [{
|
349 | type: ContentChild,
|
350 | args: [MAT_CHIP_AVATAR]
|
351 | }], trailingIcon: [{
|
352 | type: ContentChild,
|
353 | args: [MAT_CHIP_TRAILING_ICON]
|
354 | }], removeIcon: [{
|
355 | type: ContentChild,
|
356 | args: [MAT_CHIP_REMOVE]
|
357 | }], role: [{
|
358 | type: Input
|
359 | }], selected: [{
|
360 | type: Input
|
361 | }], value: [{
|
362 | type: Input
|
363 | }], selectable: [{
|
364 | type: Input
|
365 | }], disabled: [{
|
366 | type: Input
|
367 | }], removable: [{
|
368 | type: Input
|
369 | }], selectionChange: [{
|
370 | type: Output
|
371 | }], destroyed: [{
|
372 | type: Output
|
373 | }], removed: [{
|
374 | type: Output
|
375 | }] } });
|
376 | /**
|
377 | * Applies proper (click) support and adds styling for use with the Material Design "cancel" icon
|
378 | * available at https://material.io/icons/#ic_cancel.
|
379 | *
|
380 | * Example:
|
381 | *
|
382 | * `<mat-chip>
|
383 | * <mat-icon matChipRemove>cancel</mat-icon>
|
384 | * </mat-chip>`
|
385 | *
|
386 | * You *may* use a custom icon, but you may need to override the `mat-chip-remove` positioning
|
387 | * styles to properly center the icon within the chip.
|
388 | */
|
389 | export class MatChipRemove {
|
390 | constructor(_parentChip, elementRef) {
|
391 | this._parentChip = _parentChip;
|
392 | if (elementRef.nativeElement.nodeName === 'BUTTON') {
|
393 | elementRef.nativeElement.setAttribute('type', 'button');
|
394 | }
|
395 | }
|
396 | /** Calls the parent chip's public `remove()` method if applicable. */
|
397 | _handleClick(event) {
|
398 | const parentChip = this._parentChip;
|
399 | if (parentChip.removable && !parentChip.disabled) {
|
400 | parentChip.remove();
|
401 | }
|
402 | // We need to stop event propagation because otherwise the event will bubble up to the
|
403 | // form field and cause the `onContainerClick` method to be invoked. This method would then
|
404 | // reset the focused chip that has been focused after chip removal. Usually the parent
|
405 | // the parent click listener of the `MatChip` would prevent propagation, but it can happen
|
406 | // that the chip is being removed before the event bubbles up.
|
407 | event.stopPropagation();
|
408 | event.preventDefault();
|
409 | }
|
410 | }
|
411 | MatChipRemove.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: MatChipRemove, deps: [{ token: MatChip }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
412 | MatChipRemove.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.1", type: MatChipRemove, selector: "[matChipRemove]", host: { listeners: { "click": "_handleClick($event)" }, classAttribute: "mat-chip-remove mat-chip-trailing-icon" }, providers: [{ provide: MAT_CHIP_REMOVE, useExisting: MatChipRemove }], ngImport: i0 });
|
413 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.1", ngImport: i0, type: MatChipRemove, decorators: [{
|
414 | type: Directive,
|
415 | args: [{
|
416 | selector: '[matChipRemove]',
|
417 | host: {
|
418 | 'class': 'mat-chip-remove mat-chip-trailing-icon',
|
419 | '(click)': '_handleClick($event)',
|
420 | },
|
421 | providers: [{ provide: MAT_CHIP_REMOVE, useExisting: MatChipRemove }],
|
422 | }]
|
423 | }], ctorParameters: function () { return [{ type: MatChip }, { type: i0.ElementRef }]; } });
|
424 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chip.js","sourceRoot":"","sources":["../../../../../../src/material/chips/chip.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {FocusableOption} from '@angular/cdk/a11y';\nimport {BooleanInput, coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {BACKSPACE, DELETE, SPACE} from '@angular/cdk/keycodes';\nimport {Platform} from '@angular/cdk/platform';\nimport {DOCUMENT} from '@angular/common';\nimport {\n  Attribute,\n  ChangeDetectorRef,\n  ContentChild,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  InjectionToken,\n  Input,\n  NgZone,\n  OnDestroy,\n  Optional,\n  Output,\n} from '@angular/core';\nimport {\n  CanColor,\n  CanDisable,\n  CanDisableRipple,\n  HasTabIndex,\n  MAT_RIPPLE_GLOBAL_OPTIONS,\n  mixinColor,\n  mixinDisableRipple,\n  mixinTabIndex,\n  RippleConfig,\n  RippleGlobalOptions,\n  RippleRenderer,\n  RippleTarget,\n} from '@angular/material/core';\nimport {ANIMATION_MODULE_TYPE} from '@angular/platform-browser/animations';\nimport {Subject} from 'rxjs';\nimport {take} from 'rxjs/operators';\n\n/** Represents an event fired on an individual `mat-chip`. */\nexport interface MatChipEvent {\n  /** The chip the event was fired on. */\n  chip: MatChip;\n}\n\n/** Event object emitted by MatChip when selected or deselected. */\nexport class MatChipSelectionChange {\n  constructor(\n    /** Reference to the chip that emitted the event. */\n    public source: MatChip,\n    /** Whether the chip that emitted the event is selected. */\n    public selected: boolean,\n    /** Whether the selection change was a result of a user interaction. */\n    public isUserInput = false,\n  ) {}\n}\n\n/**\n * Injection token that can be used to reference instances of `MatChipRemove`. It serves as\n * alternative token to the actual `MatChipRemove` class which could cause unnecessary\n * retention of the class and its directive metadata.\n */\nexport const MAT_CHIP_REMOVE = new InjectionToken<MatChipRemove>('MatChipRemove');\n\n/**\n * Injection token that can be used to reference instances of `MatChipAvatar`. It serves as\n * alternative token to the actual `MatChipAvatar` class which could cause unnecessary\n * retention of the class and its directive metadata.\n */\nexport const MAT_CHIP_AVATAR = new InjectionToken<MatChipAvatar>('MatChipAvatar');\n\n/**\n * Injection token that can be used to reference instances of `MatChipTrailingIcon`. It serves as\n * alternative token to the actual `MatChipTrailingIcon` class which could cause unnecessary\n * retention of the class and its directive metadata.\n */\nexport const MAT_CHIP_TRAILING_ICON = new InjectionToken<MatChipTrailingIcon>(\n  'MatChipTrailingIcon',\n);\n\n// Boilerplate for applying mixins to MatChip.\n/** @docs-private */\nabstract class MatChipBase {\n  abstract disabled: boolean;\n  constructor(public _elementRef: ElementRef) {}\n}\n\nconst _MatChipMixinBase = mixinTabIndex(mixinColor(mixinDisableRipple(MatChipBase), 'primary'), -1);\n\n/**\n * Dummy directive to add CSS class to chip avatar.\n * @docs-private\n */\n@Directive({\n  selector: 'mat-chip-avatar, [matChipAvatar]',\n  host: {'class': 'mat-chip-avatar'},\n  providers: [{provide: MAT_CHIP_AVATAR, useExisting: MatChipAvatar}],\n})\nexport class MatChipAvatar {}\n\n/**\n * Dummy directive to add CSS class to chip trailing icon.\n * @docs-private\n */\n@Directive({\n  selector: 'mat-chip-trailing-icon, [matChipTrailingIcon]',\n  host: {'class': 'mat-chip-trailing-icon'},\n  providers: [{provide: MAT_CHIP_TRAILING_ICON, useExisting: MatChipTrailingIcon}],\n})\nexport class MatChipTrailingIcon {}\n\n/** Material Design styled chip directive. Used inside the MatChipList component. */\n@Directive({\n  selector: `mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]`,\n  inputs: ['color', 'disableRipple', 'tabIndex'],\n  exportAs: 'matChip',\n  host: {\n    'class': 'mat-chip mat-focus-indicator',\n    '[attr.tabindex]': 'disabled ? null : tabIndex',\n    '[attr.role]': 'role',\n    '[class.mat-chip-selected]': 'selected',\n    '[class.mat-chip-with-avatar]': 'avatar',\n    '[class.mat-chip-with-trailing-icon]': 'trailingIcon || removeIcon',\n    '[class.mat-chip-disabled]': 'disabled',\n    '[class._mat-animation-noopable]': '_animationsDisabled',\n    '[attr.disabled]': 'disabled || null',\n    '[attr.aria-disabled]': 'disabled.toString()',\n    '[attr.aria-selected]': 'ariaSelected',\n    '(click)': '_handleClick($event)',\n    '(keydown)': '_handleKeydown($event)',\n    '(focus)': 'focus()',\n    '(blur)': '_blur()',\n  },\n})\nexport class MatChip\n  extends _MatChipMixinBase\n  implements\n    FocusableOption,\n    OnDestroy,\n    CanColor,\n    CanDisableRipple,\n    RippleTarget,\n    HasTabIndex,\n    CanDisable\n{\n  /** Reference to the RippleRenderer for the chip. */\n  private _chipRipple: RippleRenderer;\n\n  /**\n   * Reference to the element that acts as the chip's ripple target. This element is\n   * dynamically added as a child node of the chip. The chip itself cannot be used as the\n   * ripple target because it must be the host of the focus indicator.\n   */\n  private _chipRippleTarget: HTMLElement;\n\n  /**\n   * Ripple configuration for ripples that are launched on pointer down. The ripple config\n   * is set to the global ripple options since we don't have any configurable options for\n   * the chip ripples.\n   * @docs-private\n   */\n  rippleConfig: RippleConfig & RippleGlobalOptions;\n\n  /**\n   * Whether ripples are disabled on interaction\n   * @docs-private\n   */\n  get rippleDisabled(): boolean {\n    return (\n      this.disabled ||\n      this.disableRipple ||\n      this._animationsDisabled ||\n      !!this.rippleConfig.disabled\n    );\n  }\n\n  /** Whether the chip has focus. */\n  _hasFocus: boolean = false;\n\n  /** Whether animations for the chip are enabled. */\n  _animationsDisabled: boolean;\n\n  /** Whether the chip list is selectable */\n  chipListSelectable: boolean = true;\n\n  /** Whether the chip list is in multi-selection mode. */\n  _chipListMultiple: boolean = false;\n\n  /** Whether the chip list as a whole is disabled. */\n  _chipListDisabled: boolean = false;\n\n  /** The chip avatar */\n  @ContentChild(MAT_CHIP_AVATAR) avatar: MatChipAvatar;\n\n  /** The chip's trailing icon. */\n  @ContentChild(MAT_CHIP_TRAILING_ICON) trailingIcon: MatChipTrailingIcon;\n\n  /** The chip's remove toggler. */\n  @ContentChild(MAT_CHIP_REMOVE) removeIcon: MatChipRemove;\n\n  /** ARIA role that should be applied to the chip. */\n  @Input() role: string = 'option';\n\n  /** Whether the chip is selected. */\n  @Input()\n  get selected(): boolean {\n    return this._selected;\n  }\n  set selected(value: BooleanInput) {\n    const coercedValue = coerceBooleanProperty(value);\n\n    if (coercedValue !== this._selected) {\n      this._selected = coercedValue;\n      this._dispatchSelectionChange();\n    }\n  }\n  protected _selected: boolean = false;\n\n  /** The value of the chip. Defaults to the content inside `<mat-chip>` tags. */\n  @Input()\n  get value(): any {\n    return this._value !== undefined ? this._value : this._elementRef.nativeElement.textContent;\n  }\n  set value(value: any) {\n    this._value = value;\n  }\n  protected _value: any;\n\n  /**\n   * Whether or not the chip is selectable. When a chip is not selectable,\n   * changes to its selected state are always ignored. By default a chip is\n   * selectable, and it becomes non-selectable if its parent chip list is\n   * not selectable.\n   */\n  @Input()\n  get selectable(): boolean {\n    return this._selectable && this.chipListSelectable;\n  }\n  set selectable(value: BooleanInput) {\n    this._selectable = coerceBooleanProperty(value);\n  }\n  protected _selectable: boolean = true;\n\n  /** Whether the chip is disabled. */\n  @Input()\n  get disabled(): boolean {\n    return this._chipListDisabled || this._disabled;\n  }\n  set disabled(value: BooleanInput) {\n    this._disabled = coerceBooleanProperty(value);\n  }\n  protected _disabled: boolean = false;\n\n  /**\n   * Determines whether or not the chip displays the remove styling and emits (removed) events.\n   */\n  @Input()\n  get removable(): boolean {\n    return this._removable;\n  }\n  set removable(value: BooleanInput) {\n    this._removable = coerceBooleanProperty(value);\n  }\n  protected _removable: boolean = true;\n\n  /** Emits when the chip is focused. */\n  readonly _onFocus = new Subject<MatChipEvent>();\n\n  /** Emits when the chip is blured. */\n  readonly _onBlur = new Subject<MatChipEvent>();\n\n  /** Emitted when the chip is selected or deselected. */\n  @Output() readonly selectionChange: EventEmitter<MatChipSelectionChange> =\n    new EventEmitter<MatChipSelectionChange>();\n\n  /** Emitted when the chip is destroyed. */\n  @Output() readonly destroyed: EventEmitter<MatChipEvent> = new EventEmitter<MatChipEvent>();\n\n  /** Emitted when a chip is to be removed. */\n  @Output() readonly removed: EventEmitter<MatChipEvent> = new EventEmitter<MatChipEvent>();\n\n  /** The ARIA selected applied to the chip. */\n  get ariaSelected(): string | null {\n    // Remove the `aria-selected` when the chip is deselected in single-selection mode, because\n    // it adds noise to NVDA users where \"not selected\" will be read out for each chip.\n    return this.selectable && (this._chipListMultiple || this.selected)\n      ? this.selected.toString()\n      : null;\n  }\n\n  constructor(\n    elementRef: ElementRef<HTMLElement>,\n    private _ngZone: NgZone,\n    platform: Platform,\n    @Optional()\n    @Inject(MAT_RIPPLE_GLOBAL_OPTIONS)\n    globalRippleOptions: RippleGlobalOptions | null,\n    private _changeDetectorRef: ChangeDetectorRef,\n    @Inject(DOCUMENT) _document: any,\n    @Optional() @Inject(ANIMATION_MODULE_TYPE) animationMode?: string,\n    @Attribute('tabindex') tabIndex?: string,\n  ) {\n    super(elementRef);\n\n    this._addHostClassName();\n\n    // Dynamically create the ripple target, append it within the chip, and use it as the\n    // chip's ripple target. Adding the class '.mat-chip-ripple' ensures that it will have\n    // the proper styles.\n    this._chipRippleTarget = _document.createElement('div');\n    this._chipRippleTarget.classList.add('mat-chip-ripple');\n    this._elementRef.nativeElement.appendChild(this._chipRippleTarget);\n    this._chipRipple = new RippleRenderer(this, _ngZone, this._chipRippleTarget, platform);\n    this._chipRipple.setupTriggerEvents(elementRef);\n\n    this.rippleConfig = globalRippleOptions || {};\n    this._animationsDisabled = animationMode === 'NoopAnimations';\n    this.tabIndex = tabIndex != null ? parseInt(tabIndex) || -1 : -1;\n  }\n\n  _addHostClassName() {\n    const basicChipAttrName = 'mat-basic-chip';\n    const element = this._elementRef.nativeElement as HTMLElement;\n\n    if (\n      element.hasAttribute(basicChipAttrName) ||\n      element.tagName.toLowerCase() === basicChipAttrName\n    ) {\n      element.classList.add(basicChipAttrName);\n      return;\n    } else {\n      element.classList.add('mat-standard-chip');\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyed.emit({chip: this});\n    this._chipRipple._removeTriggerEvents();\n  }\n\n  /** Selects the chip. */\n  select(): void {\n    if (!this._selected) {\n      this._selected = true;\n      this._dispatchSelectionChange();\n      this._changeDetectorRef.markForCheck();\n    }\n  }\n\n  /** Deselects the chip. */\n  deselect(): void {\n    if (this._selected) {\n      this._selected = false;\n      this._dispatchSelectionChange();\n      this._changeDetectorRef.markForCheck();\n    }\n  }\n\n  /** Select this chip and emit selected event */\n  selectViaInteraction(): void {\n    if (!this._selected) {\n      this._selected = true;\n      this._dispatchSelectionChange(true);\n      this._changeDetectorRef.markForCheck();\n    }\n  }\n\n  /** Toggles the current selected state of this chip. */\n  toggleSelected(isUserInput: boolean = false): boolean {\n    this._selected = !this.selected;\n    this._dispatchSelectionChange(isUserInput);\n    this._changeDetectorRef.markForCheck();\n    return this.selected;\n  }\n\n  /** Allows for programmatic focusing of the chip. */\n  focus(): void {\n    if (!this._hasFocus) {\n      this._elementRef.nativeElement.focus();\n      this._onFocus.next({chip: this});\n    }\n    this._hasFocus = true;\n  }\n\n  /**\n   * Allows for programmatic removal of the chip. Called by the MatChipList when the DELETE or\n   * BACKSPACE keys are pressed.\n   *\n   * Informs any listeners of the removal request. Does not remove the chip from the DOM.\n   */\n  remove(): void {\n    if (this.removable) {\n      this.removed.emit({chip: this});\n    }\n  }\n\n  /** Handles click events on the chip. */\n  _handleClick(event: Event) {\n    if (this.disabled) {\n      event.preventDefault();\n    }\n  }\n\n  /** Handle custom key presses. */\n  _handleKeydown(event: KeyboardEvent): void {\n    if (this.disabled) {\n      return;\n    }\n\n    switch (event.keyCode) {\n      case DELETE:\n      case BACKSPACE:\n        // If we are removable, remove the focused chip\n        this.remove();\n        // Always prevent so page navigation does not occur\n        event.preventDefault();\n        break;\n      case SPACE:\n        // If we are selectable, toggle the focused chip\n        if (this.selectable) {\n          this.toggleSelected(true);\n        }\n\n        // Always prevent space from scrolling the page since the list has focus\n        event.preventDefault();\n        break;\n    }\n  }\n\n  _blur(): void {\n    // When animations are enabled, Angular may end up removing the chip from the DOM a little\n    // earlier than usual, causing it to be blurred and throwing off the logic in the chip list\n    // that moves focus not the next item. To work around the issue, we defer marking the chip\n    // as not focused until the next time the zone stabilizes.\n    this._ngZone.onStable.pipe(take(1)).subscribe(() => {\n      this._ngZone.run(() => {\n        this._hasFocus = false;\n        this._onBlur.next({chip: this});\n      });\n    });\n  }\n\n  private _dispatchSelectionChange(isUserInput = false) {\n    this.selectionChange.emit({\n      source: this,\n      isUserInput,\n      selected: this._selected,\n    });\n  }\n}\n\n/**\n * Applies proper (click) support and adds styling for use with the Material Design \"cancel\" icon\n * available at https://material.io/icons/#ic_cancel.\n *\n * Example:\n *\n *     `<mat-chip>\n *       <mat-icon matChipRemove>cancel</mat-icon>\n *     </mat-chip>`\n *\n * You *may* use a custom icon, but you may need to override the `mat-chip-remove` positioning\n * styles to properly center the icon within the chip.\n */\n@Directive({\n  selector: '[matChipRemove]',\n  host: {\n    'class': 'mat-chip-remove mat-chip-trailing-icon',\n    '(click)': '_handleClick($event)',\n  },\n  providers: [{provide: MAT_CHIP_REMOVE, useExisting: MatChipRemove}],\n})\nexport class MatChipRemove {\n  constructor(protected _parentChip: MatChip, elementRef: ElementRef<HTMLElement>) {\n    if (elementRef.nativeElement.nodeName === 'BUTTON') {\n      elementRef.nativeElement.setAttribute('type', 'button');\n    }\n  }\n\n  /** Calls the parent chip's public `remove()` method if applicable. */\n  _handleClick(event: Event): void {\n    const parentChip = this._parentChip;\n\n    if (parentChip.removable && !parentChip.disabled) {\n      parentChip.remove();\n    }\n\n    // We need to stop event propagation because otherwise the event will bubble up to the\n    // form field and cause the `onContainerClick` method to be invoked. This method would then\n    // reset the focused chip that has been focused after chip removal. Usually the parent\n    // the parent click listener of the `MatChip` would prevent propagation, but it can happen\n    // that the chip is being removed before the event bubbles up.\n    event.stopPropagation();\n    event.preventDefault();\n  }\n}\n"]} |
\ | No newline at end of file |