@skyux/lists 7.15.0 → 7.17.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/documentation.json +1396 -219
- package/esm2020/lib/modules/repeater/repeater-item.component.mjs +13 -11
- package/esm2020/lib/modules/repeater/repeater.component.mjs +7 -4
- package/esm2020/testing/repeater/repeater-harness.mjs +1 -2
- package/esm2020/testing/repeater/repeater-item-harness.mjs +33 -4
- package/fesm2015/skyux-lists-testing.mjs +41 -4
- package/fesm2015/skyux-lists-testing.mjs.map +1 -1
- package/fesm2015/skyux-lists.mjs +18 -13
- package/fesm2015/skyux-lists.mjs.map +1 -1
- package/fesm2020/skyux-lists-testing.mjs +32 -4
- package/fesm2020/skyux-lists-testing.mjs.map +1 -1
- package/fesm2020/skyux-lists.mjs +18 -13
- package/fesm2020/skyux-lists.mjs.map +1 -1
- package/lib/modules/repeater/repeater-item.component.d.ts +2 -1
- package/package.json +10 -10
- package/testing/repeater/repeater-harness.d.ts +0 -1
- package/testing/repeater/repeater-item-harness.d.ts +17 -2
|
@@ -173,15 +173,18 @@ _SkyRepeaterComponent_adapterService = new WeakMap(), _SkyRepeaterComponent_chan
|
|
|
173
173
|
if (itemAdded && itemAdded.isExpanded) {
|
|
174
174
|
foundExpanded = true;
|
|
175
175
|
}
|
|
176
|
-
this.items
|
|
176
|
+
for (const item of this.items) {
|
|
177
177
|
item.isCollapsible = isCollapsible && !!item.hasItemContent;
|
|
178
|
+
// Collapse any items that aren't the item that was just added.
|
|
178
179
|
if (item !== itemAdded && isSingle && item.isExpanded) {
|
|
179
180
|
if (foundExpanded) {
|
|
180
|
-
item
|
|
181
|
+
// If this item is being collapsed because a new item was
|
|
182
|
+
// added, animate it.
|
|
183
|
+
item.updateForExpanded(false, !!itemAdded);
|
|
181
184
|
}
|
|
182
185
|
foundExpanded = true;
|
|
183
186
|
}
|
|
184
|
-
}
|
|
187
|
+
}
|
|
185
188
|
__classPrivateFieldGet(this, _SkyRepeaterComponent_instances, "m", _SkyRepeaterComponent_updateRole).call(this);
|
|
186
189
|
}
|
|
187
190
|
}, _SkyRepeaterComponent_initializeDragAndDrop = function _SkyRepeaterComponent_initializeDragAndDrop() {
|
|
@@ -310,4 +313,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.11", ngImpo
|
|
|
310
313
|
type: ContentChildren,
|
|
311
314
|
args: [SkyRepeaterItemComponent]
|
|
312
315
|
}] } });
|
|
313
|
-
//# 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  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} from '@angular/core';\n\nimport { DragulaService } from 'ng2-dragula';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyRepeaterAdapterService } from './repeater-adapter.service';\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: [SkyRepeaterService, SkyRepeaterAdapterService],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyRepeaterComponent\n  implements AfterContentInit, 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  // TODO: Remove 'string' as a valid type in a breaking change.\n  @Input()\n  public set expandMode(value: SkyRepeaterExpandModeType | string | undefined) {\n    this.#repeaterService.expandMode = value;\n    this.#updateForExpandMode();\n  }\n\n  public get expandMode(): SkyRepeaterExpandModeType | string {\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  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  #adapterService: SkyRepeaterAdapterService;\n  #changeDetector: ChangeDetectorRef;\n  #dragulaService: DragulaService;\n  #elementRef: ElementRef;\n  #renderer: Renderer2;\n  #repeaterService: SkyRepeaterService;\n  #ngUnsubscribe = new Subject<void>();\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    repeaterService: SkyRepeaterService,\n    adapterService: SkyRepeaterAdapterService,\n    dragulaService: DragulaService,\n    elementRef: ElementRef,\n    renderer: Renderer2\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#repeaterService = repeaterService;\n    this.#adapterService = adapterService;\n    this.#dragulaService = dragulaService;\n    this.#elementRef = elementRef;\n    this.#renderer = renderer;\n\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      if (this.reorderable && !this.#everyItemHasTag()) {\n        console.warn(\n          'Please supply tag properties for each repeater item when reordering functionality is enabled.'\n        );\n      }\n    });\n\n    // HACK: Not updating for expand mode in a timeout causes an error.\n    // https://github.com/angular/angular/issues/6005\n    this.items?.changes.pipe(takeUntil(this.#ngUnsubscribe)).subscribe(() => {\n      setTimeout(() => {\n        if (this.items?.last) {\n          this.#updateForExpandMode(this.items.last);\n          this.items.last.reorderable = this.reorderable;\n        }\n\n        if (this.activeIndex !== undefined) {\n          this.#repeaterService.activateItemByIndex(this.activeIndex);\n        }\n\n        this.#updateRole();\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 ngOnChanges(changes: SimpleChanges): void {\n    if (changes['activeIndex']) {\n      this.#repeaterService.enableActiveState = true;\n      if (\n        changes['activeIndex'].currentValue !==\n        changes['activeIndex'].previousValue\n      ) {\n        this.#repeaterService.activateItemByIndex(this.activeIndex);\n      }\n    }\n\n    if (changes.reorderable) {\n      if (this.items) {\n        this.items.forEach((item) => (item.reorderable = this.reorderable));\n      }\n      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      this.items.forEach((item) => {\n        item.isCollapsible = isCollapsible && !!item.hasItemContent;\n\n        if (item !== itemAdded && isSingle && item.isExpanded) {\n          if (foundExpanded) {\n            item.updateForExpanded(false);\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 !!this.reorderable && !!target && target.contains(handle!);\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.#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.#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\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","<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"]}
|
|
316
|
+
//# 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  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} from '@angular/core';\n\nimport { DragulaService } from 'ng2-dragula';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyRepeaterAdapterService } from './repeater-adapter.service';\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: [SkyRepeaterService, SkyRepeaterAdapterService],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyRepeaterComponent\n  implements AfterContentInit, 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  // TODO: Remove 'string' as a valid type in a breaking change.\n  @Input()\n  public set expandMode(value: SkyRepeaterExpandModeType | string | undefined) {\n    this.#repeaterService.expandMode = value;\n    this.#updateForExpandMode();\n  }\n\n  public get expandMode(): SkyRepeaterExpandModeType | string {\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  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  #adapterService: SkyRepeaterAdapterService;\n  #changeDetector: ChangeDetectorRef;\n  #dragulaService: DragulaService;\n  #elementRef: ElementRef;\n  #renderer: Renderer2;\n  #repeaterService: SkyRepeaterService;\n  #ngUnsubscribe = new Subject<void>();\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    repeaterService: SkyRepeaterService,\n    adapterService: SkyRepeaterAdapterService,\n    dragulaService: DragulaService,\n    elementRef: ElementRef,\n    renderer: Renderer2\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#repeaterService = repeaterService;\n    this.#adapterService = adapterService;\n    this.#dragulaService = dragulaService;\n    this.#elementRef = elementRef;\n    this.#renderer = renderer;\n\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      if (this.reorderable && !this.#everyItemHasTag()) {\n        console.warn(\n          'Please supply tag properties for each repeater item when reordering functionality is enabled.'\n        );\n      }\n    });\n\n    // HACK: Not updating for expand mode in a timeout causes an error.\n    // https://github.com/angular/angular/issues/6005\n    this.items?.changes.pipe(takeUntil(this.#ngUnsubscribe)).subscribe(() => {\n      setTimeout(() => {\n        if (this.items?.last) {\n          this.#updateForExpandMode(this.items.last);\n          this.items.last.reorderable = this.reorderable;\n        }\n\n        if (this.activeIndex !== undefined) {\n          this.#repeaterService.activateItemByIndex(this.activeIndex);\n        }\n\n        this.#updateRole();\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 ngOnChanges(changes: SimpleChanges): void {\n    if (changes['activeIndex']) {\n      this.#repeaterService.enableActiveState = true;\n      if (\n        changes['activeIndex'].currentValue !==\n        changes['activeIndex'].previousValue\n      ) {\n        this.#repeaterService.activateItemByIndex(this.activeIndex);\n      }\n    }\n\n    if (changes.reorderable) {\n      if (this.items) {\n        this.items.forEach((item) => (item.reorderable = this.reorderable));\n      }\n      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 !!this.reorderable && !!target && target.contains(handle!);\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.#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.#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\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","<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"]}
|
|
@@ -2,7 +2,6 @@ import { SkyComponentHarness } from '@skyux/core/testing';
|
|
|
2
2
|
import { SkyRepeaterItemHarness } from './repeater-item-harness';
|
|
3
3
|
/**
|
|
4
4
|
* Harness for interacting with a repeater component in tests.
|
|
5
|
-
* @internal
|
|
6
5
|
*/
|
|
7
6
|
export class SkyRepeaterHarness extends SkyComponentHarness {
|
|
8
7
|
/**
|
|
@@ -23,4 +22,4 @@ export class SkyRepeaterHarness extends SkyComponentHarness {
|
|
|
23
22
|
* @internal
|
|
24
23
|
*/
|
|
25
24
|
SkyRepeaterHarness.hostSelector = 'sky-repeater';
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwZWF0ZXItaGFybmVzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9saXN0cy90ZXN0aW5nL3NyYy9yZXBlYXRlci9yZXBlYXRlci1oYXJuZXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRzFELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBR2pFOztHQUVHO0FBQ0gsTUFBTSxPQUFPLGtCQUFtQixTQUFRLG1CQUFtQjtJQU16RDs7O09BR0c7SUFDSSxNQUFNLENBQUMsSUFBSSxDQUNoQixPQUFrQztRQUVsQyxPQUFPLGtCQUFrQixDQUFDLHFCQUFxQixDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzNELENBQUM7SUFFRDs7T0FFRztJQUNJLEtBQUssQ0FBQyxnQkFBZ0IsQ0FDM0IsT0FBdUM7UUFFdkMsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLHNCQUFzQixDQUFDLElBQUksQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDO0lBQzFFLENBQUM7O0FBdEJEOztHQUVHO0FBQ1csK0JBQVksR0FBRyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIYXJuZXNzUHJlZGljYXRlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3Rlc3RpbmcnO1xuaW1wb3J0IHsgU2t5Q29tcG9uZW50SGFybmVzcyB9IGZyb20gJ0Bza3l1eC9jb3JlL3Rlc3RpbmcnO1xuXG5pbXBvcnQgeyBTa3lSZXBlYXRlckhhcm5lc3NGaWx0ZXJzIH0gZnJvbSAnLi9yZXBlYXRlci1oYXJuZXNzLWZpbHRlcnMnO1xuaW1wb3J0IHsgU2t5UmVwZWF0ZXJJdGVtSGFybmVzcyB9IGZyb20gJy4vcmVwZWF0ZXItaXRlbS1oYXJuZXNzJztcbmltcG9ydCB7IFNreVJlcGVhdGVySXRlbUhhcm5lc3NGaWx0ZXJzIH0gZnJvbSAnLi9yZXBlYXRlci1pdGVtLWhhcm5lc3MtZmlsdGVycyc7XG5cbi8qKlxuICogSGFybmVzcyBmb3IgaW50ZXJhY3Rpbmcgd2l0aCBhIHJlcGVhdGVyIGNvbXBvbmVudCBpbiB0ZXN0cy5cbiAqL1xuZXhwb3J0IGNsYXNzIFNreVJlcGVhdGVySGFybmVzcyBleHRlbmRzIFNreUNvbXBvbmVudEhhcm5lc3Mge1xuICAvKipcbiAgICogQGludGVybmFsXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGhvc3RTZWxlY3RvciA9ICdza3ktcmVwZWF0ZXInO1xuXG4gIC8qKlxuICAgKiBHZXRzIGEgYEhhcm5lc3NQcmVkaWNhdGVgIHRoYXQgY2FuIGJlIHVzZWQgdG8gc2VhcmNoIGZvciBhXG4gICAqIGBTa3lSZXBlYXRlckhhcm5lc3NgIHRoYXQgbWVldHMgY2VydGFpbiBjcml0ZXJpYS5cbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgd2l0aChcbiAgICBmaWx0ZXJzOiBTa3lSZXBlYXRlckhhcm5lc3NGaWx0ZXJzXG4gICk6IEhhcm5lc3NQcmVkaWNhdGU8U2t5UmVwZWF0ZXJIYXJuZXNzPiB7XG4gICAgcmV0dXJuIFNreVJlcGVhdGVySGFybmVzcy5nZXREYXRhU2t5SWRQcmVkaWNhdGUoZmlsdGVycyk7XG4gIH1cblxuICAvKipcbiAgICogR2V0cyBhIGxpc3Qgb2YgY2hpbGQgcmVwZWF0ZXIgaXRlbXMuXG4gICAqL1xuICBwdWJsaWMgYXN5bmMgZ2V0UmVwZWF0ZXJJdGVtcyhcbiAgICBmaWx0ZXJzPzogU2t5UmVwZWF0ZXJJdGVtSGFybmVzc0ZpbHRlcnNcbiAgKTogUHJvbWlzZTxTa3lSZXBlYXRlckl0ZW1IYXJuZXNzW10+IHtcbiAgICByZXR1cm4gdGhpcy5sb2NhdG9yRm9yQWxsKFNreVJlcGVhdGVySXRlbUhhcm5lc3Mud2l0aChmaWx0ZXJzIHx8IHt9KSkoKTtcbiAgfVxufVxuIl19
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var _SkyRepeaterItemHarness_getCheckbox, _SkyRepeaterItemHarness_getChevron, _SkyRepeaterItemHarness_getContent, _SkyRepeaterItemHarness_getReorderHandle, _SkyRepeaterItemHarness_getTitle;
|
|
1
|
+
var _SkyRepeaterItemHarness_getBackToTop, _SkyRepeaterItemHarness_getCheckbox, _SkyRepeaterItemHarness_getChevron, _SkyRepeaterItemHarness_getContent, _SkyRepeaterItemHarness_getReorderHandle, _SkyRepeaterItemHarness_getTitle;
|
|
2
2
|
import { __classPrivateFieldGet } from "tslib";
|
|
3
3
|
import { HarnessPredicate, } from '@angular/cdk/testing';
|
|
4
4
|
import { SkyComponentHarness } from '@skyux/core/testing';
|
|
@@ -6,11 +6,11 @@ import { SkyCheckboxHarness } from '@skyux/forms/testing';
|
|
|
6
6
|
import { SkyChevronHarness } from '@skyux/indicators/testing';
|
|
7
7
|
/**
|
|
8
8
|
* Harness for interacting with a repeater item component in tests.
|
|
9
|
-
* @internal
|
|
10
9
|
*/
|
|
11
10
|
export class SkyRepeaterItemHarness extends SkyComponentHarness {
|
|
12
11
|
constructor() {
|
|
13
12
|
super(...arguments);
|
|
13
|
+
_SkyRepeaterItemHarness_getBackToTop.set(this, this.locatorForOptional('button.sky-repeater-item-reorder-top'));
|
|
14
14
|
_SkyRepeaterItemHarness_getCheckbox.set(this, this.locatorForOptional(SkyCheckboxHarness));
|
|
15
15
|
_SkyRepeaterItemHarness_getChevron.set(this, this.locatorForOptional(SkyChevronHarness));
|
|
16
16
|
_SkyRepeaterItemHarness_getContent.set(this, this.locatorFor('.sky-repeater-item-content'));
|
|
@@ -48,6 +48,24 @@ export class SkyRepeaterItemHarness extends SkyComponentHarness {
|
|
|
48
48
|
async queryHarness(query) {
|
|
49
49
|
return this.locatorForOptional(query)();
|
|
50
50
|
}
|
|
51
|
+
/**
|
|
52
|
+
* Returns child harnesses.
|
|
53
|
+
*/
|
|
54
|
+
async queryHarnesses(harness) {
|
|
55
|
+
return this.locatorForAll(harness)();
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Returns a child test element.
|
|
59
|
+
*/
|
|
60
|
+
async querySelector(selector) {
|
|
61
|
+
return this.locatorForOptional(selector)();
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Returns child test elements.
|
|
65
|
+
*/
|
|
66
|
+
async querySelectorAll(selector) {
|
|
67
|
+
return this.locatorForAll(selector)();
|
|
68
|
+
}
|
|
51
69
|
/**
|
|
52
70
|
* Selects the repeater item.
|
|
53
71
|
*/
|
|
@@ -128,10 +146,21 @@ export class SkyRepeaterItemHarness extends SkyComponentHarness {
|
|
|
128
146
|
async isReorderable() {
|
|
129
147
|
return !!(await __classPrivateFieldGet(this, _SkyRepeaterItemHarness_getReorderHandle, "f").call(this));
|
|
130
148
|
}
|
|
149
|
+
/**
|
|
150
|
+
* Moves the repeater item to the top of the list
|
|
151
|
+
*/
|
|
152
|
+
async sendToTop() {
|
|
153
|
+
if (await this.isReorderable()) {
|
|
154
|
+
await (await __classPrivateFieldGet(this, _SkyRepeaterItemHarness_getBackToTop, "f").call(this))?.click();
|
|
155
|
+
}
|
|
156
|
+
else {
|
|
157
|
+
throw new Error('Could not send to top because the repeater is not reorderable.');
|
|
158
|
+
}
|
|
159
|
+
}
|
|
131
160
|
}
|
|
132
|
-
_SkyRepeaterItemHarness_getCheckbox = new WeakMap(), _SkyRepeaterItemHarness_getChevron = new WeakMap(), _SkyRepeaterItemHarness_getContent = new WeakMap(), _SkyRepeaterItemHarness_getReorderHandle = new WeakMap(), _SkyRepeaterItemHarness_getTitle = new WeakMap();
|
|
161
|
+
_SkyRepeaterItemHarness_getBackToTop = new WeakMap(), _SkyRepeaterItemHarness_getCheckbox = new WeakMap(), _SkyRepeaterItemHarness_getChevron = new WeakMap(), _SkyRepeaterItemHarness_getContent = new WeakMap(), _SkyRepeaterItemHarness_getReorderHandle = new WeakMap(), _SkyRepeaterItemHarness_getTitle = new WeakMap();
|
|
133
162
|
/**
|
|
134
163
|
* @internal
|
|
135
164
|
*/
|
|
136
165
|
SkyRepeaterItemHarness.hostSelector = 'sky-repeater-item';
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeater-item-harness.js","sourceRoot":"","sources":["../../../../../../../libs/components/lists/testing/src/repeater/repeater-item-harness.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentHarness,\n  HarnessPredicate,\n  HarnessQuery,\n} from '@angular/cdk/testing';\nimport { SkyComponentHarness } from '@skyux/core/testing';\nimport { SkyCheckboxHarness } from '@skyux/forms/testing';\nimport { SkyChevronHarness } from '@skyux/indicators/testing';\n\nimport { SkyRepeaterItemHarnessFilters } from './repeater-item-harness-filters';\n\n/**\n * Harness for interacting with a repeater item component in tests.\n * @internal\n */\nexport class SkyRepeaterItemHarness extends SkyComponentHarness {\n  /**\n   * @internal\n   */\n  public static hostSelector = 'sky-repeater-item';\n\n  #getCheckbox = this.locatorForOptional(SkyCheckboxHarness);\n\n  #getChevron = this.locatorForOptional(SkyChevronHarness);\n\n  #getContent = this.locatorFor('.sky-repeater-item-content');\n\n  #getReorderHandle = this.locatorForOptional(\n    'button.sky-repeater-item-grab-handle'\n  );\n\n  #getTitle = this.locatorFor('.sky-repeater-item-title');\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for a\n   * `SkyRepeaterItemHarness` that meets certain criteria.\n   */\n  public static with(\n    filters: SkyRepeaterItemHarnessFilters\n  ): HarnessPredicate<SkyRepeaterItemHarness> {\n    return SkyRepeaterItemHarness.getDataSkyIdPredicate(filters)\n      .addOption('contentText', filters.contentText, async (harness, text) =>\n        HarnessPredicate.stringMatches(await harness.getContentText(), text)\n      )\n      .addOption('titleText', filters.titleText, async (harness, text) =>\n        HarnessPredicate.stringMatches(await harness.getTitleText(), text)\n      );\n  }\n\n  /**\n   * Whether the repeater item is selectable.\n   */\n  public async isSelectable(): Promise<boolean> {\n    return !!(await this.#getCheckbox());\n  }\n\n  /**\n   * Whether the repeater item is selected.\n   */\n  public async isSelected(): Promise<boolean> {\n    const checkbox = await this.#getCheckbox();\n    if (!checkbox) {\n      throw new Error(\n        'Could not determine if repeater item is selected because it is not selectable.'\n      );\n    }\n\n    return checkbox.isChecked();\n  }\n\n  /**\n   * Returns a child harness.\n   */\n  public async queryHarness<T extends ComponentHarness>(\n    query: HarnessQuery<T>\n  ): Promise<T | null> {\n    return this.locatorForOptional(query)();\n  }\n\n  /**\n   * Selects the repeater item.\n   */\n  public async select(): Promise<void> {\n    const checkbox = await this.#getCheckbox();\n    if (!checkbox) {\n      throw new Error(\n        'Could not select the repeater item because it is not selectable.'\n      );\n    }\n\n    await checkbox.check();\n  }\n\n  /**\n   * Deselects the repeater item.\n   */\n  public async deselect(): Promise<void> {\n    const checkbox = await this.#getCheckbox();\n    if (!checkbox) {\n      throw new Error(\n        'Could not deselect the repeater item because it is not selectable.'\n      );\n    }\n\n    await checkbox.uncheck();\n  }\n\n  /**\n   * Gets the text of the repeater item content.\n   */\n  public async getContentText(): Promise<string> {\n    return (await this.#getContent()).text();\n  }\n\n  /**\n   * Gets the text of the repeater item title.\n   */\n  public async getTitleText(): Promise<string> {\n    return (await this.#getTitle()).text();\n  }\n\n  /**\n   * Whether the repeater item is collapsible.\n   */\n  public async isCollapsible(): Promise<boolean> {\n    return !!(await this.#getChevron());\n  }\n\n  /**\n   * Whether the repeater item is expanded, or throws an error informing of the lack of collapsibility.\n   */\n  public async isExpanded(): Promise<boolean> {\n    const chevron = await this.#getChevron();\n    if (chevron) {\n      return (await chevron.getDirection()) === 'up';\n    }\n    throw new Error(\n      'Could not determine if repeater item is expanded because it is not collapsible.'\n    );\n  }\n\n  /**\n   * Expands the repeater item, or does nothing if already expanded.\n   */\n  public async expand(): Promise<void> {\n    const chevron = await this.#getChevron();\n    if (chevron) {\n      if ((await chevron.getDirection()) === 'down') {\n        await chevron.toggle();\n      }\n      return;\n    }\n    throw new Error(\n      'Could not expand the repeater item because it is not collapsible.'\n    );\n  }\n\n  /**\n   * Collapses the repeater item, or does nothing if already collapsed.\n   */\n  public async collapse(): Promise<void> {\n    const chevron = await this.#getChevron();\n    if (chevron) {\n      if ((await chevron.getDirection()) === 'up') {\n        await chevron.toggle();\n      }\n      return;\n    }\n    throw new Error(\n      'Could not collapse the repeater item because it is not collapsible.'\n    );\n  }\n\n  /**\n   * Whether the repeater item is reorderable.\n   */\n  public async isReorderable(): Promise<boolean> {\n    return !!(await this.#getReorderHandle());\n  }\n}\n"]}
|
|
166
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeater-item-harness.js","sourceRoot":"","sources":["../../../../../../../libs/components/lists/testing/src/repeater/repeater-item-harness.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentHarness,\n  HarnessPredicate,\n  HarnessQuery,\n  TestElement,\n} from '@angular/cdk/testing';\nimport { SkyComponentHarness } from '@skyux/core/testing';\nimport { SkyCheckboxHarness } from '@skyux/forms/testing';\nimport { SkyChevronHarness } from '@skyux/indicators/testing';\n\nimport { SkyRepeaterItemHarnessFilters } from './repeater-item-harness-filters';\n\n/**\n * Harness for interacting with a repeater item component in tests.\n */\nexport class SkyRepeaterItemHarness extends SkyComponentHarness {\n  /**\n   * @internal\n   */\n  public static hostSelector = 'sky-repeater-item';\n\n  #getBackToTop = this.locatorForOptional(\n    'button.sky-repeater-item-reorder-top'\n  );\n\n  #getCheckbox = this.locatorForOptional(SkyCheckboxHarness);\n\n  #getChevron = this.locatorForOptional(SkyChevronHarness);\n\n  #getContent = this.locatorFor('.sky-repeater-item-content');\n\n  #getReorderHandle = this.locatorForOptional(\n    'button.sky-repeater-item-grab-handle'\n  );\n\n  #getTitle = this.locatorFor('.sky-repeater-item-title');\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for a\n   * `SkyRepeaterItemHarness` that meets certain criteria.\n   */\n  public static with(\n    filters: SkyRepeaterItemHarnessFilters\n  ): HarnessPredicate<SkyRepeaterItemHarness> {\n    return SkyRepeaterItemHarness.getDataSkyIdPredicate(filters)\n      .addOption('contentText', filters.contentText, async (harness, text) =>\n        HarnessPredicate.stringMatches(await harness.getContentText(), text)\n      )\n      .addOption('titleText', filters.titleText, async (harness, text) =>\n        HarnessPredicate.stringMatches(await harness.getTitleText(), text)\n      );\n  }\n\n  /**\n   * Whether the repeater item is selectable.\n   */\n  public async isSelectable(): Promise<boolean> {\n    return !!(await this.#getCheckbox());\n  }\n\n  /**\n   * Whether the repeater item is selected.\n   */\n  public async isSelected(): Promise<boolean> {\n    const checkbox = await this.#getCheckbox();\n    if (!checkbox) {\n      throw new Error(\n        'Could not determine if repeater item is selected because it is not selectable.'\n      );\n    }\n\n    return checkbox.isChecked();\n  }\n\n  /**\n   * Returns a child harness.\n   */\n  public async queryHarness<T extends ComponentHarness>(\n    query: HarnessQuery<T>\n  ): Promise<T | null> {\n    return this.locatorForOptional(query)();\n  }\n\n  /**\n   * Returns child harnesses.\n   */\n  public async queryHarnesses<T extends ComponentHarness>(\n    harness: HarnessQuery<T>\n  ): Promise<T[]> {\n    return this.locatorForAll(harness)();\n  }\n\n  /**\n   * Returns a child test element.\n   */\n  public async querySelector(selector: string): Promise<TestElement | null> {\n    return this.locatorForOptional(selector)();\n  }\n\n  /**\n   * Returns child test elements.\n   */\n  public async querySelectorAll(selector: string): Promise<TestElement[]> {\n    return this.locatorForAll(selector)();\n  }\n\n  /**\n   * Selects the repeater item.\n   */\n  public async select(): Promise<void> {\n    const checkbox = await this.#getCheckbox();\n    if (!checkbox) {\n      throw new Error(\n        'Could not select the repeater item because it is not selectable.'\n      );\n    }\n\n    await checkbox.check();\n  }\n\n  /**\n   * Deselects the repeater item.\n   */\n  public async deselect(): Promise<void> {\n    const checkbox = await this.#getCheckbox();\n    if (!checkbox) {\n      throw new Error(\n        'Could not deselect the repeater item because it is not selectable.'\n      );\n    }\n\n    await checkbox.uncheck();\n  }\n\n  /**\n   * Gets the text of the repeater item content.\n   */\n  public async getContentText(): Promise<string> {\n    return (await this.#getContent()).text();\n  }\n\n  /**\n   * Gets the text of the repeater item title.\n   */\n  public async getTitleText(): Promise<string> {\n    return (await this.#getTitle()).text();\n  }\n\n  /**\n   * Whether the repeater item is collapsible.\n   */\n  public async isCollapsible(): Promise<boolean> {\n    return !!(await this.#getChevron());\n  }\n\n  /**\n   * Whether the repeater item is expanded, or throws an error informing of the lack of collapsibility.\n   */\n  public async isExpanded(): Promise<boolean> {\n    const chevron = await this.#getChevron();\n    if (chevron) {\n      return (await chevron.getDirection()) === 'up';\n    }\n    throw new Error(\n      'Could not determine if repeater item is expanded because it is not collapsible.'\n    );\n  }\n\n  /**\n   * Expands the repeater item, or does nothing if already expanded.\n   */\n  public async expand(): Promise<void> {\n    const chevron = await this.#getChevron();\n    if (chevron) {\n      if ((await chevron.getDirection()) === 'down') {\n        await chevron.toggle();\n      }\n      return;\n    }\n    throw new Error(\n      'Could not expand the repeater item because it is not collapsible.'\n    );\n  }\n\n  /**\n   * Collapses the repeater item, or does nothing if already collapsed.\n   */\n  public async collapse(): Promise<void> {\n    const chevron = await this.#getChevron();\n    if (chevron) {\n      if ((await chevron.getDirection()) === 'up') {\n        await chevron.toggle();\n      }\n      return;\n    }\n    throw new Error(\n      'Could not collapse the repeater item because it is not collapsible.'\n    );\n  }\n\n  /**\n   * Whether the repeater item is reorderable.\n   */\n  public async isReorderable(): Promise<boolean> {\n    return !!(await this.#getReorderHandle());\n  }\n\n  /**\n   * Moves the repeater item to the top of the list\n   */\n  public async sendToTop(): Promise<void> {\n    if (await this.isReorderable()) {\n      await (await this.#getBackToTop())?.click();\n    } else {\n      throw new Error(\n        'Could not send to top because the repeater is not reorderable.'\n      );\n    }\n  }\n}\n"]}
|
|
@@ -231,14 +231,14 @@ _SkyPagingFixture__debugEl = new WeakMap(), _SkyPagingFixture_fixture = new Weak
|
|
|
231
231
|
});
|
|
232
232
|
};
|
|
233
233
|
|
|
234
|
-
var _SkyRepeaterItemHarness_getCheckbox, _SkyRepeaterItemHarness_getChevron, _SkyRepeaterItemHarness_getContent, _SkyRepeaterItemHarness_getReorderHandle, _SkyRepeaterItemHarness_getTitle;
|
|
234
|
+
var _SkyRepeaterItemHarness_getBackToTop, _SkyRepeaterItemHarness_getCheckbox, _SkyRepeaterItemHarness_getChevron, _SkyRepeaterItemHarness_getContent, _SkyRepeaterItemHarness_getReorderHandle, _SkyRepeaterItemHarness_getTitle;
|
|
235
235
|
/**
|
|
236
236
|
* Harness for interacting with a repeater item component in tests.
|
|
237
|
-
* @internal
|
|
238
237
|
*/
|
|
239
238
|
class SkyRepeaterItemHarness extends SkyComponentHarness {
|
|
240
239
|
constructor() {
|
|
241
240
|
super(...arguments);
|
|
241
|
+
_SkyRepeaterItemHarness_getBackToTop.set(this, this.locatorForOptional('button.sky-repeater-item-reorder-top'));
|
|
242
242
|
_SkyRepeaterItemHarness_getCheckbox.set(this, this.locatorForOptional(SkyCheckboxHarness));
|
|
243
243
|
_SkyRepeaterItemHarness_getChevron.set(this, this.locatorForOptional(SkyChevronHarness));
|
|
244
244
|
_SkyRepeaterItemHarness_getContent.set(this, this.locatorFor('.sky-repeater-item-content'));
|
|
@@ -282,6 +282,30 @@ class SkyRepeaterItemHarness extends SkyComponentHarness {
|
|
|
282
282
|
return this.locatorForOptional(query)();
|
|
283
283
|
});
|
|
284
284
|
}
|
|
285
|
+
/**
|
|
286
|
+
* Returns child harnesses.
|
|
287
|
+
*/
|
|
288
|
+
queryHarnesses(harness) {
|
|
289
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
290
|
+
return this.locatorForAll(harness)();
|
|
291
|
+
});
|
|
292
|
+
}
|
|
293
|
+
/**
|
|
294
|
+
* Returns a child test element.
|
|
295
|
+
*/
|
|
296
|
+
querySelector(selector) {
|
|
297
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
298
|
+
return this.locatorForOptional(selector)();
|
|
299
|
+
});
|
|
300
|
+
}
|
|
301
|
+
/**
|
|
302
|
+
* Returns child test elements.
|
|
303
|
+
*/
|
|
304
|
+
querySelectorAll(selector) {
|
|
305
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
306
|
+
return this.locatorForAll(selector)();
|
|
307
|
+
});
|
|
308
|
+
}
|
|
285
309
|
/**
|
|
286
310
|
* Selects the repeater item.
|
|
287
311
|
*/
|
|
@@ -380,8 +404,22 @@ class SkyRepeaterItemHarness extends SkyComponentHarness {
|
|
|
380
404
|
return !!(yield __classPrivateFieldGet(this, _SkyRepeaterItemHarness_getReorderHandle, "f").call(this));
|
|
381
405
|
});
|
|
382
406
|
}
|
|
407
|
+
/**
|
|
408
|
+
* Moves the repeater item to the top of the list
|
|
409
|
+
*/
|
|
410
|
+
sendToTop() {
|
|
411
|
+
var _a;
|
|
412
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
413
|
+
if (yield this.isReorderable()) {
|
|
414
|
+
yield ((_a = (yield __classPrivateFieldGet(this, _SkyRepeaterItemHarness_getBackToTop, "f").call(this))) === null || _a === void 0 ? void 0 : _a.click());
|
|
415
|
+
}
|
|
416
|
+
else {
|
|
417
|
+
throw new Error('Could not send to top because the repeater is not reorderable.');
|
|
418
|
+
}
|
|
419
|
+
});
|
|
420
|
+
}
|
|
383
421
|
}
|
|
384
|
-
_SkyRepeaterItemHarness_getCheckbox = new WeakMap(), _SkyRepeaterItemHarness_getChevron = new WeakMap(), _SkyRepeaterItemHarness_getContent = new WeakMap(), _SkyRepeaterItemHarness_getReorderHandle = new WeakMap(), _SkyRepeaterItemHarness_getTitle = new WeakMap();
|
|
422
|
+
_SkyRepeaterItemHarness_getBackToTop = new WeakMap(), _SkyRepeaterItemHarness_getCheckbox = new WeakMap(), _SkyRepeaterItemHarness_getChevron = new WeakMap(), _SkyRepeaterItemHarness_getContent = new WeakMap(), _SkyRepeaterItemHarness_getReorderHandle = new WeakMap(), _SkyRepeaterItemHarness_getTitle = new WeakMap();
|
|
385
423
|
/**
|
|
386
424
|
* @internal
|
|
387
425
|
*/
|
|
@@ -389,7 +427,6 @@ SkyRepeaterItemHarness.hostSelector = 'sky-repeater-item';
|
|
|
389
427
|
|
|
390
428
|
/**
|
|
391
429
|
* Harness for interacting with a repeater component in tests.
|
|
392
|
-
* @internal
|
|
393
430
|
*/
|
|
394
431
|
class SkyRepeaterHarness extends SkyComponentHarness {
|
|
395
432
|
/**
|