diff --git a/packages/app/src/components/WidgetsBrowser/index.jsx b/packages/app/src/components/WidgetsBrowser/index.jsx new file mode 100644 index 00000000..c878852b --- /dev/null +++ b/packages/app/src/components/WidgetsBrowser/index.jsx @@ -0,0 +1,96 @@ +import React from "react" +import { Skeleton, Result, Input, Button } from "antd" +import { Icons } from "components/Icons" +import Image from "components/Image" + +import useRequest from "comty.js/hooks/useRequest" +import WidgetModel from "comty.js/models/widget" +import WidgetItemPreview from "components/WidgetItemPreview" + +import "./index.less" + +export const WidgetBrowser = (props) => { + const [L_Widgets, R_Widgets, E_Widgets, M_Widgets] = useRequest(WidgetModel.browse) + + const [searchValue, setSearchValue] = React.useState("") + + const handleOnSearch = (e) => { + // not allow to input space as first character + if (e.target.value[0] === " ") { + return + } + + setSearchValue(e.target.value) + } + + React.useEffect(() => { + const timer = setTimeout(async () => { + await M_Widgets({ + keywords: { + name: searchValue + } + }) + }, 400) + + return () => clearTimeout(timer) + }, [searchValue]) + + if (E_Widgets) { + console.error(E_Widgets) + + return