2018-03-26 14:32:43 -07:00
|
|
|
// @flow
|
2018-11-25 20:21:25 -05:00
|
|
|
import * as ICONS from 'constants/icons';
|
2017-12-21 18:08:54 -03:00
|
|
|
import React from 'react';
|
2021-07-07 15:10:28 +08:00
|
|
|
import { lazyImport } from 'util/lazyImport';
|
2020-12-11 13:33:27 -05:00
|
|
|
import { useIsMobile } from 'effects/use-screensize';
|
2021-06-11 14:06:29 +08:00
|
|
|
|
2021-07-07 15:10:28 +08:00
|
|
|
const Button = lazyImport(() => import('component/button' /* webpackChunkName: "button" */));
|
|
|
|
const Icon = lazyImport(() => import('component/common/icon' /* webpackChunkName: "icon" */));
|
|
|
|
const WunderbarSuggestions = lazyImport(() => import('component/wunderbarSuggestions' /* webpackChunkName: "secondary" */));
|
2018-10-04 01:59:47 -04:00
|
|
|
|
2018-03-26 14:32:43 -07:00
|
|
|
type Props = {
|
2021-06-16 10:27:58 +08:00
|
|
|
doOpenMobileSearch: (any) => void,
|
2021-06-03 10:59:01 +08:00
|
|
|
channelsOnly?: boolean,
|
|
|
|
noTopSuggestion?: boolean,
|
|
|
|
noBottomLinks?: boolean,
|
|
|
|
customSelectAction?: (string) => void,
|
2018-03-26 14:32:43 -07:00
|
|
|
};
|
|
|
|
|
2020-12-03 12:29:47 -05:00
|
|
|
export default function WunderBar(props: Props) {
|
2021-06-03 10:59:01 +08:00
|
|
|
const { doOpenMobileSearch, channelsOnly, noTopSuggestion, noBottomLinks, customSelectAction } = props;
|
2020-12-11 13:33:27 -05:00
|
|
|
const isMobile = useIsMobile();
|
2020-12-03 12:29:47 -05:00
|
|
|
|
2020-12-11 13:33:27 -05:00
|
|
|
return isMobile ? (
|
2021-06-11 14:06:29 +08:00
|
|
|
<React.Suspense fallback={null}>
|
2021-06-25 16:02:45 +08:00
|
|
|
<Button
|
|
|
|
icon={ICONS.SEARCH}
|
|
|
|
className="wunderbar__mobile-search"
|
|
|
|
onClick={() => doOpenMobileSearch({ ...props })}
|
|
|
|
/>
|
2021-06-11 14:06:29 +08:00
|
|
|
</React.Suspense>
|
2020-12-11 13:33:27 -05:00
|
|
|
) : (
|
2021-06-11 14:06:29 +08:00
|
|
|
<React.Suspense
|
|
|
|
fallback={
|
|
|
|
<div className="wunderbar__wrapper wunderbar wunderbar__input" aria-disabled>
|
|
|
|
<Icon icon={ICONS.SEARCH} aria-disabled />
|
|
|
|
</div>
|
|
|
|
}
|
|
|
|
>
|
|
|
|
<WunderbarSuggestions
|
|
|
|
channelsOnly={channelsOnly}
|
|
|
|
noTopSuggestion={noTopSuggestion}
|
|
|
|
noBottomLinks={noBottomLinks}
|
|
|
|
customSelectAction={customSelectAction}
|
|
|
|
/>
|
|
|
|
</React.Suspense>
|
2020-12-03 12:29:47 -05:00
|
|
|
);
|
|
|
|
}
|