mirror of
https://github.com/haiwen/seahub.git
synced 2025-04-27 11:01:14 +00:00
Merge pull request #7743 from haiwen/fix/dirent_selection
fix dirent state in grid view
This commit is contained in:
commit
0b8aa00f4d
@ -72,6 +72,23 @@ class DirentGridItem extends React.Component {
|
||||
}
|
||||
}
|
||||
|
||||
componentDidUpdate(prevProps) {
|
||||
if (prevProps.dirent !== this.props.dirent) {
|
||||
this.setState({ dirent: this.props.dirent });
|
||||
}
|
||||
|
||||
const { repoID, path } = this.props;
|
||||
const { dirent } = this.state;
|
||||
if (this.checkGenerateThumbnail(dirent) && !this.isGeneratingThumbnail) {
|
||||
this.isGeneratingThumbnail = true;
|
||||
this.thumbnailCenter.createThumbnail({
|
||||
repoID,
|
||||
path: [path, dirent.name].join('/'),
|
||||
callback: this.updateDirentThumbnail,
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
componentWillUnmount() {
|
||||
if (this.clickTimeout) {
|
||||
clearTimeout(this.clickTimeout);
|
||||
|
@ -17,7 +17,7 @@ class Dirent {
|
||||
this.mtime_relative = dayjs.unix(json.mtime).fromNow();
|
||||
}
|
||||
this.permission = json.permission || 'rw';
|
||||
this.isSelected = false; // is check or not
|
||||
this.isSelected = json.isSelected || false; // is check or not
|
||||
this.starred = json.starred || false;
|
||||
if (json.type === 'dir') {
|
||||
this.has_been_shared_out = false;
|
||||
|
@ -25,6 +25,7 @@ const ExcaliEditor = () => {
|
||||
setIsFetching(false);
|
||||
});
|
||||
onSetFavicon();
|
||||
// eslint-disable-next-line react-hooks/exhaustive-deps
|
||||
}, []);
|
||||
|
||||
const saveSceneContent = useCallback(async () => {
|
||||
|
@ -1543,35 +1543,47 @@ class LibContentView extends React.Component {
|
||||
newSelectedDirentList = [clickedDirent];
|
||||
}
|
||||
|
||||
this.setState({
|
||||
direntList: direntList.map(dirent => {
|
||||
dirent.isSelected = newSelectedDirentList.some(selectedDirent => selectedDirent.name === dirent.name);
|
||||
return dirent;
|
||||
}),
|
||||
isDirentSelected: newSelectedDirentList.length > 0,
|
||||
isAllDirentSelected: newSelectedDirentList.length === direntList.length,
|
||||
selectedDirentList: newSelectedDirentList,
|
||||
lastSelectedIndex: clickedIndex,
|
||||
this.setState(prevState => {
|
||||
const newDirentList = prevState.direntList.map(dirent => {
|
||||
const isSelected = newSelectedDirentList.some(selected => selected.name === dirent.name);
|
||||
return new Dirent({
|
||||
...dirent,
|
||||
isSelected: isSelected,
|
||||
});
|
||||
});
|
||||
|
||||
const updatedSelectedDirents = newSelectedDirentList.map(selected =>
|
||||
newDirentList.find(dirent => dirent.name === selected.name)
|
||||
);
|
||||
|
||||
return {
|
||||
direntList: newDirentList,
|
||||
isDirentSelected: updatedSelectedDirents.length > 0,
|
||||
isAllDirentSelected: updatedSelectedDirents.length === newDirentList.length,
|
||||
selectedDirentList: updatedSelectedDirents,
|
||||
lastSelectedIndex: clickedIndex,
|
||||
};
|
||||
});
|
||||
} else {
|
||||
this.setState({
|
||||
direntList: direntList.map(dirent => {
|
||||
dirent.isSelected = false;
|
||||
return dirent;
|
||||
}),
|
||||
this.setState(prevState => ({
|
||||
direntList: prevState.direntList.map(dirent => new Dirent({ ...dirent, isSelected: false })),
|
||||
isDirentSelected: false,
|
||||
isAllDirentSelected: false,
|
||||
selectedDirentList: [],
|
||||
lastSelectedIndex: null,
|
||||
});
|
||||
}));
|
||||
}
|
||||
};
|
||||
|
||||
onSelectedDirentListUpdate = (newSelectedDirentList, lastSelectedIndex = null) => {
|
||||
this.setState({
|
||||
direntList: this.state.direntList.map(dirent => {
|
||||
dirent.isSelected = newSelectedDirentList.some(selectedDirent => selectedDirent.name === dirent.name);
|
||||
return dirent;
|
||||
return new Dirent({
|
||||
...dirent,
|
||||
isSelected: newSelectedDirentList.some(
|
||||
selected => selected.name === dirent.name
|
||||
)
|
||||
});
|
||||
}),
|
||||
isDirentSelected: newSelectedDirentList.length > 0,
|
||||
selectedDirentList: newSelectedDirentList,
|
||||
|
Loading…
Reference in New Issue
Block a user