From 0d3a5be1512815a38f37ae81e7d9fc0948fd3f16 Mon Sep 17 00:00:00 2001 From: verou <857149855@qq.com> Date: 星期二, 25 三月 2025 13:54:57 +0800 Subject: [PATCH] 1 --- rsf-admin/src/page/components/TreeSelectInput.jsx | 10 +++++++--- 1 files changed, 7 insertions(+), 3 deletions(-) diff --git a/rsf-admin/src/page/components/TreeSelectInput.jsx b/rsf-admin/src/page/components/TreeSelectInput.jsx index d53b767..569451a 100644 --- a/rsf-admin/src/page/components/TreeSelectInput.jsx +++ b/rsf-admin/src/page/components/TreeSelectInput.jsx @@ -1,17 +1,20 @@ import React, { useState, useEffect } from 'react'; -import { useCreateContext, useTranslate } from 'react-admin' +import { useCreateContext, useTranslate, useRecordContext } from 'react-admin' import { MenuItem, Select, FormControl, InputLabel, Typography } from '@mui/material'; import request from '@/utils/request'; import * as Common from '@/utils/common'; import { useFormContext } from 'react-hook-form'; -const TreeSelectInput = ({ resource, label, source = 'parentId', value, isTranslate = false, ...rest }) => { +const TreeSelectInput = ({ resource, onChange, label, source = 'parentId', value, isTranslate = false, ...rest }) => { const translate = useTranslate(); const { setValue } = useFormContext(); const [filter, setFilter] = React.useState(""); const [treeData, setTreeData] = React.useState([]); const [proxyVal, setProxyVal] = React.useState(''); + + const record = useRecordContext() + const val = value || record?.[source]; useEffect(() => { const http = async (resource) => { @@ -20,7 +23,7 @@ }); if (res?.data?.code === 200) { setTreeData(Common.flattenTree(res.data.data)); - setProxyVal(value); + setProxyVal(val); } else { notify(res.data.msg); } @@ -35,6 +38,7 @@ shouldValidate: true, shouldDirty: true, }); + onChange(event) }; return ( -- Gitblit v1.9.1