1
0
mirror of https://github.com/haiwen/seahub.git synced 2025-09-21 19:37:28 +00:00
Files
seahub/frontend/src/pages/data-grid/app-main.js

188 lines
4.6 KiB
JavaScript
Raw Normal View History

import React from 'react';
2019-05-07 17:58:53 +08:00
import isHotkey from 'is-hotkey';
2019-04-26 07:16:01 +08:00
import ReactDataGrid from '@seafile/react-data-grid/';
2019-05-07 17:58:53 +08:00
import { Menu } from '@seafile/react-data-grid-addons';
import { seafileAPI } from '../../utils/seafile-api';
2019-04-26 07:16:01 +08:00
import ModalPortal from '../../components/modal-portal';
import NewColumnDialog from './new-column-dialog';
2019-05-07 17:58:53 +08:00
import GridHeaderContextMenu from './grid-header-contextmenu';
import GridContentContextMenu from './grid-content-contextmenu';
2019-05-06 14:47:20 +08:00
import DTableStore from './store/dtable-store';
2019-06-03 17:21:19 +08:00
const { workspaceID, fileName } = window.app.pageOptions;
2019-05-07 17:58:53 +08:00
const DEFAULT_DATA = {
columns: [
{
key: 'name',
name: 'Name',
type: '',
width: 80,
editable: true,
resizable: true
}
],
rows: [{name: 'name_' + 0}]
}
class AppMain extends React.Component {
constructor(props, context) {
super(props, context);
this.state = {
2019-05-07 17:58:53 +08:00
value: null,
2019-04-26 07:16:01 +08:00
isNewColumnDialogShow: false,
};
2019-05-07 17:58:53 +08:00
this.dTableStore = new DTableStore();
}
componentDidMount() {
2019-06-03 17:21:19 +08:00
seafileAPI.getTableDownloadLink(workspaceID, fileName).then(res => {
2019-05-07 17:58:53 +08:00
let url = res.data;
seafileAPI.getFileContent(url).then(res => {
let data = res.data ? res.data : JSON.stringify(DEFAULT_DATA);
let value = this.dTableStore.deseralizeGridData(data);
this.setState({value});
});
});
2019-05-07 17:58:53 +08:00
document.addEventListener('keydown', this.onHotKey);
}
componentWillUnmount() {
document.removeEventListener('keydown', this.onHotKey);
}
getRowAt = (index) => {
if (index < 0 || index > this.getSize()) {
return undefined;
}
2019-05-07 17:58:53 +08:00
return this.state.value.rows[index];
};
getSize = () => {
2019-05-07 17:58:53 +08:00
return this.state.value.rows.length;
};
onInsertRow = () => {
2019-05-07 17:58:53 +08:00
let newRowIndex = this.getSize();
2019-05-07 17:58:53 +08:00
let value = this.dTableStore.insertRow(newRowIndex);
this.setState({value});
this.props.onContentChanged();
}
onInsertColumn = () => {
2019-04-26 07:16:01 +08:00
this.setState({isNewColumnDialogShow: true});
}
onNewColumn = (columnName, columnType) => {
2019-05-07 17:58:53 +08:00
let idx = this.state.value.columns.length;
let value = this.dTableStore.insertColumn(idx, columnName, columnType);
this.setState({value});
2019-04-26 07:16:01 +08:00
this.onNewColumnCancel();
2019-05-07 17:58:53 +08:00
this.props.onContentChanged();
2019-04-26 07:16:01 +08:00
}
onNewColumnCancel = () => {
this.setState({isNewColumnDialogShow: false});
2019-05-07 17:58:53 +08:00
this.props.onContentChanged();
2019-04-26 07:16:01 +08:00
}
onRowDelete = (e, data) => {
2019-05-07 17:58:53 +08:00
2019-04-26 07:16:01 +08:00
let { rowIdx } = data;
2019-05-07 17:58:53 +08:00
let value = this.dTableStore.deleteRow(rowIdx);
this.setState({value});
this.props.onContentChanged();
2019-04-26 07:16:01 +08:00
}
onColumnDelete = (e, data) => {
2019-05-07 17:58:53 +08:00
2019-04-26 07:16:01 +08:00
let column = data.column;
2019-05-06 14:36:47 +08:00
let idx = column.idx - 1;
2019-05-07 17:58:53 +08:00
let value = this.dTableStore.deleteColumn(idx);
this.setState({value});
2019-05-07 17:58:53 +08:00
this.props.onContentChanged();
}
2019-05-07 17:58:53 +08:00
onColumnResize = (index, width) => {
let idx = index - 1;
let value = this.dTableStore.resizeColumn(idx, width);
this.setState({value});
2019-05-06 14:36:47 +08:00
2019-05-07 17:58:53 +08:00
this.props.onContentChanged();
2019-04-26 07:16:01 +08:00
}
2019-05-07 21:15:37 +08:00
handleGridRowsUpdated = ({fromRow, updated}) => {
2019-05-07 17:58:53 +08:00
let rowIdx = fromRow;
2019-05-07 21:15:37 +08:00
let value = this.dTableStore.modifyCell(rowIdx, updated);
2019-05-07 17:58:53 +08:00
this.setState({value});
2019-05-07 17:58:53 +08:00
this.props.onContentChanged();
}
2019-04-26 07:16:01 +08:00
2019-05-07 17:58:53 +08:00
serializeGridData = () => {
return this.dTableStore.serializeGridData();
2019-04-26 07:16:01 +08:00
}
onHotKey = (event) => {
if (isHotkey('mod+s', event)) {
event.preventDefault();
this.props.onSave();
return true;
}
}
render() {
2019-05-07 17:58:53 +08:00
if (!this.state.value) {
return '';
}
return (
<div id="main">
<ReactDataGrid
ref={ node => this.grid = node }
enableCellSelect={true}
2019-05-07 17:58:53 +08:00
columns={this.state.value.columns}
rowGetter={this.getRowAt}
rowsCount={this.getSize()}
onGridRowsUpdated={this.handleGridRowsUpdated}
enableRowSelect={true}
rowHeight={50}
2019-04-29 10:17:43 +08:00
minHeight={500}
rowScrollTimeout={200}
enableInsertColumn={true}
enableInsertRow={true}
onInsertRow={this.onInsertRow}
onInsertColumn={this.onInsertColumn}
2019-04-26 07:16:01 +08:00
RowsContainer={Menu.ContextMenuTrigger}
headerContextMenu={<GridHeaderContextMenu id="grid-header-contxtmenu" onColumnDelete={this.onColumnDelete} />}
contextMenu={<GridContentContextMenu id="grid-content-contxtmenu" onRowDelete={this.onRowDelete} />}
onColumnResize={this.onColumnResize}
/>
2019-04-26 07:16:01 +08:00
{this.state.isNewColumnDialogShow && (
<ModalPortal>
<NewColumnDialog
onNewColumnCancel={this.onNewColumnCancel}
onNewColumn={this.onNewColumn}
/>
</ModalPortal>
)}
</div>
);
}
}
export default AppMain;