
* Use generated hooks in apps * Remove unused files * Use proper types in apps * Use generated hooks in attributes * Use generated hooks in auth module * Use generated hooks in categories * Use generated hooks in channels * Use generated types in collections * Remove legacy types from background tasks * Use generated hooks in customers * Use generated hooks in discounts * Use generated hook in file upload * Use generated types in gift cards * Use generated types in home * Use generated hooks in navigation * Use generated hooks in orders * Use generated hooks in pages * Use generated hooks in page types * Use generated hooks in permission groups * Use generated hooks in plugins * Use generated hooks in products * Use fragment to mark product variants * Improve code a bit * Use generated hooks in page types * Use generated types in searches * Use generated hooks in shipping * Use generated hooks in site settings * Use generated hooks in staff members * Use generated hooks in taxes * Place all gql generated files in one directory * Use generated hooks in translations * Use global types from new generated module * Use generated hooks in warehouses * Use generated hooks in webhooks * Use generated fragment types * Unclutter types * Remove hoc components * Split hooks and types * Fetch introspection file * Delete obsolete schema file * Fix rebase artifacts * Fix autoreplace * Fix auth provider tests * Fix urls * Remove leftover types * Fix rebase artifacts
21 lines
623 B
TypeScript
21 lines
623 B
TypeScript
import { ChannelDetailsFragment } from "@saleor/graphql";
|
|
import { FetchMoreProps, Search, SearchProps } from "@saleor/types";
|
|
import { filter } from "fuzzaldrin";
|
|
import React from "react";
|
|
|
|
export const useChannelsSearch = function<T extends { name: string }>(
|
|
channels: T[]
|
|
) {
|
|
const [query, onQueryChange] = React.useState("");
|
|
const filteredChannels =
|
|
filter<T, "name">(channels, query, { key: "name" }) || [];
|
|
|
|
return { query, onQueryChange, filteredChannels };
|
|
};
|
|
|
|
export interface ChannelsWithLoadMoreProps
|
|
extends FetchMoreProps,
|
|
Search,
|
|
SearchProps {
|
|
channels: ChannelDetailsFragment[];
|
|
}
|