From bd07775a262c488c3ad3ef59cfb0a669630b9837 Mon Sep 17 00:00:00 2001 From: vapao Date: Mon, 17 Apr 2023 23:13:32 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E6=96=87=E4=BB=B6=E7=AE=A1?= =?UTF-8?q?=E7=90=86=E5=99=A8=E8=B7=AF=E5=BE=84=E8=BE=93=E5=85=A5=E6=A1=86?= =?UTF-8?q?=E6=8A=A5=E9=94=99=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- spug_web/src/pages/ssh/FileManager.js | 33 ++++++++++++--------------- 1 file changed, 14 insertions(+), 19 deletions(-) diff --git a/spug_web/src/pages/ssh/FileManager.js b/spug_web/src/pages/ssh/FileManager.js index 9f999b74..576df9b7 100644 --- a/spug_web/src/pages/ssh/FileManager.js +++ b/spug_web/src/pages/ssh/FileManager.js @@ -25,7 +25,6 @@ class FileManager extends React.Component { constructor(props) { super(props); this.input = null; - this.input2 = null this.pwdHistoryCaches = new Map() this.state = { fetching: false, @@ -45,8 +44,9 @@ class FileManager extends React.Component { componentDidUpdate(prevProps) { if (this.props.id !== prevProps.id) { - this.fetchFiles() - this.setState({objects: []}) + let pwd = this.pwdHistoryCaches.get(this.props.id) || [] + this.setState({objects: [], pwd}) + this.fetchFiles(pwd) } } @@ -101,12 +101,7 @@ class FileManager extends React.Component { fetchFiles = (pwd) => { this.setState({ fetching: true }); - pwd = pwd || (this.pwdHistoryCaches.get(this.props.id) || []); - if (this.pwdHistoryCaches.has(this.props.id)) { - let pwdCache = this.pwdHistoryCaches.get(this.props.id) - pwdCache.push(pwd.length > 0 ? pwd.splice(-1) : null) - pwd = pwdCache.filter(x => !!x) - } + pwd = pwd || this.state.pwd; const path = '/' + pwd.join('/'); return http.get('/api/file/', {params: {id: this.props.id, path}}) .then(res => { @@ -132,19 +127,19 @@ class FileManager extends React.Component { this.fetchFiles(pwd) }; + handleInputEdit = () => { + let inputPath = '/' + this.state.pwd.join('/') + this.setState({inputPath}) + } + handleInputEnter = () => { - if (this.state.inputPath === null) { - if (this.state.pwd.length > 0) { - this.setState({inputPath: `/${this.state.pwd.join('/')}/`}) - } else { - this.setState({inputPath: '/'}) - } - setTimeout(() => this.input2.focus(), 100) - } else { + if (this.state.inputPath) { let pwdStr = this.state.inputPath.replace(/^\/+/, '') pwdStr = pwdStr.replace(/\/+$/, '') this.fetchFiles(pwdStr.split('/')) .then(() => this.setState({inputPath: null})) + } else { + this.setState({inputPath: null}) } } @@ -229,7 +224,7 @@ class FileManager extends React.Component { this.input = ref}/>
{this.state.inputPath !== null ? ( - this.input2 = ref} size="small" className={styles.input} + 回车确认
} value={this.state.inputPath} onChange={e => this.setState({inputPath: e.target.value})} onBlur={this.handleInputEnter} @@ -244,7 +239,7 @@ class FileManager extends React.Component { {item} ))} - +