@skyux/lists 9.3.1 → 9.4.1
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.
- package/documentation.json +974 -912
- package/esm2022/lib/modules/filter/filter-button.component.mjs +8 -4
- package/esm2022/lib/modules/filter/filter-inline-item.component.mjs +3 -3
- package/esm2022/lib/modules/filter/filter-inline.component.mjs +3 -3
- package/esm2022/lib/modules/filter/filter-summary-item.component.mjs +3 -3
- package/esm2022/lib/modules/filter/filter-summary.component.mjs +3 -3
- package/esm2022/lib/modules/paging/paging.component.mjs +3 -3
- package/esm2022/lib/modules/repeater/repeater-item-content.component.mjs +3 -3
- package/esm2022/lib/modules/repeater/repeater-item-context-menu.component.mjs +3 -3
- package/esm2022/lib/modules/repeater/repeater-item-title.component.mjs +3 -3
- package/esm2022/lib/modules/repeater/repeater-item.component.mjs +3 -3
- package/esm2022/lib/modules/repeater/repeater.component.mjs +3 -3
- package/esm2022/lib/modules/shared/sky-lists-resources.module.mjs +3 -1
- package/esm2022/lib/modules/sort/sort-item.component.mjs +3 -3
- package/esm2022/lib/modules/sort/sort.component.mjs +9 -5
- package/fesm2022/skyux-lists.mjs +38 -30
- package/fesm2022/skyux-lists.mjs.map +1 -1
- package/lib/modules/filter/filter-button.component.d.ts +5 -1
- package/lib/modules/sort/sort.component.d.ts +7 -2
- package/package.json +10 -10
|
@@ -443,11 +443,11 @@ export class SkyRepeaterItemComponent {
|
|
|
443
443
|
});
|
|
444
444
|
}
|
|
445
445
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: SkyRepeaterItemComponent, deps: [{ token: i1.SkyRepeaterService }, { token: i0.ChangeDetectorRef }, { token: i2.SkyRepeaterAdapterService }, { token: i0.ElementRef }, { token: i3.SkyLibResourcesService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
446
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.5", type: SkyRepeaterItemComponent, selector: "sky-repeater-item", inputs: { disabled: "disabled", itemName: "itemName", 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: { listeners: { "keydown": "onKeydown($event)" }, 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 [attr.aria-label]=\"itemName\"\n [attr.aria-selected]=\"selectable ? !!isSelected : undefined\"\n [attr.role]=\"(itemRole$ | async)?.item\"\n [attr.tabIndex]=\"tabindex\"\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 #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\n [attr.role]=\"!showInlineForm ? (itemRole$ | async)?.content : undefined\"\n class=\"sky-repeater-item-left\"\n >\n <ng-container *ngIf=\"reorderable\">\n <span\n aria-live=\"assertive\"\n class=\"sky-screen-reader-only\"\n [id]=\"contentId + '-reorder-state'\"\n >\n {{ reorderState }}\n </span>\n <span\n class=\"sky-screen-reader-only\"\n [id]=\"contentId + '-reorder-instructions'\"\n >{{ reorderButtonLabel }}</span\n >\n <button\n class=\"sky-btn sky-tile-tools-control sky-repeater-item-grab-handle\"\n type=\"button\"\n [attr.aria-describedby]=\"contentId + '-reorder-instructions'\"\n [attr.aria-label]=\"\n itemName\n ? ('skyux_repeater_item_reorder_label' | skyLibResources : itemName)\n : ('skyux_repeater_item_reorder_label_default' | skyLibResources)\n \"\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]=\"\n itemName\n ? ('skyux_repeater_item_checkbox_label' | skyLibResources : itemName)\n : ('skyux_repeater_item_checkbox_label_default' | skyLibResources)\n \"\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 [attr.role]=\"(itemRole$ | async)?.title\"\n [hidden]=\"titleRef.children.length === 0\"\n (click)=\"headerClick()\"\n >\n <div class=\"sky-repeater-item-title sky-font-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 itemName\n ? ('skyux_repeater_item_reorder_top_label'\n | skyLibResources : itemName)\n : ('skyux_repeater_item_reorder_top_label_default'\n | 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 [ariaControls]=\"contentId\"\n [ariaLabel]=\"\n itemName\n ? isExpanded\n ? ('skyux_repeater_item_expand' | skyLibResources : itemName)\n : ('skyux_repeater_item_collapse' | skyLibResources : itemName)\n : isExpanded\n ? ('skyux_repeater_item_expand_default' | skyLibResources)\n : ('skyux_repeater_item_collapse_default' | skyLibResources)\n \"\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 [@.disabled]=\"animationDisabled\"\n [@skyAnimationSlide]=\"slideDirection\"\n #itemContentRef\n [attr.role]=\"(itemRole$ | async)?.content\"\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;align-items:flex-start;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-grab-handle{color:#cdcfd2;cursor:pointer;border:0;width:24px;height:24px;cursor:grab;cursor:-moz-grab;padding:0;margin:5px 10px 5px 0}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-split-view-drawer sky-repeater-item .sky-repeater-item{padding-left:var(--sky-padding-even-md)}.sky-theme-modern .sky-split-view-drawer sky-repeater-item .sky-repeater-item.sky-repeater-item-active{padding-left:calc(var(--sky-padding-even-md) - 4px)}.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:#fff;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"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.λ2, selector: "sky-chevron", inputs: ["ariaControls", "ariaLabel", "direction", "disabled"], outputs: ["directionChange"] }, { kind: "component", type: i6.λ3, selector: "sky-checkbox", inputs: ["label", "labelledBy", "id", "disabled", "tabindex", "name", "icon", "checkboxType", "checked", "indeterminate", "required"], outputs: ["change", "checkedChange", "disabledChange", "indeterminateChange"] }, { kind: "component", type: i5.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "component", type: i7.λ1, selector: "sky-inline-form", inputs: ["config", "template", "showForm"], outputs: ["close"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.SkyLibResourcesPipe, name: "skyLibResources" }], animations: [skyAnimationSlide], encapsulation: i0.ViewEncapsulation.None }); }
|
|
446
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.5", type: SkyRepeaterItemComponent, selector: "sky-repeater-item", inputs: { disabled: "disabled", itemName: "itemName", 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: { listeners: { "keydown": "onKeydown($event)" }, 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 [attr.aria-label]=\"itemName\"\n [attr.aria-selected]=\"selectable ? !!isSelected : undefined\"\n [attr.role]=\"(itemRole$ | async)?.item\"\n [attr.tabIndex]=\"tabindex\"\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 #itemRef\n>\n <div #inlineDelete>\n <ng-content select=\"sky-inline-delete\" />\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\n [attr.role]=\"!showInlineForm ? (itemRole$ | async)?.content : undefined\"\n class=\"sky-repeater-item-left\"\n >\n <ng-container *ngIf=\"reorderable\">\n <span\n aria-live=\"assertive\"\n class=\"sky-screen-reader-only\"\n [id]=\"contentId + '-reorder-state'\"\n >\n {{ reorderState }}\n </span>\n <span\n class=\"sky-screen-reader-only\"\n [id]=\"contentId + '-reorder-instructions'\"\n >{{ reorderButtonLabel }}</span\n >\n <button\n class=\"sky-btn sky-tile-tools-control sky-repeater-item-grab-handle\"\n type=\"button\"\n [attr.aria-describedby]=\"contentId + '-reorder-instructions'\"\n [attr.aria-label]=\"\n itemName\n ? ('skyux_repeater_item_reorder_label' | skyLibResources : itemName)\n : ('skyux_repeater_item_reorder_label_default' | skyLibResources)\n \"\n (blur)=\"onReorderHandleBlur($event)\"\n (keydown)=\"onReorderHandleKeyDown($event)\"\n #grabHandle\n >\n <sky-icon icon=\"arrows-v\" />\n </button>\n </ng-container>\n <sky-checkbox\n *ngIf=\"selectable\"\n class=\"sky-repeater-item-checkbox\"\n [checked]=\"isSelected\"\n [label]=\"\n itemName\n ? ('skyux_repeater_item_checkbox_label' | skyLibResources : itemName)\n : ('skyux_repeater_item_checkbox_label_default' | skyLibResources)\n \"\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\" />\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 [attr.role]=\"(itemRole$ | async)?.title\"\n [hidden]=\"titleRef.children.length === 0\"\n (click)=\"headerClick()\"\n >\n <div class=\"sky-repeater-item-title sky-font-emphasized\" #titleRef>\n <ng-content select=\"sky-repeater-item-title\" />\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 itemName\n ? ('skyux_repeater_item_reorder_top_label'\n | skyLibResources : itemName)\n : ('skyux_repeater_item_reorder_top_label_default'\n | skyLibResources)\n \"\n (click)=\"moveToTop($event)\"\n >\n <sky-icon icon=\"arrow-circle-up\" />\n {{ 'skyux_repeater_item_reorder_top' | skyLibResources }}\n </button>\n <div *ngIf=\"isCollapsible\" class=\"sky-repeater-item-chevron\">\n <sky-chevron\n [ariaControls]=\"contentId\"\n [ariaLabel]=\"\n itemName\n ? isExpanded\n ? ('skyux_repeater_item_expand' | skyLibResources : itemName)\n : ('skyux_repeater_item_collapse' | skyLibResources : itemName)\n : isExpanded\n ? ('skyux_repeater_item_expand_default' | skyLibResources)\n : ('skyux_repeater_item_collapse_default' | skyLibResources)\n \"\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 [@.disabled]=\"animationDisabled\"\n [@skyAnimationSlide]=\"slideDirection\"\n #itemContentRef\n [attr.role]=\"(itemRole$ | async)?.content\"\n >\n <ng-content select=\"sky-repeater-item-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;align-items:flex-start;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-grab-handle{color:#cdcfd2;cursor:pointer;border:0;width:24px;height:24px;cursor:grab;cursor:-moz-grab;padding:0;margin:5px 10px 5px 0}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-split-view-drawer sky-repeater-item .sky-repeater-item{padding-left:var(--sky-padding-even-md)}.sky-theme-modern .sky-split-view-drawer sky-repeater-item .sky-repeater-item.sky-repeater-item-active{padding-left:calc(var(--sky-padding-even-md) - 4px)}.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:#fff;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"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.λ2, selector: "sky-chevron", inputs: ["ariaControls", "ariaLabel", "direction", "disabled"], outputs: ["directionChange"] }, { kind: "component", type: i6.λ3, selector: "sky-checkbox", inputs: ["label", "labelledBy", "id", "disabled", "tabindex", "name", "icon", "checkboxType", "checked", "indeterminate", "required"], outputs: ["change", "checkedChange", "disabledChange", "indeterminateChange"] }, { kind: "component", type: i5.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "component", type: i7.λ1, selector: "sky-inline-form", inputs: ["config", "template", "showForm"], outputs: ["close"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.SkyLibResourcesPipe, name: "skyLibResources" }], animations: [skyAnimationSlide], encapsulation: i0.ViewEncapsulation.None }); }
|
|
447
447
|
}
|
|
448
448
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: SkyRepeaterItemComponent, decorators: [{
|
|
449
449
|
type: Component,
|
|
450
|
-
args: [{ selector: 'sky-repeater-item', animations: [skyAnimationSlide], encapsulation: ViewEncapsulation.None, template: "<div\n class=\"sky-repeater-item sky-padding-even-default\"\n [attr.aria-label]=\"itemName\"\n [attr.aria-selected]=\"selectable ? !!isSelected : undefined\"\n [attr.role]=\"(itemRole$ | async)?.item\"\n [attr.tabIndex]=\"tabindex\"\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 #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\n [attr.role]=\"!showInlineForm ? (itemRole$ | async)?.content : undefined\"\n class=\"sky-repeater-item-left\"\n >\n <ng-container *ngIf=\"reorderable\">\n <span\n aria-live=\"assertive\"\n class=\"sky-screen-reader-only\"\n [id]=\"contentId + '-reorder-state'\"\n >\n {{ reorderState }}\n </span>\n <span\n class=\"sky-screen-reader-only\"\n [id]=\"contentId + '-reorder-instructions'\"\n >{{ reorderButtonLabel }}</span\n >\n <button\n class=\"sky-btn sky-tile-tools-control sky-repeater-item-grab-handle\"\n type=\"button\"\n [attr.aria-describedby]=\"contentId + '-reorder-instructions'\"\n [attr.aria-label]=\"\n itemName\n ? ('skyux_repeater_item_reorder_label' | skyLibResources : itemName)\n : ('skyux_repeater_item_reorder_label_default' | skyLibResources)\n \"\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]=\"\n itemName\n ? ('skyux_repeater_item_checkbox_label' | skyLibResources : itemName)\n : ('skyux_repeater_item_checkbox_label_default' | skyLibResources)\n \"\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 [attr.role]=\"(itemRole$ | async)?.title\"\n [hidden]=\"titleRef.children.length === 0\"\n (click)=\"headerClick()\"\n >\n <div class=\"sky-repeater-item-title sky-font-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 itemName\n ? ('skyux_repeater_item_reorder_top_label'\n | skyLibResources : itemName)\n : ('skyux_repeater_item_reorder_top_label_default'\n | 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 [ariaControls]=\"contentId\"\n [ariaLabel]=\"\n itemName\n ? isExpanded\n ? ('skyux_repeater_item_expand' | skyLibResources : itemName)\n : ('skyux_repeater_item_collapse' | skyLibResources : itemName)\n : isExpanded\n ? ('skyux_repeater_item_expand_default' | skyLibResources)\n : ('skyux_repeater_item_collapse_default' | skyLibResources)\n \"\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 [@.disabled]=\"animationDisabled\"\n [@skyAnimationSlide]=\"slideDirection\"\n #itemContentRef\n [attr.role]=\"(itemRole$ | async)?.content\"\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;align-items:flex-start;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-grab-handle{color:#cdcfd2;cursor:pointer;border:0;width:24px;height:24px;cursor:grab;cursor:-moz-grab;padding:0;margin:5px 10px 5px 0}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-split-view-drawer sky-repeater-item .sky-repeater-item{padding-left:var(--sky-padding-even-md)}.sky-theme-modern .sky-split-view-drawer sky-repeater-item .sky-repeater-item.sky-repeater-item-active{padding-left:calc(var(--sky-padding-even-md) - 4px)}.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:#fff;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"] }]
|
|
450
|
+
args: [{ selector: 'sky-repeater-item', animations: [skyAnimationSlide], encapsulation: ViewEncapsulation.None, template: "<div\n class=\"sky-repeater-item sky-padding-even-default\"\n [attr.aria-label]=\"itemName\"\n [attr.aria-selected]=\"selectable ? !!isSelected : undefined\"\n [attr.role]=\"(itemRole$ | async)?.item\"\n [attr.tabIndex]=\"tabindex\"\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 #itemRef\n>\n <div #inlineDelete>\n <ng-content select=\"sky-inline-delete\" />\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\n [attr.role]=\"!showInlineForm ? (itemRole$ | async)?.content : undefined\"\n class=\"sky-repeater-item-left\"\n >\n <ng-container *ngIf=\"reorderable\">\n <span\n aria-live=\"assertive\"\n class=\"sky-screen-reader-only\"\n [id]=\"contentId + '-reorder-state'\"\n >\n {{ reorderState }}\n </span>\n <span\n class=\"sky-screen-reader-only\"\n [id]=\"contentId + '-reorder-instructions'\"\n >{{ reorderButtonLabel }}</span\n >\n <button\n class=\"sky-btn sky-tile-tools-control sky-repeater-item-grab-handle\"\n type=\"button\"\n [attr.aria-describedby]=\"contentId + '-reorder-instructions'\"\n [attr.aria-label]=\"\n itemName\n ? ('skyux_repeater_item_reorder_label' | skyLibResources : itemName)\n : ('skyux_repeater_item_reorder_label_default' | skyLibResources)\n \"\n (blur)=\"onReorderHandleBlur($event)\"\n (keydown)=\"onReorderHandleKeyDown($event)\"\n #grabHandle\n >\n <sky-icon icon=\"arrows-v\" />\n </button>\n </ng-container>\n <sky-checkbox\n *ngIf=\"selectable\"\n class=\"sky-repeater-item-checkbox\"\n [checked]=\"isSelected\"\n [label]=\"\n itemName\n ? ('skyux_repeater_item_checkbox_label' | skyLibResources : itemName)\n : ('skyux_repeater_item_checkbox_label_default' | skyLibResources)\n \"\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\" />\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 [attr.role]=\"(itemRole$ | async)?.title\"\n [hidden]=\"titleRef.children.length === 0\"\n (click)=\"headerClick()\"\n >\n <div class=\"sky-repeater-item-title sky-font-emphasized\" #titleRef>\n <ng-content select=\"sky-repeater-item-title\" />\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 itemName\n ? ('skyux_repeater_item_reorder_top_label'\n | skyLibResources : itemName)\n : ('skyux_repeater_item_reorder_top_label_default'\n | skyLibResources)\n \"\n (click)=\"moveToTop($event)\"\n >\n <sky-icon icon=\"arrow-circle-up\" />\n {{ 'skyux_repeater_item_reorder_top' | skyLibResources }}\n </button>\n <div *ngIf=\"isCollapsible\" class=\"sky-repeater-item-chevron\">\n <sky-chevron\n [ariaControls]=\"contentId\"\n [ariaLabel]=\"\n itemName\n ? isExpanded\n ? ('skyux_repeater_item_expand' | skyLibResources : itemName)\n : ('skyux_repeater_item_collapse' | skyLibResources : itemName)\n : isExpanded\n ? ('skyux_repeater_item_expand_default' | skyLibResources)\n : ('skyux_repeater_item_collapse_default' | skyLibResources)\n \"\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 [@.disabled]=\"animationDisabled\"\n [@skyAnimationSlide]=\"slideDirection\"\n #itemContentRef\n [attr.role]=\"(itemRole$ | async)?.content\"\n >\n <ng-content select=\"sky-repeater-item-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;align-items:flex-start;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-grab-handle{color:#cdcfd2;cursor:pointer;border:0;width:24px;height:24px;cursor:grab;cursor:-moz-grab;padding:0;margin:5px 10px 5px 0}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-split-view-drawer sky-repeater-item .sky-repeater-item{padding-left:var(--sky-padding-even-md)}.sky-theme-modern .sky-split-view-drawer sky-repeater-item .sky-repeater-item.sky-repeater-item-active{padding-left:calc(var(--sky-padding-even-md) - 4px)}.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:#fff;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"] }]
|
|
451
451
|
}], ctorParameters: function () { return [{ type: i1.SkyRepeaterService }, { type: i0.ChangeDetectorRef }, { type: i2.SkyRepeaterAdapterService }, { type: i0.ElementRef }, { type: i3.SkyLibResourcesService }]; }, propDecorators: { disabled: [{
|
|
452
452
|
type: Input
|
|
453
453
|
}], itemName: [{
|
|
@@ -501,4 +501,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
|
|
|
501
501
|
type: HostListener,
|
|
502
502
|
args: ['keydown', ['$event']]
|
|
503
503
|
}] } });
|
|
504
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeater-item.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/repeater/repeater-item.component.ts","../../../../../../../../libs/components/lists/src/lib/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  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { skyAnimationSlide } from '@skyux/animations';\nimport { SkyCheckboxChange } from '@skyux/forms';\nimport { SkyLibResourcesService } from '@skyux/i18n';\nimport {\n  SkyInlineFormCloseArgs,\n  SkyInlineFormConfig,\n} from '@skyux/inline-form';\n\nimport { Observable, Subject, forkJoin as observableForkJoin } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyRepeaterAdapterService } from './repeater-adapter.service';\nimport { SkyRepeaterItemContentComponent } from './repeater-item-content.component';\nimport { SkyRepeaterItemContextMenuComponent } from './repeater-item-context-menu.component';\nimport { SkyRepeaterItemRolesType } from './repeater-item-roles.type';\nimport { SkyRepeaterService } from './repeater.service';\n\nlet nextContentId = 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   * Make the first, non-disabled item tab-focusable.\n   * - Disabled items should not be focusable per [W3C](https://www.w3.org/TR/wai-aria-practices-1.1/#kbd_disabled_controls).\n   * - One item per list/grid/listbox should be tab focusable per [W3C](https://www.w3.org/TR/wai-aria-practices-1.1/#grid).\n   */\n  public get tabindex(): 0 | -1 {\n    return this.#repeaterService.items.filter((item) => !item.disabled)[0] ===\n      this\n      ? 0\n      : -1;\n  }\n\n  /**\n   * Whether to exclude an item when cycling through.\n   */\n  @Input()\n  public set disabled(value: boolean | undefined) {\n    if (this.#_isDisabled !== value) {\n      if (value) {\n        this.isSelected = false;\n        this.#_isDisabled = true;\n      } else {\n        this.#_isDisabled = false;\n      }\n      if (this.isActive) {\n        this.#repeaterService.activateItemByIndex(undefined);\n      }\n      if (this.#elementRef.nativeElement.matches(':focus-within')) {\n        this.#elementRef.nativeElement.ownerDocument.activeElement.blur();\n      }\n      this.#changeDetector.markForCheck();\n    }\n  }\n  public get disabled(): boolean | undefined {\n    return this.#_isDisabled;\n  }\n\n  /**\n   * The human-readable name for the repeater item that is available for multiple purposes,\n   * such as accessibility and instrumentation. For example, the component uses the name to\n   * construct ARIA labels for the repeater item controls\n   * to [support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility).\n   * For more information about the `aria-label` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-label).\n   */\n  @Input()\n  public itemName: string | undefined;\n\n  /**\n   * 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 | undefined;\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<unknown> | undefined;\n\n  /**\n   * Whether the repeater item is expanded.\n   * @default true\n   */\n  @Input()\n  public set isExpanded(value: boolean | undefined) {\n    this.updateForExpanded(value !== false, true);\n  }\n\n  public get isExpanded(): boolean {\n    return this.#isExpanded;\n  }\n\n  /**\n   * 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 | undefined) {\n    if (!this.disabled && value !== this.#_isSelected) {\n      this.#_isSelected = value;\n      this.isSelectedChange.emit(this.#_isSelected);\n    }\n  }\n\n  public get isSelected(): boolean | undefined {\n    return this.#_isSelected;\n  }\n\n  /**\n   * 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 | undefined = false;\n\n  /**\n   * Whether to display a checkbox in the left of the repeater item.\n   */\n  @Input()\n  public selectable: boolean | undefined = false;\n\n  /**\n   * 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 | undefined = false;\n\n  /**\n   * The 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 | undefined;\n\n  public contentId: string;\n\n  public hasItemContent = false;\n\n  public isActive = false;\n\n  public set isCollapsible(value: boolean | undefined) {\n    if (this.isCollapsible !== value) {\n      this.#_isCollapsible = value !== false;\n\n      /*istanbul ignore else */\n      if (!this.#_isCollapsible) {\n        this.updateForExpanded(true, true);\n      }\n    }\n\n    this.#changeDetector.markForCheck();\n  }\n\n  public get isCollapsible(): boolean {\n    return this.#_isCollapsible;\n  }\n\n  public itemRole$: Observable<SkyRepeaterItemRolesType>;\n\n  public reorderButtonLabel = '';\n\n  public reorderState: string | undefined;\n\n  public slideDirection: string | undefined;\n\n  public animationDisabled = false;\n\n  @HostBinding('class')\n  public get repeaterGroupClass(): string {\n    return 'sky-repeater-item-group-' + this.#repeaterService.repeaterGroupId;\n  }\n\n  @ViewChild('grabHandle', { read: ElementRef })\n  public grabHandle: ElementRef | undefined;\n\n  @ViewChild('itemContentRef', { read: ElementRef })\n  public itemContentRef: ElementRef | undefined;\n\n  @ViewChild('itemHeaderRef', { read: ElementRef })\n  public itemHeaderRef: ElementRef | undefined;\n\n  @ViewChild('itemRef', { read: ElementRef })\n  public itemRef: ElementRef | undefined;\n\n  @ContentChildren(SkyRepeaterItemContentComponent)\n  public repeaterItemContentComponents:\n    | QueryList<SkyRepeaterItemContentComponent>\n    | undefined;\n\n  #adapterService: SkyRepeaterAdapterService;\n  #changeDetector: ChangeDetectorRef;\n  #elementRef: ElementRef;\n  #isExpanded = true;\n  #keyboardReorderingEnabled = false;\n  #ngUnsubscribe = new Subject<void>();\n  #reorderCancelText = '';\n  #reorderCurrentIndex = -1;\n  #reorderFinishText = '';\n  #reorderInstructions = '';\n  #reorderMovedText = '';\n  #reorderStateDescription = '';\n  #reorderSteps = 0;\n  #repeaterService: SkyRepeaterService;\n  #resourceService: SkyLibResourcesService;\n  #_isCollapsible = true;\n  #_isDisabled: boolean | undefined = false;\n  #_isSelected: boolean | undefined;\n\n  constructor(\n    repeaterService: SkyRepeaterService,\n    changeDetector: ChangeDetectorRef,\n    adapterService: SkyRepeaterAdapterService,\n    elementRef: ElementRef,\n    resourceService: SkyLibResourcesService\n  ) {\n    this.#repeaterService = repeaterService;\n    this.#changeDetector = changeDetector;\n    this.#adapterService = adapterService;\n    this.#elementRef = elementRef;\n    this.#resourceService = resourceService;\n\n    this.#slideForExpanded(false);\n\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    ])\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(\n        ([\n          reorderCancelText,\n          reorderFinishText,\n          reorderInstructionsText,\n          reorderOperationText,\n          reorderMovedText,\n        ]) => {\n          this.#reorderCancelText = reorderCancelText;\n          this.#reorderFinishText = reorderFinishText;\n          this.#reorderStateDescription = reorderInstructionsText;\n          this.#reorderInstructions = reorderOperationText;\n          this.#reorderMovedText = reorderMovedText;\n          this.reorderButtonLabel = this.#reorderInstructions;\n        }\n      );\n\n    this.contentId = `sky-repeater-item-content-${++nextContentId}`;\n    this.itemRole$ = this.#repeaterService.itemRole.asObservable();\n  }\n\n  public ngOnInit(): void {\n    this.#repeaterService.registerItem(this);\n    this.#repeaterService.activeItemChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((item) => {\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;\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  @HostListener('keydown', ['$event'])\n  public onKeydown($event: KeyboardEvent): void {\n    if (\n      [' ', 'Enter', 'Home', 'End', 'ArrowUp', 'ArrowDown'].includes($event.key)\n    ) {\n      if (\n        ($event.target as HTMLElement).matches(\n          'input, textarea, select, option, [contenteditable], [contenteditable] *'\n        )\n      ) {\n        return;\n      }\n      $event.preventDefault();\n      $event.stopPropagation();\n      let activateItem: SkyRepeaterItemComponent | undefined = undefined;\n      /* istanbul ignore else */\n      if ([' ', 'Enter'].includes($event.key)) {\n        if (this.selectable) {\n          this.isSelected = !this.isSelected;\n        }\n        // eslint-disable-next-line @typescript-eslint/no-this-alias\n        activateItem = this;\n      }\n      /* istanbul ignore else */\n      if (['Home', 'End'].includes($event.key)) {\n        const items = this.#repeaterService.items.filter(\n          (item) => !item.disabled\n        );\n        if ($event.key === 'Home') {\n          activateItem = items.shift();\n        } else {\n          activateItem = items.pop();\n        }\n      }\n      /* istanbul ignore else */\n      if (['ArrowUp', 'ArrowDown'].includes($event.key)) {\n        const currentIndex = this.#repeaterService.items.findIndex(\n          (item) => item === this\n        );\n        let sliceFrom: number;\n        let sliceTo: number | undefined;\n        if ($event.key === 'ArrowUp') {\n          sliceFrom = 0;\n          sliceTo = currentIndex;\n        } else {\n          sliceFrom = currentIndex + 1;\n          sliceTo = undefined;\n        }\n        const items = this.#repeaterService.items\n          .slice(sliceFrom, sliceTo)\n          .filter((item) => !item.disabled);\n        activateItem = $event.key === 'ArrowUp' ? items.pop() : items.shift();\n        if (!activateItem) {\n          // Wrap around.\n          if ($event.key === 'ArrowDown') {\n            sliceFrom = 0;\n            sliceTo = currentIndex;\n          } else {\n            sliceFrom = currentIndex + 1;\n            sliceTo = undefined;\n          }\n          const items = this.#repeaterService.items\n            .slice(sliceFrom, sliceTo)\n            .filter((item) => !item.disabled);\n          activateItem = $event.key === 'ArrowUp' ? items.pop() : items.shift();\n        }\n      }\n      /* istanbul ignore else */\n      if (activateItem && !activateItem.isActive) {\n        this.#repeaterService.activateItem(activateItem);\n        if (\n          !(activateItem.#elementRef.nativeElement as Element).matches(\n            ':focus-within'\n          )\n        ) {\n          activateItem.itemRef?.nativeElement.focus();\n        }\n      }\n    }\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(event.target as HTMLElement);\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(event.target as HTMLElement);\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  #slideForExpanded(animate: boolean): void {\n    this.animationDisabled = !animate;\n    this.slideDirection = this.isExpanded ? 'down' : 'up';\n  }\n\n  #keyboardReorderUp(): void {\n    const newIndex = this.#adapterService.moveItemUp(\n      this.#elementRef.nativeElement\n    );\n    if (newIndex !== undefined) {\n      this.#reorderCurrentIndex = newIndex;\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\n  #keyboardReorderDown(): void {\n    const newIndex = this.#adapterService.moveItemDown(\n      this.#elementRef.nativeElement\n    );\n    if (newIndex) {\n      this.#reorderCurrentIndex = newIndex;\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\n  #keyboardToggleReorder(): void {\n    this.#keyboardReorderingEnabled = !this.#keyboardReorderingEnabled;\n    this.#reorderSteps = 0;\n\n    if (this.#keyboardReorderingEnabled) {\n      this.reorderState = this.#reorderStateDescription;\n    } else {\n      // TODO: Needs improvement to be localized\n      this.reorderState = `${this.#reorderFinishText} ${\n        this.#reorderCurrentIndex + 1\n      } ${this.#reorderInstructions}`;\n      this.#reorderCurrentIndex = -1;\n    }\n  }\n\n  #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  #updateExpandOnContentChange(): void {\n    this.repeaterItemContentComponents?.changes\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.hasItemContent = !!this.repeaterItemContentComponents?.length;\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  [attr.aria-label]=\"itemName\"\n  [attr.aria-selected]=\"selectable ? !!isSelected : undefined\"\n  [attr.role]=\"(itemRole$ | async)?.item\"\n  [attr.tabIndex]=\"tabindex\"\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  #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\n    [attr.role]=\"!showInlineForm ? (itemRole$ | async)?.content : undefined\"\n    class=\"sky-repeater-item-left\"\n  >\n    <ng-container *ngIf=\"reorderable\">\n      <span\n        aria-live=\"assertive\"\n        class=\"sky-screen-reader-only\"\n        [id]=\"contentId + '-reorder-state'\"\n      >\n        {{ reorderState }}\n      </span>\n      <span\n        class=\"sky-screen-reader-only\"\n        [id]=\"contentId + '-reorder-instructions'\"\n        >{{ reorderButtonLabel }}</span\n      >\n      <button\n        class=\"sky-btn sky-tile-tools-control sky-repeater-item-grab-handle\"\n        type=\"button\"\n        [attr.aria-describedby]=\"contentId + '-reorder-instructions'\"\n        [attr.aria-label]=\"\n          itemName\n            ? ('skyux_repeater_item_reorder_label' | skyLibResources : itemName)\n            : ('skyux_repeater_item_reorder_label_default' | skyLibResources)\n        \"\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]=\"\n        itemName\n          ? ('skyux_repeater_item_checkbox_label' | skyLibResources : itemName)\n          : ('skyux_repeater_item_checkbox_label_default' | skyLibResources)\n      \"\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      [attr.role]=\"(itemRole$ | async)?.title\"\n      [hidden]=\"titleRef.children.length === 0\"\n      (click)=\"headerClick()\"\n    >\n      <div class=\"sky-repeater-item-title sky-font-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          itemName\n            ? ('skyux_repeater_item_reorder_top_label'\n              | skyLibResources : itemName)\n            : ('skyux_repeater_item_reorder_top_label_default'\n              | 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          [ariaControls]=\"contentId\"\n          [ariaLabel]=\"\n            itemName\n              ? isExpanded\n                ? ('skyux_repeater_item_expand' | skyLibResources : itemName)\n                : ('skyux_repeater_item_collapse' | skyLibResources : itemName)\n              : isExpanded\n              ? ('skyux_repeater_item_expand_default' | skyLibResources)\n              : ('skyux_repeater_item_collapse_default' | skyLibResources)\n          \"\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      [@.disabled]=\"animationDisabled\"\n      [@skyAnimationSlide]=\"slideDirection\"\n      #itemContentRef\n      [attr.role]=\"(itemRole$ | async)?.content\"\n    >\n      <ng-content select=\"sky-repeater-item-content\"></ng-content>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
504
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeater-item.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/repeater/repeater-item.component.ts","../../../../../../../../libs/components/lists/src/lib/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  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { skyAnimationSlide } from '@skyux/animations';\nimport { SkyCheckboxChange } from '@skyux/forms';\nimport { SkyLibResourcesService } from '@skyux/i18n';\nimport {\n  SkyInlineFormCloseArgs,\n  SkyInlineFormConfig,\n} from '@skyux/inline-form';\n\nimport { Observable, Subject, forkJoin as observableForkJoin } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyRepeaterAdapterService } from './repeater-adapter.service';\nimport { SkyRepeaterItemContentComponent } from './repeater-item-content.component';\nimport { SkyRepeaterItemContextMenuComponent } from './repeater-item-context-menu.component';\nimport { SkyRepeaterItemRolesType } from './repeater-item-roles.type';\nimport { SkyRepeaterService } from './repeater.service';\n\nlet nextContentId = 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   * Make the first, non-disabled item tab-focusable.\n   * - Disabled items should not be focusable per [W3C](https://www.w3.org/TR/wai-aria-practices-1.1/#kbd_disabled_controls).\n   * - One item per list/grid/listbox should be tab focusable per [W3C](https://www.w3.org/TR/wai-aria-practices-1.1/#grid).\n   */\n  public get tabindex(): 0 | -1 {\n    return this.#repeaterService.items.filter((item) => !item.disabled)[0] ===\n      this\n      ? 0\n      : -1;\n  }\n\n  /**\n   * Whether to exclude an item when cycling through.\n   */\n  @Input()\n  public set disabled(value: boolean | undefined) {\n    if (this.#_isDisabled !== value) {\n      if (value) {\n        this.isSelected = false;\n        this.#_isDisabled = true;\n      } else {\n        this.#_isDisabled = false;\n      }\n      if (this.isActive) {\n        this.#repeaterService.activateItemByIndex(undefined);\n      }\n      if (this.#elementRef.nativeElement.matches(':focus-within')) {\n        this.#elementRef.nativeElement.ownerDocument.activeElement.blur();\n      }\n      this.#changeDetector.markForCheck();\n    }\n  }\n  public get disabled(): boolean | undefined {\n    return this.#_isDisabled;\n  }\n\n  /**\n   * The human-readable name for the repeater item that is available for multiple purposes,\n   * such as accessibility and instrumentation. For example, the component uses the name to\n   * construct ARIA labels for the repeater item controls\n   * to [support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility).\n   * For more information about the `aria-label` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-label).\n   */\n  @Input()\n  public itemName: string | undefined;\n\n  /**\n   * 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 | undefined;\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<unknown> | undefined;\n\n  /**\n   * Whether the repeater item is expanded.\n   * @default true\n   */\n  @Input()\n  public set isExpanded(value: boolean | undefined) {\n    this.updateForExpanded(value !== false, true);\n  }\n\n  public get isExpanded(): boolean {\n    return this.#isExpanded;\n  }\n\n  /**\n   * 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 | undefined) {\n    if (!this.disabled && value !== this.#_isSelected) {\n      this.#_isSelected = value;\n      this.isSelectedChange.emit(this.#_isSelected);\n    }\n  }\n\n  public get isSelected(): boolean | undefined {\n    return this.#_isSelected;\n  }\n\n  /**\n   * 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 | undefined = false;\n\n  /**\n   * Whether to display a checkbox in the left of the repeater item.\n   */\n  @Input()\n  public selectable: boolean | undefined = false;\n\n  /**\n   * 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 | undefined = false;\n\n  /**\n   * The 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 | undefined;\n\n  public contentId: string;\n\n  public hasItemContent = false;\n\n  public isActive = false;\n\n  public set isCollapsible(value: boolean | undefined) {\n    if (this.isCollapsible !== value) {\n      this.#_isCollapsible = value !== false;\n\n      /*istanbul ignore else */\n      if (!this.#_isCollapsible) {\n        this.updateForExpanded(true, true);\n      }\n    }\n\n    this.#changeDetector.markForCheck();\n  }\n\n  public get isCollapsible(): boolean {\n    return this.#_isCollapsible;\n  }\n\n  public itemRole$: Observable<SkyRepeaterItemRolesType>;\n\n  public reorderButtonLabel = '';\n\n  public reorderState: string | undefined;\n\n  public slideDirection: string | undefined;\n\n  public animationDisabled = false;\n\n  @HostBinding('class')\n  public get repeaterGroupClass(): string {\n    return 'sky-repeater-item-group-' + this.#repeaterService.repeaterGroupId;\n  }\n\n  @ViewChild('grabHandle', { read: ElementRef })\n  public grabHandle: ElementRef | undefined;\n\n  @ViewChild('itemContentRef', { read: ElementRef })\n  public itemContentRef: ElementRef | undefined;\n\n  @ViewChild('itemHeaderRef', { read: ElementRef })\n  public itemHeaderRef: ElementRef | undefined;\n\n  @ViewChild('itemRef', { read: ElementRef })\n  public itemRef: ElementRef | undefined;\n\n  @ContentChildren(SkyRepeaterItemContentComponent)\n  public repeaterItemContentComponents:\n    | QueryList<SkyRepeaterItemContentComponent>\n    | undefined;\n\n  #adapterService: SkyRepeaterAdapterService;\n  #changeDetector: ChangeDetectorRef;\n  #elementRef: ElementRef;\n  #isExpanded = true;\n  #keyboardReorderingEnabled = false;\n  #ngUnsubscribe = new Subject<void>();\n  #reorderCancelText = '';\n  #reorderCurrentIndex = -1;\n  #reorderFinishText = '';\n  #reorderInstructions = '';\n  #reorderMovedText = '';\n  #reorderStateDescription = '';\n  #reorderSteps = 0;\n  #repeaterService: SkyRepeaterService;\n  #resourceService: SkyLibResourcesService;\n  #_isCollapsible = true;\n  #_isDisabled: boolean | undefined = false;\n  #_isSelected: boolean | undefined;\n\n  constructor(\n    repeaterService: SkyRepeaterService,\n    changeDetector: ChangeDetectorRef,\n    adapterService: SkyRepeaterAdapterService,\n    elementRef: ElementRef,\n    resourceService: SkyLibResourcesService\n  ) {\n    this.#repeaterService = repeaterService;\n    this.#changeDetector = changeDetector;\n    this.#adapterService = adapterService;\n    this.#elementRef = elementRef;\n    this.#resourceService = resourceService;\n\n    this.#slideForExpanded(false);\n\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    ])\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(\n        ([\n          reorderCancelText,\n          reorderFinishText,\n          reorderInstructionsText,\n          reorderOperationText,\n          reorderMovedText,\n        ]) => {\n          this.#reorderCancelText = reorderCancelText;\n          this.#reorderFinishText = reorderFinishText;\n          this.#reorderStateDescription = reorderInstructionsText;\n          this.#reorderInstructions = reorderOperationText;\n          this.#reorderMovedText = reorderMovedText;\n          this.reorderButtonLabel = this.#reorderInstructions;\n        }\n      );\n\n    this.contentId = `sky-repeater-item-content-${++nextContentId}`;\n    this.itemRole$ = this.#repeaterService.itemRole.asObservable();\n  }\n\n  public ngOnInit(): void {\n    this.#repeaterService.registerItem(this);\n    this.#repeaterService.activeItemChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((item) => {\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;\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  @HostListener('keydown', ['$event'])\n  public onKeydown($event: KeyboardEvent): void {\n    if (\n      [' ', 'Enter', 'Home', 'End', 'ArrowUp', 'ArrowDown'].includes($event.key)\n    ) {\n      if (\n        ($event.target as HTMLElement).matches(\n          'input, textarea, select, option, [contenteditable], [contenteditable] *'\n        )\n      ) {\n        return;\n      }\n      $event.preventDefault();\n      $event.stopPropagation();\n      let activateItem: SkyRepeaterItemComponent | undefined = undefined;\n      /* istanbul ignore else */\n      if ([' ', 'Enter'].includes($event.key)) {\n        if (this.selectable) {\n          this.isSelected = !this.isSelected;\n        }\n        // eslint-disable-next-line @typescript-eslint/no-this-alias\n        activateItem = this;\n      }\n      /* istanbul ignore else */\n      if (['Home', 'End'].includes($event.key)) {\n        const items = this.#repeaterService.items.filter(\n          (item) => !item.disabled\n        );\n        if ($event.key === 'Home') {\n          activateItem = items.shift();\n        } else {\n          activateItem = items.pop();\n        }\n      }\n      /* istanbul ignore else */\n      if (['ArrowUp', 'ArrowDown'].includes($event.key)) {\n        const currentIndex = this.#repeaterService.items.findIndex(\n          (item) => item === this\n        );\n        let sliceFrom: number;\n        let sliceTo: number | undefined;\n        if ($event.key === 'ArrowUp') {\n          sliceFrom = 0;\n          sliceTo = currentIndex;\n        } else {\n          sliceFrom = currentIndex + 1;\n          sliceTo = undefined;\n        }\n        const items = this.#repeaterService.items\n          .slice(sliceFrom, sliceTo)\n          .filter((item) => !item.disabled);\n        activateItem = $event.key === 'ArrowUp' ? items.pop() : items.shift();\n        if (!activateItem) {\n          // Wrap around.\n          if ($event.key === 'ArrowDown') {\n            sliceFrom = 0;\n            sliceTo = currentIndex;\n          } else {\n            sliceFrom = currentIndex + 1;\n            sliceTo = undefined;\n          }\n          const items = this.#repeaterService.items\n            .slice(sliceFrom, sliceTo)\n            .filter((item) => !item.disabled);\n          activateItem = $event.key === 'ArrowUp' ? items.pop() : items.shift();\n        }\n      }\n      /* istanbul ignore else */\n      if (activateItem && !activateItem.isActive) {\n        this.#repeaterService.activateItem(activateItem);\n        if (\n          !(activateItem.#elementRef.nativeElement as Element).matches(\n            ':focus-within'\n          )\n        ) {\n          activateItem.itemRef?.nativeElement.focus();\n        }\n      }\n    }\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(event.target as HTMLElement);\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(event.target as HTMLElement);\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  #slideForExpanded(animate: boolean): void {\n    this.animationDisabled = !animate;\n    this.slideDirection = this.isExpanded ? 'down' : 'up';\n  }\n\n  #keyboardReorderUp(): void {\n    const newIndex = this.#adapterService.moveItemUp(\n      this.#elementRef.nativeElement\n    );\n    if (newIndex !== undefined) {\n      this.#reorderCurrentIndex = newIndex;\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\n  #keyboardReorderDown(): void {\n    const newIndex = this.#adapterService.moveItemDown(\n      this.#elementRef.nativeElement\n    );\n    if (newIndex) {\n      this.#reorderCurrentIndex = newIndex;\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\n  #keyboardToggleReorder(): void {\n    this.#keyboardReorderingEnabled = !this.#keyboardReorderingEnabled;\n    this.#reorderSteps = 0;\n\n    if (this.#keyboardReorderingEnabled) {\n      this.reorderState = this.#reorderStateDescription;\n    } else {\n      // TODO: Needs improvement to be localized\n      this.reorderState = `${this.#reorderFinishText} ${\n        this.#reorderCurrentIndex + 1\n      } ${this.#reorderInstructions}`;\n      this.#reorderCurrentIndex = -1;\n    }\n  }\n\n  #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  #updateExpandOnContentChange(): void {\n    this.repeaterItemContentComponents?.changes\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.hasItemContent = !!this.repeaterItemContentComponents?.length;\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  [attr.aria-label]=\"itemName\"\n  [attr.aria-selected]=\"selectable ? !!isSelected : undefined\"\n  [attr.role]=\"(itemRole$ | async)?.item\"\n  [attr.tabIndex]=\"tabindex\"\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  #itemRef\n>\n  <div #inlineDelete>\n    <ng-content select=\"sky-inline-delete\" />\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\n    [attr.role]=\"!showInlineForm ? (itemRole$ | async)?.content : undefined\"\n    class=\"sky-repeater-item-left\"\n  >\n    <ng-container *ngIf=\"reorderable\">\n      <span\n        aria-live=\"assertive\"\n        class=\"sky-screen-reader-only\"\n        [id]=\"contentId + '-reorder-state'\"\n      >\n        {{ reorderState }}\n      </span>\n      <span\n        class=\"sky-screen-reader-only\"\n        [id]=\"contentId + '-reorder-instructions'\"\n        >{{ reorderButtonLabel }}</span\n      >\n      <button\n        class=\"sky-btn sky-tile-tools-control sky-repeater-item-grab-handle\"\n        type=\"button\"\n        [attr.aria-describedby]=\"contentId + '-reorder-instructions'\"\n        [attr.aria-label]=\"\n          itemName\n            ? ('skyux_repeater_item_reorder_label' | skyLibResources : itemName)\n            : ('skyux_repeater_item_reorder_label_default' | skyLibResources)\n        \"\n        (blur)=\"onReorderHandleBlur($event)\"\n        (keydown)=\"onReorderHandleKeyDown($event)\"\n        #grabHandle\n      >\n        <sky-icon icon=\"arrows-v\" />\n      </button>\n    </ng-container>\n    <sky-checkbox\n      *ngIf=\"selectable\"\n      class=\"sky-repeater-item-checkbox\"\n      [checked]=\"isSelected\"\n      [label]=\"\n        itemName\n          ? ('skyux_repeater_item_checkbox_label' | skyLibResources : itemName)\n          : ('skyux_repeater_item_checkbox_label_default' | skyLibResources)\n      \"\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\" />\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      [attr.role]=\"(itemRole$ | async)?.title\"\n      [hidden]=\"titleRef.children.length === 0\"\n      (click)=\"headerClick()\"\n    >\n      <div class=\"sky-repeater-item-title sky-font-emphasized\" #titleRef>\n        <ng-content select=\"sky-repeater-item-title\" />\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          itemName\n            ? ('skyux_repeater_item_reorder_top_label'\n              | skyLibResources : itemName)\n            : ('skyux_repeater_item_reorder_top_label_default'\n              | skyLibResources)\n        \"\n        (click)=\"moveToTop($event)\"\n      >\n        <sky-icon icon=\"arrow-circle-up\" />\n        {{ 'skyux_repeater_item_reorder_top' | skyLibResources }}\n      </button>\n      <div *ngIf=\"isCollapsible\" class=\"sky-repeater-item-chevron\">\n        <sky-chevron\n          [ariaControls]=\"contentId\"\n          [ariaLabel]=\"\n            itemName\n              ? isExpanded\n                ? ('skyux_repeater_item_expand' | skyLibResources : itemName)\n                : ('skyux_repeater_item_collapse' | skyLibResources : itemName)\n              : isExpanded\n              ? ('skyux_repeater_item_expand_default' | skyLibResources)\n              : ('skyux_repeater_item_collapse_default' | skyLibResources)\n          \"\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      [@.disabled]=\"animationDisabled\"\n      [@skyAnimationSlide]=\"slideDirection\"\n      #itemContentRef\n      [attr.role]=\"(itemRole$ | async)?.content\"\n    >\n      <ng-content select=\"sky-repeater-item-content\" />\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
@@ -345,7 +345,7 @@ export class SkyRepeaterComponent {
|
|
|
345
345
|
SkyRepeaterService,
|
|
346
346
|
SkyRepeaterAdapterService,
|
|
347
347
|
SkyRepeaterAutoScrollService,
|
|
348
|
-
], queries: [{ propertyName: "items", predicate: SkyRepeaterItemComponent }], usesOnChanges: true, ngImport: i0, template: "<ng-container #repeaterHost>\n <div\n class=\"sky-repeater\"\n [attr.role]=\"role\"\n [attr.aria-label]=\"ariaLabel || ('skyux_repeater_label' | skyLibResources)\"\n [dragula]=\"dragulaGroupName\"\n (cdkObserveContent)=\"onCdkObserveContent()\"\n >\n <ng-content
|
|
348
|
+
], queries: [{ propertyName: "items", predicate: SkyRepeaterItemComponent }], usesOnChanges: true, ngImport: i0, template: "<ng-container #repeaterHost>\n <div\n class=\"sky-repeater\"\n [attr.role]=\"role\"\n [attr.aria-label]=\"ariaLabel || ('skyux_repeater_label' | skyLibResources)\"\n [dragula]=\"dragulaGroupName\"\n (cdkObserveContent)=\"onCdkObserveContent()\"\n >\n <ng-content />\n </div>\n</ng-container>\n", styles: [".sky-repeater{padding:0}\n"], dependencies: [{ kind: "directive", type: i1.DragulaDirective, selector: "[dragula]", inputs: ["dragula", "dragulaModel"], outputs: ["dragulaModelChange"] }, { kind: "directive", type: i2.CdkObserveContent, selector: "[cdkObserveContent]", inputs: ["cdkObserveContentDisabled", "debounce"], outputs: ["cdkObserveContent"], exportAs: ["cdkObserveContent"] }, { kind: "pipe", type: i3.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
349
349
|
}
|
|
350
350
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: SkyRepeaterComponent, decorators: [{
|
|
351
351
|
type: Component,
|
|
@@ -353,7 +353,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
|
|
|
353
353
|
SkyRepeaterService,
|
|
354
354
|
SkyRepeaterAdapterService,
|
|
355
355
|
SkyRepeaterAutoScrollService,
|
|
356
|
-
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container #repeaterHost>\n <div\n class=\"sky-repeater\"\n [attr.role]=\"role\"\n [attr.aria-label]=\"ariaLabel || ('skyux_repeater_label' | skyLibResources)\"\n [dragula]=\"dragulaGroupName\"\n (cdkObserveContent)=\"onCdkObserveContent()\"\n >\n <ng-content
|
|
356
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container #repeaterHost>\n <div\n class=\"sky-repeater\"\n [attr.role]=\"role\"\n [attr.aria-label]=\"ariaLabel || ('skyux_repeater_label' | skyLibResources)\"\n [dragula]=\"dragulaGroupName\"\n (cdkObserveContent)=\"onCdkObserveContent()\"\n >\n <ng-content />\n </div>\n</ng-container>\n", styles: [".sky-repeater{padding:0}\n"] }]
|
|
357
357
|
}], ctorParameters: function () { return []; }, propDecorators: { activeIndex: [{
|
|
358
358
|
type: Input
|
|
359
359
|
}], ariaLabel: [{
|
|
@@ -370,4 +370,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
|
|
|
370
370
|
type: ContentChildren,
|
|
371
371
|
args: [SkyRepeaterItemComponent]
|
|
372
372
|
}] } });
|
|
373
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeater.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/repeater/repeater.component.ts","../../../../../../../../libs/components/lists/src/lib/modules/repeater/repeater.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewChecked,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges,\n  inject,\n} from '@angular/core';\nimport { SkyLogService } from '@skyux/core';\nimport { SkyScrollableHostService } from '@skyux/core';\n\nimport { DragulaService } from 'ng2-dragula';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyRepeaterAdapterService } from './repeater-adapter.service';\nimport { SkyRepeaterAutoScrollService } from './repeater-auto-scroll.service';\nimport { SkyRepeaterAutoScroller } from './repeater-auto-scroller';\nimport { SkyRepeaterExpandModeType } from './repeater-expand-mode-type';\nimport { SkyRepeaterItemRolesType } from './repeater-item-roles.type';\nimport { SkyRepeaterItemComponent } from './repeater-item.component';\nimport { SkyRepeaterRoleType } from './repeater-role.type';\nimport { SkyRepeaterService } from './repeater.service';\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: [\n    SkyRepeaterService,\n    SkyRepeaterAdapterService,\n    SkyRepeaterAutoScrollService,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyRepeaterComponent\n  implements AfterContentInit, AfterViewChecked, OnChanges, OnDestroy, OnInit\n{\n  /**\n   * 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 | undefined;\n\n  /**\n   * The ARIA label for the repeater list.\n   * This sets the repeater list's `aria-label` attribute to provide a text equivalent for screen readers\n   * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility).\n   * For more information about the `aria-label` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-label).\n   * @default \"List of items\"\n   */\n  @Input()\n  public ariaLabel: string | undefined;\n\n  /**\n   * 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 | undefined = false;\n\n  /**\n   * The layout that determines 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: SkyRepeaterExpandModeType | undefined) {\n    this.#repeaterService.expandMode = value;\n    this.#updateForExpandMode();\n  }\n\n  public get expandMode(): SkyRepeaterExpandModeType {\n    return this.#repeaterService.expandMode;\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  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  public orderChange = new EventEmitter<any[]>();\n\n  @ContentChildren(SkyRepeaterItemComponent)\n  public items: QueryList<SkyRepeaterItemComponent> | undefined;\n\n  public dragulaGroupName: string;\n\n  public role: SkyRepeaterRoleType | undefined;\n\n  #autoScroller: SkyRepeaterAutoScroller | undefined;\n  #ngUnsubscribe = new Subject<void>();\n  #itemNameWarned = false;\n\n  #adapterService = inject(SkyRepeaterAdapterService);\n  #changeDetector = inject(ChangeDetectorRef);\n  #dragulaService = inject(DragulaService);\n  #elementRef = inject(ElementRef);\n  #renderer = inject(Renderer2);\n  #repeaterService = inject(SkyRepeaterService);\n  #autoScrollSvc = inject(SkyRepeaterAutoScrollService);\n  #scrollableHostSvc = inject(SkyScrollableHostService);\n  #logSvc = inject(SkyLogService);\n\n  constructor() {\n    this.dragulaGroupName = `sky-repeater-dragula-${\n      this.#repeaterService.repeaterGroupId\n    }`;\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) => {\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.#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      this.#validateTags();\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?.length) {\n          this.#updateForExpandMode(this.items.last);\n\n          this.#updateReorderability();\n\n          this.#repeaterService.items = this.items.toArray();\n        }\n\n        if (this.activeIndex !== undefined) {\n          this.#repeaterService.activateItemByIndex(this.activeIndex);\n        }\n\n        this.#updateRole();\n\n        this.#validateTags();\n      });\n    });\n\n    setTimeout(() => {\n      this.#updateForExpandMode();\n\n      this.items?.forEach((item) => {\n        item.reorderable = this.reorderable;\n      });\n\n      this.#updateRole();\n    }, 0);\n  }\n\n  public ngAfterViewChecked(): void {\n    if (!this.#itemNameWarned && this.items?.some((item) => !item.itemName)) {\n      this.#logSvc?.deprecated('SkyRepeaterItemComponent without `itemName`', {\n        deprecationMajorVersion: 8,\n        replacementRecommendation: 'Always specify an `itemName` property.',\n      });\n\n      this.#itemNameWarned = true;\n    }\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.#updateReorderability();\n      }\n      this.#updateRole();\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  public ngOnInit(): void {\n    this.#updateRole();\n  }\n\n  public onCdkObserveContent(): void {\n    this.#updateRole();\n  }\n\n  #updateForExpandMode(itemAdded?: SkyRepeaterItemComponent): void {\n    if (this.items) {\n      let foundExpanded = false;\n      const isCollapsible = this.expandMode !== 'none';\n      const 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      for (const item of this.items) {\n        item.isCollapsible = isCollapsible && !!item.hasItemContent;\n\n        // Collapse any items that aren't the item that was just added.\n        if (item !== itemAdded && isSingle && item.isExpanded) {\n          if (foundExpanded) {\n            // If this item is being collapsed because a new item was\n            // added, animate it.\n            item.updateForExpanded(false, !!itemAdded);\n          }\n\n          foundExpanded = true;\n        }\n      }\n\n      this.#updateRole();\n    }\n  }\n\n  #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.createGroup(this.dragulaGroupName, {\n        moves: (el, _container, handle) => {\n          const target = el?.querySelector('.sky-repeater-item-grab-handle');\n          return !!(\n            this.reorderable && target?.contains(handle as Element | null)\n          );\n        },\n      });\n    }\n\n    let draggedItemIndex = -1;\n\n    this.#dragulaService\n      .drag(this.dragulaGroupName)\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((args) => {\n        /* istanbul ignore else */\n        if (args.name === this.dragulaGroupName) {\n          this.#destroyAutoScroll();\n\n          this.#autoScroller = this.#autoScrollSvc.autoScroll(\n            [this.#scrollableHostSvc.getScrollableHost(this.#elementRef)],\n            {\n              margin: 20,\n              maxSpeed: 10,\n              scrollWhenOutside: true,\n              autoScroll: () => true,\n            }\n          );\n\n          this.#renderer.addClass(args.el, 'sky-repeater-item-dragging');\n          draggedItemIndex = this.#adapterService.getRepeaterItemIndex(\n            args.el as HTMLElement\n          );\n        }\n      });\n\n    this.#dragulaService\n      .dragend(this.dragulaGroupName)\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((args) => {\n        /* istanbul ignore else */\n        if (args.name === this.dragulaGroupName) {\n          this.#destroyAutoScroll();\n\n          this.#renderer.removeClass(args.el, 'sky-repeater-item-dragging');\n          const newItemIndex = this.#adapterService.getRepeaterItemIndex(\n            args.el as HTMLElement\n          );\n\n          /* sanity check */\n          /* istanbul ignore else */\n          if (draggedItemIndex >= 0) {\n            this.#repeaterService.reorderItem(draggedItemIndex, newItemIndex);\n            draggedItemIndex = -1;\n          }\n\n          this.#emitTags();\n        }\n      });\n  }\n\n  #destroyDragAndDrop(): void {\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    this.#destroyAutoScroll();\n  }\n\n  #destroyAutoScroll(): void {\n    if (this.#autoScroller) {\n      this.#autoScroller.destroy();\n      this.#autoScroller = undefined;\n    }\n  }\n\n  #emitTags(): void {\n    const tags = this.#repeaterService.items.map((item) => item.tag);\n    this.orderChange.emit(tags);\n  }\n\n  #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  #updateRole(): void {\n    // Determine a role using a hierarchy based on https://www.w3.org/TR/wai-aria-practices-1.1/\n    //   1. If there are one or more interactions in the repeater item projected content, use grid.\n    //   2. If there are selectable repeater items and no other interactions, use listbox.\n    //   3. If there are no interactions, use list.\n\n    // Default to list role.\n    let autoRole: SkyRepeaterRoleType = 'list';\n\n    const roleMap: Record<SkyRepeaterRoleType, SkyRepeaterItemRolesType> = {\n      list: { item: 'listitem', title: undefined, content: undefined },\n      listbox: { item: 'option', title: undefined, content: undefined },\n      grid: { item: 'row', title: 'rowheader', content: 'gridcell' },\n    };\n\n    // Based on https://html.spec.whatwg.org/multipage/dom.html#interactive-content\n    const interactionSelector = [\n      'a[href]',\n      'audio[controls]',\n      'button',\n      'details',\n      'embed',\n      'iframe',\n      'img[usemap]',\n      'input:not([type=\"hidden\"])',\n      'label',\n      'select',\n      'textarea',\n      'video[controls]',\n      '[contenteditable]',\n      '.sky-repeater[role=\"grid\"]',\n    ]\n      .map(\n        (selector) =>\n          `sky-repeater-item-title ${selector}:not([hidden]), sky-repeater-item-content ${selector}:not([hidden])`\n      )\n      .concat([`skyux-dropdown`])\n      .join(', ');\n\n    const hasInteraction =\n      this.reorderable ||\n      this.items?.some((item) => item.isCollapsible) ||\n      this.items?.some((item) => !!item.selectable) ||\n      !!(this.#elementRef.nativeElement as HTMLElement).querySelector(\n        interactionSelector\n      );\n\n    if (hasInteraction) {\n      // If the repeater matches interaction selector https://www.w3.org/TR/wai-aria-practices-1.1/#grid\n      autoRole = 'grid';\n    }\n\n    if (this.role !== autoRole) {\n      this.#repeaterService.itemRole.next({\n        ...roleMap[autoRole],\n      });\n      this.role = `${autoRole}`;\n      this.#changeDetector.markForCheck();\n    }\n  }\n\n  #updateReorderability(): void {\n    if (this.items) {\n      for (const item of this.items) {\n        item.reorderable = this.reorderable;\n      }\n    }\n  }\n\n  #validateTags(): void {\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","<ng-container #repeaterHost>\n  <div\n    class=\"sky-repeater\"\n    [attr.role]=\"role\"\n    [attr.aria-label]=\"ariaLabel || ('skyux_repeater_label' | skyLibResources)\"\n    [dragula]=\"dragulaGroupName\"\n    (cdkObserveContent)=\"onCdkObserveContent()\"\n  >\n    <ng-content></ng-content>\n  </div>\n</ng-container>\n"]}
|
|
373
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeater.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/repeater/repeater.component.ts","../../../../../../../../libs/components/lists/src/lib/modules/repeater/repeater.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewChecked,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges,\n  inject,\n} from '@angular/core';\nimport { SkyLogService } from '@skyux/core';\nimport { SkyScrollableHostService } from '@skyux/core';\n\nimport { DragulaService } from 'ng2-dragula';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyRepeaterAdapterService } from './repeater-adapter.service';\nimport { SkyRepeaterAutoScrollService } from './repeater-auto-scroll.service';\nimport { SkyRepeaterAutoScroller } from './repeater-auto-scroller';\nimport { SkyRepeaterExpandModeType } from './repeater-expand-mode-type';\nimport { SkyRepeaterItemRolesType } from './repeater-item-roles.type';\nimport { SkyRepeaterItemComponent } from './repeater-item.component';\nimport { SkyRepeaterRoleType } from './repeater-role.type';\nimport { SkyRepeaterService } from './repeater.service';\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: [\n    SkyRepeaterService,\n    SkyRepeaterAdapterService,\n    SkyRepeaterAutoScrollService,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyRepeaterComponent\n  implements AfterContentInit, AfterViewChecked, OnChanges, OnDestroy, OnInit\n{\n  /**\n   * 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 | undefined;\n\n  /**\n   * The ARIA label for the repeater list.\n   * This sets the repeater list's `aria-label` attribute to provide a text equivalent for screen readers\n   * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility).\n   * For more information about the `aria-label` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-label).\n   * @default \"List of items\"\n   */\n  @Input()\n  public ariaLabel: string | undefined;\n\n  /**\n   * 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 | undefined = false;\n\n  /**\n   * The layout that determines 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: SkyRepeaterExpandModeType | undefined) {\n    this.#repeaterService.expandMode = value;\n    this.#updateForExpandMode();\n  }\n\n  public get expandMode(): SkyRepeaterExpandModeType {\n    return this.#repeaterService.expandMode;\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  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  public orderChange = new EventEmitter<any[]>();\n\n  @ContentChildren(SkyRepeaterItemComponent)\n  public items: QueryList<SkyRepeaterItemComponent> | undefined;\n\n  public dragulaGroupName: string;\n\n  public role: SkyRepeaterRoleType | undefined;\n\n  #autoScroller: SkyRepeaterAutoScroller | undefined;\n  #ngUnsubscribe = new Subject<void>();\n  #itemNameWarned = false;\n\n  #adapterService = inject(SkyRepeaterAdapterService);\n  #changeDetector = inject(ChangeDetectorRef);\n  #dragulaService = inject(DragulaService);\n  #elementRef = inject(ElementRef);\n  #renderer = inject(Renderer2);\n  #repeaterService = inject(SkyRepeaterService);\n  #autoScrollSvc = inject(SkyRepeaterAutoScrollService);\n  #scrollableHostSvc = inject(SkyScrollableHostService);\n  #logSvc = inject(SkyLogService);\n\n  constructor() {\n    this.dragulaGroupName = `sky-repeater-dragula-${\n      this.#repeaterService.repeaterGroupId\n    }`;\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) => {\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.#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      this.#validateTags();\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?.length) {\n          this.#updateForExpandMode(this.items.last);\n\n          this.#updateReorderability();\n\n          this.#repeaterService.items = this.items.toArray();\n        }\n\n        if (this.activeIndex !== undefined) {\n          this.#repeaterService.activateItemByIndex(this.activeIndex);\n        }\n\n        this.#updateRole();\n\n        this.#validateTags();\n      });\n    });\n\n    setTimeout(() => {\n      this.#updateForExpandMode();\n\n      this.items?.forEach((item) => {\n        item.reorderable = this.reorderable;\n      });\n\n      this.#updateRole();\n    }, 0);\n  }\n\n  public ngAfterViewChecked(): void {\n    if (!this.#itemNameWarned && this.items?.some((item) => !item.itemName)) {\n      this.#logSvc?.deprecated('SkyRepeaterItemComponent without `itemName`', {\n        deprecationMajorVersion: 8,\n        replacementRecommendation: 'Always specify an `itemName` property.',\n      });\n\n      this.#itemNameWarned = true;\n    }\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.#updateReorderability();\n      }\n      this.#updateRole();\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  public ngOnInit(): void {\n    this.#updateRole();\n  }\n\n  public onCdkObserveContent(): void {\n    this.#updateRole();\n  }\n\n  #updateForExpandMode(itemAdded?: SkyRepeaterItemComponent): void {\n    if (this.items) {\n      let foundExpanded = false;\n      const isCollapsible = this.expandMode !== 'none';\n      const 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      for (const item of this.items) {\n        item.isCollapsible = isCollapsible && !!item.hasItemContent;\n\n        // Collapse any items that aren't the item that was just added.\n        if (item !== itemAdded && isSingle && item.isExpanded) {\n          if (foundExpanded) {\n            // If this item is being collapsed because a new item was\n            // added, animate it.\n            item.updateForExpanded(false, !!itemAdded);\n          }\n\n          foundExpanded = true;\n        }\n      }\n\n      this.#updateRole();\n    }\n  }\n\n  #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.createGroup(this.dragulaGroupName, {\n        moves: (el, _container, handle) => {\n          const target = el?.querySelector('.sky-repeater-item-grab-handle');\n          return !!(\n            this.reorderable && target?.contains(handle as Element | null)\n          );\n        },\n      });\n    }\n\n    let draggedItemIndex = -1;\n\n    this.#dragulaService\n      .drag(this.dragulaGroupName)\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((args) => {\n        /* istanbul ignore else */\n        if (args.name === this.dragulaGroupName) {\n          this.#destroyAutoScroll();\n\n          this.#autoScroller = this.#autoScrollSvc.autoScroll(\n            [this.#scrollableHostSvc.getScrollableHost(this.#elementRef)],\n            {\n              margin: 20,\n              maxSpeed: 10,\n              scrollWhenOutside: true,\n              autoScroll: () => true,\n            }\n          );\n\n          this.#renderer.addClass(args.el, 'sky-repeater-item-dragging');\n          draggedItemIndex = this.#adapterService.getRepeaterItemIndex(\n            args.el as HTMLElement\n          );\n        }\n      });\n\n    this.#dragulaService\n      .dragend(this.dragulaGroupName)\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((args) => {\n        /* istanbul ignore else */\n        if (args.name === this.dragulaGroupName) {\n          this.#destroyAutoScroll();\n\n          this.#renderer.removeClass(args.el, 'sky-repeater-item-dragging');\n          const newItemIndex = this.#adapterService.getRepeaterItemIndex(\n            args.el as HTMLElement\n          );\n\n          /* sanity check */\n          /* istanbul ignore else */\n          if (draggedItemIndex >= 0) {\n            this.#repeaterService.reorderItem(draggedItemIndex, newItemIndex);\n            draggedItemIndex = -1;\n          }\n\n          this.#emitTags();\n        }\n      });\n  }\n\n  #destroyDragAndDrop(): void {\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    this.#destroyAutoScroll();\n  }\n\n  #destroyAutoScroll(): void {\n    if (this.#autoScroller) {\n      this.#autoScroller.destroy();\n      this.#autoScroller = undefined;\n    }\n  }\n\n  #emitTags(): void {\n    const tags = this.#repeaterService.items.map((item) => item.tag);\n    this.orderChange.emit(tags);\n  }\n\n  #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  #updateRole(): void {\n    // Determine a role using a hierarchy based on https://www.w3.org/TR/wai-aria-practices-1.1/\n    //   1. If there are one or more interactions in the repeater item projected content, use grid.\n    //   2. If there are selectable repeater items and no other interactions, use listbox.\n    //   3. If there are no interactions, use list.\n\n    // Default to list role.\n    let autoRole: SkyRepeaterRoleType = 'list';\n\n    const roleMap: Record<SkyRepeaterRoleType, SkyRepeaterItemRolesType> = {\n      list: { item: 'listitem', title: undefined, content: undefined },\n      listbox: { item: 'option', title: undefined, content: undefined },\n      grid: { item: 'row', title: 'rowheader', content: 'gridcell' },\n    };\n\n    // Based on https://html.spec.whatwg.org/multipage/dom.html#interactive-content\n    const interactionSelector = [\n      'a[href]',\n      'audio[controls]',\n      'button',\n      'details',\n      'embed',\n      'iframe',\n      'img[usemap]',\n      'input:not([type=\"hidden\"])',\n      'label',\n      'select',\n      'textarea',\n      'video[controls]',\n      '[contenteditable]',\n      '.sky-repeater[role=\"grid\"]',\n    ]\n      .map(\n        (selector) =>\n          `sky-repeater-item-title ${selector}:not([hidden]), sky-repeater-item-content ${selector}:not([hidden])`\n      )\n      .concat([`skyux-dropdown`])\n      .join(', ');\n\n    const hasInteraction =\n      this.reorderable ||\n      this.items?.some((item) => item.isCollapsible) ||\n      this.items?.some((item) => !!item.selectable) ||\n      !!(this.#elementRef.nativeElement as HTMLElement).querySelector(\n        interactionSelector\n      );\n\n    if (hasInteraction) {\n      // If the repeater matches interaction selector https://www.w3.org/TR/wai-aria-practices-1.1/#grid\n      autoRole = 'grid';\n    }\n\n    if (this.role !== autoRole) {\n      this.#repeaterService.itemRole.next({\n        ...roleMap[autoRole],\n      });\n      this.role = `${autoRole}`;\n      this.#changeDetector.markForCheck();\n    }\n  }\n\n  #updateReorderability(): void {\n    if (this.items) {\n      for (const item of this.items) {\n        item.reorderable = this.reorderable;\n      }\n    }\n  }\n\n  #validateTags(): void {\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","<ng-container #repeaterHost>\n  <div\n    class=\"sky-repeater\"\n    [attr.role]=\"role\"\n    [attr.aria-label]=\"ariaLabel || ('skyux_repeater_label' | skyLibResources)\"\n    [dragula]=\"dragulaGroupName\"\n    (cdkObserveContent)=\"onCdkObserveContent()\"\n  >\n    <ng-content />\n  </div>\n</ng-container>\n"]}
|