diff options
| author | Shin'ya Ueoka <ueokande@i-beam.org> | 2021-04-12 13:09:09 +0000 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-04-12 13:09:09 +0000 | 
| commit | d80d0f87b82ba4bd74ed9b2bb7354421a28a11b3 (patch) | |
| tree | 691185ad88418d0f44c236d0913cf5c425b29b23 /src/console/components/FindPrompt.tsx | |
| parent | ea73c900f66107fd4a5b2f3b05080bcf643c94ea (diff) | |
| parent | 8a5bba1da639355a25da8c279a9f1cf0a7300a9f (diff) | |
Merge pull request #1098 from ueokande/replace-redux-with-react-hooks
Refactor state management with React Hooks on Console
Diffstat (limited to 'src/console/components/FindPrompt.tsx')
| -rw-r--r-- | src/console/components/FindPrompt.tsx | 58 | 
1 files changed, 58 insertions, 0 deletions
diff --git a/src/console/components/FindPrompt.tsx b/src/console/components/FindPrompt.tsx new file mode 100644 index 0000000..c437d16 --- /dev/null +++ b/src/console/components/FindPrompt.tsx @@ -0,0 +1,58 @@ +import React from "react"; +import Input from "./console/Input"; +import styled from "styled-components"; +import useAutoResize from "../hooks/useAutoResize"; +import { useExecFind, useHide } from "../app/hooks"; + +const ConsoleWrapper = styled.div` +  border-top: 1px solid gray; +`; + +const FindPrompt: React.FC = () => { +  const [inputValue, setInputValue] = React.useState(""); +  const hide = useHide(); +  const execFind = useExecFind(); + +  const onBlur = () => { +    hide(); +  }; + +  useAutoResize(); + +  const doEnter = (e: React.KeyboardEvent<HTMLInputElement>) => { +    e.stopPropagation(); +    e.preventDefault(); + +    const value = (e.target as HTMLInputElement).value; +    execFind(value === "" ? undefined : value); +  }; + +  const onKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => { +    switch (e.key) { +      case "Escape": +        hide(); +        break; +      case "Enter": +        doEnter(e); +        break; +    } +  }; + +  const onChange = (e: React.ChangeEvent<HTMLInputElement>) => { +    setInputValue(e.target.value); +  }; + +  return ( +    <ConsoleWrapper> +      <Input +        prompt={"/"} +        onBlur={onBlur} +        onKeyDown={onKeyDown} +        onChange={onChange} +        value={inputValue} +      /> +    </ConsoleWrapper> +  ); +}; + +export default FindPrompt;  | 
