From 077b54c76a67a7eff60de6a925413972386e8382 Mon Sep 17 00:00:00 2001 From: cbae Date: Tue, 24 Sep 2024 11:38:36 -0700 Subject: [PATCH 1/4] Marks Select arrays as readonly --- packages/select/src/common/itemListRenderer.ts | 4 ++-- packages/select/src/common/listItemsProps.ts | 4 ++-- packages/select/src/common/predicate.ts | 2 +- packages/select/src/components/multi-select/multiSelect.tsx | 4 ++-- packages/select/src/components/query-list/queryList.tsx | 4 ++-- 5 files changed, 9 insertions(+), 9 deletions(-) diff --git a/packages/select/src/common/itemListRenderer.ts b/packages/select/src/common/itemListRenderer.ts index 180f762fad1..89c75aa580e 100644 --- a/packages/select/src/common/itemListRenderer.ts +++ b/packages/select/src/common/itemListRenderer.ts @@ -35,13 +35,13 @@ export interface ItemListRendererProps { * map each item in this array through `renderItem`, with support for * optional `noResults` and `initialContent` states. */ - filteredItems: T[]; + filteredItems: readonly T[]; /** * Array of all items in the list. * See `filteredItems` for a filtered array based on `query` and predicate props. */ - items: T[]; + items: readonly T[]; /** * The current query string. diff --git a/packages/select/src/common/listItemsProps.ts b/packages/select/src/common/listItemsProps.ts index 2beb4431b38..433bd5cd17d 100644 --- a/packages/select/src/common/listItemsProps.ts +++ b/packages/select/src/common/listItemsProps.ts @@ -44,7 +44,7 @@ export interface ListItemsProps extends Props { activeItem?: T | CreateNewItem | null; /** Array of items in the list. */ - items: T[]; + items: readonly T[]; /** * Specifies how to test if two items are equal. By default, simple strict @@ -157,7 +157,7 @@ export interface ListItemsProps extends Props { /** * Callback invoked when multiple items are selected at once via pasting. */ - onItemsPaste?: (items: T[]) => void; + onItemsPaste?: (items: readonly T[]) => void; /** * Callback invoked when the query string changes. diff --git a/packages/select/src/common/predicate.ts b/packages/select/src/common/predicate.ts index 8011cbe0338..af16229b715 100644 --- a/packages/select/src/common/predicate.ts +++ b/packages/select/src/common/predicate.ts @@ -18,7 +18,7 @@ * A custom predicate for returning an entirely new `items` array based on the provided query. * See usage sites in `ListItemsProps`. */ -export type ItemListPredicate = (query: string, items: T[]) => T[]; +export type ItemListPredicate = (query: string, items: readonly T[]) => readonly T[]; /** * A custom predicate for filtering items based on the provided query. diff --git a/packages/select/src/components/multi-select/multiSelect.tsx b/packages/select/src/components/multi-select/multiSelect.tsx index c1be8deeae9..bd4e933ac13 100644 --- a/packages/select/src/components/multi-select/multiSelect.tsx +++ b/packages/select/src/components/multi-select/multiSelect.tsx @@ -44,7 +44,7 @@ export interface MultiSelectProps extends ListItemsProps, SelectPopoverPro * Element which triggers the multiselect popover. Providing this prop will replace the default TagInput * target thats rendered and move the search functionality to within the Popover. */ - customTarget?: (selectedItems: T[], isOpen: boolean) => React.ReactNode; + customTarget?: (selectedItems: readonly T[], isOpen: boolean) => React.ReactNode; /** * Whether the component is non-interactive. @@ -104,7 +104,7 @@ export interface MultiSelectProps extends ListItemsProps, SelectPopoverPro placeholder?: string; /** Controlled selected values. */ - selectedItems: T[]; + selectedItems: readonly T[]; /** * Props to pass to the [TagInput component](##core/components/tag-input). diff --git a/packages/select/src/components/query-list/queryList.tsx b/packages/select/src/components/query-list/queryList.tsx index e326843711a..a6ff0bc87f8 100644 --- a/packages/select/src/components/query-list/queryList.tsx +++ b/packages/select/src/components/query-list/queryList.tsx @@ -137,7 +137,7 @@ export interface QueryListState { createNewItem: T | T[] | undefined; /** The original `items` array filtered by `itemListPredicate` or `itemPredicate`. */ - filteredItems: T[]; + filteredItems: readonly T[]; /** The current query string. */ query: string; @@ -676,7 +676,7 @@ function isItemDisabled(item: T | null, index: number, itemDisabled?: ListIte * @param startIndex which index to begin moving from */ export function getFirstEnabledItem( - items: T[], + items: readonly T[], itemDisabled?: keyof T | ((item: T, index: number) => boolean), direction = 1, startIndex = items.length - 1, From 0cbfbcd98bb728c378e544fe8f649065f42cccc2 Mon Sep 17 00:00:00 2001 From: cbae Date: Tue, 24 Sep 2024 11:59:56 -0700 Subject: [PATCH 2/4] compilefix --- packages/docs-theme/src/components/navigator.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/docs-theme/src/components/navigator.tsx b/packages/docs-theme/src/components/navigator.tsx index c6e69faf934..0c7eabdc3d9 100644 --- a/packages/docs-theme/src/components/navigator.tsx +++ b/packages/docs-theme/src/components/navigator.tsx @@ -84,7 +84,7 @@ export class Navigator extends React.PureComponent { } private filterMatches: ItemListPredicate = (query, items) => - filter(items, query, { + filter(items.slice(), query, { key: "route", maxInners: items.length / 5, maxResults: 10, From 933c1e2d934d56794702c9f5e1c219639001280d Mon Sep 17 00:00:00 2001 From: cbae Date: Wed, 9 Oct 2024 13:43:41 -0700 Subject: [PATCH 3/4] compilefix --- .../src/examples/select-examples/multiSelectExample.tsx | 8 +++++--- .../src/examples/select-examples/selectExample.tsx | 4 ++-- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/packages/docs-app/src/examples/select-examples/multiSelectExample.tsx b/packages/docs-app/src/examples/select-examples/multiSelectExample.tsx index ff5d0129c25..502f4ad7da0 100644 --- a/packages/docs-app/src/examples/select-examples/multiSelectExample.tsx +++ b/packages/docs-app/src/examples/select-examples/multiSelectExample.tsx @@ -251,7 +251,9 @@ export class MultiSelectExample extends React.PureComponent ; + private renderCustomTarget = (selectedItems: readonly Film[]) => ( + + ); private renderTag = (film: Film) => film.title; @@ -287,7 +289,7 @@ export class MultiSelectExample extends React.PureComponent { let nextCreatedItems = createdItems.slice(); let nextFilms = films.slice(); @@ -336,7 +338,7 @@ export class MultiSelectExample extends React.PureComponent { + private handleFilmsPaste = (films: readonly Film[]) => { // On paste, don't bother with deselecting already selected values, just // add the new ones. this.selectFilms(films); diff --git a/packages/docs-app/src/examples/select-examples/selectExample.tsx b/packages/docs-app/src/examples/select-examples/selectExample.tsx index 18759c67f50..e9fab83d2d3 100644 --- a/packages/docs-app/src/examples/select-examples/selectExample.tsx +++ b/packages/docs-app/src/examples/select-examples/selectExample.tsx @@ -169,7 +169,7 @@ export class SelectExample extends React.PureComponent { + private getGroupedItems = (filteredItems: readonly Film[]) => { return filteredItems.reduce>( (acc, item, index) => { const group = this.getGroup(item); @@ -193,7 +193,7 @@ export class SelectExample extends React.PureComponent { + private groupedItemListPredicate = (query: string, items: readonly Film[]) => { return items .filter((item, index) => filterFilm(query, item, index)) .sort((a, b) => this.getGroup(a).localeCompare(this.getGroup(b))); From 9ef980904f2455e04cb68bbcb79f123e4401a86e Mon Sep 17 00:00:00 2001 From: cbae Date: Wed, 9 Oct 2024 14:31:35 -0700 Subject: [PATCH 4/4] compile --- packages/select/test/queryListTests.tsx | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/packages/select/test/queryListTests.tsx b/packages/select/test/queryListTests.tsx index 87dccf112de..47836069880 100644 --- a/packages/select/test/queryListTests.tsx +++ b/packages/select/test/queryListTests.tsx @@ -82,7 +82,9 @@ describe("", () => { }); it("itemListPredicate filters entire list by query", () => { - const predicate = sinon.spy((query: string, films: Film[]) => films.filter(f => f.year === +query)); + const predicate = sinon.spy((query: string, films: readonly Film[]) => + films.filter(f => f.year === +query), + ); shallow( {...testProps} itemListPredicate={predicate} query="1994" />); assert.equal(predicate.callCount, 1, "called once for entire list");