make table name editable
This commit is contained in:
parent
cc1a73d6dd
commit
a4d3dab249
@ -8,9 +8,11 @@ import {
|
|||||||
} from "@arco-design/web-react/icon";
|
} from "@arco-design/web-react/icon";
|
||||||
|
|
||||||
const Rect = (props) => {
|
const Rect = (props) => {
|
||||||
|
const [node, setNode] = useState(Node.NONE);
|
||||||
const [isHovered, setIsHovered] = useState(false);
|
const [isHovered, setIsHovered] = useState(false);
|
||||||
const [hoveredField, setHoveredField] = useState(-1);
|
const [hoveredField, setHoveredField] = useState(-1);
|
||||||
const [node, setNode] = useState(Node.NONE);
|
const [name, setName] = useState("New table");
|
||||||
|
|
||||||
const [fields, setFields] = useState([
|
const [fields, setFields] = useState([
|
||||||
{
|
{
|
||||||
name: "id",
|
name: "id",
|
||||||
@ -32,11 +34,7 @@ const Rect = (props) => {
|
|||||||
},
|
},
|
||||||
]);
|
]);
|
||||||
|
|
||||||
const table = {
|
const height = fields.length * 36 + 40 + 4;
|
||||||
name: "Students",
|
|
||||||
};
|
|
||||||
|
|
||||||
const height = fields.length * 36 + 40 + 2;
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<g>
|
<g>
|
||||||
@ -62,8 +60,21 @@ const Rect = (props) => {
|
|||||||
isHovered ? "border-sky-500" : "border-gray-500"
|
isHovered ? "border-sky-500" : "border-gray-500"
|
||||||
} bg-gray-300 select-none rounded-md`}
|
} bg-gray-300 select-none rounded-md`}
|
||||||
>
|
>
|
||||||
<div className="p-3 font-bold text-slate-800 h-[40px] bg-gray-400 rounded-t-md flex justify-between">
|
<div className="p-3 font-bold text-slate-800 h-[40px] bg-gray-400 rounded-t-md flex justify-between items-center">
|
||||||
{table.name}
|
{
|
||||||
|
<form onSubmit={(e) => e.preventDefault()}>
|
||||||
|
<input
|
||||||
|
type="text"
|
||||||
|
value={name}
|
||||||
|
onChange={(e) => setName(e.target.value)}
|
||||||
|
className={`p-1 select-text w-[100px] bg-gray-400 focus:bg-gray-200 ${
|
||||||
|
name < 1
|
||||||
|
? "ring-2 ring-red-600"
|
||||||
|
: "focus:ring-2 focus:ring-sky-500 "
|
||||||
|
}`}
|
||||||
|
/>
|
||||||
|
</form>
|
||||||
|
}
|
||||||
{isHovered && (
|
{isHovered && (
|
||||||
<div className="flex justify-end items-center">
|
<div className="flex justify-end items-center">
|
||||||
<button className="btn bg-sky-800 text-white text-xs py-1 px-2 me-2 opacity-80">
|
<button className="btn bg-sky-800 text-white text-xs py-1 px-2 me-2 opacity-80">
|
||||||
|
Loading…
Reference in New Issue
Block a user