WorkspaceContent.jsx 2.3KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. import React from 'react'
  2. import { connect } from 'react-redux'
  3. import Folder from '../component/Workspace/Folder.jsx'
  4. import FileItem from '../component/Workspace/FileItem.jsx'
  5. import FileItemHeader from '../component/Workspace/FileItemHeader.jsx'
  6. // import Thread from './FileType/Thread.jsx'
  7. import PageHtml from './FileType/PageHtml.jsx'
  8. import PageWrapper from '../component/common/layout/PageWrapper.jsx'
  9. import PageTitle from '../component/common/layout/PageTitle.jsx'
  10. import PageContent from '../component/common/layout/PageContent.jsx'
  11. import DropdownCreateButton from '../component/common/Input/DropdownCreateButton.jsx'
  12. import { getWorkspaceContent } from '../action-creator.async.js'
  13. class WorkspaceContent extends React.Component {
  14. constructor (props) {
  15. super(props)
  16. this.state = {
  17. activeFileType: ''
  18. }
  19. }
  20. componentDidMount () {
  21. this.props.dispatch(getWorkspaceContent(/* this.props.workspace.id */1))
  22. }
  23. render () {
  24. const { workspace } = this.props
  25. return (
  26. <PageWrapper customeClass='workspace'>
  27. <PageTitle
  28. parentClass='workspace__header'
  29. customClass='justify-content-between'
  30. title={workspace.title}
  31. >
  32. <DropdownCreateButton parentClass='workspace__header__btnaddworkspace' />
  33. </PageTitle>
  34. <PageContent parentClass='workspace__content'>
  35. <div className='workspace__content__fileandfolder folder__content active'>
  36. <FileItemHeader />
  37. { workspace.content.map(c => c.type === 'folder'
  38. ? <Folder folderData={c} key={c.id} />
  39. : (
  40. <FileItem
  41. name={c.title}
  42. type={c.type}
  43. status={c.status}
  44. onClickItem={() => this.setState({activeFileType: 'file'})}
  45. key={c.id}
  46. />
  47. )
  48. )}
  49. </div>
  50. <DropdownCreateButton customClass='workspace__content__button mb-5' />
  51. <PageHtml visible={this.state.activeFileType === 'file'} />
  52. {/*
  53. <Thread visible={this.state.activeFileType === 'chat'} />
  54. */}
  55. </PageContent>
  56. </PageWrapper>
  57. )
  58. }
  59. }
  60. const mapStateToProps = ({ workspace }) => ({ workspace })
  61. export default connect(mapStateToProps)(WorkspaceContent)