carbon-components-angular 5.53.0 → 5.54.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (210) hide show
  1. package/docs/documentation/components/Accordion.html +2 -2
  2. package/docs/documentation/components/AccordionItem.html +2 -2
  3. package/docs/documentation/components/ActionableNotification.html +2 -2
  4. package/docs/documentation/components/AlertModal.html +2 -2
  5. package/docs/documentation/components/BaseIconButton.html +2 -2
  6. package/docs/documentation/components/BaseNotification.html +2 -2
  7. package/docs/documentation/components/BaseTabHeader.html +2 -2
  8. package/docs/documentation/components/Breadcrumb.html +2 -2
  9. package/docs/documentation/components/BreadcrumbItemComponent.html +2 -2
  10. package/docs/documentation/components/ButtonSet.html +2 -2
  11. package/docs/documentation/components/Checkbox.html +2 -2
  12. package/docs/documentation/components/ClickableTile.html +2 -2
  13. package/docs/documentation/components/CodeSnippet.html +2 -2
  14. package/docs/documentation/components/ComboBox.html +2 -2
  15. package/docs/documentation/components/ContainedList.html +2 -2
  16. package/docs/documentation/components/ContainedListItem.html +2 -2
  17. package/docs/documentation/components/ContentSwitcher.html +2 -2
  18. package/docs/documentation/components/ContextMenuComponent.html +2 -2
  19. package/docs/documentation/components/ContextMenuDividerComponent.html +2 -2
  20. package/docs/documentation/components/ContextMenuGroupComponent.html +2 -2
  21. package/docs/documentation/components/ContextMenuItemComponent.html +2 -2
  22. package/docs/documentation/components/DatePicker.html +2 -2
  23. package/docs/documentation/components/DatePickerInput.html +2 -2
  24. package/docs/documentation/components/Dialog.html +2 -2
  25. package/docs/documentation/components/Documentation.html +2 -2
  26. package/docs/documentation/components/Dropdown.html +2 -2
  27. package/docs/documentation/components/DropdownList.html +2 -2
  28. package/docs/documentation/components/ExpandableTile.html +2 -2
  29. package/docs/documentation/components/FileComponent.html +2 -2
  30. package/docs/documentation/components/FileUploader.html +2 -2
  31. package/docs/documentation/components/Hamburger.html +2 -2
  32. package/docs/documentation/components/Header.html +2 -2
  33. package/docs/documentation/components/HeaderAction.html +2 -2
  34. package/docs/documentation/components/HeaderGlobal.html +2 -2
  35. package/docs/documentation/components/HeaderItem.html +2 -2
  36. package/docs/documentation/components/HeaderMenu.html +2 -2
  37. package/docs/documentation/components/HeaderNavigation.html +2 -2
  38. package/docs/documentation/components/IconButton.html +2 -2
  39. package/docs/documentation/components/InlineLoading.html +2 -2
  40. package/docs/documentation/components/Label.html +2 -2
  41. package/docs/documentation/components/ListColumn.html +2 -2
  42. package/docs/documentation/components/ListHeader.html +2 -2
  43. package/docs/documentation/components/ListRow.html +2 -2
  44. package/docs/documentation/components/Loading.html +2 -2
  45. package/docs/documentation/components/Modal.html +2 -2
  46. package/docs/documentation/components/ModalFooter.html +2 -2
  47. package/docs/documentation/components/ModalHeader.html +2 -2
  48. package/docs/documentation/components/Notification.html +2 -2
  49. package/docs/documentation/components/NumberComponent.html +2 -2
  50. package/docs/documentation/components/OverflowMenu.html +2 -2
  51. package/docs/documentation/components/OverflowMenuCustomPane.html +2 -2
  52. package/docs/documentation/components/OverflowMenuOption.html +2 -2
  53. package/docs/documentation/components/OverflowMenuPane.html +2 -2
  54. package/docs/documentation/components/Overlay.html +2 -2
  55. package/docs/documentation/components/Pagination.html +2 -2
  56. package/docs/documentation/components/PaginationNav.html +2 -2
  57. package/docs/documentation/components/PaginationNavItem.html +2 -2
  58. package/docs/documentation/components/PaginationOverflow.html +2 -2
  59. package/docs/documentation/components/Panel.html +2 -2
  60. package/docs/documentation/components/PasswordInputLabelComponent.html +2 -2
  61. package/docs/documentation/components/Placeholder.html +2 -2
  62. package/docs/documentation/components/PopoverContent.html +2 -2
  63. package/docs/documentation/components/ProgressBar.html +2 -2
  64. package/docs/documentation/components/ProgressIndicator.html +2 -2
  65. package/docs/documentation/components/Radio.html +2 -2
  66. package/docs/documentation/components/RadioGroup.html +2 -2
  67. package/docs/documentation/components/Search.html +2 -2
  68. package/docs/documentation/components/Select.html +2 -2
  69. package/docs/documentation/components/SelectionTile.html +2 -2
  70. package/docs/documentation/components/SideNav.html +2 -2
  71. package/docs/documentation/components/SideNavItem.html +2 -2
  72. package/docs/documentation/components/SideNavMenu.html +2 -2
  73. package/docs/documentation/components/SkeletonPlaceholder.html +2 -2
  74. package/docs/documentation/components/SkeletonText.html +2 -2
  75. package/docs/documentation/components/Slider.html +2 -2
  76. package/docs/documentation/components/StructuredList.html +2 -2
  77. package/docs/documentation/components/SwitcherList.html +2 -2
  78. package/docs/documentation/components/SwitcherListItem.html +2 -2
  79. package/docs/documentation/components/Tab.html +2 -2
  80. package/docs/documentation/components/TabHeaderGroup.html +2 -2
  81. package/docs/documentation/components/TabHeaders.html +2 -2
  82. package/docs/documentation/components/TabSkeleton.html +2 -2
  83. package/docs/documentation/components/Table.html +2 -2
  84. package/docs/documentation/components/TableBody.html +2 -2
  85. package/docs/documentation/components/TableCheckbox.html +2 -2
  86. package/docs/documentation/components/TableContainer.html +2 -2
  87. package/docs/documentation/components/TableData.html +2 -2
  88. package/docs/documentation/components/TableExpandButton.html +2 -2
  89. package/docs/documentation/components/TableExpandedRow.html +2 -2
  90. package/docs/documentation/components/TableHead.html +2 -2
  91. package/docs/documentation/components/TableHeadCell.html +2 -2
  92. package/docs/documentation/components/TableHeadCheckbox.html +2 -2
  93. package/docs/documentation/components/TableHeadExpand.html +2 -2
  94. package/docs/documentation/components/TableHeader.html +2 -2
  95. package/docs/documentation/components/TableRadio.html +2 -2
  96. package/docs/documentation/components/TableRowComponent.html +2 -2
  97. package/docs/documentation/components/TableToolbar.html +2 -2
  98. package/docs/documentation/components/TableToolbarActions.html +2 -2
  99. package/docs/documentation/components/TableToolbarContent.html +2 -2
  100. package/docs/documentation/components/TableToolbarSearch.html +2 -2
  101. package/docs/documentation/components/Tabs.html +2 -2
  102. package/docs/documentation/components/Tag.html +73 -13
  103. package/docs/documentation/components/TagFilter.html +116 -51
  104. package/docs/documentation/components/TagOperationalComponent.html +920 -0
  105. package/docs/documentation/components/TagSelectableComponent.html +1085 -0
  106. package/docs/documentation/components/TextInputLabelComponent.html +2 -2
  107. package/docs/documentation/components/TextareaLabelComponent.html +2 -2
  108. package/docs/documentation/components/Tile.html +2 -2
  109. package/docs/documentation/components/TileGroup.html +2 -2
  110. package/docs/documentation/components/TimePicker.html +2 -2
  111. package/docs/documentation/components/TimePickerSelect.html +2 -2
  112. package/docs/documentation/components/Toast.html +2 -2
  113. package/docs/documentation/components/Toggle.html +81 -67
  114. package/docs/documentation/components/Toggletip.html +2 -2
  115. package/docs/documentation/components/Tooltip.html +2 -2
  116. package/docs/documentation/components/TooltipDefinition.html +2 -2
  117. package/docs/documentation/components/TreeNodeComponent.html +2 -2
  118. package/docs/documentation/components/TreeViewComponent.html +2 -2
  119. package/docs/documentation/coverage.html +46 -10
  120. package/docs/documentation/directives/TagIconDirective.html +368 -0
  121. package/docs/documentation/graph/dependencies.svg +1750 -1678
  122. package/docs/documentation/js/menu-wc.js +23 -3
  123. package/docs/documentation/js/menu-wc_es5.js +1 -1
  124. package/docs/documentation/js/search/search_index.js +2 -2
  125. package/docs/documentation/miscellaneous/enumerations.html +8 -8
  126. package/docs/documentation/modules/ComboBoxModule/dependencies.svg +4 -4
  127. package/docs/documentation/modules/ComboBoxModule.html +4 -4
  128. package/docs/documentation/modules/DatePickerInputModule/dependencies.svg +4 -4
  129. package/docs/documentation/modules/DatePickerInputModule.html +4 -4
  130. package/docs/documentation/modules/DatePickerModule/dependencies.svg +39 -39
  131. package/docs/documentation/modules/DatePickerModule.html +39 -39
  132. package/docs/documentation/modules/FileUploaderModule/dependencies.svg +34 -34
  133. package/docs/documentation/modules/FileUploaderModule.html +34 -34
  134. package/docs/documentation/modules/InlineLoadingModule/dependencies.svg +4 -4
  135. package/docs/documentation/modules/InlineLoadingModule.html +4 -4
  136. package/docs/documentation/modules/LoadingModule/dependencies.svg +4 -4
  137. package/docs/documentation/modules/LoadingModule.html +4 -4
  138. package/docs/documentation/modules/NFormsModule/dependencies.svg +4 -4
  139. package/docs/documentation/modules/NFormsModule.html +4 -4
  140. package/docs/documentation/modules/NumberModule/dependencies.svg +24 -24
  141. package/docs/documentation/modules/NumberModule.html +24 -24
  142. package/docs/documentation/modules/ProgressBarModule/dependencies.svg +4 -4
  143. package/docs/documentation/modules/ProgressBarModule.html +4 -4
  144. package/docs/documentation/modules/ProgressIndicatorModule/dependencies.svg +4 -4
  145. package/docs/documentation/modules/ProgressIndicatorModule.html +4 -4
  146. package/docs/documentation/modules/RadioModule/dependencies.svg +53 -49
  147. package/docs/documentation/modules/RadioModule.html +53 -49
  148. package/docs/documentation/modules/SearchModule/dependencies.svg +6 -6
  149. package/docs/documentation/modules/SearchModule.html +6 -6
  150. package/docs/documentation/modules/SliderModule/dependencies.svg +4 -4
  151. package/docs/documentation/modules/SliderModule.html +4 -4
  152. package/docs/documentation/modules/TabsModule/dependencies.svg +69 -69
  153. package/docs/documentation/modules/TabsModule.html +69 -69
  154. package/docs/documentation/modules/TagModule/dependencies.svg +123 -51
  155. package/docs/documentation/modules/TagModule.html +160 -55
  156. package/docs/documentation/modules/ThemeModule/dependencies.svg +4 -4
  157. package/docs/documentation/modules/ThemeModule.html +4 -4
  158. package/docs/documentation/modules/TilesModule/dependencies.svg +101 -101
  159. package/docs/documentation/modules/TilesModule.html +101 -101
  160. package/docs/documentation/modules/TimePickerModule/dependencies.svg +4 -4
  161. package/docs/documentation/modules/TimePickerModule.html +4 -4
  162. package/docs/documentation/modules/TimePickerSelectModule/dependencies.svg +49 -45
  163. package/docs/documentation/modules/TimePickerSelectModule.html +49 -45
  164. package/docs/documentation/modules/ToggleModule/dependencies.svg +4 -4
  165. package/docs/documentation/modules/ToggleModule.html +4 -4
  166. package/docs/documentation/modules/TreeviewModule/dependencies.svg +4 -4
  167. package/docs/documentation/modules/TreeviewModule.html +4 -4
  168. package/docs/documentation/modules/UIShellModule/dependencies.svg +4 -4
  169. package/docs/documentation/modules/UIShellModule.html +4 -4
  170. package/docs/documentation/overview.html +1752 -1680
  171. package/docs/documentation.json +948 -89
  172. package/docs/storybook/{1895.0331c090.iframe.bundle.js → 1895.4ffc48da.iframe.bundle.js} +1 -1
  173. package/docs/storybook/contained-list-contained-list-stories.b87addfb.iframe.bundle.js +1 -0
  174. package/docs/storybook/iframe.html +2 -2
  175. package/docs/storybook/index.json +1 -1
  176. package/docs/storybook/main.4ed7d347.iframe.bundle.js +1 -0
  177. package/docs/storybook/{patterns-filtering-multiple-categories-stories.17085244.iframe.bundle.js → patterns-filtering-multiple-categories-stories.c7cc76c2.iframe.bundle.js} +1 -1
  178. package/docs/storybook/project.json +1 -1
  179. package/docs/storybook/{runtime~main.3d777cd5.iframe.bundle.js → runtime~main.5af8858a.iframe.bundle.js} +1 -1
  180. package/docs/storybook/stories.json +1 -1
  181. package/docs/storybook/tag-tag-stories.8b0e9efc.iframe.bundle.js +1 -0
  182. package/docs/storybook/{toggle-toggle-stories.def6c644.iframe.bundle.js → toggle-toggle-stories.7832edbb.iframe.bundle.js} +1 -1
  183. package/esm2020/tag/index.mjs +4 -1
  184. package/esm2020/tag/tag-filter.component.mjs +47 -32
  185. package/esm2020/tag/tag-icon.directive.mjs +19 -0
  186. package/esm2020/tag/tag-operational.component.mjs +62 -0
  187. package/esm2020/tag/tag-selectable.component.mjs +89 -0
  188. package/esm2020/tag/tag.component.mjs +28 -4
  189. package/esm2020/tag/tag.module.mjs +27 -4
  190. package/esm2020/toggle/toggle.component.mjs +9 -4
  191. package/fesm2015/carbon-components-angular-tag.mjs +259 -40
  192. package/fesm2015/carbon-components-angular-tag.mjs.map +1 -1
  193. package/fesm2015/carbon-components-angular-toggle.mjs +8 -3
  194. package/fesm2015/carbon-components-angular-toggle.mjs.map +1 -1
  195. package/fesm2020/carbon-components-angular-tag.mjs +259 -40
  196. package/fesm2020/carbon-components-angular-tag.mjs.map +1 -1
  197. package/fesm2020/carbon-components-angular-toggle.mjs +8 -3
  198. package/fesm2020/carbon-components-angular-toggle.mjs.map +1 -1
  199. package/package.json +1 -1
  200. package/tag/index.d.ts +3 -0
  201. package/tag/tag-filter.component.d.ts +5 -1
  202. package/tag/tag-icon.directive.d.ts +26 -0
  203. package/tag/tag-operational.component.d.ts +35 -0
  204. package/tag/tag-selectable.component.d.ts +42 -0
  205. package/tag/tag.component.d.ts +7 -2
  206. package/tag/tag.module.d.ts +6 -3
  207. package/toggle/toggle.component.d.ts +6 -1
  208. package/docs/storybook/contained-list-contained-list-stories.3c337840.iframe.bundle.js +0 -1
  209. package/docs/storybook/main.a065377d.iframe.bundle.js +0 -1
  210. package/docs/storybook/tag-tag-stories.60e1dec6.iframe.bundle.js +0 -1
@@ -1,5 +1,6 @@
1
1
  import { Component, Input, HostBinding } from "@angular/core";
2
2
  import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common";
3
4
  /**
4
5
  * Component that represents a tag for labelling/categorizing using keywords. Get started with importing the module:
5
6
  *
@@ -20,18 +21,39 @@ export class Tag {
20
21
  */
21
22
  this.size = "md";
22
23
  this.class = "";
24
+ this.skeleton = false;
23
25
  }
26
+ /**
27
+ * @todo
28
+ * Remove `cds--tag--${this.size}` in v7
29
+ */
24
30
  get attrClass() {
25
- return `cds--tag cds--tag--${this.type} cds--tag--${this.size} cds--layout--size-${this.size} ${this.class}`;
31
+ const skeletonClass = this.skeleton ? "cds--skeleton" : "";
32
+ const sizeClass = `cds--tag--${this.size} cds--layout--size-${this.size}`;
33
+ return `cds--tag cds--tag--${this.type} ${sizeClass} ${skeletonClass} ${this.class}`;
26
34
  }
27
35
  }
28
36
  Tag.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: Tag, deps: [], target: i0.ɵɵFactoryTarget.Component });
29
- Tag.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: Tag, selector: "cds-tag, ibm-tag", inputs: { type: "type", size: "size", class: "class" }, host: { properties: { "attr.class": "this.attrClass" } }, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true });
37
+ Tag.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: Tag, selector: "cds-tag, ibm-tag", inputs: { type: "type", size: "size", class: "class", skeleton: "skeleton" }, host: { properties: { "attr.class": "this.attrClass" } }, ngImport: i0, template: `
38
+ <ng-container *ngIf="!skeleton">
39
+ <ng-content select="[cdsTagIcon],[ibmTagIcon]"></ng-content>
40
+ <span class="cds--tag__label">
41
+ <ng-content></ng-content>
42
+ </span>
43
+ </ng-container>
44
+ `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
30
45
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: Tag, decorators: [{
31
46
  type: Component,
32
47
  args: [{
33
48
  selector: "cds-tag, ibm-tag",
34
- template: `<ng-content></ng-content>`
49
+ template: `
50
+ <ng-container *ngIf="!skeleton">
51
+ <ng-content select="[cdsTagIcon],[ibmTagIcon]"></ng-content>
52
+ <span class="cds--tag__label">
53
+ <ng-content></ng-content>
54
+ </span>
55
+ </ng-container>
56
+ `
35
57
  }]
36
58
  }], propDecorators: { type: [{
37
59
  type: Input
@@ -39,8 +61,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
39
61
  type: Input
40
62
  }], class: [{
41
63
  type: Input
64
+ }], skeleton: [{
65
+ type: Input
42
66
  }], attrClass: [{
43
67
  type: HostBinding,
44
68
  args: ["attr.class"]
45
69
  }] } });
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFnLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90YWcvdGFnLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ04sU0FBUyxFQUNULEtBQUssRUFDTCxXQUFXLEVBQ1gsTUFBTSxlQUFlLENBQUM7O0FBa0J2Qjs7Ozs7Ozs7R0FRRztBQUtILE1BQU0sT0FBTyxHQUFHO0lBSmhCO1FBS0M7O1dBRUc7UUFDTSxTQUFJLEdBQVksTUFBTSxDQUFDO1FBRWhDOztXQUVHO1FBQ00sU0FBSSxHQUFnQixJQUFJLENBQUM7UUFFekIsVUFBSyxHQUFHLEVBQUUsQ0FBQztLQUtwQjtJQUhBLElBQStCLFNBQVM7UUFDdkMsT0FBTyxzQkFBc0IsSUFBSSxDQUFDLElBQUksY0FBYyxJQUFJLENBQUMsSUFBSSxzQkFBc0IsSUFBSSxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDOUcsQ0FBQzs7Z0dBZlcsR0FBRztvRkFBSCxHQUFHLDBLQUZMLDJCQUEyQjsyRkFFekIsR0FBRztrQkFKZixTQUFTO21CQUFDO29CQUNWLFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFFBQVEsRUFBRSwyQkFBMkI7aUJBQ3JDOzhCQUtTLElBQUk7c0JBQVosS0FBSztnQkFLRyxJQUFJO3NCQUFaLEtBQUs7Z0JBRUcsS0FBSztzQkFBYixLQUFLO2dCQUV5QixTQUFTO3NCQUF2QyxXQUFXO3VCQUFDLFlBQVkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuXHRDb21wb25lbnQsXG5cdElucHV0LFxuXHRIb3N0QmluZGluZ1xufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG4vKipcbiAqIFN1cHBvcnRlZCB0YWcgdHlwZXMgZm9yIGNhcmJvbiB2MTBcbiAqL1xuZXhwb3J0IHR5cGUgVGFnVHlwZSA9IFwicmVkXCIgfFxuXHRcIm1hZ2VudGFcIiB8XG5cdFwicHVycGxlXCIgfFxuXHRcImJsdWVcIiB8XG5cdFwiY3lhblwiIHxcblx0XCJ0ZWFsXCIgfFxuXHRcImdyZWVuXCIgfFxuXHRcImdyYXlcIiB8XG5cdFwiY29vbC1ncmF5XCIgfFxuXHRcIndhcm0tZ3JheVwiIHxcblx0XCJoaWdoLWNvbnRyYXN0XCIgfFxuXHRcIm91dGxpbmVcIjtcblxuLyoqXG4gKiBDb21wb25lbnQgdGhhdCByZXByZXNlbnRzIGEgdGFnIGZvciBsYWJlbGxpbmcvY2F0ZWdvcml6aW5nIHVzaW5nIGtleXdvcmRzLiBHZXQgc3RhcnRlZCB3aXRoIGltcG9ydGluZyB0aGUgbW9kdWxlOlxuICpcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGltcG9ydCB7IFRhZ01vZHVsZSB9IGZyb20gJ2NhcmJvbi1jb21wb25lbnRzLWFuZ3VsYXInO1xuICogYGBgXG4gKlxuICogW1NlZSBkZW1vXSguLi8uLi8/cGF0aD0vc3RvcnkvY29tcG9uZW50cy10YWctLWJhc2ljKVxuICovXG5AQ29tcG9uZW50KHtcblx0c2VsZWN0b3I6IFwiY2RzLXRhZywgaWJtLXRhZ1wiLFxuXHR0ZW1wbGF0ZTogYDxuZy1jb250ZW50PjwvbmctY29udGVudD5gXG59KVxuZXhwb3J0IGNsYXNzIFRhZyB7XG5cdC8qKlxuXHQgKiBUeXBlIG9mIHRoZSB0YWcgZGV0ZXJtaW5lcyB0aGUgc3R5bGluZ1xuXHQgKi9cblx0QElucHV0KCkgdHlwZTogVGFnVHlwZSA9IFwiZ3JheVwiO1xuXG5cdC8qKlxuXHQgKiBUYWcgcmVuZGVyIHNpemVcblx0ICovXG5cdEBJbnB1dCgpIHNpemU6IFwic21cIiB8IFwibWRcIiA9IFwibWRcIjtcblxuXHRASW5wdXQoKSBjbGFzcyA9IFwiXCI7XG5cblx0QEhvc3RCaW5kaW5nKFwiYXR0ci5jbGFzc1wiKSBnZXQgYXR0ckNsYXNzKCkge1xuXHRcdHJldHVybiBgY2RzLS10YWcgY2RzLS10YWctLSR7dGhpcy50eXBlfSBjZHMtLXRhZy0tJHt0aGlzLnNpemV9IGNkcy0tbGF5b3V0LS1zaXplLSR7dGhpcy5zaXplfSAke3RoaXMuY2xhc3N9YDtcblx0fVxufVxuIl19
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFnLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90YWcvdGFnLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ04sU0FBUyxFQUNULEtBQUssRUFDTCxXQUFXLEVBQ1gsTUFBTSxlQUFlLENBQUM7OztBQWtCdkI7Ozs7Ozs7O0dBUUc7QUFZSCxNQUFNLE9BQU8sR0FBRztJQVhoQjtRQVlDOztXQUVHO1FBQ00sU0FBSSxHQUFZLE1BQU0sQ0FBQztRQUVoQzs7V0FFRztRQUNNLFNBQUksR0FBdUIsSUFBSSxDQUFDO1FBRWhDLFVBQUssR0FBRyxFQUFFLENBQUM7UUFFWCxhQUFRLEdBQUcsS0FBSyxDQUFDO0tBWTFCO0lBVkE7OztPQUdHO0lBQ0gsSUFBK0IsU0FBUztRQUN2QyxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUMzRCxNQUFNLFNBQVMsR0FBRyxhQUFhLElBQUksQ0FBQyxJQUFJLHNCQUFzQixJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7UUFFMUUsT0FBTyxzQkFBc0IsSUFBSSxDQUFDLElBQUksSUFBSSxTQUFTLElBQUksYUFBYSxJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN0RixDQUFDOztnR0F4QlcsR0FBRztvRkFBSCxHQUFHLGdNQVRMOzs7Ozs7O0VBT1Q7MkZBRVcsR0FBRztrQkFYZixTQUFTO21CQUFDO29CQUNWLFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFFBQVEsRUFBRTs7Ozs7OztFQU9UO2lCQUNEOzhCQUtTLElBQUk7c0JBQVosS0FBSztnQkFLRyxJQUFJO3NCQUFaLEtBQUs7Z0JBRUcsS0FBSztzQkFBYixLQUFLO2dCQUVHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBTXlCLFNBQVM7c0JBQXZDLFdBQVc7dUJBQUMsWUFBWSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG5cdENvbXBvbmVudCxcblx0SW5wdXQsXG5cdEhvc3RCaW5kaW5nXG59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbi8qKlxuICogU3VwcG9ydGVkIHRhZyB0eXBlcyBmb3IgY2FyYm9uIHYxMFxuICovXG5leHBvcnQgdHlwZSBUYWdUeXBlID0gXCJyZWRcIiB8XG5cdFwibWFnZW50YVwiIHxcblx0XCJwdXJwbGVcIiB8XG5cdFwiYmx1ZVwiIHxcblx0XCJjeWFuXCIgfFxuXHRcInRlYWxcIiB8XG5cdFwiZ3JlZW5cIiB8XG5cdFwiZ3JheVwiIHxcblx0XCJjb29sLWdyYXlcIiB8XG5cdFwid2FybS1ncmF5XCIgfFxuXHRcImhpZ2gtY29udHJhc3RcIiB8XG5cdFwib3V0bGluZVwiO1xuXG4vKipcbiAqIENvbXBvbmVudCB0aGF0IHJlcHJlc2VudHMgYSB0YWcgZm9yIGxhYmVsbGluZy9jYXRlZ29yaXppbmcgdXNpbmcga2V5d29yZHMuIEdldCBzdGFydGVkIHdpdGggaW1wb3J0aW5nIHRoZSBtb2R1bGU6XG4gKlxuICogYGBgdHlwZXNjcmlwdFxuICogaW1wb3J0IHsgVGFnTW9kdWxlIH0gZnJvbSAnY2FyYm9uLWNvbXBvbmVudHMtYW5ndWxhcic7XG4gKiBgYGBcbiAqXG4gKiBbU2VlIGRlbW9dKC4uLy4uLz9wYXRoPS9zdG9yeS9jb21wb25lbnRzLXRhZy0tYmFzaWMpXG4gKi9cbkBDb21wb25lbnQoe1xuXHRzZWxlY3RvcjogXCJjZHMtdGFnLCBpYm0tdGFnXCIsXG5cdHRlbXBsYXRlOiBgXG5cdFx0PG5nLWNvbnRhaW5lciAqbmdJZj1cIiFza2VsZXRvblwiPlxuXHRcdFx0PG5nLWNvbnRlbnQgc2VsZWN0PVwiW2Nkc1RhZ0ljb25dLFtpYm1UYWdJY29uXVwiPjwvbmctY29udGVudD5cblx0XHRcdDxzcGFuIGNsYXNzPVwiY2RzLS10YWdfX2xhYmVsXCI+XG5cdFx0XHRcdDxuZy1jb250ZW50PjwvbmctY29udGVudD5cblx0XHRcdDwvc3Bhbj5cblx0XHQ8L25nLWNvbnRhaW5lcj5cblx0YFxufSlcbmV4cG9ydCBjbGFzcyBUYWcge1xuXHQvKipcblx0ICogVHlwZSBvZiB0aGUgdGFnIGRldGVybWluZXMgdGhlIHN0eWxpbmdcblx0ICovXG5cdEBJbnB1dCgpIHR5cGU6IFRhZ1R5cGUgPSBcImdyYXlcIjtcblxuXHQvKipcblx0ICogVGFnIHJlbmRlciBzaXplXG5cdCAqL1xuXHRASW5wdXQoKSBzaXplOiBcInNtXCIgfCBcIm1kXCIgfCBcImxnXCIgPSBcIm1kXCI7XG5cblx0QElucHV0KCkgY2xhc3MgPSBcIlwiO1xuXG5cdEBJbnB1dCgpIHNrZWxldG9uID0gZmFsc2U7XG5cblx0LyoqXG5cdCAqIEB0b2RvXG5cdCAqIFJlbW92ZSBgY2RzLS10YWctLSR7dGhpcy5zaXplfWAgaW4gdjdcblx0ICovXG5cdEBIb3N0QmluZGluZyhcImF0dHIuY2xhc3NcIikgZ2V0IGF0dHJDbGFzcygpIHtcblx0XHRjb25zdCBza2VsZXRvbkNsYXNzID0gdGhpcy5za2VsZXRvbiA/IFwiY2RzLS1za2VsZXRvblwiIDogXCJcIjtcblx0XHRjb25zdCBzaXplQ2xhc3MgPSBgY2RzLS10YWctLSR7dGhpcy5zaXplfSBjZHMtLWxheW91dC0tc2l6ZS0ke3RoaXMuc2l6ZX1gO1xuXG5cdFx0cmV0dXJuIGBjZHMtLXRhZyBjZHMtLXRhZy0tJHt0aGlzLnR5cGV9ICR7c2l6ZUNsYXNzfSAke3NrZWxldG9uQ2xhc3N9ICR7dGhpcy5jbGFzc31gO1xuXHR9XG59XG4iXX0=
@@ -3,18 +3,41 @@ import { CommonModule } from "@angular/common";
3
3
  import { Tag } from "./tag.component";
4
4
  import { TagFilter } from "./tag-filter.component";
5
5
  import { IconModule } from "carbon-components-angular/icon";
6
+ import { TagIconDirective } from "./tag-icon.directive";
7
+ import { TagSelectableComponent } from "./tag-selectable.component";
8
+ import { TagOperationalComponent } from "./tag-operational.component";
6
9
  import * as i0 from "@angular/core";
7
10
  export class TagModule {
8
11
  }
9
12
  TagModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TagModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
10
- TagModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: TagModule, declarations: [Tag, TagFilter], imports: [CommonModule, IconModule], exports: [Tag, TagFilter] });
13
+ TagModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: TagModule, declarations: [Tag,
14
+ TagFilter,
15
+ TagIconDirective,
16
+ TagSelectableComponent,
17
+ TagOperationalComponent], imports: [CommonModule, IconModule], exports: [Tag,
18
+ TagFilter,
19
+ TagIconDirective,
20
+ TagSelectableComponent,
21
+ TagOperationalComponent] });
11
22
  TagModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TagModule, imports: [CommonModule, IconModule] });
12
23
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TagModule, decorators: [{
13
24
  type: NgModule,
14
25
  args: [{
15
- declarations: [Tag, TagFilter],
16
- exports: [Tag, TagFilter],
26
+ declarations: [
27
+ Tag,
28
+ TagFilter,
29
+ TagIconDirective,
30
+ TagSelectableComponent,
31
+ TagOperationalComponent
32
+ ],
33
+ exports: [
34
+ Tag,
35
+ TagFilter,
36
+ TagIconDirective,
37
+ TagSelectableComponent,
38
+ TagOperationalComponent
39
+ ],
17
40
  imports: [CommonModule, IconModule]
18
41
  }]
19
42
  }] });
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFnLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90YWcvdGFnLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdEMsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ25ELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7QUFPNUQsTUFBTSxPQUFPLFNBQVM7O3NHQUFULFNBQVM7dUdBQVQsU0FBUyxpQkFKTCxHQUFHLEVBQUUsU0FBUyxhQUVuQixZQUFZLEVBQUUsVUFBVSxhQUR4QixHQUFHLEVBQUUsU0FBUzt1R0FHYixTQUFTLFlBRlYsWUFBWSxFQUFFLFVBQVU7MkZBRXZCLFNBQVM7a0JBTHJCLFFBQVE7bUJBQUM7b0JBQ1QsWUFBWSxFQUFFLENBQUUsR0FBRyxFQUFFLFNBQVMsQ0FBRTtvQkFDaEMsT0FBTyxFQUFFLENBQUUsR0FBRyxFQUFFLFNBQVMsQ0FBRTtvQkFDM0IsT0FBTyxFQUFFLENBQUUsWUFBWSxFQUFFLFVBQVUsQ0FBRTtpQkFDckMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5cbmltcG9ydCB7IFRhZyB9IGZyb20gXCIuL3RhZy5jb21wb25lbnRcIjtcbmltcG9ydCB7IFRhZ0ZpbHRlciB9IGZyb20gXCIuL3RhZy1maWx0ZXIuY29tcG9uZW50XCI7XG5pbXBvcnQgeyBJY29uTW9kdWxlIH0gZnJvbSBcImNhcmJvbi1jb21wb25lbnRzLWFuZ3VsYXIvaWNvblwiO1xuXG5ATmdNb2R1bGUoe1xuXHRkZWNsYXJhdGlvbnM6IFsgVGFnLCBUYWdGaWx0ZXIgXSxcblx0ZXhwb3J0czogWyBUYWcsIFRhZ0ZpbHRlciBdLFxuXHRpbXBvcnRzOiBbIENvbW1vbk1vZHVsZSwgSWNvbk1vZHVsZSBdXG59KVxuZXhwb3J0IGNsYXNzIFRhZ01vZHVsZSB7IH1cbiJdfQ==
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFnLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90YWcvdGFnLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdEMsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ25ELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUM1RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNwRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQzs7QUFtQnRFLE1BQU0sT0FBTyxTQUFTOztzR0FBVCxTQUFTO3VHQUFULFNBQVMsaUJBZnBCLEdBQUc7UUFDSCxTQUFTO1FBQ1QsZ0JBQWdCO1FBQ2hCLHNCQUFzQjtRQUN0Qix1QkFBdUIsYUFTZCxZQUFZLEVBQUUsVUFBVSxhQU5qQyxHQUFHO1FBQ0gsU0FBUztRQUNULGdCQUFnQjtRQUNoQixzQkFBc0I7UUFDdEIsdUJBQXVCO3VHQUlaLFNBQVMsWUFGWCxZQUFZLEVBQUUsVUFBVTsyRkFFdEIsU0FBUztrQkFqQnJCLFFBQVE7bUJBQUM7b0JBQ1QsWUFBWSxFQUFFO3dCQUNiLEdBQUc7d0JBQ0gsU0FBUzt3QkFDVCxnQkFBZ0I7d0JBQ2hCLHNCQUFzQjt3QkFDdEIsdUJBQXVCO3FCQUN2QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1IsR0FBRzt3QkFDSCxTQUFTO3dCQUNULGdCQUFnQjt3QkFDaEIsc0JBQXNCO3dCQUN0Qix1QkFBdUI7cUJBQ3ZCO29CQUNELE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxVQUFVLENBQUM7aUJBQ25DIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xuXG5pbXBvcnQgeyBUYWcgfSBmcm9tIFwiLi90YWcuY29tcG9uZW50XCI7XG5pbXBvcnQgeyBUYWdGaWx0ZXIgfSBmcm9tIFwiLi90YWctZmlsdGVyLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgSWNvbk1vZHVsZSB9IGZyb20gXCJjYXJib24tY29tcG9uZW50cy1hbmd1bGFyL2ljb25cIjtcbmltcG9ydCB7IFRhZ0ljb25EaXJlY3RpdmUgfSBmcm9tIFwiLi90YWctaWNvbi5kaXJlY3RpdmVcIjtcbmltcG9ydCB7IFRhZ1NlbGVjdGFibGVDb21wb25lbnQgfSBmcm9tIFwiLi90YWctc2VsZWN0YWJsZS5jb21wb25lbnRcIjtcbmltcG9ydCB7IFRhZ09wZXJhdGlvbmFsQ29tcG9uZW50IH0gZnJvbSBcIi4vdGFnLW9wZXJhdGlvbmFsLmNvbXBvbmVudFwiO1xuXG5ATmdNb2R1bGUoe1xuXHRkZWNsYXJhdGlvbnM6IFtcblx0XHRUYWcsXG5cdFx0VGFnRmlsdGVyLFxuXHRcdFRhZ0ljb25EaXJlY3RpdmUsXG5cdFx0VGFnU2VsZWN0YWJsZUNvbXBvbmVudCxcblx0XHRUYWdPcGVyYXRpb25hbENvbXBvbmVudFxuXHRdLFxuXHRleHBvcnRzOiBbXG5cdFx0VGFnLFxuXHRcdFRhZ0ZpbHRlcixcblx0XHRUYWdJY29uRGlyZWN0aXZlLFxuXHRcdFRhZ1NlbGVjdGFibGVDb21wb25lbnQsXG5cdFx0VGFnT3BlcmF0aW9uYWxDb21wb25lbnRcblx0XSxcblx0aW1wb3J0czogW0NvbW1vbk1vZHVsZSwgSWNvbk1vZHVsZV1cbn0pXG5leHBvcnQgY2xhc3MgVGFnTW9kdWxlIHt9XG4iXX0=
@@ -5,6 +5,7 @@ import * as i0 from "@angular/core";
5
5
  import * as i1 from "carbon-components-angular/i18n";
6
6
  import * as i2 from "@angular/common";
7
7
  /**
8
+ * @deprecated since v5 - Use boolean
8
9
  * Defines the set of states for a toggle component.
9
10
  */
10
11
  export var ToggleState;
@@ -119,7 +120,7 @@ export class Toggle extends Checkbox {
119
120
  */
120
121
  Toggle.toggleCount = 0;
121
122
  Toggle.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: Toggle, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.I18n }], target: i0.ɵɵFactoryTarget.Component });
122
- Toggle.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: Toggle, selector: "cds-toggle, ibm-toggle", inputs: { offText: "offText", onText: "onText", label: "label", size: "size", hideLabel: "hideLabel", skeleton: "skeleton" }, host: { properties: { "class.cds--toggle--skeleton": "this.skeleton", "class.cds--toggle": "this.toggleClass", "class.cds--toggle--disabled": "this.disabledClass", "class.cds--form-item": "this.formItem" } }, providers: [
123
+ Toggle.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: Toggle, selector: "cds-toggle, ibm-toggle", inputs: { offText: "offText", onText: "onText", label: "label", size: "size", hideLabel: "hideLabel", ariaLabel: "ariaLabel", skeleton: "skeleton" }, host: { properties: { "class.cds--toggle--skeleton": "this.skeleton", "class.cds--toggle": "this.toggleClass", "class.cds--toggle--disabled": "this.disabledClass", "class.cds--form-item": "this.formItem" } }, providers: [
123
124
  {
124
125
  provide: NG_VALUE_ACCESSOR,
125
126
  useExisting: Toggle,
@@ -134,7 +135,8 @@ Toggle.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.
134
135
  role="switch"
135
136
  type="button"
136
137
  [attr.aria-checked]="checked"
137
- (click)="onClick($event)">
138
+ (click)="onClick($event)"
139
+ [attr.aria-label]="ariaLabel">
138
140
  </button>
139
141
  <label
140
142
  class="cds--toggle__label"
@@ -190,7 +192,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
190
192
  role="switch"
191
193
  type="button"
192
194
  [attr.aria-checked]="checked"
193
- (click)="onClick($event)">
195
+ (click)="onClick($event)"
196
+ [attr.aria-label]="ariaLabel">
194
197
  </button>
195
198
  <label
196
199
  class="cds--toggle__label"
@@ -251,6 +254,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
251
254
  type: Input
252
255
  }], hideLabel: [{
253
256
  type: Input
257
+ }], ariaLabel: [{
258
+ type: Input
254
259
  }], skeleton: [{
255
260
  type: HostBinding,
256
261
  args: ["class.cds--toggle--skeleton"]
@@ -266,4 +271,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
266
271
  type: HostBinding,
267
272
  args: ["class.cds--form-item"]
268
273
  }] } });
269
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9nZ2xlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90b2dnbGUvdG9nZ2xlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDOUQsT0FBTyxFQUVOLFNBQVMsRUFDVCxLQUFLLEVBQ0wsV0FBVyxFQUNYLFdBQVcsRUFDWCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7OztBQUtuRDs7R0FFRztBQUNILE1BQU0sQ0FBTixJQUFZLFdBSVg7QUFKRCxXQUFZLFdBQVc7SUFDdEIsNkNBQUksQ0FBQTtJQUNKLG1EQUFPLENBQUE7SUFDUCx1REFBUyxDQUFBO0FBQ1YsQ0FBQyxFQUpXLFdBQVcsS0FBWCxXQUFXLFFBSXRCO0FBRUQ7Ozs7R0FJRztBQUVIOzs7Ozs7Ozs7Ozs7R0FZRztBQStESCxNQUFNLE9BQU8sTUFBTyxTQUFRLFFBQVE7SUE0RG5DOztPQUVHO0lBQ0gsWUFBc0IsaUJBQW9DLEVBQVksSUFBVTtRQUMvRSxLQUFLLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQURKLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBbUI7UUFBWSxTQUFJLEdBQUosSUFBSSxDQUFNO1FBOUJoRjs7V0FFRztRQUNNLFNBQUksR0FBZ0IsSUFBSSxDQUFDO1FBQ2xDOztXQUVHO1FBQ00sY0FBUyxHQUFHLEtBQUssQ0FBQztRQUUwQixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBRXBDLGdCQUFXLEdBQUcsSUFBSSxDQUFDO1FBU3JEOztXQUVHO1FBQ0gsT0FBRSxHQUFHLFNBQVMsR0FBRyxNQUFNLENBQUMsV0FBVyxDQUFDO1FBRTFCLGVBQVUsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUNwRCxjQUFTLEdBQUcsSUFBSSxDQUFD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bnRlbnQiOlsiaW1wb3J0IHsgQ2hlY2tib3ggfSBmcm9tIFwiY2FyYm9uLWNvbXBvbmVudHMtYW5ndWxhci9jaGVja2JveFwiO1xuaW1wb3J0IHtcblx0Q2hhbmdlRGV0ZWN0b3JSZWYsXG5cdENvbXBvbmVudCxcblx0SW5wdXQsXG5cdEhvc3RCaW5kaW5nLFxuXHRUZW1wbGF0ZVJlZlxufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcblxuaW1wb3J0IHsgSTE4biB9IGZyb20gXCJjYXJib24tY29tcG9uZW50cy1hbmd1bGFyL2kxOG5cIjtcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tIFwicnhqc1wiO1xuXG4vKipcbiAqIERlZmluZXMgdGhlIHNldCBvZiBzdGF0ZXMgZm9yIGEgdG9nZ2xlIGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGVudW0gVG9nZ2xlU3RhdGUge1xuXHRJbml0LFxuXHRDaGVja2VkLFxuXHRVbmNoZWNrZWRcbn1cblxuLyoqXG4gKiBAdG9kbyAtIFRvZ2dsZSBjb21wb25lbnQgd2lsbCBubyBsb25nZXIgZXh0ZW5kIGBDaGVja2JveGAgY29tcG9uZW50IGFzIG9mIHY2XG4gKiBUb2dnbGUgaXMgbm8gbG9uZ2VyIHJlcGllcyBvbiB1c2luZyBjaGVja2JveCwgc28gZG9lc24ndCBtYWtlIHNlbnNlIGZvciB1cyB0byBjb250aW51ZSBpbmhlcml0aW5nIEFMTCBjaGVja2JveFxuICogY29tcG9uZW50IGF0dHJpYnV0ZXMuXG4gKi9cblxuLyoqXG4gKiBHZXQgc3RhcnRlZCB3aXRoIGltcG9ydGluZyB0aGUgbW9kdWxlOlxuICpcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGltcG9ydCB7IFRvZ2dsZU1vZHVsZSB9IGZyb20gJ2NhcmJvbi1jb21wb25lbnRzLWFuZ3VsYXInO1xuICogYGBgXG4gKlxuICogYGBgaHRtbFxuICogPGNkcy10b2dnbGUgWyhuZ01vZGVsKV09XCJ0b2dnbGVTdGF0ZVwiPlRvZ2dsZTwvY2RzLXRvZ2dsZT5cbiAqIGBgYFxuICpcbiAqIFtTZWUgZGVtb10oLi4vLi4vP3BhdGg9L3N0b3J5L2NvbXBvbmVudHMtdG9nZ2xlLS1iYXNpYylcbiAqL1xuQENvbXBvbmVudCh7XG5cdHNlbGVjdG9yOiBcImNkcy10b2dnbGUsIGlibS10b2dnbGVcIixcblx0dGVtcGxhdGU6IGBcblx0XHQ8bmctY29udGFpbmVyICpuZ0lmPVwiIXNrZWxldG9uOyBlbHNlIHNrZWxldG9uVGVtcGxhdGU7XCI+XG5cdFx0XHQ8YnV0dG9uXG5cdFx0XHRcdGNsYXNzPVwiY2RzLS10b2dnbGVfX2J1dHRvblwiXG5cdFx0XHRcdFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXG5cdFx0XHRcdFtpZF09XCJpZFwiXG5cdFx0XHRcdHJvbGU9XCJzd2l0Y2hcIlxuXHRcdFx0XHR0eXBlPVwiYnV0dG9uXCJcblx0XHRcdFx0W2F0dHIuYXJpYS1jaGVja2VkXT1cImNoZWNrZWRcIlxuXHRcdFx0XHQoY2xpY2spPVwib25DbGljaygkZXZlbnQpXCI+XG5cdFx0XHQ8L2J1dHRvbj5cblx0XHRcdDxsYWJlbFxuXHRcdFx0XHRjbGFzcz1cImNkcy0tdG9nZ2xlX19sYWJlbFwiXG5cdFx0XHRcdFtmb3JdPVwiaWRcIj5cblx0XHRcdFx0PHNwYW5cblx0XHRcdFx0XHRjbGFzcz1cImNkcy0tdG9nZ2xlX19sYWJlbC10ZXh0XCJcblx0XHRcdFx0XHRbbmdDbGFzc109XCJ7XG5cdFx0XHRcdFx0XHQnY2RzLS12aXN1YWxseS1oaWRkZW4nOiBoaWRlTGFiZWxcblx0XHRcdFx0XHR9XCI+XG5cdFx0XHRcdFx0PG5nLWNvbnRhaW5lciAqbmdJZj1cIiFpc1RlbXBsYXRlKGxhYmVsKVwiPnt7bGFiZWx9fTwvbmctY29udGFpbmVyPlxuXHRcdFx0XHRcdDxuZy10ZW1wbGF0ZSAqbmdJZj1cImlzVGVtcGxhdGUobGFiZWwpXCIgW25nVGVtcGxhdGVPdXRsZXRdPVwibGFiZWxcIj48L25nLXRlbXBsYXRlPlxuXHRcdFx0XHQ8L3NwYW4+XG5cdFx0XHRcdDxkaXZcblx0XHRcdFx0XHRjbGFzcz1cImNkcy0tdG9nZ2xlX19hcHBlYXJhbmNlXCJcblx0XHRcdFx0XHRbbmdDbGFzc109XCJ7XG5cdFx0XHRcdFx0XHQnY2RzLS10b2dnbGVfX2FwcGVhcmFuY2UtLXNtJzogc2l6ZSA9PT0gJ3NtJ1xuXHRcdFx0XHRcdH1cIj5cblx0XHRcdFx0XHQ8ZGl2XG5cdFx0XHRcdFx0XHRjbGFzcz1cImNkcy0tdG9nZ2xlX19zd2l0Y2hcIlxuXHRcdFx0XHRcdFx0W25nQ2xhc3NdPVwie1xuXHRcdFx0XHRcdFx0XHQnY2RzLS10b2dnbGVfX3N3aXRjaC0tY2hlY2tlZCc6IGNoZWNrZWRcblx0XHRcdFx0XHRcdH1cIj5cblx0XHRcdFx0XHRcdDxzdmdcblx0XHRcdFx0XHRcdFx0Km5nSWY9XCJzaXplID09PSAnc20nXCJcblx0XHRcdFx0XHRcdFx0Y2xhc3M9J2Nkcy0tdG9nZ2xlX19jaGVjaydcblx0XHRcdFx0XHRcdFx0d2lkdGg9XCI2cHhcIlxuXHRcdFx0XHRcdFx0XHRoZWlnaHQ9XCI1cHhcIlxuXHRcdFx0XHRcdFx0XHR2aWV3Qm94PVwiMCAwIDYgNVwiPlxuXHRcdFx0XHRcdFx0XHQ8cGF0aCBkPVwiTTIuMiAyLjdMNSAwIDYgMSAyLjIgNSAwIDIuNyAxIDEuNXpcIiAvPlxuXHRcdFx0XHRcdFx0PC9zdmc+XG5cdFx0XHRcdFx0PC9kaXY+XG5cdFx0XHRcdFx0PHNwYW4gY2xhc3M9XCJjZHMtLXRvZ2dsZV9fdGV4dFwiPlxuXHRcdFx0XHRcdFx0e3soaGlkZUxhYmVsID8gbGFiZWwgOiAoZ2V0Q2hlY2tlZFRleHQoKSB8IGFzeW5jKSl9fVxuXHRcdFx0XHRcdDwvc3Bhbj5cblx0XHRcdFx0PC9kaXY+XG5cdFx0XHQ8L2xhYmVsPlxuXHRcdDwvbmctY29udGFpbmVyPlxuXHRcdDxuZy10ZW1wbGF0ZSAjc2tlbGV0b25UZW1wbGF0ZT5cblx0XHRcdDxkaXYgY2xhc3M9XCJjZHMtLXRvZ2dsZV9fc2tlbGV0b24tY2lyY2xlXCI+PC9kaXY+XG5cdFx0XHQ8ZGl2IGNsYXNzPVwiY2RzLS10b2dnbGVfX3NrZWxldG9uLXJlY3RhbmdsZVwiPjwvZGl2PlxuXHRcdDwvbmctdGVtcGxhdGU+XG5cdGAsXG5cdHByb3ZpZGVyczogW1xuXHRcdHtcblx0XHRcdHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxuXHRcdFx0dXNlRXhpc3Rpbmc6IFRvZ2dsZSxcblx0XHRcdG11bHRpOiB0cnVlXG5cdFx0fVxuXHRdXG59KVxuZXhwb3J0IGNsYXNzIFRvZ2dsZSBleHRlbmRzIENoZWNrYm94IHtcblx0LyoqXG5cdCAqIFZhcmlhYmxlIHVzZWQgZm9yIGNyZWF0aW5nIHVuaXF1ZSBpZHMgZm9yIHRvZ2dsZSBjb21wb25lbnRzLlxuXHQgKi9cblx0c3RhdGljIHRvZ2dsZUNvdW50ID0gMDtcblxuXHQvKipcblx0ICogVGV4dCB0aGF0IGlzIHNldCBvbiB0aGUgbGVmdCBzaWRlIG9mIHRoZSB0b2dnbGUuXG5cdCAqL1xuXHRASW5wdXQoKVxuXHRzZXQgb2ZmVGV4dCh2YWx1ZTogc3RyaW5nIHwgT2JzZXJ2YWJsZTxzdHJpbmc+KSB7XG5cdFx0dGhpcy5fb2ZmVmFsdWVzLm92ZXJyaWRlKHZhbHVlKTtcblx0fVxuXG5cdGdldCBvZmZUZXh0KCkge1xuXHRcdHJldHVybiB0aGlzLl9vZmZWYWx1ZXMudmFsdWU7XG5cdH1cblxuXHQvKipcblx0ICogVGV4dCB0aGF0IGlzIHNldCBvbiB0aGUgcmlnaHQgc2lkZSBvZiB0aGUgdG9nZ2xlLlxuXHQgKi9cblx0QElucHV0KClcblx0c2V0IG9uVGV4dCh2YWx1ZTogc3RyaW5nIHwgT2JzZXJ2YWJsZTxzdHJpbmc+KSB7XG5cdFx0dGhpcy5fb25WYWx1ZXMub3ZlcnJpZGUodmFsdWUpO1xuXHR9XG5cblx0Z2V0IG9uVGV4dCgpIHtcblx0XHRyZXR1cm4gdGhpcy5fb25WYWx1ZXMudmFsdWU7XG5cdH1cblx0LyoqXG5cdCAqIFRleHQgdGhhdCBpcyBzZXQgYXMgdGhlIGxhYmVsIG9mIHRoZSB0b2dnbGUuXG5cdCAqL1xuXHRASW5wdXQoKSBsYWJlbDogc3RyaW5nIHwgVGVtcGxhdGVSZWY8YW55Pjtcblx0LyoqXG5cdCAqIFNpemUgb2YgdGhlIHRvZ2dsZSBjb21wb25lbnQuXG5cdCAqL1xuXHRASW5wdXQoKSBzaXplOiBcInNtXCIgfCBcIm1kXCIgPSBcIm1kXCI7XG5cdC8qKlxuXHQgKiBTZXQgdG8gYHRydWVgIHRvIGhpZGUgdGhlIHRvZ2dsZSBsYWJlbCAmIHNldCB0b2dnbGUgb24vb2ZmIHRleHQgdG8gbGFiZWwuXG5cdCAqL1xuXHRASW5wdXQoKSBoaWRlTGFiZWwgPSBmYWxzZTtcblxuXHRASG9zdEJpbmRpbmcoXCJjbGFzcy5jZHMtLXRvZ2dsZS0tc2tlbGV0b25cIikgQElucHV0KCkgc2tlbGV0b24gPSBmYWxzZTtcblxuXHRASG9zdEJpbmRpbmcoXCJjbGFzcy5jZHMtLXRvZ2dsZVwiKSB0b2dnbGVDbGFzcyA9IHRydWU7XG5cdEBIb3N0QmluZGluZyhcImNsYXNzLmNkcy0tdG9nZ2xlLS1kaXNhYmxlZFwiKSBnZXQgZGlzYWJsZWRDbGFzcyAoKSB7XG5cdFx0cmV0dXJuIHRoaXMuZGlzYWJsZWQ7XG5cdH1cblxuXHRASG9zdEJpbmRpbmcoXCJjbGFzcy5jZHMtLWZvcm0taXRlbVwiKSBnZXQgZm9ybUl0ZW0oKSB7XG5cdFx0cmV0dXJuICF0aGlzLnNrZWxldG9uO1xuXHR9XG5cblx0LyoqXG5cdCAqIFRoZSB1bmlxdWUgaWQgYWxsb2NhdGVkIHRvIHRoZSBgVG9nZ2xlYC5cblx0ICovXG5cdGlkID0gXCJ0b2dnbGUtXCIgKyBUb2dnbGUudG9nZ2xlQ291bnQ7XG5cblx0cHJvdGVjdGVkIF9vZmZWYWx1ZXMgPSB0aGlzLmkxOG4uZ2V0T3ZlcnJpZGFibGUoXCJUT0dHTEUuT0ZGXCIpO1xuXHRwcm90ZWN0ZWQgX29uVmFsdWVzID0gdGhpcy5pMThuLmdldE92ZXJyaWRhYmxlKFwiVE9HR0xFLk9OXCIpO1xuXHQvKipcblx0ICogQ3JlYXRlcyBhbiBpbnN0YW5jZSBvZiBUb2dnbGUuXG5cdCAqL1xuXHRjb25zdHJ1Y3Rvcihwcm90ZWN0ZWQgY2hhbmdlRGV0ZWN0b3JSZWY6IENoYW5nZURldGVjdG9yUmVmLCBwcm90ZWN0ZWQgaTE4bjogSTE4bikge1xuXHRcdHN1cGVyKGNoYW5nZURldGVjdG9yUmVmKTtcblx0XHRUb2dnbGUudG9nZ2xlQ291bnQrKztcblx0fVxuXG5cdC8qKlxuXHQgKiBgQ29udHJvbFZhbHVlQWNjZXNzb3JgIG1ldGhvZCB0byBwcm9ncmFtbWF0aWNhbGx5IGRpc2FibGUgdGhlIHRvZ2dsZSBpbnB1dC5cblx0ICpcblx0ICogZXg6IGB0aGlzLmZvcm1Hcm91cC5nZXQoXCJteVRvZ2dsZVwiKS5kaXNhYmxlKCk7YFxuXHQgKlxuXHQgKiBAcGFyYW0gaXNEaXNhYmxlZCBgdHJ1ZWAgdG8gZGlzYWJsZSB0aGUgaW5wdXRcblx0ICovXG5cdHNldERpc2FibGVkU3RhdGUoaXNEaXNhYmxlZDogYm9vbGVhbikge1xuXHRcdHRoaXMuZGlzYWJsZWQgPSBpc0Rpc2FibGVkO1xuXHR9XG5cblx0Z2V0T2ZmVGV4dCgpOiBPYnNlcnZhYmxlPHN0cmluZz4ge1xuXHRcdHJldHVybiB0aGlzLl9vZmZWYWx1ZXMuc3ViamVjdDtcblx0fVxuXG5cdGdldE9uVGV4dCgpOiBPYnNlcnZhYmxlPHN0cmluZz4ge1xuXHRcdHJldHVybiB0aGlzLl9vblZhbHVlcy5zdWJqZWN0O1xuXHR9XG5cblx0Z2V0Q2hlY2tlZFRleHQoKTogT2JzZXJ2YWJsZTxzdHJpbmc+IHtcblx0XHRpZiAodGhpcy5jaGVja2VkKSB7XG5cdFx0XHRyZXR1cm4gdGhpcy5fb25WYWx1ZXMuc3ViamVjdDtcblx0XHR9XG5cdFx0cmV0dXJuIHRoaXMuX29mZlZhbHVlcy5zdWJqZWN0O1xuXHR9XG5cblx0LyoqXG5cdCAqIENyZWF0ZXMgaW5zdGFuY2Ugb2YgYFRvZ2dsZUNoYW5nZWAgdXNlZCB0byBwcm9wYWdhdGUgdGhlIGNoYW5nZSBldmVudC5cblx0ICovXG5cdGVtaXRDaGFuZ2VFdmVudCgpIHtcblx0XHR0aGlzLmNoZWNrZWRDaGFuZ2UuZW1pdCh0aGlzLmNoZWNrZWQpO1xuXHRcdHRoaXMucHJvcGFnYXRlQ2hhbmdlKHRoaXMuY2hlY2tlZCk7XG5cdH1cblxuXHRwdWJsaWMgaXNUZW1wbGF0ZSh2YWx1ZSkge1xuXHRcdHJldHVybiB2YWx1ZSBpbnN0YW5jZW9mIFRlbXBsYXRlUmVmO1xuXHR9XG59XG4iXX0=
274
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9nZ2xlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90b2dnbGUvdG9nZ2xlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDOUQsT0FBTyxFQUVOLFNBQVMsRUFDVCxLQUFLLEVBQ0wsV0FBVyxFQUNYLFdBQVcsRUFDWCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7OztBQUtuRDs7O0dBR0c7QUFDSCxNQUFNLENBQU4sSUFBWSxXQUlYO0FBSkQsV0FBWSxXQUFXO0lBQ3RCLDZDQUFJLENBQUE7SUFDSixtREFBTyxDQUFBO0lBQ1AsdURBQVMsQ0FBQTtBQUNWLENBQUMsRUFKVyxXQUFXLEtBQVgsV0FBVyxRQUl0QjtBQUVEOzs7O0dBSUc7QUFFSDs7Ozs7Ozs7Ozs7O0dBWUc7QUFnRUgsTUFBTSxPQUFPLE1BQU8sU0FBUSxRQUFRO0lBaUVuQzs7T0FFRztJQUNILFlBQXNCLGlCQUFvQyxFQUFZLElBQVU7UUFDL0UsS0FBSyxDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFESixzQkFBaUIsR0FBakIsaUJBQWlCLENBQW1CO1FBQVksU0FBSSxHQUFKLElBQUksQ0FBTTtRQW5DaEY7O1dBRUc7UUFDTSxTQUFJLEdBQWdCLElBQUksQ0FBQztRQUNsQzs7V0FFRztRQUNNLGNBQVMsR0FBRyxLQUFLLENBQUM7UUFPMEIsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUVwQyxnQkFBVyxHQUFHLElBQUksQ0FBQztRQVNyRDs7V0FFRztRQUNILE9BQUUsR0FBRyxTQUFTLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQztRQUUxQixlQUFVLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDcEQsY0FBUyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBTTNELE1BQU0sQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUN0QixDQUFDO0lBakVEOztPQUVHO0lBQ0gsSUFDSSxPQUFPLENBQUMsS0FBa0M7UUFDN0MsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUVELElBQUksT0FBTztRQUNWLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUM7SUFDOUIsQ0FBQztJQUVEOztPQUVHO0lBQ0gsSUFDSSxNQUFNLENBQUMsS0FBa0M7UUFDNUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDaEMsQ0FBQztJQUVELElBQUksTUFBTTtRQUNULE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUM7SUFDN0IsQ0FBQztJQXNCRCxJQUFnRCxhQUFhO1FBQzVELE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN0QixDQUFDO0lBRUQsSUFBeUMsUUFBUTtRQUNoRCxPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN2QixDQUFDO0lBaUJEOzs7Ozs7T0FNRztJQUNILGdCQUFnQixDQUFDLFVBQW1CO1FBQ25DLElBQUksQ0FBQyxRQUFRLEdBQUcsVUFBVSxDQUFDO0lBQzVCLENBQUM7SUFFRCxVQUFVO1FBQ1QsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQztJQUNoQyxDQUFDO0lBRUQsU0FBUztRQUNSLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUM7SUFDL0IsQ0FBQztJQUVELGNBQWM7UUFDYixJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUU7WUFDakIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQztTQUM5QjtRQUNELE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUM7SUFDaEMsQ0FBQztJQUVEOztPQUVHO0lBQ0gsZUFBZTtRQUNkLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN0QyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRU0sVUFBVSxDQUFDLEtBQUs7UUFDdEIsT0FBTyxLQUFLLFlBQVksV0FBVyxDQUFDO0lBQ3JDLENBQUM7O0FBNUdEOztHQUVHO0FBQ0ksa0JBQVcsR0FBRyxDQUFDLENBQUM7bUdBSlgsTUFBTTt1RkFBTixNQUFNLHdaQVJQO1FBQ1Y7WUFDQyxPQUFPLEVBQUUsaUJBQWlCO1lBQzFCLFdBQVcsRUFBRSxNQUFNO1lBQ25CLEtBQUssRUFBRSxJQUFJO1NBQ1g7S0FDRCxpREEzRFM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7RUFvRFQ7MkZBU1csTUFBTTtrQkEvRGxCLFNBQVM7bUJBQUM7b0JBQ1YsUUFBUSxFQUFFLHdCQUF3QjtvQkFDbEMsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0VBb0RUO29CQUNELFNBQVMsRUFBRTt3QkFDVjs0QkFDQyxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLFFBQVE7NEJBQ25CLEtBQUssRUFBRSxJQUFJO3lCQUNYO3FCQUNEO2lCQUNEOzJIQVdJLE9BQU87c0JBRFYsS0FBSztnQkFhRixNQUFNO3NCQURULEtBQUs7Z0JBV0csS0FBSztzQkFBYixLQUFLO2dCQUlHLElBQUk7c0JBQVosS0FBSztnQkFJRyxTQUFTO3NCQUFqQixLQUFLO2dCQUtHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBRStDLFFBQVE7c0JBQTVELFdBQVc7dUJBQUMsNkJBQTZCOztzQkFBRyxLQUFLO2dCQUVoQixXQUFXO3NCQUE1QyxXQUFXO3VCQUFDLG1CQUFtQjtnQkFDZ0IsYUFBYTtzQkFBNUQsV0FBVzt1QkFBQyw2QkFBNkI7Z0JBSUQsUUFBUTtzQkFBaEQsV0FBVzt1QkFBQyxzQkFBc0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGVja2JveCB9IGZyb20gXCJjYXJib24tY29tcG9uZW50cy1hbmd1bGFyL2NoZWNrYm94XCI7XG5pbXBvcnQge1xuXHRDaGFuZ2VEZXRlY3RvclJlZixcblx0Q29tcG9uZW50LFxuXHRJbnB1dCxcblx0SG9zdEJpbmRpbmcsXG5cdFRlbXBsYXRlUmVmXG59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuXG5pbXBvcnQgeyBJMThuIH0gZnJvbSBcImNhcmJvbi1jb21wb25lbnRzLWFuZ3VsYXIvaTE4blwiO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gXCJyeGpzXCI7XG5cbi8qKlxuICogQGRlcHJlY2F0ZWQgc2luY2UgdjUgLSBVc2UgYm9vbGVhblxuICogRGVmaW5lcyB0aGUgc2V0IG9mIHN0YXRlcyBmb3IgYSB0b2dnbGUgY29tcG9uZW50LlxuICovXG5leHBvcnQgZW51bSBUb2dnbGVTdGF0ZSB7XG5cdEluaXQsXG5cdENoZWNrZWQsXG5cdFVuY2hlY2tlZFxufVxuXG4vKipcbiAqIEB0b2RvIC0gVG9nZ2xlIGNvbXBvbmVudCB3aWxsIG5vIGxvbmdlciBleHRlbmQgYENoZWNrYm94YCBjb21wb25lbnQgYXMgb2YgdjZcbiAqIFRvZ2dsZSBpcyBubyBsb25nZXIgcmVwaWVzIG9uIHVzaW5nIGNoZWNrYm94LCBzbyBkb2Vzbid0IG1ha2Ugc2Vuc2UgZm9yIHVzIHRvIGNvbnRpbnVlIGluaGVyaXRpbmcgQUxMIGNoZWNrYm94XG4gKiBjb21wb25lbnQgYXR0cmlidXRlcy5cbiAqL1xuXG4vKipcbiAqIEdldCBzdGFydGVkIHdpdGggaW1wb3J0aW5nIHRoZSBtb2R1bGU6XG4gKlxuICogYGBgdHlwZXNjcmlwdFxuICogaW1wb3J0IHsgVG9nZ2xlTW9kdWxlIH0gZnJvbSAnY2FyYm9uLWNvbXBvbmVudHMtYW5ndWxhcic7XG4gKiBgYGBcbiAqXG4gKiBgYGBodG1sXG4gKiA8Y2RzLXRvZ2dsZSBbKG5nTW9kZWwpXT1cInRvZ2dsZVN0YXRlXCI+VG9nZ2xlPC9jZHMtdG9nZ2xlPlxuICogYGBgXG4gKlxuICogW1NlZSBkZW1vXSguLi8uLi8/cGF0aD0vc3RvcnkvY29tcG9uZW50cy10b2dnbGUtLWJhc2ljKVxuICovXG5AQ29tcG9uZW50KHtcblx0c2VsZWN0b3I6IFwiY2RzLXRvZ2dsZSwgaWJtLXRvZ2dsZVwiLFxuXHR0ZW1wbGF0ZTogYFxuXHRcdDxuZy1jb250YWluZXIgKm5nSWY9XCIhc2tlbGV0b247IGVsc2Ugc2tlbGV0b25UZW1wbGF0ZTtcIj5cblx0XHRcdDxidXR0b25cblx0XHRcdFx0Y2xhc3M9XCJjZHMtLXRvZ2dsZV9fYnV0dG9uXCJcblx0XHRcdFx0W2Rpc2FibGVkXT1cImRpc2FibGVkXCJcblx0XHRcdFx0W2lkXT1cImlkXCJcblx0XHRcdFx0cm9sZT1cInN3aXRjaFwiXG5cdFx0XHRcdHR5cGU9XCJidXR0b25cIlxuXHRcdFx0XHRbYXR0ci5hcmlhLWNoZWNrZWRdPVwiY2hlY2tlZFwiXG5cdFx0XHRcdChjbGljayk9XCJvbkNsaWNrKCRldmVudClcIlxuXHRcdFx0XHRbYXR0ci5hcmlhLWxhYmVsXT1cImFyaWFMYWJlbFwiPlxuXHRcdFx0PC9idXR0b24+XG5cdFx0XHQ8bGFiZWxcblx0XHRcdFx0Y2xhc3M9XCJjZHMtLXRvZ2dsZV9fbGFiZWxcIlxuXHRcdFx0XHRbZm9yXT1cImlkXCI+XG5cdFx0XHRcdDxzcGFuXG5cdFx0XHRcdFx0Y2xhc3M9XCJjZHMtLXRvZ2dsZV9fbGFiZWwtdGV4dFwiXG5cdFx0XHRcdFx0W25nQ2xhc3NdPVwie1xuXHRcdFx0XHRcdFx0J2Nkcy0tdmlzdWFsbHktaGlkZGVuJzogaGlkZUxhYmVsXG5cdFx0XHRcdFx0fVwiPlxuXHRcdFx0XHRcdDxuZy1jb250YWluZXIgKm5nSWY9XCIhaXNUZW1wbGF0ZShsYWJlbClcIj57e2xhYmVsfX08L25nLWNvbnRhaW5lcj5cblx0XHRcdFx0XHQ8bmctdGVtcGxhdGUgKm5nSWY9XCJpc1RlbXBsYXRlKGxhYmVsKVwiIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImxhYmVsXCI+PC9uZy10ZW1wbGF0ZT5cblx0XHRcdFx0PC9zcGFuPlxuXHRcdFx0XHQ8ZGl2XG5cdFx0XHRcdFx0Y2xhc3M9XCJjZHMtLXRvZ2dsZV9fYXBwZWFyYW5jZVwiXG5cdFx0XHRcdFx0W25nQ2xhc3NdPVwie1xuXHRcdFx0XHRcdFx0J2Nkcy0tdG9nZ2xlX19hcHBlYXJhbmNlLS1zbSc6IHNpemUgPT09ICdzbSdcblx0XHRcdFx0XHR9XCI+XG5cdFx0XHRcdFx0PGRpdlxuXHRcdFx0XHRcdFx0Y2xhc3M9XCJjZHMtLXRvZ2dsZV9fc3dpdGNoXCJcblx0XHRcdFx0XHRcdFtuZ0NsYXNzXT1cIntcblx0XHRcdFx0XHRcdFx0J2Nkcy0tdG9nZ2xlX19zd2l0Y2gtLWNoZWNrZWQnOiBjaGVja2VkXG5cdFx0XHRcdFx0XHR9XCI+XG5cdFx0XHRcdFx0XHQ8c3ZnXG5cdFx0XHRcdFx0XHRcdCpuZ0lmPVwic2l6ZSA9PT0gJ3NtJ1wiXG5cdFx0XHRcdFx0XHRcdGNsYXNzPSdjZHMtLXRvZ2dsZV9fY2hlY2snXG5cdFx0XHRcdFx0XHRcdHdpZHRoPVwiNnB4XCJcblx0XHRcdFx0XHRcdFx0aGVpZ2h0PVwiNXB4XCJcblx0XHRcdFx0XHRcdFx0dmlld0JveD1cIjAgMCA2IDVcIj5cblx0XHRcdFx0XHRcdFx0PHBhdGggZD1cIk0yLjIgMi43TDUgMCA2IDEgMi4yIDUgMCAyLjcgMSAxLjV6XCIgLz5cblx0XHRcdFx0XHRcdDwvc3ZnPlxuXHRcdFx0XHRcdDwvZGl2PlxuXHRcdFx0XHRcdDxzcGFuIGNsYXNzPVwiY2RzLS10b2dnbGVfX3RleHRcIj5cblx0XHRcdFx0XHRcdHt7KGhpZGVMYWJlbCA/IGxhYmVsIDogKGdldENoZWNrZWRUZXh0KCkgfCBhc3luYykpfX1cblx0XHRcdFx0XHQ8L3NwYW4+XG5cdFx0XHRcdDwvZGl2PlxuXHRcdFx0PC9sYWJlbD5cblx0XHQ8L25nLWNvbnRhaW5lcj5cblx0XHQ8bmctdGVtcGxhdGUgI3NrZWxldG9uVGVtcGxhdGU+XG5cdFx0XHQ8ZGl2IGNsYXNzPVwiY2RzLS10b2dnbGVfX3NrZWxldG9uLWNpcmNsZVwiPjwvZGl2PlxuXHRcdFx0PGRpdiBjbGFzcz1cImNkcy0tdG9nZ2xlX19za2VsZXRvbi1yZWN0YW5nbGVcIj48L2Rpdj5cblx0XHQ8L25nLXRlbXBsYXRlPlxuXHRgLFxuXHRwcm92aWRlcnM6IFtcblx0XHR7XG5cdFx0XHRwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcblx0XHRcdHVzZUV4aXN0aW5nOiBUb2dnbGUsXG5cdFx0XHRtdWx0aTogdHJ1ZVxuXHRcdH1cblx0XVxufSlcbmV4cG9ydCBjbGFzcyBUb2dnbGUgZXh0ZW5kcyBDaGVja2JveCB7XG5cdC8qKlxuXHQgKiBWYXJpYWJsZSB1c2VkIGZvciBjcmVhdGluZyB1bmlxdWUgaWRzIGZvciB0b2dnbGUgY29tcG9uZW50cy5cblx0ICovXG5cdHN0YXRpYyB0b2dnbGVDb3VudCA9IDA7XG5cblx0LyoqXG5cdCAqIFRleHQgdGhhdCBpcyBzZXQgb24gdGhlIGxlZnQgc2lkZSBvZiB0aGUgdG9nZ2xlLlxuXHQgKi9cblx0QElucHV0KClcblx0c2V0IG9mZlRleHQodmFsdWU6IHN0cmluZyB8IE9ic2VydmFibGU8c3RyaW5nPikge1xuXHRcdHRoaXMuX29mZlZhbHVlcy5vdmVycmlkZSh2YWx1ZSk7XG5cdH1cblxuXHRnZXQgb2ZmVGV4dCgpIHtcblx0XHRyZXR1cm4gdGhpcy5fb2ZmVmFsdWVzLnZhbHVlO1xuXHR9XG5cblx0LyoqXG5cdCAqIFRleHQgdGhhdCBpcyBzZXQgb24gdGhlIHJpZ2h0IHNpZGUgb2YgdGhlIHRvZ2dsZS5cblx0ICovXG5cdEBJbnB1dCgpXG5cdHNldCBvblRleHQodmFsdWU6IHN0cmluZyB8IE9ic2VydmFibGU8c3RyaW5nPikge1xuXHRcdHRoaXMuX29uVmFsdWVzLm92ZXJyaWRlKHZhbHVlKTtcblx0fVxuXG5cdGdldCBvblRleHQoKSB7XG5cdFx0cmV0dXJuIHRoaXMuX29uVmFsdWVzLnZhbHVlO1xuXHR9XG5cdC8qKlxuXHQgKiBUZXh0IHRoYXQgaXMgc2V0IGFzIHRoZSBsYWJlbCBvZiB0aGUgdG9nZ2xlLlxuXHQgKi9cblx0QElucHV0KCkgbGFiZWw6IHN0cmluZyB8IFRlbXBsYXRlUmVmPGFueT47XG5cdC8qKlxuXHQgKiBTaXplIG9mIHRoZSB0b2dnbGUgY29tcG9uZW50LlxuXHQgKi9cblx0QElucHV0KCkgc2l6ZTogXCJzbVwiIHwgXCJtZFwiID0gXCJtZFwiO1xuXHQvKipcblx0ICogU2V0IHRvIGB0cnVlYCB0byBoaWRlIHRoZSB0b2dnbGUgbGFiZWwgJiBzZXQgdG9nZ2xlIG9uL29mZiB0ZXh0IHRvIGxhYmVsLlxuXHQgKi9cblx0QElucHV0KCkgaGlkZUxhYmVsID0gZmFsc2U7XG5cblx0LyoqXG5cdCAqIFNldCBgYXJpYS1sYWJlbGAgcHJvcGVydHkgZm9yIHRoZSBidXR0b24gd2hlbiBsYWJlbCBpcyBlbXB0eVxuXHQgKi9cblx0QElucHV0KCkgYXJpYUxhYmVsOiBzdHJpbmc7XG5cblx0QEhvc3RCaW5kaW5nKFwiY2xhc3MuY2RzLS10b2dnbGUtLXNrZWxldG9uXCIpIEBJbnB1dCgpIHNrZWxldG9uID0gZmFsc2U7XG5cblx0QEhvc3RCaW5kaW5nKFwiY2xhc3MuY2RzLS10b2dnbGVcIikgdG9nZ2xlQ2xhc3MgPSB0cnVlO1xuXHRASG9zdEJpbmRpbmcoXCJjbGFzcy5jZHMtLXRvZ2dsZS0tZGlzYWJsZWRcIikgZ2V0IGRpc2FibGVkQ2xhc3MgKCkge1xuXHRcdHJldHVybiB0aGlzLmRpc2FibGVkO1xuXHR9XG5cblx0QEhvc3RCaW5kaW5nKFwiY2xhc3MuY2RzLS1mb3JtLWl0ZW1cIikgZ2V0IGZvcm1JdGVtKCkge1xuXHRcdHJldHVybiAhdGhpcy5za2VsZXRvbjtcblx0fVxuXG5cdC8qKlxuXHQgKiBUaGUgdW5pcXVlIGlkIGFsbG9jYXRlZCB0byB0aGUgYFRvZ2dsZWAuXG5cdCAqL1xuXHRpZCA9IFwidG9nZ2xlLVwiICsgVG9nZ2xlLnRvZ2dsZUNvdW50O1xuXG5cdHByb3RlY3RlZCBfb2ZmVmFsdWVzID0gdGhpcy5pMThuLmdldE92ZXJyaWRhYmxlKFwiVE9HR0xFLk9GRlwiKTtcblx0cHJvdGVjdGVkIF9vblZhbHVlcyA9IHRoaXMuaTE4bi5nZXRPdmVycmlkYWJsZShcIlRPR0dMRS5PTlwiKTtcblx0LyoqXG5cdCAqIENyZWF0ZXMgYW4gaW5zdGFuY2Ugb2YgVG9nZ2xlLlxuXHQgKi9cblx0Y29uc3RydWN0b3IocHJvdGVjdGVkIGNoYW5nZURldGVjdG9yUmVmOiBDaGFuZ2VEZXRlY3RvclJlZiwgcHJvdGVjdGVkIGkxOG46IEkxOG4pIHtcblx0XHRzdXBlcihjaGFuZ2VEZXRlY3RvclJlZik7XG5cdFx0VG9nZ2xlLnRvZ2dsZUNvdW50Kys7XG5cdH1cblxuXHQvKipcblx0ICogYENvbnRyb2xWYWx1ZUFjY2Vzc29yYCBtZXRob2QgdG8gcHJvZ3JhbW1hdGljYWxseSBkaXNhYmxlIHRoZSB0b2dnbGUgaW5wdXQuXG5cdCAqXG5cdCAqIGV4OiBgdGhpcy5mb3JtR3JvdXAuZ2V0KFwibXlUb2dnbGVcIikuZGlzYWJsZSgpO2Bcblx0ICpcblx0ICogQHBhcmFtIGlzRGlzYWJsZWQgYHRydWVgIHRvIGRpc2FibGUgdGhlIGlucHV0XG5cdCAqL1xuXHRzZXREaXNhYmxlZFN0YXRlKGlzRGlzYWJsZWQ6IGJvb2xlYW4pIHtcblx0XHR0aGlzLmRpc2FibGVkID0gaXNEaXNhYmxlZDtcblx0fVxuXG5cdGdldE9mZlRleHQoKTogT2JzZXJ2YWJsZTxzdHJpbmc+IHtcblx0XHRyZXR1cm4gdGhpcy5fb2ZmVmFsdWVzLnN1YmplY3Q7XG5cdH1cblxuXHRnZXRPblRleHQoKTogT2JzZXJ2YWJsZTxzdHJpbmc+IHtcblx0XHRyZXR1cm4gdGhpcy5fb25WYWx1ZXMuc3ViamVjdDtcblx0fVxuXG5cdGdldENoZWNrZWRUZXh0KCk6IE9ic2VydmFibGU8c3RyaW5nPiB7XG5cdFx0aWYgKHRoaXMuY2hlY2tlZCkge1xuXHRcdFx0cmV0dXJuIHRoaXMuX29uVmFsdWVzLnN1YmplY3Q7XG5cdFx0fVxuXHRcdHJldHVybiB0aGlzLl9vZmZWYWx1ZXMuc3ViamVjdDtcblx0fVxuXG5cdC8qKlxuXHQgKiBDcmVhdGVzIGluc3RhbmNlIG9mIGBUb2dnbGVDaGFuZ2VgIHVzZWQgdG8gcHJvcGFnYXRlIHRoZSBjaGFuZ2UgZXZlbnQuXG5cdCAqL1xuXHRlbWl0Q2hhbmdlRXZlbnQoKSB7XG5cdFx0dGhpcy5jaGVja2VkQ2hhbmdlLmVtaXQodGhpcy5jaGVja2VkKTtcblx0XHR0aGlzLnByb3BhZ2F0ZUNoYW5nZSh0aGlzLmNoZWNrZWQpO1xuXHR9XG5cblx0cHVibGljIGlzVGVtcGxhdGUodmFsdWUpIHtcblx0XHRyZXR1cm4gdmFsdWUgaW5zdGFuY2VvZiBUZW1wbGF0ZVJlZjtcblx0fVxufVxuIl19
@@ -1,8 +1,9 @@
1
1
  import * as i0 from '@angular/core';
2
- import { Component, Input, HostBinding, EventEmitter, Output, NgModule } from '@angular/core';
3
- import * as i1 from 'carbon-components-angular/icon';
4
- import { IconModule } from 'carbon-components-angular/icon';
2
+ import { Component, Input, HostBinding, EventEmitter, Output, Directive, ChangeDetectionStrategy, HostListener, NgModule } from '@angular/core';
3
+ import * as i1 from '@angular/common';
5
4
  import { CommonModule } from '@angular/common';
5
+ import * as i2 from 'carbon-components-angular/icon';
6
+ import { IconModule } from 'carbon-components-angular/icon';
6
7
 
7
8
  /**
8
9
  * Component that represents a tag for labelling/categorizing using keywords. Get started with importing the module:
@@ -24,18 +25,39 @@ class Tag {
24
25
  */
25
26
  this.size = "md";
26
27
  this.class = "";
28
+ this.skeleton = false;
27
29
  }
30
+ /**
31
+ * @todo
32
+ * Remove `cds--tag--${this.size}` in v7
33
+ */
28
34
  get attrClass() {
29
- return `cds--tag cds--tag--${this.type} cds--tag--${this.size} cds--layout--size-${this.size} ${this.class}`;
35
+ const skeletonClass = this.skeleton ? "cds--skeleton" : "";
36
+ const sizeClass = `cds--tag--${this.size} cds--layout--size-${this.size}`;
37
+ return `cds--tag cds--tag--${this.type} ${sizeClass} ${skeletonClass} ${this.class}`;
30
38
  }
31
39
  }
32
40
  Tag.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: Tag, deps: [], target: i0.ɵɵFactoryTarget.Component });
33
- Tag.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: Tag, selector: "cds-tag, ibm-tag", inputs: { type: "type", size: "size", class: "class" }, host: { properties: { "attr.class": "this.attrClass" } }, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true });
41
+ Tag.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: Tag, selector: "cds-tag, ibm-tag", inputs: { type: "type", size: "size", class: "class", skeleton: "skeleton" }, host: { properties: { "attr.class": "this.attrClass" } }, ngImport: i0, template: `
42
+ <ng-container *ngIf="!skeleton">
43
+ <ng-content select="[cdsTagIcon],[ibmTagIcon]"></ng-content>
44
+ <span class="cds--tag__label">
45
+ <ng-content></ng-content>
46
+ </span>
47
+ </ng-container>
48
+ `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
34
49
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: Tag, decorators: [{
35
50
  type: Component,
36
51
  args: [{
37
52
  selector: "cds-tag, ibm-tag",
38
- template: `<ng-content></ng-content>`
53
+ template: `
54
+ <ng-container *ngIf="!skeleton">
55
+ <ng-content select="[cdsTagIcon],[ibmTagIcon]"></ng-content>
56
+ <span class="cds--tag__label">
57
+ <ng-content></ng-content>
58
+ </span>
59
+ </ng-container>
60
+ `
39
61
  }]
40
62
  }], propDecorators: { type: [{
41
63
  type: Input
@@ -43,6 +65,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
43
65
  type: Input
44
66
  }], class: [{
45
67
  type: Input
68
+ }], skeleton: [{
69
+ type: Input
46
70
  }], attrClass: [{
47
71
  type: HostBinding,
48
72
  args: ["attr.class"]
@@ -52,6 +76,7 @@ class TagFilter extends Tag {
52
76
  constructor() {
53
77
  super(...arguments);
54
78
  this.closeButtonLabel = "Clear Filter";
79
+ this.disabled = false;
55
80
  /**
56
81
  * Function for close/delete the tag
57
82
  */
@@ -77,8 +102,15 @@ class TagFilter extends Tag {
77
102
  this.click.emit({ action: "close" });
78
103
  this.close.emit();
79
104
  }
105
+ /**
106
+ * @todo
107
+ * Remove `cds--tag--${this.size}` in v7
108
+ */
80
109
  get attrClass() {
81
- return `cds--tag cds--tag--filter cds--tag--${this.type} cds--tag--${this.size} cds--layout--size-${this.size} ${this.class}${this.disabled ? " cds--tag--disabled" : ""}`;
110
+ const disabledClass = this.disabled ? "cds--tag--disabled" : "";
111
+ const sizeClass = `cds--tag--${this.size} cds--layout--size-${this.size}`;
112
+ const skeletonClass = this.skeleton ? "cds--skeleton" : "";
113
+ return `cds--tag cds--tag--filter cds--tag--${this.type} ${disabledClass} ${sizeClass} ${skeletonClass} ${this.class}`;
82
114
  }
83
115
  get attrAriaLabel() {
84
116
  return `${this.title || ""} ${this.closeButtonLabel}`.trim();
@@ -86,40 +118,46 @@ class TagFilter extends Tag {
86
118
  }
87
119
  TagFilter.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TagFilter, deps: null, target: i0.ɵɵFactoryTarget.Component });
88
120
  TagFilter.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TagFilter, selector: "cds-tag-filter, ibm-tag-filter", inputs: { closeButtonLabel: "closeButtonLabel", disabled: "disabled", title: "title" }, outputs: { close: "close", click: "click" }, host: { properties: { "attr.class": "this.attrClass", "attr.aria-label": "this.attrAriaLabel" } }, usesInheritance: true, ngImport: i0, template: `
89
- <span
90
- class="cds--tag__label"
91
- [attr.title]="title ? title : null"
92
- (click)="onClick($event)">
93
- <ng-content></ng-content>
94
- </span>
95
- <button
96
- class="cds--tag__close-icon"
97
- (click)="onClose($event)"
98
- [disabled]="disabled"
99
- [title]="closeButtonLabel">
100
- <span class="cds--visually-hidden">{{closeButtonLabel}}</span>
101
- <svg cdsIcon="close" size="16"></svg>
102
- </button>
103
- `, isInline: true, dependencies: [{ kind: "directive", type: i1.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }] });
121
+ <ng-container *ngIf="!skeleton">
122
+ <ng-content select="[cdsTagIcon],[ibmTagIcon]"></ng-content>
123
+ <span
124
+ class="cds--tag__label"
125
+ [attr.title]="title ? title : null"
126
+ (click)="onClick($event)">
127
+ <ng-content></ng-content>
128
+ </span>
129
+ <button
130
+ class="cds--tag__close-icon"
131
+ (click)="onClose($event)"
132
+ [disabled]="disabled"
133
+ [title]="closeButtonLabel">
134
+ <span class="cds--visually-hidden">{{closeButtonLabel}}</span>
135
+ <svg cdsIcon="close" size="16"></svg>
136
+ </button>
137
+ </ng-container>
138
+ `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }] });
104
139
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TagFilter, decorators: [{
105
140
  type: Component,
106
141
  args: [{
107
142
  selector: "cds-tag-filter, ibm-tag-filter",
108
143
  template: `
109
- <span
110
- class="cds--tag__label"
111
- [attr.title]="title ? title : null"
112
- (click)="onClick($event)">
113
- <ng-content></ng-content>
114
- </span>
115
- <button
116
- class="cds--tag__close-icon"
117
- (click)="onClose($event)"
118
- [disabled]="disabled"
119
- [title]="closeButtonLabel">
120
- <span class="cds--visually-hidden">{{closeButtonLabel}}</span>
121
- <svg cdsIcon="close" size="16"></svg>
122
- </button>
144
+ <ng-container *ngIf="!skeleton">
145
+ <ng-content select="[cdsTagIcon],[ibmTagIcon]"></ng-content>
146
+ <span
147
+ class="cds--tag__label"
148
+ [attr.title]="title ? title : null"
149
+ (click)="onClick($event)">
150
+ <ng-content></ng-content>
151
+ </span>
152
+ <button
153
+ class="cds--tag__close-icon"
154
+ (click)="onClose($event)"
155
+ [disabled]="disabled"
156
+ [title]="closeButtonLabel">
157
+ <span class="cds--visually-hidden">{{closeButtonLabel}}</span>
158
+ <svg cdsIcon="close" size="16"></svg>
159
+ </button>
160
+ </ng-container>
123
161
  `
124
162
  }]
125
163
  }], propDecorators: { closeButtonLabel: [{
@@ -140,16 +178,197 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
140
178
  args: ["attr.aria-label"]
141
179
  }] } });
142
180
 
181
+ class TagIconDirective {
182
+ constructor() {
183
+ this.tagIcon = true;
184
+ }
185
+ }
186
+ TagIconDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TagIconDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
187
+ TagIconDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: TagIconDirective, selector: "[cdsTagIcon], [ibmTagIcon]", host: { properties: { "class.cds--tag__custom-icon": "this.tagIcon" } }, ngImport: i0 });
188
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TagIconDirective, decorators: [{
189
+ type: Directive,
190
+ args: [{
191
+ selector: "[cdsTagIcon], [ibmTagIcon]"
192
+ }]
193
+ }], propDecorators: { tagIcon: [{
194
+ type: HostBinding,
195
+ args: ["class.cds--tag__custom-icon"]
196
+ }] } });
197
+
198
+ class TagSelectableComponent {
199
+ constructor() {
200
+ this.role = "button";
201
+ this.buttonType = "button";
202
+ this.tabIndex = 0;
203
+ this.size = "md";
204
+ this.skeleton = false;
205
+ this.disabled = false;
206
+ this.class = "";
207
+ this.selected = false;
208
+ this.selectedChange = new EventEmitter();
209
+ }
210
+ get ariaPressed() {
211
+ return this.selected;
212
+ }
213
+ onClick() {
214
+ this.selected = !this.selected;
215
+ this.selectedChange.emit(this.selected);
216
+ }
217
+ /**
218
+ * @todo
219
+ * Remove `cds--tag--${this.size}` in v7
220
+ */
221
+ get attrClass() {
222
+ const disabledClass = this.disabled ? "cds--tag--disabled" : "";
223
+ const sizeClass = `cds--tag--${this.size} cds--layout--size-${this.size}`;
224
+ const skeletonClass = this.skeleton ? "cds--skeleton" : "";
225
+ const selectedClass = this.selected ? "cds--tag--selectable-selected" : "";
226
+ return `cds--tag cds--tag--selectable ${selectedClass} ${disabledClass} ${sizeClass} ${skeletonClass} ${this.class}`;
227
+ }
228
+ }
229
+ TagSelectableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TagSelectableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
230
+ TagSelectableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TagSelectableComponent, selector: "cds-tag-selectable, ibm-tag-selectable", inputs: { size: "size", skeleton: "skeleton", disabled: "disabled", class: "class", selected: "selected" }, outputs: { selectedChange: "selectedChange" }, host: { listeners: { "click": "onClick()" }, properties: { "attr.role": "this.role", "attr.type": "this.buttonType", "attr.tabindex": "this.tabIndex", "attr.aria-pressed": "this.ariaPressed", "attr.class": "this.attrClass" } }, ngImport: i0, template: `
231
+ <ng-container *ngIf="!skeleton">
232
+ <ng-content select="[cdsTagIcon],[ibmTagIcon]"></ng-content>
233
+ <span class="cds--tag__label">
234
+ <ng-content></ng-content>
235
+ </span>
236
+ </ng-container>
237
+ `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
238
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TagSelectableComponent, decorators: [{
239
+ type: Component,
240
+ args: [{
241
+ selector: "cds-tag-selectable, ibm-tag-selectable",
242
+ template: `
243
+ <ng-container *ngIf="!skeleton">
244
+ <ng-content select="[cdsTagIcon],[ibmTagIcon]"></ng-content>
245
+ <span class="cds--tag__label">
246
+ <ng-content></ng-content>
247
+ </span>
248
+ </ng-container>
249
+ `,
250
+ changeDetection: ChangeDetectionStrategy.OnPush
251
+ }]
252
+ }], propDecorators: { role: [{
253
+ type: HostBinding,
254
+ args: ["attr.role"]
255
+ }], buttonType: [{
256
+ type: HostBinding,
257
+ args: ["attr.type"]
258
+ }], tabIndex: [{
259
+ type: HostBinding,
260
+ args: ["attr.tabindex"]
261
+ }], ariaPressed: [{
262
+ type: HostBinding,
263
+ args: ["attr.aria-pressed"]
264
+ }], size: [{
265
+ type: Input
266
+ }], skeleton: [{
267
+ type: Input
268
+ }], disabled: [{
269
+ type: Input
270
+ }], class: [{
271
+ type: Input
272
+ }], selected: [{
273
+ type: Input
274
+ }], selectedChange: [{
275
+ type: Output
276
+ }], onClick: [{
277
+ type: HostListener,
278
+ args: ["click"]
279
+ }], attrClass: [{
280
+ type: HostBinding,
281
+ args: ["attr.class"]
282
+ }] } });
283
+
284
+ class TagOperationalComponent extends Tag {
285
+ constructor() {
286
+ super(...arguments);
287
+ this.role = "button";
288
+ this.buttonType = "button";
289
+ this.tabIndex = 0;
290
+ this.disabled = false;
291
+ }
292
+ /**
293
+ * @todo
294
+ * Remove `cds--tag--${this.size}` in v7
295
+ */
296
+ get attrClass() {
297
+ const disabledClass = this.disabled ? "cds--tag--disabled" : "";
298
+ const sizeClass = `cds--tag--${this.size} cds--layout--size-${this.size}`;
299
+ const skeletonClass = this.skeleton ? "cds--skeleton" : "";
300
+ return `cds--tag cds--tag--operational cds--tag--${this.type} ${disabledClass} ${sizeClass} ${skeletonClass} ${this.class}`;
301
+ }
302
+ }
303
+ TagOperationalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TagOperationalComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
304
+ TagOperationalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TagOperationalComponent, selector: "cds-tag-operational, ibm-tag-operational", inputs: { disabled: "disabled" }, host: { properties: { "attr.role": "this.role", "attr.type": "this.buttonType", "attr.tabindex": "this.tabIndex", "attr.class": "this.attrClass" } }, usesInheritance: true, ngImport: i0, template: `
305
+ <ng-container *ngIf="!skeleton">
306
+ <ng-content select="[cdsTagIcon],[ibmTagIcon]"></ng-content>
307
+ <span class="cds--tag__label">
308
+ <ng-content></ng-content>
309
+ </span>
310
+ </ng-container>
311
+ `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
312
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TagOperationalComponent, decorators: [{
313
+ type: Component,
314
+ args: [{
315
+ selector: "cds-tag-operational, ibm-tag-operational",
316
+ template: `
317
+ <ng-container *ngIf="!skeleton">
318
+ <ng-content select="[cdsTagIcon],[ibmTagIcon]"></ng-content>
319
+ <span class="cds--tag__label">
320
+ <ng-content></ng-content>
321
+ </span>
322
+ </ng-container>
323
+ `,
324
+ changeDetection: ChangeDetectionStrategy.OnPush
325
+ }]
326
+ }], propDecorators: { role: [{
327
+ type: HostBinding,
328
+ args: ["attr.role"]
329
+ }], buttonType: [{
330
+ type: HostBinding,
331
+ args: ["attr.type"]
332
+ }], tabIndex: [{
333
+ type: HostBinding,
334
+ args: ["attr.tabindex"]
335
+ }], disabled: [{
336
+ type: Input
337
+ }], attrClass: [{
338
+ type: HostBinding,
339
+ args: ["attr.class"]
340
+ }] } });
341
+
143
342
  class TagModule {
144
343
  }
145
344
  TagModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TagModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
146
- TagModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: TagModule, declarations: [Tag, TagFilter], imports: [CommonModule, IconModule], exports: [Tag, TagFilter] });
345
+ TagModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: TagModule, declarations: [Tag,
346
+ TagFilter,
347
+ TagIconDirective,
348
+ TagSelectableComponent,
349
+ TagOperationalComponent], imports: [CommonModule, IconModule], exports: [Tag,
350
+ TagFilter,
351
+ TagIconDirective,
352
+ TagSelectableComponent,
353
+ TagOperationalComponent] });
147
354
  TagModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TagModule, imports: [CommonModule, IconModule] });
148
355
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TagModule, decorators: [{
149
356
  type: NgModule,
150
357
  args: [{
151
- declarations: [Tag, TagFilter],
152
- exports: [Tag, TagFilter],
358
+ declarations: [
359
+ Tag,
360
+ TagFilter,
361
+ TagIconDirective,
362
+ TagSelectableComponent,
363
+ TagOperationalComponent
364
+ ],
365
+ exports: [
366
+ Tag,
367
+ TagFilter,
368
+ TagIconDirective,
369
+ TagSelectableComponent,
370
+ TagOperationalComponent
371
+ ],
153
372
  imports: [CommonModule, IconModule]
154
373
  }]
155
374
  }] });
@@ -158,5 +377,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
158
377
  * Generated bundle index. Do not edit.
159
378
  */
160
379
 
161
- export { Tag, TagFilter, TagModule };
380
+ export { Tag, TagFilter, TagIconDirective, TagModule, TagOperationalComponent, TagSelectableComponent };
162
381
  //# sourceMappingURL=carbon-components-angular-tag.mjs.map