WorkspaceContent.jsx 2.8KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  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 PageWrapper from '../component/common/layout/PageWrapper.jsx'
  7. import PageTitle from '../component/common/layout/PageTitle.jsx'
  8. import PageContent from '../component/common/layout/PageContent.jsx'
  9. import DropdownCreateButton from '../component/common/Input/DropdownCreateButton.jsx'
  10. import {
  11. getAppList,
  12. getWorkspaceContent
  13. } from '../action-creator.async.js'
  14. // import appDatabase from '../app/index.js'
  15. class WorkspaceContent extends React.Component {
  16. constructor (props) {
  17. super(props)
  18. this.state = {
  19. activeFileType: ''
  20. }
  21. }
  22. componentDidMount () {
  23. this.props.dispatch(getWorkspaceContent(/* this.props.workspace.id */1))
  24. this.props.dispatch(getAppList())
  25. }
  26. handleClickContentItem = content => {
  27. const { workspace } = this.props
  28. GLOBAL_renderApp({
  29. workspace: {
  30. id: workspace.id,
  31. title: workspace.title
  32. },
  33. content,
  34. appConfig: {
  35. ...this.props.app[content.type],
  36. apiUrl: 'http://localhost:3001'
  37. }
  38. })
  39. }
  40. render () {
  41. const { workspace, app } = this.props
  42. // const AppContainer = (appDatabase.find(p => p.name === activeFileContent.type) || {container: '<div>unknow</div>'}).container
  43. return (
  44. <PageWrapper customeClass='workspace'>
  45. <PageTitle
  46. parentClass='workspace__header'
  47. customClass='justify-content-between'
  48. title={workspace.title}
  49. >
  50. <DropdownCreateButton parentClass='workspace__header__btnaddworkspace' />
  51. </PageTitle>
  52. <PageContent parentClass='workspace__content'>
  53. <div className='workspace__content__fileandfolder folder__content active'>
  54. <FileItemHeader />
  55. { workspace.content.map(c => c.type === 'folder'
  56. ? <Folder app={app} folderData={c} key={c.id} />
  57. : (
  58. <FileItem
  59. name={c.title}
  60. type={c.type}
  61. icon={(app[c.type] || {icon: ''}).icon}
  62. status={c.status}
  63. onClickItem={() => this.handleClickContentItem(c)}
  64. key={c.id}
  65. />
  66. )
  67. )}
  68. </div>
  69. <DropdownCreateButton customClass='workspace__content__button mb-5' />
  70. <div id='appContainer'>
  71. {/* activeFileContent.display && <AppContainer /> */}
  72. </div>
  73. </PageContent>
  74. </PageWrapper>
  75. )
  76. }
  77. }
  78. const mapStateToProps = ({ workspace, activeFileContent, app }) => ({ workspace, activeFileContent, app })
  79. export default connect(mapStateToProps)(WorkspaceContent)