@skyux/lists 5.0.0 → 5.0.4

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 (46) hide show
  1. package/bundles/skyux-lists-testing.umd.js +31 -46
  2. package/bundles/skyux-lists-testing.umd.js.map +1 -1
  3. package/bundles/skyux-lists.umd.js +283 -310
  4. package/bundles/skyux-lists.umd.js.map +1 -1
  5. package/documentation.json +524 -707
  6. package/esm2015/modules/filter/filter-button.component.js +11 -19
  7. package/esm2015/modules/filter/filter-inline-item.component.js +5 -5
  8. package/esm2015/modules/filter/filter-inline.component.js +5 -5
  9. package/esm2015/modules/filter/filter-summary-item.component.js +6 -6
  10. package/esm2015/modules/filter/filter-summary.component.js +5 -5
  11. package/esm2015/modules/filter/filter.module.js +10 -15
  12. package/esm2015/modules/infinite-scroll/infinite-scroll-dom-adapter.service.js +11 -12
  13. package/esm2015/modules/infinite-scroll/infinite-scroll.component.js +10 -12
  14. package/esm2015/modules/infinite-scroll/infinite-scroll.module.js +8 -22
  15. package/esm2015/modules/paging/paging.component.js +9 -10
  16. package/esm2015/modules/paging/paging.module.js +9 -13
  17. package/esm2015/modules/repeater/repeater-adapter.service.js +4 -4
  18. package/esm2015/modules/repeater/repeater-item-content.component.js +5 -5
  19. package/esm2015/modules/repeater/repeater-item-context-menu.component.js +5 -5
  20. package/esm2015/modules/repeater/repeater-item-title.component.js +5 -5
  21. package/esm2015/modules/repeater/repeater-item.component.js +12 -12
  22. package/esm2015/modules/repeater/repeater.component.js +24 -26
  23. package/esm2015/modules/repeater/repeater.module.js +10 -10
  24. package/esm2015/modules/repeater/repeater.service.js +5 -5
  25. package/esm2015/modules/shared/sky-lists-resources.module.js +45 -12
  26. package/esm2015/modules/sort/sort-item.component.js +10 -9
  27. package/esm2015/modules/sort/sort-menu-heading.component.js +5 -5
  28. package/esm2015/modules/sort/sort.component.js +14 -29
  29. package/esm2015/modules/sort/sort.module.js +10 -14
  30. package/esm2015/modules/sort/sort.service.js +4 -4
  31. package/esm2015/testing/filter/filter-fixture-button.js +2 -2
  32. package/esm2015/testing/filter/filter-fixture-summary.js +1 -1
  33. package/esm2015/testing/filter/filter-testing.module.js +6 -8
  34. package/esm2015/testing/infinite-scroll/infinite-scroll-fixture.js +1 -1
  35. package/esm2015/testing/infinite-scroll/infinite-scroll-testing.module.js +6 -8
  36. package/esm2015/testing/paging/paging-fixture.js +2 -2
  37. package/esm2015/testing/paging/paging-testing.module.js +6 -8
  38. package/esm2015/testing/sort/sort-fixture.js +5 -6
  39. package/esm2015/testing/sort/sort-testing.module.js +7 -13
  40. package/fesm2015/skyux-lists-testing.js +27 -40
  41. package/fesm2015/skyux-lists-testing.js.map +1 -1
  42. package/fesm2015/skyux-lists.js +212 -233
  43. package/fesm2015/skyux-lists.js.map +1 -1
  44. package/modules/filter/filter-button.component.d.ts +2 -7
  45. package/modules/sort/sort.component.d.ts +2 -8
  46. package/package.json +13 -12
@@ -1,4 +1,4 @@
1
- import { Component, ContentChild, ContentChildren, ElementRef, EventEmitter, HostBinding, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
1
+ import { Component, ContentChild, ContentChildren, ElementRef, EventEmitter, HostBinding, Input, Output, ViewChild, ViewEncapsulation, } from '@angular/core';
2
2
  import { skyAnimationSlide } from '@skyux/animations';
3
3
  import { forkJoin as observableForkJoin, Subject } from 'rxjs';
4
4
  import { takeUntil } from 'rxjs/operators';
@@ -64,8 +64,7 @@ export class SkyRepeaterItemComponent {
64
64
  this._isSelected = false;
65
65
  this.slideForExpanded(false);
66
66
  // tslint:disable-next-line: deprecation
67
- observableForkJoin(this.resourceService.getString('skyux_repeater_item_reorder_cancel'), this.resourceService.getString('skyux_repeater_item_reorder_finish'), this.resourceService.getString('skyux_repeater_item_reorder_instructions'), this.resourceService.getString('skyux_repeater_item_reorder_operation'), this.resourceService.getString('skyux_repeater_item_reorder_moved'))
68
- .subscribe((translatedStrings) => {
67
+ observableForkJoin(this.resourceService.getString('skyux_repeater_item_reorder_cancel'), this.resourceService.getString('skyux_repeater_item_reorder_finish'), this.resourceService.getString('skyux_repeater_item_reorder_instructions'), this.resourceService.getString('skyux_repeater_item_reorder_operation'), this.resourceService.getString('skyux_repeater_item_reorder_moved')).subscribe((translatedStrings) => {
69
68
  this.reorderCancelText = translatedStrings[0];
70
69
  this.reorderFinishText = translatedStrings[1];
71
70
  this.reorderStateDescription = translatedStrings[2];
@@ -202,7 +201,8 @@ export class SkyRepeaterItemComponent {
202
201
  if (this.keyboardReorderingEnabled) {
203
202
  this.keyboardReorderingEnabled = false;
204
203
  this.revertReorderSteps();
205
- this.reorderButtonLabel = this.reorderCancelText + ' ' + this.reorderInstructions;
204
+ this.reorderButtonLabel =
205
+ this.reorderCancelText + ' ' + this.reorderInstructions;
206
206
  this.adapterService.focusElement(event.target);
207
207
  event.preventDefault();
208
208
  event.stopPropagation();
@@ -292,8 +292,7 @@ export class SkyRepeaterItemComponent {
292
292
  this.reorderState = this.reorderStateDescription;
293
293
  }
294
294
  else {
295
- this.reorderState =
296
- `${this.reorderFinishText} ${this.reorderCurrentIndex + 1} ${this.reorderInstructions}`;
295
+ this.reorderState = `${this.reorderFinishText} ${this.reorderCurrentIndex + 1} ${this.reorderInstructions}`;
297
296
  }
298
297
  }
299
298
  revertReorderSteps() {
@@ -311,7 +310,8 @@ export class SkyRepeaterItemComponent {
311
310
  .subscribe(() => {
312
311
  this.hasItemContent = this.repeaterItemContentComponents.length > 0;
313
312
  /* istanbul ignore next */
314
- this.isCollapsible = this.hasItemContent && this.repeaterService.expandMode !== 'none';
313
+ this.isCollapsible =
314
+ this.hasItemContent && this.repeaterService.expandMode !== 'none';
315
315
  /* istanbul ignore else */
316
316
  if (this.repeaterService.expandMode === 'single') {
317
317
  this.repeaterService.onItemCollapseStateChange(this);
@@ -319,16 +319,16 @@ export class SkyRepeaterItemComponent {
319
319
  });
320
320
  }
321
321
  }
322
- SkyRepeaterItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: SkyRepeaterItemComponent, deps: [{ token: i1.SkyRepeaterService }, { token: i0.ChangeDetectorRef }, { token: i2.SkyRepeaterAdapterService }, { token: i0.ElementRef }, { token: i3.SkyLibResourcesService }], target: i0.ɵɵFactoryTarget.Component });
323
- SkyRepeaterItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.7", type: SkyRepeaterItemComponent, selector: "sky-repeater-item", inputs: { inlineFormConfig: "inlineFormConfig", inlineFormTemplate: "inlineFormTemplate", isExpanded: "isExpanded", isSelected: "isSelected", reorderable: "reorderable", selectable: "selectable", showInlineForm: "showInlineForm", tag: "tag" }, outputs: { collapse: "collapse", expand: "expand", inlineFormClose: "inlineFormClose", isSelectedChange: "isSelectedChange" }, host: { properties: { "class": "this.repeaterGroupClass" } }, queries: [{ propertyName: "contextMenu", first: true, predicate: SkyRepeaterItemContextMenuComponent, descendants: true, read: ElementRef }, { propertyName: "repeaterItemContentComponents", predicate: SkyRepeaterItemContentComponent }], viewQueries: [{ propertyName: "grabHandle", first: true, predicate: ["grabHandle"], descendants: true, read: ElementRef }, { propertyName: "itemContentRef", first: true, predicate: ["itemContentRef"], descendants: true, read: ElementRef }, { propertyName: "itemHeaderRef", first: true, predicate: ["itemHeaderRef"], descendants: true, read: ElementRef }, { propertyName: "itemRef", first: true, predicate: ["itemRef"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div\n class=\"sky-repeater-item sky-padding-even-default\"\n role=\"option\"\n tabindex=\"0\"\n [ngClass]=\"{\n 'sky-repeater-item-active': isActive,\n 'sky-repeater-item-collapsible': isCollapsible,\n 'sky-repeater-item-selected': isSelected\n }\"\n (click)=\"onRepeaterItemClick($event)\"\n (keydown)=\"onItemKeyDown($event)\"\n #itemRef\n>\n <div #inlineDelete>\n <ng-content\n select=\"sky-inline-delete\"\n ></ng-content>\n </div>\n\n <ng-container *ngIf=\"inlineFormTemplate\">\n <sky-inline-form\n [config]=\"inlineFormConfig\"\n [showForm]=\"showInlineForm\"\n [template]=\"inlineFormTemplate\"\n (close)=\"onInlineFormClose($event)\"\n >\n <ng-container *ngTemplateOutlet=\"skyRepeaterItemLeft\"></ng-container>\n <ng-container *ngTemplateOutlet=\"skyRepeaterItemRight\"></ng-container>\n </sky-inline-form>\n </ng-container>\n\n <ng-container *ngIf=\"!inlineFormTemplate\">\n <ng-container *ngTemplateOutlet=\"skyRepeaterItemLeft\"></ng-container>\n <ng-container *ngTemplateOutlet=\"skyRepeaterItemRight\"></ng-container>\n </ng-container>\n</div>\n\n<ng-template\n #skyRepeaterItemLeft\n>\n <div\n class=\"sky-repeater-item-left\"\n >\n <ng-container *ngIf=\"reorderable\">\n <span\n aria-live=\"assertive\"\n class=\"sky-repeater-item-reorder-assistive-text\"\n [id]=\"contentId + '-reorder-state'\"\n >\n {{reorderState}}\n </span>\n <button\n class=\"sky-btn sky-tile-tools-control sky-repeater-item-grab-handle\"\n type=\"button\"\n [attr.aria-label]=\"reorderButtonLabel\"\n (blur)=\"onReorderHandleBlur($event)\"\n (keydown)=\"onReorderHandleKeyDown($event)\"\n #grabHandle\n >\n <sky-icon\n icon=\"arrows-v\"\n ></sky-icon>\n </button>\n </ng-container>\n <sky-checkbox\n *ngIf=\"selectable\"\n class=\"sky-repeater-item-checkbox\"\n [checked]=\"isSelected\"\n [label]=\"'skyux_repeater_item_checkbox_label' | skyLibResources\"\n (change)=\"onCheckboxChange($event)\"\n >\n </sky-checkbox>\n <div\n class=\"sky-repeater-item-context-menu\"\n [hidden]=\"contextMenuEl.children.length === 0\"\n #contextMenuEl\n >\n <ng-content\n select=\"sky-repeater-item-context-menu\"\n ></ng-content>\n </div>\n </div>\n</ng-template>\n\n<ng-template\n #skyRepeaterItemRight\n>\n <div\n class=\"sky-repeater-item-right\"\n #itemHeaderRef\n >\n <div\n class=\"sky-repeater-item-header\"\n [hidden]=\"titleRef.children.length === 0\"\n (click)=\"headerClick()\"\n >\n <div\n class=\"sky-repeater-item-title sky-emphasized\"\n #titleRef\n >\n <ng-content\n select=\"sky-repeater-item-title\"\n ></ng-content>\n </div>\n <button *ngIf=\"reorderable\"\n class=\"sky-btn sky-btn-link sky-repeater-item-reorder-top\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_repeater_item_reorder_top_label' | skyLibResources\"\n (click)=\"moveToTop($event)\"\n >\n <sky-icon\n icon=\"arrow-circle-up\"\n ></sky-icon>\n {{ 'skyux_repeater_item_reorder_top' | skyLibResources }}\n </button>\n <div *ngIf=\"isCollapsible\"\n class=\"sky-repeater-item-chevron\"\n >\n <sky-chevron\n [attr.aria-controls]=\"contentId\"\n [attr.aria-expanded]=\"isExpanded\"\n [direction]=\"isExpanded ? 'up' : 'down'\"\n (directionChange)=\"chevronDirectionChange($event)\"\n >\n </sky-chevron>\n </div>\n <!-- Used for when the chevron is hidden to ensure that the right side is the same height as the left.-->\n <div *ngIf=\"!isCollapsible && !contextMenu\"\n class=\"sky-repeater-item-chevron-placeholder\"\n ></div>\n <!-- Used to ensure that the right side is the same height as the left.-->\n <div *ngIf=\"contextMenu\"\n class=\"sky-repeater-item-chevron-placeholder-with-context\"\n ></div>\n </div>\n <div\n class=\"sky-repeater-item-content\"\n [id]=\"contentId\"\n [@skyAnimationSlide]=\"slideDirection\"\n #itemContentRef\n >\n <ng-content\n select=\"sky-repeater-item-content\"\n ></ng-content>\n </div>\n </div>\n</ng-template>\n", styles: ["sky-repeater-item .sky-repeater-item{display:flex;border-bottom:1px dotted #cdcfd2;padding-top:0;position:relative;transition:box-shadow .15s}sky-repeater-item .sky-repeater-item sky-inline-form{display:block;width:100%}sky-repeater-item .sky-repeater-item sky-inline-form>:first-child,sky-repeater-item .sky-repeater-item sky-inline-form .sky-slide-dissolve-first,sky-repeater-item .sky-repeater-item sky-inline-form .sky-slide-dissolve-last{display:flex;flex:1 0 auto;width:100%}sky-repeater-item .sky-repeater-item sky-inline-form .sky-slide-dissolve-last{padding-top:10px}sky-repeater-item .sky-repeater-item.sky-repeater-item-active{background-color:#eeeeef;color:#212327;padding-left:6px;border-left:4px solid #00b4f1}sky-repeater-item .sky-repeater-item.sky-repeater-item-active .sky-inline-delete{margin-left:-4px;width:calc(100% + 4px)}sky-repeater-item .sky-repeater-item-left{display:flex;padding-top:10px;align-items:center}sky-repeater-item .sky-repeater-item-left sky-checkbox{display:flex}sky-repeater-item .sky-repeater-item-right{max-width:100%;flex-grow:1;align-self:center}sky-repeater-item .sky-repeater-item-header{align-items:center;display:flex;padding-top:10px}sky-repeater-item .sky-repeater-item-chevron{margin-left:10px}sky-repeater-item .sky-repeater-item-chevron-placeholder{height:24px}sky-repeater-item .sky-repeater-item-chevron-placeholder-with-context{height:29px}sky-repeater-item .sky-repeater-item-context-menu{padding:0 10px 0 0}sky-repeater-item .sky-repeater-item-checkbox{padding:0 5px 0 0}sky-repeater-item .sky-repeater-item-selected{background-color:#f1eef6;transition:background-color .15s}sky-repeater-item .sky-repeater-item-title{margin:0;flex-grow:1;line-height:1.1;color:#212327}sky-repeater-item sky-repeater-item-content{display:block;margin:10px 0 0}sky-repeater-item .sky-repeater-item-collapsible .sky-repeater-item-header{cursor:pointer}sky-repeater-item .sky-repeater-item-collapsible .sky-repeater-item-content{padding-right:34px}sky-repeater-item .sky-repeater-item-collapsed .sky-repeater-item-content{display:none}sky-repeater-item .sky-repeater-item-reorder-assistive-text{width:0;height:0;padding:0;opacity:0;position:absolute;margin:-1px;border:0;overflow:hidden;clip:rect(0,0,0,0);outline:none;white-space:nowrap}sky-repeater-item .sky-repeater-item-grab-handle{color:#cdcfd2;cursor:pointer;border:0;width:24px;height:24px;cursor:grab;cursor:-webkit-grab;cursor:-moz-grab;padding:0;margin-right:10px}sky-repeater-item .sky-repeater-item-grab-handle:hover{color:#979ba2;transition:color .15s}sky-repeater-item.sky-repeater-item-dragging.gu-mirror{opacity:1;opacity:initial;-ms-filter:initial;filter:initial;background-color:#fff;box-shadow:0 0 5px #0000004d}sky-repeater-item.sky-repeater-item-dragging.gu-transit .sky-repeater-item{background-color:#d8d8d8}sky-repeater-item.sky-repeater-item-dragging.gu-transit .sky-repeater-item .sky-repeater-item-left,sky-repeater-item.sky-repeater-item-dragging.gu-transit .sky-repeater-item .sky-repeater-item-right{visibility:hidden}sky-repeater-item.sky-repeater-item-dragging .sky-repeater-item-grab-handle{cursor:grabbing;cursor:-webkit-grabbing}.sky-theme-modern sky-repeater-item .sky-repeater-item{padding-bottom:20px}.sky-theme-modern sky-repeater-item .sky-repeater-item.sky-repeater-item-active{background-color:transparent;border-left-color:#1870b8}.sky-theme-modern sky-repeater-item .sky-repeater-item:focus,.sky-theme-modern sky-repeater-item .sky-repeater-item:active:focus{outline:solid 2px #1870B8;outline-offset:-2px}.sky-theme-modern sky-repeater-item .sky-repeater-item:focus:not(:active){box-shadow:0 1px 8px #0000004d}.sky-theme-modern sky-repeater-item .sky-repeater-item-header[hidden]+.sky-repeater-item-content sky-repeater-item-content{margin:20px 0 0}.sky-theme-modern sky-repeater-item .sky-repeater-item-header,.sky-theme-modern sky-repeater-item .sky-repeater-item-left{padding-top:20px}.sky-theme-modern sky-repeater-item sky-inline-form .sky-slide-dissolve-last{padding-top:20px}.sky-theme-modern.sky-theme-mode-dark sky-repeater-item .sky-repeater-item{border-bottom-color:#686c73}.sky-theme-modern.sky-theme-mode-dark sky-repeater-item .sky-repeater-item.sky-repeater-item-active{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark sky-repeater-item .sky-repeater-item-title{color:#fbfcfe}\n"], components: [{ type: i4.λ1, selector: "sky-inline-form", inputs: ["config", "template", "showForm"], outputs: ["close"] }, { type: i5.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { type: i6.λ3, selector: "sky-checkbox", inputs: ["label", "labelledBy", "id", "disabled", "tabindex", "name", "icon", "checkboxType", "checked", "required"], outputs: ["change", "checkedChange", "disabledChange"] }, { type: i5.λ2, selector: "sky-chevron", inputs: ["direction", "disabled"], outputs: ["directionChange"] }], directives: [{ type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "skyLibResources": i3.SkyLibResourcesPipe }, animations: [skyAnimationSlide], encapsulation: i0.ViewEncapsulation.None });
324
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: SkyRepeaterItemComponent, decorators: [{
322
+ SkyRepeaterItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: SkyRepeaterItemComponent, deps: [{ token: i1.SkyRepeaterService }, { token: i0.ChangeDetectorRef }, { token: i2.SkyRepeaterAdapterService }, { token: i0.ElementRef }, { token: i3.SkyLibResourcesService }], target: i0.ɵɵFactoryTarget.Component });
323
+ SkyRepeaterItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: SkyRepeaterItemComponent, selector: "sky-repeater-item", inputs: { inlineFormConfig: "inlineFormConfig", inlineFormTemplate: "inlineFormTemplate", isExpanded: "isExpanded", isSelected: "isSelected", reorderable: "reorderable", selectable: "selectable", showInlineForm: "showInlineForm", tag: "tag" }, outputs: { collapse: "collapse", expand: "expand", inlineFormClose: "inlineFormClose", isSelectedChange: "isSelectedChange" }, host: { properties: { "class": "this.repeaterGroupClass" } }, queries: [{ propertyName: "contextMenu", first: true, predicate: SkyRepeaterItemContextMenuComponent, descendants: true, read: ElementRef }, { propertyName: "repeaterItemContentComponents", predicate: SkyRepeaterItemContentComponent }], viewQueries: [{ propertyName: "grabHandle", first: true, predicate: ["grabHandle"], descendants: true, read: ElementRef }, { propertyName: "itemContentRef", first: true, predicate: ["itemContentRef"], descendants: true, read: ElementRef }, { propertyName: "itemHeaderRef", first: true, predicate: ["itemHeaderRef"], descendants: true, read: ElementRef }, { propertyName: "itemRef", first: true, predicate: ["itemRef"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div\n class=\"sky-repeater-item sky-padding-even-default\"\n role=\"option\"\n tabindex=\"0\"\n [ngClass]=\"{\n 'sky-repeater-item-active': isActive,\n 'sky-repeater-item-collapsible': isCollapsible,\n 'sky-repeater-item-selected': isSelected\n }\"\n (click)=\"onRepeaterItemClick($event)\"\n (keydown)=\"onItemKeyDown($event)\"\n #itemRef\n>\n <div #inlineDelete>\n <ng-content select=\"sky-inline-delete\"></ng-content>\n </div>\n\n <ng-container *ngIf=\"inlineFormTemplate\">\n <sky-inline-form\n [config]=\"inlineFormConfig\"\n [showForm]=\"showInlineForm\"\n [template]=\"inlineFormTemplate\"\n (close)=\"onInlineFormClose($event)\"\n >\n <ng-container *ngTemplateOutlet=\"skyRepeaterItemLeft\"></ng-container>\n <ng-container *ngTemplateOutlet=\"skyRepeaterItemRight\"></ng-container>\n </sky-inline-form>\n </ng-container>\n\n <ng-container *ngIf=\"!inlineFormTemplate\">\n <ng-container *ngTemplateOutlet=\"skyRepeaterItemLeft\"></ng-container>\n <ng-container *ngTemplateOutlet=\"skyRepeaterItemRight\"></ng-container>\n </ng-container>\n</div>\n\n<ng-template #skyRepeaterItemLeft>\n <div class=\"sky-repeater-item-left\">\n <ng-container *ngIf=\"reorderable\">\n <span\n aria-live=\"assertive\"\n class=\"sky-repeater-item-reorder-assistive-text\"\n [id]=\"contentId + '-reorder-state'\"\n >\n {{ reorderState }}\n </span>\n <button\n class=\"sky-btn sky-tile-tools-control sky-repeater-item-grab-handle\"\n type=\"button\"\n [attr.aria-label]=\"reorderButtonLabel\"\n (blur)=\"onReorderHandleBlur($event)\"\n (keydown)=\"onReorderHandleKeyDown($event)\"\n #grabHandle\n >\n <sky-icon icon=\"arrows-v\"></sky-icon>\n </button>\n </ng-container>\n <sky-checkbox\n *ngIf=\"selectable\"\n class=\"sky-repeater-item-checkbox\"\n [checked]=\"isSelected\"\n [label]=\"'skyux_repeater_item_checkbox_label' | skyLibResources\"\n (change)=\"onCheckboxChange($event)\"\n >\n </sky-checkbox>\n <div\n class=\"sky-repeater-item-context-menu\"\n [hidden]=\"contextMenuEl.children.length === 0\"\n #contextMenuEl\n >\n <ng-content select=\"sky-repeater-item-context-menu\"></ng-content>\n </div>\n </div>\n</ng-template>\n\n<ng-template #skyRepeaterItemRight>\n <div class=\"sky-repeater-item-right\" #itemHeaderRef>\n <div\n class=\"sky-repeater-item-header\"\n [hidden]=\"titleRef.children.length === 0\"\n (click)=\"headerClick()\"\n >\n <div class=\"sky-repeater-item-title sky-emphasized\" #titleRef>\n <ng-content select=\"sky-repeater-item-title\"></ng-content>\n </div>\n <button\n *ngIf=\"reorderable\"\n class=\"sky-btn sky-btn-link sky-repeater-item-reorder-top\"\n type=\"button\"\n [attr.aria-label]=\"\n 'skyux_repeater_item_reorder_top_label' | skyLibResources\n \"\n (click)=\"moveToTop($event)\"\n >\n <sky-icon icon=\"arrow-circle-up\"></sky-icon>\n {{ 'skyux_repeater_item_reorder_top' | skyLibResources }}\n </button>\n <div *ngIf=\"isCollapsible\" class=\"sky-repeater-item-chevron\">\n <sky-chevron\n [attr.aria-controls]=\"contentId\"\n [attr.aria-expanded]=\"isExpanded\"\n [direction]=\"isExpanded ? 'up' : 'down'\"\n (directionChange)=\"chevronDirectionChange($event)\"\n >\n </sky-chevron>\n </div>\n <!-- Used for when the chevron is hidden to ensure that the right side is the same height as the left.-->\n <div\n *ngIf=\"!isCollapsible && !contextMenu\"\n class=\"sky-repeater-item-chevron-placeholder\"\n ></div>\n <!-- Used to ensure that the right side is the same height as the left.-->\n <div\n *ngIf=\"contextMenu\"\n class=\"sky-repeater-item-chevron-placeholder-with-context\"\n ></div>\n </div>\n <div\n class=\"sky-repeater-item-content\"\n [id]=\"contentId\"\n [@skyAnimationSlide]=\"slideDirection\"\n #itemContentRef\n >\n <ng-content select=\"sky-repeater-item-content\"></ng-content>\n </div>\n </div>\n</ng-template>\n", styles: ["sky-repeater-item .sky-repeater-item{display:flex;border-bottom:1px dotted #cdcfd2;padding-top:0;position:relative;transition:box-shadow .15s;align-items:flex-start}sky-repeater-item .sky-repeater-item sky-inline-form{display:block;width:100%}sky-repeater-item .sky-repeater-item sky-inline-form>:first-child,sky-repeater-item .sky-repeater-item sky-inline-form .sky-slide-dissolve-first,sky-repeater-item .sky-repeater-item sky-inline-form .sky-slide-dissolve-last{display:flex;flex:1 0 auto;width:100%}sky-repeater-item .sky-repeater-item sky-inline-form .sky-slide-dissolve-last{padding-top:10px}sky-repeater-item .sky-repeater-item.sky-repeater-item-active{background-color:#eeeeef;color:#212327;padding-left:6px;border-left:4px solid #00b4f1}sky-repeater-item .sky-repeater-item.sky-repeater-item-active .sky-inline-delete{margin-left:-4px;width:calc(100% + 4px)}sky-repeater-item .sky-repeater-item-left{display:flex;padding-top:10px;align-items:center}sky-repeater-item .sky-repeater-item-left sky-checkbox{display:flex}sky-repeater-item .sky-repeater-item-right{max-width:100%;flex-grow:1;align-self:center}sky-repeater-item .sky-repeater-item-header{align-items:center;display:flex;padding-top:10px}sky-repeater-item .sky-repeater-item-chevron{margin-left:10px}sky-repeater-item .sky-repeater-item-chevron-placeholder{height:24px}sky-repeater-item .sky-repeater-item-chevron-placeholder-with-context{height:29px}sky-repeater-item .sky-repeater-item-context-menu{padding:0 10px 0 0}sky-repeater-item .sky-repeater-item-checkbox{padding:0 5px 0 0}sky-repeater-item .sky-repeater-item-selected{background-color:#f1eef6;transition:background-color .15s}sky-repeater-item .sky-repeater-item-title{margin:0;flex-grow:1;line-height:1.1;color:#212327}sky-repeater-item sky-repeater-item-content{display:block;margin:10px 0 0}sky-repeater-item .sky-repeater-item-collapsible .sky-repeater-item-header{cursor:pointer}sky-repeater-item .sky-repeater-item-collapsible .sky-repeater-item-content{padding-right:34px}sky-repeater-item .sky-repeater-item-collapsed .sky-repeater-item-content{display:none}sky-repeater-item .sky-repeater-item-reorder-assistive-text{width:0;height:0;padding:0;opacity:0;position:absolute;margin:-1px;border:0;overflow:hidden;clip:rect(0,0,0,0);outline:none;white-space:nowrap}sky-repeater-item .sky-repeater-item-grab-handle{color:#cdcfd2;cursor:pointer;border:0;width:24px;height:24px;cursor:grab;cursor:-moz-grab;padding:0;margin-right:10px}sky-repeater-item .sky-repeater-item-grab-handle:hover{color:#979ba2;transition:color .15s}sky-repeater-item.sky-repeater-item-dragging.gu-mirror{opacity:initial;-ms-filter:initial;filter:initial;background-color:#fff;box-shadow:0 0 5px #0000004d}sky-repeater-item.sky-repeater-item-dragging.gu-transit .sky-repeater-item{background-color:#d8d8d8}sky-repeater-item.sky-repeater-item-dragging.gu-transit .sky-repeater-item .sky-repeater-item-left,sky-repeater-item.sky-repeater-item-dragging.gu-transit .sky-repeater-item .sky-repeater-item-right{visibility:hidden}sky-repeater-item.sky-repeater-item-dragging .sky-repeater-item-grab-handle{cursor:grabbing;cursor:-webkit-grabbing}.sky-theme-modern sky-repeater-item .sky-repeater-item{padding-bottom:20px}.sky-theme-modern sky-repeater-item .sky-repeater-item.sky-repeater-item-active{background-color:transparent;border-left-color:#1870b8}.sky-theme-modern sky-repeater-item .sky-repeater-item:focus,.sky-theme-modern sky-repeater-item .sky-repeater-item:active:focus{outline:solid 2px #1870B8;outline-offset:-2px}.sky-theme-modern sky-repeater-item .sky-repeater-item:focus:not(:active){box-shadow:0 1px 8px #0000004d}.sky-theme-modern sky-repeater-item .sky-repeater-item-header[hidden]+.sky-repeater-item-content sky-repeater-item-content{margin:20px 0 0}.sky-theme-modern sky-repeater-item .sky-repeater-item-header,.sky-theme-modern sky-repeater-item .sky-repeater-item-left{padding-top:20px}.sky-theme-modern sky-repeater-item sky-inline-form .sky-slide-dissolve-last{padding-top:20px}.sky-theme-modern.sky-theme-mode-dark sky-repeater-item .sky-repeater-item{border-bottom-color:#686c73}.sky-theme-modern.sky-theme-mode-dark sky-repeater-item .sky-repeater-item.sky-repeater-item-active{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark sky-repeater-item .sky-repeater-item-title{color:#fbfcfe}\n"], components: [{ type: i4.λ1, selector: "sky-inline-form", inputs: ["config", "template", "showForm"], outputs: ["close"] }, { type: i5.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { type: i6.λ3, selector: "sky-checkbox", inputs: ["label", "labelledBy", "id", "disabled", "tabindex", "name", "icon", "checkboxType", "checked", "required"], outputs: ["change", "checkedChange", "disabledChange"] }, { type: i5.λ2, selector: "sky-chevron", inputs: ["direction", "disabled"], outputs: ["directionChange"] }], directives: [{ type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "skyLibResources": i3.SkyLibResourcesPipe }, animations: [skyAnimationSlide], encapsulation: i0.ViewEncapsulation.None });
324
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: SkyRepeaterItemComponent, decorators: [{
325
325
  type: Component,
326
326
  args: [{
327
327
  selector: 'sky-repeater-item',
328
328
  styleUrls: ['./repeater-item.component.scss'],
329
329
  templateUrl: './repeater-item.component.html',
330
330
  animations: [skyAnimationSlide],
331
- encapsulation: ViewEncapsulation.None
331
+ encapsulation: ViewEncapsulation.None,
332
332
  }]
333
333
  }], ctorParameters: function () { return [{ type: i1.SkyRepeaterService }, { type: i0.ChangeDetectorRef }, { type: i2.SkyRepeaterAdapterService }, { type: i0.ElementRef }, { type: i3.SkyLibResourcesService }]; }, propDecorators: { inlineFormConfig: [{
334
334
  type: Input
@@ -376,4 +376,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImpor
376
376
  type: ContentChildren,
377
377
  args: [SkyRepeaterItemContentComponent]
378
378
  }] } });
379
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeater-item.component.js","sourceRoot":"","sources":["../../../../../projects/lists/src/modules/repeater/repeater-item.component.ts","../../../../../projects/lists/src/modules/repeater/repeater-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\n\nimport {\n  skyAnimationSlide\n} from '@skyux/animations';\n\nimport {\n  SkyCheckboxChange\n} from '@skyux/forms';\n\nimport {\n  SkyLibResourcesService\n} from '@skyux/i18n';\n\nimport {\n  SkyInlineFormCloseArgs,\n  SkyInlineFormConfig\n} from '@skyux/inline-form';\n\nimport {\n  forkJoin as observableForkJoin,\n  Subject\n} from 'rxjs';\n\nimport {\n  takeUntil\n} from 'rxjs/operators';\n\nimport {\n  SkyRepeaterAdapterService\n} from './repeater-adapter.service';\n\nimport {\n  SkyRepeaterItemContentComponent\n} from './repeater-item-content.component';\n\nimport {\n  SkyRepeaterItemContextMenuComponent\n} from './repeater-item-context-menu.component';\n\nimport {\n  SkyRepeaterService\n} from './repeater.service';\n\nlet nextContentId: number = 0;\n\n/**\n * Creates an individual repeater item.\n */\n@Component({\n  selector: 'sky-repeater-item',\n  styleUrls: ['./repeater-item.component.scss'],\n  templateUrl: './repeater-item.component.html',\n  animations: [skyAnimationSlide],\n  encapsulation: ViewEncapsulation.None\n})\nexport class SkyRepeaterItemComponent implements OnDestroy, OnInit, AfterViewInit {\n\n  /**\n   * Specifies configuration options for the buttons to display on an inline form\n   * within the repeater. This property accepts\n   * [a `SkyInlineFormConfig` object](https://developer.blackbaud.com/skyux/components/inline-form#skyinlineformconfig-properties).\n   */\n  @Input()\n  public inlineFormConfig: SkyInlineFormConfig;\n\n  /**\n   * Specifies [an Angular `TemplateRef`](https://angular.io/api/core/TemplateRef) to use\n   * as a template to instantiate an inline form within the repeater.\n   */\n  @Input()\n  public inlineFormTemplate: TemplateRef<any>;\n\n  /**\n   * Indicates whether the repeater item is expanded.\n   * @default true\n   */\n  @Input()\n  public set isExpanded(value: boolean) {\n    this.updateForExpanded(value, true);\n  }\n\n  public get isExpanded(): boolean {\n    return this._isExpanded;\n  }\n\n  /**\n   * Indicates whether the repeater item's checkbox is selected.\n   * When users select the repeater item, the specified property on your model is updated accordingly.\n   * @default false\n   */\n  @Input()\n  public set isSelected(value: boolean) {\n    if (value !== this._isSelected) {\n      this._isSelected = value;\n      this.isSelectedChange.emit(this._isSelected);\n    }\n  }\n\n  public get isSelected(): boolean {\n    return this._isSelected;\n  }\n\n  /**\n   * Indicates whether users can change the order of the repeater item.\n   * The repeater component's `reorderable` property must also be set to `true`.\n   */\n  @Input()\n  public reorderable: boolean = false;\n\n  /**\n   * Indicates whether to display a checkbox in the left of the repeater item.\n   */\n  @Input()\n  public selectable: boolean = false;\n\n  /**\n   * Indicates whether to display an inline form within the repeater.\n   * Users can toggle between displaying and hiding the inline form.\n   */\n  @Input()\n  public showInlineForm: boolean = false;\n\n  /**\n   * Specifies an object that the repeater component returns for this repeater item\n   * when the `orderChange` event fires. This is required\n   * if you set the `reorderable` property to `true`.\n   */\n  @Input()\n  public tag: any;\n\n  /**\n   * Fires when users collapse the repeater item.\n   */\n  @Output()\n  public collapse = new EventEmitter<void>();\n\n  /**\n   * Fires when users expand the repeater item.\n   */\n  @Output()\n  public expand = new EventEmitter<void>();\n\n  /**\n   * Fires when the repeater includes an inline form and users close it. This event emits\n   * [a `SkyInlineFormCloseArgs` type](https://developer.blackbaud.com/skyux/components/inline-form#skyinlineformcloseargs-properties).\n   */\n  @Output()\n  public inlineFormClose = new EventEmitter<SkyInlineFormCloseArgs>();\n\n  /**\n   * Fires when users select or clear the checkbox for the repeater item.\n   */\n  @Output()\n  public isSelectedChange = new EventEmitter<boolean>();\n\n  @ContentChild(SkyRepeaterItemContextMenuComponent, { read: ElementRef })\n  public contextMenu: ElementRef;\n\n  public contentId: string = `sky-repeater-item-content-${++nextContentId}`;\n\n  public hasItemContent: boolean = false;\n\n  public isActive: boolean = false;\n\n  public set isCollapsible(value: boolean) {\n    if (this.isCollapsible !== value) {\n      this._isCollapsible = value;\n\n      /*istanbul ignore else */\n      if (!value) {\n        this.updateForExpanded(true, false);\n      }\n    }\n\n    this.changeDetector.markForCheck();\n  }\n\n  public get isCollapsible(): boolean {\n    return this._isCollapsible;\n  }\n\n  public keyboardReorderingEnabled: boolean = false;\n\n  public reorderButtonLabel: string;\n\n  public reorderState: string;\n\n  public slideDirection: string;\n\n  @HostBinding('class')\n  get repeaterGroupClass(): string {\n    return 'sky-repeater-item-group-' + this.repeaterService.repeaterGroupId;\n  }\n\n  @ViewChild('grabHandle', { read: ElementRef })\n  private grabHandle: ElementRef;\n\n  @ViewChild('itemContentRef', { read: ElementRef })\n  private itemContentRef: ElementRef;\n\n  @ViewChild('itemHeaderRef', { read: ElementRef })\n  private itemHeaderRef: ElementRef;\n\n  @ViewChild('itemRef', { read: ElementRef })\n  private itemRef: ElementRef;\n\n  @ContentChildren(SkyRepeaterItemContentComponent)\n  private repeaterItemContentComponents: QueryList<SkyRepeaterItemContentComponent>;\n\n  private ngUnsubscribe = new Subject<void>();\n\n  private reorderCancelText: string;\n\n  private reorderCurrentIndex: number;\n\n  private reorderFinishText: string;\n\n  private reorderInstructions: string;\n\n  private reorderMovedText: string;\n\n  private reorderStateDescription: string;\n\n  private reorderSteps: number;\n\n  private _isCollapsible = true;\n\n  private _isExpanded = true;\n\n  private _isSelected = false;\n\n  constructor(\n    private repeaterService: SkyRepeaterService,\n    private changeDetector: ChangeDetectorRef,\n    private adapterService: SkyRepeaterAdapterService,\n    private elementRef: ElementRef,\n    private resourceService: SkyLibResourcesService\n  ) {\n    this.slideForExpanded(false);\n\n    // tslint:disable-next-line: deprecation\n    observableForkJoin(\n      this.resourceService.getString('skyux_repeater_item_reorder_cancel'),\n      this.resourceService.getString('skyux_repeater_item_reorder_finish'),\n      this.resourceService.getString('skyux_repeater_item_reorder_instructions'),\n      this.resourceService.getString('skyux_repeater_item_reorder_operation'),\n      this.resourceService.getString('skyux_repeater_item_reorder_moved')\n    )\n    .subscribe((translatedStrings: string[]) => {\n      this.reorderCancelText = translatedStrings[0];\n      this.reorderFinishText = translatedStrings[1];\n      this.reorderStateDescription = translatedStrings[2];\n      this.reorderInstructions = translatedStrings[3];\n      this.reorderMovedText = translatedStrings[4];\n\n      this.reorderButtonLabel = this.reorderInstructions;\n    });\n  }\n\n  public ngOnInit(): void {\n    this.repeaterService.registerItem(this);\n    this.repeaterService.activeItemChange\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe((item: SkyRepeaterItemComponent) => {\n        const newIsActiveValue = this === item;\n        if (newIsActiveValue !== this.isActive) {\n          this.isActive = newIsActiveValue;\n          this.changeDetector.markForCheck();\n        }\n    });\n  }\n\n  public ngAfterViewInit(): void {\n    this.hasItemContent = this.repeaterItemContentComponents.length > 0;\n    this.updateExpandOnContentChange();\n  }\n\n  public ngOnDestroy(): void {\n    this.collapse.complete();\n    this.expand.complete();\n    this.inlineFormClose.complete();\n    this.isSelectedChange.complete();\n\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n\n    this.repeaterService.unregisterItem(this);\n  }\n\n  public headerClick(): void {\n    if (this.isCollapsible) {\n      this.updateForExpanded(!this.isExpanded, true);\n    }\n  }\n\n  public chevronDirectionChange(direction: string): void {\n    this.updateForExpanded(direction === 'up', true);\n  }\n\n  public onRepeaterItemClick(event: MouseEvent): void {\n    // Only activate item if clicking on the title, content, or parent item div.\n    // This will avoid accidental activations when clicking inside interactive elements like\n    // the expand/collapse chevron, dropdown, inline-delete, etc...\n    if (event.target === this.itemRef.nativeElement ||\n        this.itemContentRef.nativeElement.contains(event.target) ||\n        this.itemHeaderRef.nativeElement.contains(event.target)) {\n      this.repeaterService.activateItem(this);\n    }\n  }\n\n  public updateForExpanded(value: boolean, animate: boolean): void {\n    if (this.isCollapsible === false && value === false) {\n      console.warn(\n        `Setting isExpanded to false when the repeater item is not collapsible\n        will have no effect.`\n      );\n    } else if (this._isExpanded !== value) {\n      this._isExpanded = value;\n\n      if (this._isExpanded) {\n        this.expand.emit();\n      } else {\n        this.collapse.emit();\n      }\n\n      this.repeaterService.onItemCollapseStateChange(this);\n      this.slideForExpanded(animate);\n      this.changeDetector.markForCheck();\n    }\n  }\n\n  public onCheckboxChange(value: SkyCheckboxChange): void {\n    this.isSelected = value.checked;\n  }\n\n  public onInlineFormClose(inlineFormCloseArgs: SkyInlineFormCloseArgs): void {\n    this.inlineFormClose.emit(inlineFormCloseArgs);\n  }\n\n  public moveToTop(event: Event): void {\n    event.stopPropagation();\n    this.adapterService.moveItemUp(this.elementRef.nativeElement, true);\n    this.adapterService.focusElement(<HTMLElement> event.target);\n    this.repeaterService.registerOrderChange();\n  }\n\n  public onReorderHandleKeyDown(event: KeyboardEvent): void {\n    /*istanbul ignore else */\n    if (event.key) {\n      switch (event.key.toLowerCase()) {\n        case ' ':\n        case 'enter':\n          this.keyboardToggleReorder();\n          event.preventDefault();\n          event.stopPropagation();\n          break;\n\n        case 'escape':\n          /* istanbul ignore else */\n          if (this.keyboardReorderingEnabled) {\n            this.keyboardReorderingEnabled = false;\n            this.revertReorderSteps();\n            this.reorderButtonLabel = this.reorderCancelText + ' ' + this.reorderInstructions;\n            this.adapterService.focusElement(<HTMLElement> event.target);\n            event.preventDefault();\n            event.stopPropagation();\n          }\n          break;\n\n        case 'arrowup':\n          if (this.keyboardReorderingEnabled) {\n            this.keyboardReorderUp();\n            event.preventDefault();\n            event.stopPropagation();\n            this.repeaterService.registerOrderChange();\n          }\n          break;\n\n        case 'arrowdown':\n          /* istanbul ignore else */\n          if (this.keyboardReorderingEnabled) {\n            this.keyboardReorderDown();\n            event.preventDefault();\n            event.stopPropagation();\n            this.repeaterService.registerOrderChange();\n          }\n          break;\n\n        case 'arrowleft':\n        case 'arrowright':\n          /* istanbul ignore else */\n          if (this.keyboardReorderingEnabled) {\n            event.preventDefault();\n            event.stopPropagation();\n          }\n          break;\n\n        /* istanbul ignore next */\n        default:\n          break;\n      }\n    }\n  }\n\n  public onReorderHandleBlur(event: any): void {\n    this.keyboardReorderingEnabled = false;\n    this.revertReorderSteps();\n    this.reorderButtonLabel = this.reorderInstructions;\n    this.reorderState = undefined;\n  }\n\n  public onItemKeyDown(event: KeyboardEvent): void {\n    /*istanbul ignore else */\n    if (event.key) {\n      switch (event.key.toLowerCase()) {\n        case ' ':\n        case 'enter':\n          /* istanbul ignore else */\n          /* Sanity check */\n          // Space/enter should never execute unless focused on the parent item element.\n          if (event.target === this.itemRef.nativeElement) {\n            if (this.selectable) {\n              this.isSelected = !this.isSelected;\n            }\n            this.repeaterService.activateItem(this);\n            event.preventDefault();\n          }\n          break;\n\n        /* istanbul ignore next */\n        default:\n          break;\n      }\n    }\n  }\n\n  private slideForExpanded(animate: boolean): void {\n    this.slideDirection = this.isExpanded ? 'down' : 'up';\n  }\n\n  private keyboardReorderUp(): void {\n    this.reorderCurrentIndex = this.adapterService.moveItemUp(this.elementRef.nativeElement);\n    this.reorderSteps--;\n    this.adapterService.focusElement(this.grabHandle);\n    this.keyboardReorderingEnabled = true;\n    this.reorderButtonLabel = `${this.reorderMovedText} ${this.reorderCurrentIndex + 1}`;\n  }\n\n  private keyboardReorderDown(): void {\n    this.reorderCurrentIndex = this.adapterService.moveItemDown(this.elementRef.nativeElement);\n    this.reorderSteps++;\n    this.adapterService.focusElement(this.grabHandle);\n    this.keyboardReorderingEnabled = true;\n    this.reorderButtonLabel = `${this.reorderMovedText} ${this.reorderCurrentIndex + 1}`;\n  }\n\n  private keyboardToggleReorder(): void {\n    this.keyboardReorderingEnabled = !this.keyboardReorderingEnabled;\n    this.reorderSteps = 0;\n\n    if (this.keyboardReorderingEnabled) {\n      this.reorderState = this.reorderStateDescription;\n    } else {\n      this.reorderState =\n        `${this.reorderFinishText} ${this.reorderCurrentIndex + 1} ${this.reorderInstructions}`;\n    }\n  }\n\n  private revertReorderSteps(): void {\n    if (this.reorderSteps < 0) {\n      this.adapterService.moveItemDown(this.elementRef.nativeElement, Math.abs(this.reorderSteps));\n    } else if (this.reorderSteps > 0) {\n      this.adapterService.moveItemUp(this.elementRef.nativeElement, false, this.reorderSteps);\n    }\n    this.repeaterService.registerOrderChange();\n  }\n\n  private updateExpandOnContentChange(): void {\n    this.repeaterItemContentComponents.changes\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe(() => {\n        this.hasItemContent = this.repeaterItemContentComponents.length > 0;\n        /* istanbul ignore next */\n        this.isCollapsible = this.hasItemContent && this.repeaterService.expandMode !== 'none';\n        /* istanbul ignore else */\n        if (this.repeaterService.expandMode === 'single') {\n          this.repeaterService.onItemCollapseStateChange(this);\n        }\n      });\n  }\n}\n","<div\n  class=\"sky-repeater-item sky-padding-even-default\"\n  role=\"option\"\n  tabindex=\"0\"\n  [ngClass]=\"{\n    'sky-repeater-item-active': isActive,\n    'sky-repeater-item-collapsible': isCollapsible,\n    'sky-repeater-item-selected': isSelected\n  }\"\n  (click)=\"onRepeaterItemClick($event)\"\n  (keydown)=\"onItemKeyDown($event)\"\n  #itemRef\n>\n  <div #inlineDelete>\n    <ng-content\n      select=\"sky-inline-delete\"\n    ></ng-content>\n  </div>\n\n  <ng-container *ngIf=\"inlineFormTemplate\">\n    <sky-inline-form\n      [config]=\"inlineFormConfig\"\n      [showForm]=\"showInlineForm\"\n      [template]=\"inlineFormTemplate\"\n      (close)=\"onInlineFormClose($event)\"\n    >\n      <ng-container *ngTemplateOutlet=\"skyRepeaterItemLeft\"></ng-container>\n      <ng-container *ngTemplateOutlet=\"skyRepeaterItemRight\"></ng-container>\n    </sky-inline-form>\n  </ng-container>\n\n  <ng-container *ngIf=\"!inlineFormTemplate\">\n    <ng-container *ngTemplateOutlet=\"skyRepeaterItemLeft\"></ng-container>\n    <ng-container *ngTemplateOutlet=\"skyRepeaterItemRight\"></ng-container>\n  </ng-container>\n</div>\n\n<ng-template\n  #skyRepeaterItemLeft\n>\n  <div\n    class=\"sky-repeater-item-left\"\n  >\n    <ng-container *ngIf=\"reorderable\">\n      <span\n        aria-live=\"assertive\"\n        class=\"sky-repeater-item-reorder-assistive-text\"\n        [id]=\"contentId + '-reorder-state'\"\n      >\n        {{reorderState}}\n      </span>\n      <button\n        class=\"sky-btn sky-tile-tools-control sky-repeater-item-grab-handle\"\n        type=\"button\"\n        [attr.aria-label]=\"reorderButtonLabel\"\n        (blur)=\"onReorderHandleBlur($event)\"\n        (keydown)=\"onReorderHandleKeyDown($event)\"\n        #grabHandle\n      >\n        <sky-icon\n          icon=\"arrows-v\"\n        ></sky-icon>\n      </button>\n    </ng-container>\n    <sky-checkbox\n      *ngIf=\"selectable\"\n      class=\"sky-repeater-item-checkbox\"\n      [checked]=\"isSelected\"\n      [label]=\"'skyux_repeater_item_checkbox_label' | skyLibResources\"\n      (change)=\"onCheckboxChange($event)\"\n    >\n    </sky-checkbox>\n    <div\n      class=\"sky-repeater-item-context-menu\"\n      [hidden]=\"contextMenuEl.children.length === 0\"\n      #contextMenuEl\n    >\n      <ng-content\n        select=\"sky-repeater-item-context-menu\"\n      ></ng-content>\n    </div>\n  </div>\n</ng-template>\n\n<ng-template\n  #skyRepeaterItemRight\n>\n  <div\n    class=\"sky-repeater-item-right\"\n    #itemHeaderRef\n  >\n    <div\n      class=\"sky-repeater-item-header\"\n      [hidden]=\"titleRef.children.length === 0\"\n      (click)=\"headerClick()\"\n    >\n      <div\n        class=\"sky-repeater-item-title sky-emphasized\"\n        #titleRef\n      >\n        <ng-content\n          select=\"sky-repeater-item-title\"\n        ></ng-content>\n      </div>\n      <button *ngIf=\"reorderable\"\n        class=\"sky-btn sky-btn-link sky-repeater-item-reorder-top\"\n        type=\"button\"\n        [attr.aria-label]=\"'skyux_repeater_item_reorder_top_label' | skyLibResources\"\n        (click)=\"moveToTop($event)\"\n      >\n        <sky-icon\n          icon=\"arrow-circle-up\"\n        ></sky-icon>\n        {{ 'skyux_repeater_item_reorder_top' | skyLibResources }}\n      </button>\n      <div *ngIf=\"isCollapsible\"\n        class=\"sky-repeater-item-chevron\"\n      >\n        <sky-chevron\n          [attr.aria-controls]=\"contentId\"\n          [attr.aria-expanded]=\"isExpanded\"\n          [direction]=\"isExpanded ? 'up' : 'down'\"\n          (directionChange)=\"chevronDirectionChange($event)\"\n        >\n        </sky-chevron>\n      </div>\n      <!-- Used for when the chevron is hidden to ensure that the right side is the same height as the left.-->\n      <div *ngIf=\"!isCollapsible && !contextMenu\"\n        class=\"sky-repeater-item-chevron-placeholder\"\n      ></div>\n      <!-- Used to ensure that the right side is the same height as the left.-->\n      <div *ngIf=\"contextMenu\"\n        class=\"sky-repeater-item-chevron-placeholder-with-context\"\n      ></div>\n    </div>\n    <div\n      class=\"sky-repeater-item-content\"\n      [id]=\"contentId\"\n      [@skyAnimationSlide]=\"slideDirection\"\n      #itemContentRef\n    >\n      <ng-content\n        select=\"sky-repeater-item-content\"\n      ></ng-content>\n    </div>\n  </div>\n</ng-template>\n"]}
379
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeater-item.component.js","sourceRoot":"","sources":["../../../../../projects/lists/src/modules/repeater/repeater-item.component.ts","../../../../../projects/lists/src/modules/repeater/repeater-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport { skyAnimationSlide } from '@skyux/animations';\n\nimport { SkyCheckboxChange } from '@skyux/forms';\n\nimport { SkyLibResourcesService } from '@skyux/i18n';\n\nimport {\n  SkyInlineFormCloseArgs,\n  SkyInlineFormConfig,\n} from '@skyux/inline-form';\n\nimport { forkJoin as observableForkJoin, Subject } from 'rxjs';\n\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyRepeaterAdapterService } from './repeater-adapter.service';\n\nimport { SkyRepeaterItemContentComponent } from './repeater-item-content.component';\n\nimport { SkyRepeaterItemContextMenuComponent } from './repeater-item-context-menu.component';\n\nimport { SkyRepeaterService } from './repeater.service';\n\nlet nextContentId: number = 0;\n\n/**\n * Creates an individual repeater item.\n */\n@Component({\n  selector: 'sky-repeater-item',\n  styleUrls: ['./repeater-item.component.scss'],\n  templateUrl: './repeater-item.component.html',\n  animations: [skyAnimationSlide],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class SkyRepeaterItemComponent\n  implements OnDestroy, OnInit, AfterViewInit\n{\n  /**\n   * Specifies configuration options for the buttons to display on an inline form\n   * within the repeater. This property accepts\n   * [a `SkyInlineFormConfig` object](https://developer.blackbaud.com/skyux/components/inline-form#skyinlineformconfig-properties).\n   */\n  @Input()\n  public inlineFormConfig: SkyInlineFormConfig;\n\n  /**\n   * Specifies [an Angular `TemplateRef`](https://angular.io/api/core/TemplateRef) to use\n   * as a template to instantiate an inline form within the repeater.\n   */\n  @Input()\n  public inlineFormTemplate: TemplateRef<any>;\n\n  /**\n   * Indicates whether the repeater item is expanded.\n   * @default true\n   */\n  @Input()\n  public set isExpanded(value: boolean) {\n    this.updateForExpanded(value, true);\n  }\n\n  public get isExpanded(): boolean {\n    return this._isExpanded;\n  }\n\n  /**\n   * Indicates whether the repeater item's checkbox is selected.\n   * When users select the repeater item, the specified property on your model is updated accordingly.\n   * @default false\n   */\n  @Input()\n  public set isSelected(value: boolean) {\n    if (value !== this._isSelected) {\n      this._isSelected = value;\n      this.isSelectedChange.emit(this._isSelected);\n    }\n  }\n\n  public get isSelected(): boolean {\n    return this._isSelected;\n  }\n\n  /**\n   * Indicates whether users can change the order of the repeater item.\n   * The repeater component's `reorderable` property must also be set to `true`.\n   */\n  @Input()\n  public reorderable: boolean = false;\n\n  /**\n   * Indicates whether to display a checkbox in the left of the repeater item.\n   */\n  @Input()\n  public selectable: boolean = false;\n\n  /**\n   * Indicates whether to display an inline form within the repeater.\n   * Users can toggle between displaying and hiding the inline form.\n   */\n  @Input()\n  public showInlineForm: boolean = false;\n\n  /**\n   * Specifies an object that the repeater component returns for this repeater item\n   * when the `orderChange` event fires. This is required\n   * if you set the `reorderable` property to `true`.\n   */\n  @Input()\n  public tag: any;\n\n  /**\n   * Fires when users collapse the repeater item.\n   */\n  @Output()\n  public collapse = new EventEmitter<void>();\n\n  /**\n   * Fires when users expand the repeater item.\n   */\n  @Output()\n  public expand = new EventEmitter<void>();\n\n  /**\n   * Fires when the repeater includes an inline form and users close it. This event emits\n   * [a `SkyInlineFormCloseArgs` type](https://developer.blackbaud.com/skyux/components/inline-form#skyinlineformcloseargs-properties).\n   */\n  @Output()\n  public inlineFormClose = new EventEmitter<SkyInlineFormCloseArgs>();\n\n  /**\n   * Fires when users select or clear the checkbox for the repeater item.\n   */\n  @Output()\n  public isSelectedChange = new EventEmitter<boolean>();\n\n  @ContentChild(SkyRepeaterItemContextMenuComponent, { read: ElementRef })\n  public contextMenu: ElementRef;\n\n  public contentId: string = `sky-repeater-item-content-${++nextContentId}`;\n\n  public hasItemContent: boolean = false;\n\n  public isActive: boolean = false;\n\n  public set isCollapsible(value: boolean) {\n    if (this.isCollapsible !== value) {\n      this._isCollapsible = value;\n\n      /*istanbul ignore else */\n      if (!value) {\n        this.updateForExpanded(true, false);\n      }\n    }\n\n    this.changeDetector.markForCheck();\n  }\n\n  public get isCollapsible(): boolean {\n    return this._isCollapsible;\n  }\n\n  public keyboardReorderingEnabled: boolean = false;\n\n  public reorderButtonLabel: string;\n\n  public reorderState: string;\n\n  public slideDirection: string;\n\n  @HostBinding('class')\n  get repeaterGroupClass(): string {\n    return 'sky-repeater-item-group-' + this.repeaterService.repeaterGroupId;\n  }\n\n  @ViewChild('grabHandle', { read: ElementRef })\n  private grabHandle: ElementRef;\n\n  @ViewChild('itemContentRef', { read: ElementRef })\n  private itemContentRef: ElementRef;\n\n  @ViewChild('itemHeaderRef', { read: ElementRef })\n  private itemHeaderRef: ElementRef;\n\n  @ViewChild('itemRef', { read: ElementRef })\n  private itemRef: ElementRef;\n\n  @ContentChildren(SkyRepeaterItemContentComponent)\n  private repeaterItemContentComponents: QueryList<SkyRepeaterItemContentComponent>;\n\n  private ngUnsubscribe = new Subject<void>();\n\n  private reorderCancelText: string;\n\n  private reorderCurrentIndex: number;\n\n  private reorderFinishText: string;\n\n  private reorderInstructions: string;\n\n  private reorderMovedText: string;\n\n  private reorderStateDescription: string;\n\n  private reorderSteps: number;\n\n  private _isCollapsible = true;\n\n  private _isExpanded = true;\n\n  private _isSelected = false;\n\n  constructor(\n    private repeaterService: SkyRepeaterService,\n    private changeDetector: ChangeDetectorRef,\n    private adapterService: SkyRepeaterAdapterService,\n    private elementRef: ElementRef,\n    private resourceService: SkyLibResourcesService\n  ) {\n    this.slideForExpanded(false);\n\n    // tslint:disable-next-line: deprecation\n    observableForkJoin(\n      this.resourceService.getString('skyux_repeater_item_reorder_cancel'),\n      this.resourceService.getString('skyux_repeater_item_reorder_finish'),\n      this.resourceService.getString(\n        'skyux_repeater_item_reorder_instructions'\n      ),\n      this.resourceService.getString('skyux_repeater_item_reorder_operation'),\n      this.resourceService.getString('skyux_repeater_item_reorder_moved')\n    ).subscribe((translatedStrings: string[]) => {\n      this.reorderCancelText = translatedStrings[0];\n      this.reorderFinishText = translatedStrings[1];\n      this.reorderStateDescription = translatedStrings[2];\n      this.reorderInstructions = translatedStrings[3];\n      this.reorderMovedText = translatedStrings[4];\n\n      this.reorderButtonLabel = this.reorderInstructions;\n    });\n  }\n\n  public ngOnInit(): void {\n    this.repeaterService.registerItem(this);\n    this.repeaterService.activeItemChange\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe((item: SkyRepeaterItemComponent) => {\n        const newIsActiveValue = this === item;\n        if (newIsActiveValue !== this.isActive) {\n          this.isActive = newIsActiveValue;\n          this.changeDetector.markForCheck();\n        }\n      });\n  }\n\n  public ngAfterViewInit(): void {\n    this.hasItemContent = this.repeaterItemContentComponents.length > 0;\n    this.updateExpandOnContentChange();\n  }\n\n  public ngOnDestroy(): void {\n    this.collapse.complete();\n    this.expand.complete();\n    this.inlineFormClose.complete();\n    this.isSelectedChange.complete();\n\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n\n    this.repeaterService.unregisterItem(this);\n  }\n\n  public headerClick(): void {\n    if (this.isCollapsible) {\n      this.updateForExpanded(!this.isExpanded, true);\n    }\n  }\n\n  public chevronDirectionChange(direction: string): void {\n    this.updateForExpanded(direction === 'up', true);\n  }\n\n  public onRepeaterItemClick(event: MouseEvent): void {\n    // Only activate item if clicking on the title, content, or parent item div.\n    // This will avoid accidental activations when clicking inside interactive elements like\n    // the expand/collapse chevron, dropdown, inline-delete, etc...\n    if (\n      event.target === this.itemRef.nativeElement ||\n      this.itemContentRef.nativeElement.contains(event.target) ||\n      this.itemHeaderRef.nativeElement.contains(event.target)\n    ) {\n      this.repeaterService.activateItem(this);\n    }\n  }\n\n  public updateForExpanded(value: boolean, animate: boolean): void {\n    if (this.isCollapsible === false && value === false) {\n      console.warn(\n        `Setting isExpanded to false when the repeater item is not collapsible\n        will have no effect.`\n      );\n    } else if (this._isExpanded !== value) {\n      this._isExpanded = value;\n\n      if (this._isExpanded) {\n        this.expand.emit();\n      } else {\n        this.collapse.emit();\n      }\n\n      this.repeaterService.onItemCollapseStateChange(this);\n      this.slideForExpanded(animate);\n      this.changeDetector.markForCheck();\n    }\n  }\n\n  public onCheckboxChange(value: SkyCheckboxChange): void {\n    this.isSelected = value.checked;\n  }\n\n  public onInlineFormClose(inlineFormCloseArgs: SkyInlineFormCloseArgs): void {\n    this.inlineFormClose.emit(inlineFormCloseArgs);\n  }\n\n  public moveToTop(event: Event): void {\n    event.stopPropagation();\n    this.adapterService.moveItemUp(this.elementRef.nativeElement, true);\n    this.adapterService.focusElement(<HTMLElement>event.target);\n    this.repeaterService.registerOrderChange();\n  }\n\n  public onReorderHandleKeyDown(event: KeyboardEvent): void {\n    /*istanbul ignore else */\n    if (event.key) {\n      switch (event.key.toLowerCase()) {\n        case ' ':\n        case 'enter':\n          this.keyboardToggleReorder();\n          event.preventDefault();\n          event.stopPropagation();\n          break;\n\n        case 'escape':\n          /* istanbul ignore else */\n          if (this.keyboardReorderingEnabled) {\n            this.keyboardReorderingEnabled = false;\n            this.revertReorderSteps();\n            this.reorderButtonLabel =\n              this.reorderCancelText + ' ' + this.reorderInstructions;\n            this.adapterService.focusElement(<HTMLElement>event.target);\n            event.preventDefault();\n            event.stopPropagation();\n          }\n          break;\n\n        case 'arrowup':\n          if (this.keyboardReorderingEnabled) {\n            this.keyboardReorderUp();\n            event.preventDefault();\n            event.stopPropagation();\n            this.repeaterService.registerOrderChange();\n          }\n          break;\n\n        case 'arrowdown':\n          /* istanbul ignore else */\n          if (this.keyboardReorderingEnabled) {\n            this.keyboardReorderDown();\n            event.preventDefault();\n            event.stopPropagation();\n            this.repeaterService.registerOrderChange();\n          }\n          break;\n\n        case 'arrowleft':\n        case 'arrowright':\n          /* istanbul ignore else */\n          if (this.keyboardReorderingEnabled) {\n            event.preventDefault();\n            event.stopPropagation();\n          }\n          break;\n\n        /* istanbul ignore next */\n        default:\n          break;\n      }\n    }\n  }\n\n  public onReorderHandleBlur(event: any): void {\n    this.keyboardReorderingEnabled = false;\n    this.revertReorderSteps();\n    this.reorderButtonLabel = this.reorderInstructions;\n    this.reorderState = undefined;\n  }\n\n  public onItemKeyDown(event: KeyboardEvent): void {\n    /*istanbul ignore else */\n    if (event.key) {\n      switch (event.key.toLowerCase()) {\n        case ' ':\n        case 'enter':\n          /* istanbul ignore else */\n          /* Sanity check */\n          // Space/enter should never execute unless focused on the parent item element.\n          if (event.target === this.itemRef.nativeElement) {\n            if (this.selectable) {\n              this.isSelected = !this.isSelected;\n            }\n            this.repeaterService.activateItem(this);\n            event.preventDefault();\n          }\n          break;\n\n        /* istanbul ignore next */\n        default:\n          break;\n      }\n    }\n  }\n\n  private slideForExpanded(animate: boolean): void {\n    this.slideDirection = this.isExpanded ? 'down' : 'up';\n  }\n\n  private keyboardReorderUp(): void {\n    this.reorderCurrentIndex = this.adapterService.moveItemUp(\n      this.elementRef.nativeElement\n    );\n    this.reorderSteps--;\n    this.adapterService.focusElement(this.grabHandle);\n    this.keyboardReorderingEnabled = true;\n    this.reorderButtonLabel = `${this.reorderMovedText} ${\n      this.reorderCurrentIndex + 1\n    }`;\n  }\n\n  private keyboardReorderDown(): void {\n    this.reorderCurrentIndex = this.adapterService.moveItemDown(\n      this.elementRef.nativeElement\n    );\n    this.reorderSteps++;\n    this.adapterService.focusElement(this.grabHandle);\n    this.keyboardReorderingEnabled = true;\n    this.reorderButtonLabel = `${this.reorderMovedText} ${\n      this.reorderCurrentIndex + 1\n    }`;\n  }\n\n  private keyboardToggleReorder(): void {\n    this.keyboardReorderingEnabled = !this.keyboardReorderingEnabled;\n    this.reorderSteps = 0;\n\n    if (this.keyboardReorderingEnabled) {\n      this.reorderState = this.reorderStateDescription;\n    } else {\n      this.reorderState = `${this.reorderFinishText} ${\n        this.reorderCurrentIndex + 1\n      } ${this.reorderInstructions}`;\n    }\n  }\n\n  private revertReorderSteps(): void {\n    if (this.reorderSteps < 0) {\n      this.adapterService.moveItemDown(\n        this.elementRef.nativeElement,\n        Math.abs(this.reorderSteps)\n      );\n    } else if (this.reorderSteps > 0) {\n      this.adapterService.moveItemUp(\n        this.elementRef.nativeElement,\n        false,\n        this.reorderSteps\n      );\n    }\n    this.repeaterService.registerOrderChange();\n  }\n\n  private updateExpandOnContentChange(): void {\n    this.repeaterItemContentComponents.changes\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe(() => {\n        this.hasItemContent = this.repeaterItemContentComponents.length > 0;\n        /* istanbul ignore next */\n        this.isCollapsible =\n          this.hasItemContent && this.repeaterService.expandMode !== 'none';\n        /* istanbul ignore else */\n        if (this.repeaterService.expandMode === 'single') {\n          this.repeaterService.onItemCollapseStateChange(this);\n        }\n      });\n  }\n}\n","<div\n  class=\"sky-repeater-item sky-padding-even-default\"\n  role=\"option\"\n  tabindex=\"0\"\n  [ngClass]=\"{\n    'sky-repeater-item-active': isActive,\n    'sky-repeater-item-collapsible': isCollapsible,\n    'sky-repeater-item-selected': isSelected\n  }\"\n  (click)=\"onRepeaterItemClick($event)\"\n  (keydown)=\"onItemKeyDown($event)\"\n  #itemRef\n>\n  <div #inlineDelete>\n    <ng-content select=\"sky-inline-delete\"></ng-content>\n  </div>\n\n  <ng-container *ngIf=\"inlineFormTemplate\">\n    <sky-inline-form\n      [config]=\"inlineFormConfig\"\n      [showForm]=\"showInlineForm\"\n      [template]=\"inlineFormTemplate\"\n      (close)=\"onInlineFormClose($event)\"\n    >\n      <ng-container *ngTemplateOutlet=\"skyRepeaterItemLeft\"></ng-container>\n      <ng-container *ngTemplateOutlet=\"skyRepeaterItemRight\"></ng-container>\n    </sky-inline-form>\n  </ng-container>\n\n  <ng-container *ngIf=\"!inlineFormTemplate\">\n    <ng-container *ngTemplateOutlet=\"skyRepeaterItemLeft\"></ng-container>\n    <ng-container *ngTemplateOutlet=\"skyRepeaterItemRight\"></ng-container>\n  </ng-container>\n</div>\n\n<ng-template #skyRepeaterItemLeft>\n  <div class=\"sky-repeater-item-left\">\n    <ng-container *ngIf=\"reorderable\">\n      <span\n        aria-live=\"assertive\"\n        class=\"sky-repeater-item-reorder-assistive-text\"\n        [id]=\"contentId + '-reorder-state'\"\n      >\n        {{ reorderState }}\n      </span>\n      <button\n        class=\"sky-btn sky-tile-tools-control sky-repeater-item-grab-handle\"\n        type=\"button\"\n        [attr.aria-label]=\"reorderButtonLabel\"\n        (blur)=\"onReorderHandleBlur($event)\"\n        (keydown)=\"onReorderHandleKeyDown($event)\"\n        #grabHandle\n      >\n        <sky-icon icon=\"arrows-v\"></sky-icon>\n      </button>\n    </ng-container>\n    <sky-checkbox\n      *ngIf=\"selectable\"\n      class=\"sky-repeater-item-checkbox\"\n      [checked]=\"isSelected\"\n      [label]=\"'skyux_repeater_item_checkbox_label' | skyLibResources\"\n      (change)=\"onCheckboxChange($event)\"\n    >\n    </sky-checkbox>\n    <div\n      class=\"sky-repeater-item-context-menu\"\n      [hidden]=\"contextMenuEl.children.length === 0\"\n      #contextMenuEl\n    >\n      <ng-content select=\"sky-repeater-item-context-menu\"></ng-content>\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #skyRepeaterItemRight>\n  <div class=\"sky-repeater-item-right\" #itemHeaderRef>\n    <div\n      class=\"sky-repeater-item-header\"\n      [hidden]=\"titleRef.children.length === 0\"\n      (click)=\"headerClick()\"\n    >\n      <div class=\"sky-repeater-item-title sky-emphasized\" #titleRef>\n        <ng-content select=\"sky-repeater-item-title\"></ng-content>\n      </div>\n      <button\n        *ngIf=\"reorderable\"\n        class=\"sky-btn sky-btn-link sky-repeater-item-reorder-top\"\n        type=\"button\"\n        [attr.aria-label]=\"\n          'skyux_repeater_item_reorder_top_label' | skyLibResources\n        \"\n        (click)=\"moveToTop($event)\"\n      >\n        <sky-icon icon=\"arrow-circle-up\"></sky-icon>\n        {{ 'skyux_repeater_item_reorder_top' | skyLibResources }}\n      </button>\n      <div *ngIf=\"isCollapsible\" class=\"sky-repeater-item-chevron\">\n        <sky-chevron\n          [attr.aria-controls]=\"contentId\"\n          [attr.aria-expanded]=\"isExpanded\"\n          [direction]=\"isExpanded ? 'up' : 'down'\"\n          (directionChange)=\"chevronDirectionChange($event)\"\n        >\n        </sky-chevron>\n      </div>\n      <!-- Used for when the chevron is hidden to ensure that the right side is the same height as the left.-->\n      <div\n        *ngIf=\"!isCollapsible && !contextMenu\"\n        class=\"sky-repeater-item-chevron-placeholder\"\n      ></div>\n      <!-- Used to ensure that the right side is the same height as the left.-->\n      <div\n        *ngIf=\"contextMenu\"\n        class=\"sky-repeater-item-chevron-placeholder-with-context\"\n      ></div>\n    </div>\n    <div\n      class=\"sky-repeater-item-content\"\n      [id]=\"contentId\"\n      [@skyAnimationSlide]=\"slideDirection\"\n      #itemContentRef\n    >\n      <ng-content select=\"sky-repeater-item-content\"></ng-content>\n    </div>\n  </div>\n</ng-template>\n"]}
@@ -1,4 +1,4 @@
1
- import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, Output } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, Output, } from '@angular/core';
2
2
  import { Subject } from 'rxjs';
3
3
  import { takeUntil } from 'rxjs/operators';
4
4
  import { SkyRepeaterItemComponent } from './repeater-item.component';
@@ -8,8 +8,7 @@ import * as i0 from "@angular/core";
8
8
  import * as i1 from "./repeater.service";
9
9
  import * as i2 from "./repeater-adapter.service";
10
10
  import * as i3 from "ng2-dragula";
11
- import * as i4 from "@angular/common";
12
- import * as i5 from "@skyux/i18n";
11
+ import * as i4 from "@skyux/i18n";
13
12
  let uniqueId = 0;
14
13
  /**
15
14
  * Creates a container to display repeater items.
@@ -46,7 +45,9 @@ export class SkyRepeaterComponent {
46
45
  .subscribe((item) => {
47
46
  if (this.expandMode === 'single' && item.isExpanded) {
48
47
  this.items.forEach((otherItem) => {
49
- if (otherItem !== item && otherItem.isExpanded && otherItem.isCollapsible) {
48
+ if (otherItem !== item &&
49
+ otherItem.isExpanded &&
50
+ otherItem.isCollapsible) {
50
51
  otherItem.isExpanded = false;
51
52
  }
52
53
  });
@@ -68,6 +69,7 @@ export class SkyRepeaterComponent {
68
69
  this.repeaterService.repeaterGroupId = uniqueId;
69
70
  this.updateForExpandMode();
70
71
  this.adapterService.setRepeaterHost(this.elementRef);
72
+ this.initializeDragAndDrop();
71
73
  }
72
74
  /**
73
75
  * Specifies a layout to determine which repeater items are expanded by default and whether
@@ -108,9 +110,7 @@ export class SkyRepeaterComponent {
108
110
  });
109
111
  // HACK: Not updating for expand mode in a timeout causes an error.
110
112
  // https://github.com/angular/angular/issues/6005
111
- this.items.changes
112
- .pipe(takeUntil(this.ngUnsubscribe))
113
- .subscribe(() => {
113
+ this.items.changes.pipe(takeUntil(this.ngUnsubscribe)).subscribe(() => {
114
114
  setTimeout(() => {
115
115
  if (!!this.items.last) {
116
116
  this.updateForExpandMode(this.items.last);
@@ -123,7 +123,7 @@ export class SkyRepeaterComponent {
123
123
  });
124
124
  setTimeout(() => {
125
125
  this.updateForExpandMode();
126
- this.items.forEach(item => {
126
+ this.items.forEach((item) => {
127
127
  item.reorderable = this.reorderable;
128
128
  });
129
129
  }, 0);
@@ -131,16 +131,14 @@ export class SkyRepeaterComponent {
131
131
  ngOnChanges(changes) {
132
132
  if (changes['activeIndex']) {
133
133
  this.repeaterService.enableActiveState = true;
134
- if (changes['activeIndex'].currentValue !== changes['activeIndex'].previousValue) {
134
+ if (changes['activeIndex'].currentValue !==
135
+ changes['activeIndex'].previousValue) {
135
136
  this.repeaterService.activateItemByIndex(this.activeIndex);
136
137
  }
137
138
  }
138
139
  if (changes.reorderable) {
139
140
  if (this.items) {
140
- this.items.forEach(item => item.reorderable = this.reorderable);
141
- }
142
- if (this.reorderable) {
143
- this.initializeDragAndDrop();
141
+ this.items.forEach((item) => (item.reorderable = this.reorderable));
144
142
  }
145
143
  this.changeDetector.markForCheck();
146
144
  }
@@ -171,18 +169,16 @@ export class SkyRepeaterComponent {
171
169
  }
172
170
  }
173
171
  initializeDragAndDrop() {
172
+ /* Sanity check that we haven't already set up dragging abilities */
173
+ /* istanbul ignore else */
174
174
  if (!this.dragulaService.find(this.dragulaGroupName)) {
175
175
  this.dragulaService.setOptions(this.dragulaGroupName, {
176
176
  moves: (el, container, handle) => {
177
177
  const target = el.querySelector('.sky-repeater-item-grab-handle');
178
- return (target && target.contains(handle));
179
- }
178
+ return this.reorderable && target && target.contains(handle);
179
+ },
180
180
  });
181
181
  }
182
- // Reset the current dragula subscriptions.
183
- this.dragulaUnsubscribe.next();
184
- this.dragulaUnsubscribe.complete();
185
- this.dragulaUnsubscribe = new Subject();
186
182
  let draggedItemIndex;
187
183
  this.dragulaService.drag
188
184
  .pipe(takeUntil(this.dragulaUnsubscribe))
@@ -214,12 +210,14 @@ export class SkyRepeaterComponent {
214
210
  this.dragulaUnsubscribe.next();
215
211
  this.dragulaUnsubscribe.complete();
216
212
  this.dragulaUnsubscribe = undefined;
213
+ /* Sanity check that we have set up dragging abilities */
214
+ /* istanbul ignore else */
217
215
  if (this.dragulaService.find(this.dragulaGroupName)) {
218
216
  this.dragulaService.destroy(this.dragulaGroupName);
219
217
  }
220
218
  }
221
219
  emitTags() {
222
- const tags = this.repeaterService.items.map(item => item.tag);
220
+ const tags = this.repeaterService.items.map((item) => item.tag);
223
221
  this.orderChange.emit(tags);
224
222
  }
225
223
  everyItemHasTag() {
@@ -228,21 +226,21 @@ export class SkyRepeaterComponent {
228
226
  if (!this.items || this.items.length === 0) {
229
227
  return false;
230
228
  }
231
- return this.items.toArray().every(item => {
229
+ return this.items.toArray().every((item) => {
232
230
  return item.tag !== undefined;
233
231
  });
234
232
  }
235
233
  }
236
- SkyRepeaterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: SkyRepeaterComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.SkyRepeaterService }, { token: i2.SkyRepeaterAdapterService }, { token: i3.DragulaService }, { token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
237
- SkyRepeaterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.7", type: SkyRepeaterComponent, selector: "sky-repeater", inputs: { activeIndex: "activeIndex", ariaLabel: "ariaLabel", reorderable: "reorderable", expandMode: "expandMode" }, outputs: { activeIndexChange: "activeIndexChange", orderChange: "orderChange" }, providers: [SkyRepeaterService, SkyRepeaterAdapterService], queries: [{ propertyName: "items", predicate: SkyRepeaterItemComponent }], usesOnChanges: true, ngImport: i0, template: "<ng-container #repeaterHost>\n <div *ngIf=\"!reorderable; else draggable\"\n class=\"sky-repeater\"\n role=\"listbox\"\n [attr.aria-label]=\"ariaLabel || ( 'skyux_repeater_label' | skyLibResources)\"\n >\n <ng-container *ngTemplateOutlet=\"content\">\n </ng-container>\n </div>\n</ng-container>\n\n<ng-template #draggable>\n <div\n class=\"sky-repeater\"\n role=\"listbox\"\n [attr.aria-label]=\"ariaLabel || ( 'skyux_repeater_label' | skyLibResources)\"\n [dragula]=\"dragulaGroupName\"\n >\n <ng-container *ngTemplateOutlet=\"content\">\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template #content>\n <ng-content></ng-content>\n</ng-template>", styles: [".sky-repeater{padding:0}\n"], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.DragulaDirective, selector: "[dragula]", inputs: ["dragula", "dragulaModel", "dragulaOptions"] }], pipes: { "skyLibResources": i5.SkyLibResourcesPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
238
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: SkyRepeaterComponent, decorators: [{
234
+ SkyRepeaterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: SkyRepeaterComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.SkyRepeaterService }, { token: i2.SkyRepeaterAdapterService }, { token: i3.DragulaService }, { token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
235
+ SkyRepeaterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: SkyRepeaterComponent, selector: "sky-repeater", inputs: { activeIndex: "activeIndex", ariaLabel: "ariaLabel", reorderable: "reorderable", expandMode: "expandMode" }, outputs: { activeIndexChange: "activeIndexChange", orderChange: "orderChange" }, providers: [SkyRepeaterService, SkyRepeaterAdapterService], queries: [{ propertyName: "items", predicate: SkyRepeaterItemComponent }], usesOnChanges: true, ngImport: i0, template: "<ng-container #repeaterHost>\n <div\n class=\"sky-repeater\"\n role=\"listbox\"\n [attr.aria-label]=\"ariaLabel || ('skyux_repeater_label' | skyLibResources)\"\n [dragula]=\"dragulaGroupName\"\n >\n <ng-content></ng-content>\n </div>\n</ng-container>\n", styles: [".sky-repeater{padding:0}\n"], directives: [{ type: i3.DragulaDirective, selector: "[dragula]", inputs: ["dragula", "dragulaModel", "dragulaOptions"] }], pipes: { "skyLibResources": i4.SkyLibResourcesPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
236
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: SkyRepeaterComponent, decorators: [{
239
237
  type: Component,
240
238
  args: [{
241
239
  selector: 'sky-repeater',
242
240
  styleUrls: ['./repeater.component.scss'],
243
241
  templateUrl: './repeater.component.html',
244
242
  providers: [SkyRepeaterService, SkyRepeaterAdapterService],
245
- changeDetection: ChangeDetectionStrategy.OnPush
243
+ changeDetection: ChangeDetectionStrategy.OnPush,
246
244
  }]
247
245
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.SkyRepeaterService }, { type: i2.SkyRepeaterAdapterService }, { type: i3.DragulaService }, { type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { activeIndex: [{
248
246
  type: Input
@@ -260,4 +258,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImpor
260
258
  type: ContentChildren,
261
259
  args: [SkyRepeaterItemComponent]
262
260
  }] } });
263
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeater.component.js","sourceRoot":"","sources":["../../../../../projects/lists/src/modules/repeater/repeater.component.ts","../../../../../projects/lists/src/modules/repeater/repeater.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges\n} from '@angular/core';\n\nimport {\n  DragulaService\n} from 'ng2-dragula';\n\nimport {\n  Subject\n} from 'rxjs';\n\nimport {\n  takeUntil\n} from 'rxjs/operators';\n\nimport {\n  SkyRepeaterItemComponent\n} from './repeater-item.component';\n\nimport {\n  SkyRepeaterService\n} from './repeater.service';\n\nimport {\n  SkyRepeaterAdapterService\n} from './repeater-adapter.service';\n\nlet uniqueId = 0;\n\n/**\n * Creates a container to display repeater items.\n */\n@Component({\n  selector: 'sky-repeater',\n  styleUrls: ['./repeater.component.scss'],\n  templateUrl: './repeater.component.html',\n  providers: [SkyRepeaterService, SkyRepeaterAdapterService],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class SkyRepeaterComponent implements AfterContentInit, OnChanges, OnDestroy {\n\n  /**\n   * Specifies the index of the repeater item to visually highlight as active.\n   * For example, use this property in conjunction with the\n   * [split view component](https://developer.blackbaud.com/skyux/components/split-view)\n   * to highlight a repeater item while users edit it. Only one item can be active at a time.\n   */\n  @Input()\n  public activeIndex: number;\n\n  /**\n   * Specifies an ARIA label for the repeater list.\n   * This sets the repeater list's `aria-label` attribute\n   * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility).\n   * @default 'List of items'\n   */\n  @Input()\n  public ariaLabel: string;\n\n  /**\n   * Indicates whether users can change the order of items in the repeater list.\n   * Each repeater item also has `reorderable` property to indicate whether\n   * users can change its order.\n   */\n  @Input()\n  public reorderable: boolean = false;\n\n  /**\n   * Specifies a layout to determine which repeater items are expanded by default and whether\n   * repeater items are expandable and collapsible. Collapsed items display titles only.\n   * The valid options are `multiple`, `none`, and `single`.\n   * - `multiple` loads repeater items in an expanded state unless `isExpanded` is set to\n   * `false` for a repeater item. This layout allows users to expand and collapse\n   * as many repeater items as necessary. It is best-suited to repeater items where body\n   * content is important but users don't always need to see it.\n   * - `none` loads all repeater items in an expanded state and does not allow users to\n   * collapse them. This default layout provides the quickest access to the details in the\n   * repeater items. It is best-suited to repeater items with concise content\n   * that users need to view frequently.\n   * - `single` loads one repeater item in an expanded state and collapses all others.\n   * The expanded repeater item is the first one where `isExpanded` is set to `true`. This layout\n   * allows users to expand one item at a time. It provides the most compact view and is\n   * best-suited to repeater items where the most important information is in the titles\n   * and users only occasionally need to view the body content.\n   * @default none\n   */\n  @Input()\n  public set expandMode(value: string) {\n    this.repeaterService.expandMode = value;\n    this._expandMode = value;\n    this.updateForExpandMode();\n  }\n\n  public get expandMode(): string {\n    return this._expandMode || 'none';\n  }\n\n  /**\n   * Fires when the active repeater item changes.\n   */\n  @Output()\n  public activeIndexChange = new EventEmitter<number>();\n\n  /**\n   * Fires when users change the order of repeater items.\n   * This event emits an ordered array of the `tag` properties that the consumer provides for each repeater item.\n   */\n  @Output()\n  public orderChange = new EventEmitter<any[]>();\n\n  @ContentChildren(SkyRepeaterItemComponent)\n  public items: QueryList<SkyRepeaterItemComponent>;\n\n  public dragulaGroupName: string;\n\n  private dragulaUnsubscribe = new Subject<void>();\n\n  private ngUnsubscribe = new Subject<void>();\n\n  private _expandMode = 'none';\n\n  constructor(\n    private changeDetector: ChangeDetectorRef,\n    private repeaterService: SkyRepeaterService,\n    private adapterService: SkyRepeaterAdapterService,\n    private dragulaService: DragulaService,\n    private elementRef: ElementRef,\n    private renderer: Renderer2\n  ) {\n    this.dragulaGroupName = `sky-repeater-dragula-${++uniqueId}`;\n\n    this.repeaterService.itemCollapseStateChange\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe((item: SkyRepeaterItemComponent) => {\n        if (this.expandMode === 'single' && item.isExpanded) {\n          this.items.forEach((otherItem) => {\n            if (otherItem !== item && otherItem.isExpanded && otherItem.isCollapsible) {\n              otherItem.isExpanded = false;\n            }\n          });\n        }\n      });\n\n    this.repeaterService.activeItemIndexChange\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe((index: number) => {\n        if (index !== this.activeIndex) {\n          this.activeIndex = index;\n          this.activeIndexChange.emit(index);\n        }\n      });\n\n    this.repeaterService.orderChange\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe(() => {\n        this.emitTags();\n      });\n\n    this.repeaterService.repeaterGroupId = uniqueId;\n\n    this.updateForExpandMode();\n\n    this.adapterService.setRepeaterHost(this.elementRef);\n  }\n\n  public ngAfterContentInit(): void {\n    // If activeIndex has been set on init, call service to activate the appropriate item.\n    setTimeout(() => {\n      if (this.activeIndex || this.activeIndex === 0) {\n        this.repeaterService.activateItemByIndex(this.activeIndex);\n      }\n\n      if (this.reorderable && !this.everyItemHasTag()) {\n        console.warn('Please supply tag properties for each repeater item when reordering functionality is enabled.');\n      }\n    });\n\n    // HACK: Not updating for expand mode in a timeout causes an error.\n    // https://github.com/angular/angular/issues/6005\n    this.items.changes\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe(() => {\n        setTimeout(() => {\n          if (!!this.items.last) {\n            this.updateForExpandMode(this.items.last);\n            this.items.last.reorderable = this.reorderable;\n          }\n\n          if (this.activeIndex !== undefined) {\n            this.repeaterService.activateItemByIndex(this.activeIndex);\n          }\n        });\n      });\n\n    setTimeout(() => {\n      this.updateForExpandMode();\n\n      this.items.forEach(item => {\n        item.reorderable = this.reorderable;\n      });\n    }, 0);\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes['activeIndex']) {\n      this.repeaterService.enableActiveState = true;\n      if (changes['activeIndex'].currentValue !== changes['activeIndex'].previousValue) {\n        this.repeaterService.activateItemByIndex(this.activeIndex);\n      }\n    }\n\n    if (changes.reorderable) {\n      if (this.items) {\n        this.items.forEach(item => item.reorderable = this.reorderable);\n      }\n\n      if (this.reorderable) {\n        this.initializeDragAndDrop();\n      }\n\n      this.changeDetector.markForCheck();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n    this.destroyDragAndDrop();\n  }\n\n  private updateForExpandMode(itemAdded?: SkyRepeaterItemComponent): void {\n    if (this.items) {\n      let foundExpanded = false;\n      let isCollapsible = this.expandMode !== 'none';\n      let isSingle = this.expandMode === 'single';\n\n      // Keep any newly-added expanded item expanded and collapse the rest.\n      if (itemAdded && itemAdded.isExpanded) {\n        foundExpanded = true;\n      }\n\n      this.items.forEach((item) => {\n        item.isCollapsible = isCollapsible && !!item.hasItemContent;\n\n        if (item !== itemAdded && isSingle && item.isExpanded) {\n          if (foundExpanded) {\n            item.updateForExpanded(false, false);\n          }\n\n          foundExpanded = true;\n        }\n      });\n    }\n  }\n\n  private initializeDragAndDrop(): void {\n    if (!this.dragulaService.find(this.dragulaGroupName)) {\n      this.dragulaService.setOptions(this.dragulaGroupName, {\n        moves: (el: HTMLElement, container: HTMLElement, handle: HTMLElement) => {\n          const target = el.querySelector('.sky-repeater-item-grab-handle');\n          return (target && target.contains(handle));\n        }\n      });\n    }\n\n    // Reset the current dragula subscriptions.\n    this.dragulaUnsubscribe.next();\n    this.dragulaUnsubscribe.complete();\n    this.dragulaUnsubscribe = new Subject<void>();\n\n    let draggedItemIndex: number;\n\n    this.dragulaService.drag\n      .pipe(takeUntil(this.dragulaUnsubscribe))\n      .subscribe(([groupName, subject]: any[]) => {\n        /* istanbul ignore else */\n        if (groupName === this.dragulaGroupName) {\n          this.renderer.addClass(subject, 'sky-repeater-item-dragging');\n          draggedItemIndex = this.adapterService.getRepeaterItemIndex(subject);\n        }\n      });\n\n    this.dragulaService.dragend\n      .pipe(takeUntil(this.dragulaUnsubscribe))\n      .subscribe(([groupName, subject]: any[]) => {\n        /* istanbul ignore else */\n        if (groupName === this.dragulaGroupName) {\n          this.renderer.removeClass(subject, 'sky-repeater-item-dragging');\n          let newItemIndex = this.adapterService.getRepeaterItemIndex(subject);\n\n          /* sanity check */\n          /* istanbul ignore else */\n          if (draggedItemIndex >= 0) {\n            this.repeaterService.reorderItem(draggedItemIndex, newItemIndex);\n            draggedItemIndex = undefined;\n          }\n\n          this.emitTags();\n        }\n      });\n  }\n\n  private destroyDragAndDrop(): void {\n    this.dragulaUnsubscribe.next();\n    this.dragulaUnsubscribe.complete();\n    this.dragulaUnsubscribe = undefined;\n\n    if (this.dragulaService.find(this.dragulaGroupName)) {\n      this.dragulaService.destroy(this.dragulaGroupName);\n    }\n  }\n\n  private emitTags(): void {\n    const tags = this.repeaterService.items.map(item => item.tag);\n    this.orderChange.emit(tags);\n  }\n\n  private everyItemHasTag(): boolean {\n    /* sanity check */\n    /* istanbul ignore if */\n    if (!this.items || this.items.length === 0) {\n      return false;\n    }\n    return this.items.toArray().every(item => {\n      return item.tag !== undefined;\n    });\n  }\n}\n","<ng-container #repeaterHost>\n  <div *ngIf=\"!reorderable; else draggable\"\n    class=\"sky-repeater\"\n    role=\"listbox\"\n    [attr.aria-label]=\"ariaLabel || ( 'skyux_repeater_label' | skyLibResources)\"\n  >\n    <ng-container *ngTemplateOutlet=\"content\">\n    </ng-container>\n  </div>\n</ng-container>\n\n<ng-template #draggable>\n  <div\n    class=\"sky-repeater\"\n    role=\"listbox\"\n    [attr.aria-label]=\"ariaLabel || ( 'skyux_repeater_label' | skyLibResources)\"\n    [dragula]=\"dragulaGroupName\"\n  >\n    <ng-container *ngTemplateOutlet=\"content\">\n    </ng-container>\n  </div>\n</ng-template>\n\n<ng-template #content>\n  <ng-content></ng-content>\n</ng-template>"]}
261
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeater.component.js","sourceRoot":"","sources":["../../../../../projects/lists/src/modules/repeater/repeater.component.ts","../../../../../projects/lists/src/modules/repeater/repeater.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges,\n} from '@angular/core';\n\nimport { DragulaService } from 'ng2-dragula';\n\nimport { Subject } from 'rxjs';\n\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyRepeaterItemComponent } from './repeater-item.component';\n\nimport { SkyRepeaterService } from './repeater.service';\n\nimport { SkyRepeaterAdapterService } from './repeater-adapter.service';\n\nlet uniqueId = 0;\n\n/**\n * Creates a container to display repeater items.\n */\n@Component({\n  selector: 'sky-repeater',\n  styleUrls: ['./repeater.component.scss'],\n  templateUrl: './repeater.component.html',\n  providers: [SkyRepeaterService, SkyRepeaterAdapterService],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyRepeaterComponent\n  implements AfterContentInit, OnChanges, OnDestroy\n{\n  /**\n   * Specifies the index of the repeater item to visually highlight as active.\n   * For example, use this property in conjunction with the\n   * [split view component](https://developer.blackbaud.com/skyux/components/split-view)\n   * to highlight a repeater item while users edit it. Only one item can be active at a time.\n   */\n  @Input()\n  public activeIndex: number;\n\n  /**\n   * Specifies an ARIA label for the repeater list.\n   * This sets the repeater list's `aria-label` attribute\n   * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility).\n   * @default 'List of items'\n   */\n  @Input()\n  public ariaLabel: string;\n\n  /**\n   * Indicates whether users can change the order of items in the repeater list.\n   * Each repeater item also has `reorderable` property to indicate whether\n   * users can change its order.\n   */\n  @Input()\n  public reorderable: boolean = false;\n\n  /**\n   * Specifies a layout to determine which repeater items are expanded by default and whether\n   * repeater items are expandable and collapsible. Collapsed items display titles only.\n   * The valid options are `multiple`, `none`, and `single`.\n   * - `multiple` loads repeater items in an expanded state unless `isExpanded` is set to\n   * `false` for a repeater item. This layout allows users to expand and collapse\n   * as many repeater items as necessary. It is best-suited to repeater items where body\n   * content is important but users don't always need to see it.\n   * - `none` loads all repeater items in an expanded state and does not allow users to\n   * collapse them. This default layout provides the quickest access to the details in the\n   * repeater items. It is best-suited to repeater items with concise content\n   * that users need to view frequently.\n   * - `single` loads one repeater item in an expanded state and collapses all others.\n   * The expanded repeater item is the first one where `isExpanded` is set to `true`. This layout\n   * allows users to expand one item at a time. It provides the most compact view and is\n   * best-suited to repeater items where the most important information is in the titles\n   * and users only occasionally need to view the body content.\n   * @default none\n   */\n  @Input()\n  public set expandMode(value: string) {\n    this.repeaterService.expandMode = value;\n    this._expandMode = value;\n    this.updateForExpandMode();\n  }\n\n  public get expandMode(): string {\n    return this._expandMode || 'none';\n  }\n\n  /**\n   * Fires when the active repeater item changes.\n   */\n  @Output()\n  public activeIndexChange = new EventEmitter<number>();\n\n  /**\n   * Fires when users change the order of repeater items.\n   * This event emits an ordered array of the `tag` properties that the consumer provides for each repeater item.\n   */\n  @Output()\n  public orderChange = new EventEmitter<any[]>();\n\n  @ContentChildren(SkyRepeaterItemComponent)\n  public items: QueryList<SkyRepeaterItemComponent>;\n\n  public dragulaGroupName: string;\n\n  private dragulaUnsubscribe = new Subject<void>();\n\n  private ngUnsubscribe = new Subject<void>();\n\n  private _expandMode = 'none';\n\n  constructor(\n    private changeDetector: ChangeDetectorRef,\n    private repeaterService: SkyRepeaterService,\n    private adapterService: SkyRepeaterAdapterService,\n    private dragulaService: DragulaService,\n    private elementRef: ElementRef,\n    private renderer: Renderer2\n  ) {\n    this.dragulaGroupName = `sky-repeater-dragula-${++uniqueId}`;\n\n    this.repeaterService.itemCollapseStateChange\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe((item: SkyRepeaterItemComponent) => {\n        if (this.expandMode === 'single' && item.isExpanded) {\n          this.items.forEach((otherItem) => {\n            if (\n              otherItem !== item &&\n              otherItem.isExpanded &&\n              otherItem.isCollapsible\n            ) {\n              otherItem.isExpanded = false;\n            }\n          });\n        }\n      });\n\n    this.repeaterService.activeItemIndexChange\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe((index: number) => {\n        if (index !== this.activeIndex) {\n          this.activeIndex = index;\n          this.activeIndexChange.emit(index);\n        }\n      });\n\n    this.repeaterService.orderChange\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe(() => {\n        this.emitTags();\n      });\n\n    this.repeaterService.repeaterGroupId = uniqueId;\n\n    this.updateForExpandMode();\n\n    this.adapterService.setRepeaterHost(this.elementRef);\n\n    this.initializeDragAndDrop();\n  }\n\n  public ngAfterContentInit(): void {\n    // If activeIndex has been set on init, call service to activate the appropriate item.\n    setTimeout(() => {\n      if (this.activeIndex || this.activeIndex === 0) {\n        this.repeaterService.activateItemByIndex(this.activeIndex);\n      }\n\n      if (this.reorderable && !this.everyItemHasTag()) {\n        console.warn(\n          'Please supply tag properties for each repeater item when reordering functionality is enabled.'\n        );\n      }\n    });\n\n    // HACK: Not updating for expand mode in a timeout causes an error.\n    // https://github.com/angular/angular/issues/6005\n    this.items.changes.pipe(takeUntil(this.ngUnsubscribe)).subscribe(() => {\n      setTimeout(() => {\n        if (!!this.items.last) {\n          this.updateForExpandMode(this.items.last);\n          this.items.last.reorderable = this.reorderable;\n        }\n\n        if (this.activeIndex !== undefined) {\n          this.repeaterService.activateItemByIndex(this.activeIndex);\n        }\n      });\n    });\n\n    setTimeout(() => {\n      this.updateForExpandMode();\n\n      this.items.forEach((item) => {\n        item.reorderable = this.reorderable;\n      });\n    }, 0);\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes['activeIndex']) {\n      this.repeaterService.enableActiveState = true;\n      if (\n        changes['activeIndex'].currentValue !==\n        changes['activeIndex'].previousValue\n      ) {\n        this.repeaterService.activateItemByIndex(this.activeIndex);\n      }\n    }\n\n    if (changes.reorderable) {\n      if (this.items) {\n        this.items.forEach((item) => (item.reorderable = this.reorderable));\n      }\n\n      this.changeDetector.markForCheck();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n    this.destroyDragAndDrop();\n  }\n\n  private updateForExpandMode(itemAdded?: SkyRepeaterItemComponent): void {\n    if (this.items) {\n      let foundExpanded = false;\n      let isCollapsible = this.expandMode !== 'none';\n      let isSingle = this.expandMode === 'single';\n\n      // Keep any newly-added expanded item expanded and collapse the rest.\n      if (itemAdded && itemAdded.isExpanded) {\n        foundExpanded = true;\n      }\n\n      this.items.forEach((item) => {\n        item.isCollapsible = isCollapsible && !!item.hasItemContent;\n\n        if (item !== itemAdded && isSingle && item.isExpanded) {\n          if (foundExpanded) {\n            item.updateForExpanded(false, false);\n          }\n\n          foundExpanded = true;\n        }\n      });\n    }\n  }\n\n  private initializeDragAndDrop(): void {\n    /* Sanity check that we haven't already set up dragging abilities */\n    /* istanbul ignore else */\n    if (!this.dragulaService.find(this.dragulaGroupName)) {\n      this.dragulaService.setOptions(this.dragulaGroupName, {\n        moves: (\n          el: HTMLElement,\n          container: HTMLElement,\n          handle: HTMLElement\n        ) => {\n          const target = el.querySelector('.sky-repeater-item-grab-handle');\n          return this.reorderable && target && target.contains(handle);\n        },\n      });\n    }\n\n    let draggedItemIndex: number;\n\n    this.dragulaService.drag\n      .pipe(takeUntil(this.dragulaUnsubscribe))\n      .subscribe(([groupName, subject]: any[]) => {\n        /* istanbul ignore else */\n        if (groupName === this.dragulaGroupName) {\n          this.renderer.addClass(subject, 'sky-repeater-item-dragging');\n          draggedItemIndex = this.adapterService.getRepeaterItemIndex(subject);\n        }\n      });\n\n    this.dragulaService.dragend\n      .pipe(takeUntil(this.dragulaUnsubscribe))\n      .subscribe(([groupName, subject]: any[]) => {\n        /* istanbul ignore else */\n        if (groupName === this.dragulaGroupName) {\n          this.renderer.removeClass(subject, 'sky-repeater-item-dragging');\n          let newItemIndex = this.adapterService.getRepeaterItemIndex(subject);\n\n          /* sanity check */\n          /* istanbul ignore else */\n          if (draggedItemIndex >= 0) {\n            this.repeaterService.reorderItem(draggedItemIndex, newItemIndex);\n            draggedItemIndex = undefined;\n          }\n\n          this.emitTags();\n        }\n      });\n  }\n\n  private destroyDragAndDrop(): void {\n    this.dragulaUnsubscribe.next();\n    this.dragulaUnsubscribe.complete();\n    this.dragulaUnsubscribe = undefined;\n\n    /* Sanity check that we have set up dragging abilities */\n    /* istanbul ignore else */\n    if (this.dragulaService.find(this.dragulaGroupName)) {\n      this.dragulaService.destroy(this.dragulaGroupName);\n    }\n  }\n\n  private emitTags(): void {\n    const tags = this.repeaterService.items.map((item) => item.tag);\n    this.orderChange.emit(tags);\n  }\n\n  private everyItemHasTag(): boolean {\n    /* sanity check */\n    /* istanbul ignore if */\n    if (!this.items || this.items.length === 0) {\n      return false;\n    }\n    return this.items.toArray().every((item) => {\n      return item.tag !== undefined;\n    });\n  }\n}\n","<ng-container #repeaterHost>\n  <div\n    class=\"sky-repeater\"\n    role=\"listbox\"\n    [attr.aria-label]=\"ariaLabel || ('skyux_repeater_label' | skyLibResources)\"\n    [dragula]=\"dragulaGroupName\"\n  >\n    <ng-content></ng-content>\n  </div>\n</ng-container>\n"]}