WorkspaceListItem.jsx 5.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. import React from 'react'
  2. // import classnames from 'classnames'
  3. import PropTypes from 'prop-types'
  4. import AnimateHeight from 'react-animate-height'
  5. const pad = number => {
  6. number = number.toString()
  7. return number.length < 2 ? pad('0' + number, 2) : number
  8. }
  9. const WorkspaceListItem = props => {
  10. return (
  11. <li className='sidebar__navigation__workspace__item'>
  12. <div className='sidebar__navigation__workspace__item__wrapper' onClick={props.onClickTitle}>
  13. <div className='sidebar__navigation__workspace__item__number'>
  14. {pad(props.number)}
  15. </div>
  16. <div className='sidebar__navigation__workspace__item__name' title={props.name}>
  17. {props.name}
  18. </div>
  19. <div className='sidebar__navigation__workspace__item__icon'>
  20. <i className='fa fa-chevron-down' />
  21. </div>
  22. </div>
  23. <AnimateHeight duration={500} height={props.isOpen ? 'auto' : 0}>
  24. <ul
  25. className='sidebar__navigation__workspace__item__submenu'
  26. id={`sidebarSubMenu_${props.number}`}
  27. >
  28. <li
  29. className='sidebar__navigation__workspace__item__submenu__dropdown'
  30. onClick={() => props.onClickAllContent(props.wsId)}
  31. >
  32. <div className='dropdown__icon'>
  33. <i className='fa fa-th' />
  34. </div>
  35. <div className='sidebar__navigation__workspace__item__submenu__dropdown__showdropdown'>
  36. <div className='dropdown__title'>
  37. <div className='dropdown__title__text'>
  38. Tous les fichiers
  39. </div>
  40. </div>
  41. </div>
  42. {/*
  43. <div className='dropdown__subdropdown dropdown-menu' aria-labelledby='navbarDropdown'>
  44. <div className='dropdown__subdropdown__item dropdown-item'>
  45. <div className='dropdown__subdropdown__item__iconfile alignname'>
  46. <i className='fa fa-file-text-o' />
  47. </div>
  48. <div className='dropdown__subdropdown__item__textfile alignname'>
  49. Documents Archivés
  50. </div>
  51. </div>
  52. <div className='dropdown__subdropdown__item dropdown-item'>
  53. <div className='dropdown__subdropdown__item__iconfile alignname'>
  54. <i className='fa fa-file-text-o' />
  55. </div>
  56. <div className='dropdown__subdropdown__item__textfile alignname'>
  57. Documents Supprimés
  58. </div>
  59. </div>
  60. </div>
  61. */}
  62. </li>
  63. <li className='sidebar__navigation__workspace__item__submenu__dropdown'>
  64. <div className='dropdown__icon'>
  65. <i className='fa fa-signal dashboard-color' />
  66. </div>
  67. <div className='sidebar__navigation__workspace__item__submenu__dropdown__showdropdown'>
  68. <div className='dropdown__title'>
  69. <div className='dropdown__title__text'>
  70. Tableau de bord
  71. </div>
  72. </div>
  73. </div>
  74. </li>
  75. <li className='sidebar__navigation__workspace__item__submenu__dropdown'>
  76. <div className='dropdown__icon'>
  77. <i className='fa fa-list-ul task-color' />
  78. </div>
  79. <div className='sidebar__navigation__workspace__item__submenu__dropdown__showdropdown'>
  80. <div className='dropdown__title' id='navbarDropdown'>
  81. <div className='dropdown__title__text'>
  82. Liste de tâches
  83. </div>
  84. </div>
  85. </div>
  86. </li>
  87. <li className='sidebar__navigation__workspace__item__submenu__dropdown'>
  88. <div className='dropdown__icon'>
  89. <i className='fa fa-folder-o docandfile-color' />
  90. </div>
  91. <div
  92. className='sidebar__navigation__workspace__item__submenu__dropdown__showdropdown'
  93. aria-haspopup='true'
  94. aria-expanded='false'
  95. >
  96. <div className='dropdown__title' id='navbarDropdown'>
  97. <div className='dropdown__title__text'>
  98. Documents & fichiers
  99. </div>
  100. </div>
  101. </div>
  102. </li>
  103. <li className='sidebar__navigation__workspace__item__submenu__dropdown'>
  104. <div className='dropdown__icon'>
  105. <i className='fa fa-comments talk-color' />
  106. </div>
  107. <div
  108. className='sidebar__navigation__workspace__item__submenu__dropdown__showdropdown'
  109. aria-haspopup='true'
  110. aria-expanded='false'
  111. >
  112. <div className='dropdown__title' id='navbarDropdown'>
  113. <div className='dropdown__title__text'>
  114. Discussions
  115. </div>
  116. </div>
  117. </div>
  118. </li>
  119. <li className='sidebar__navigation__workspace__item__submenu__dropdown'>
  120. <div className='dropdown__icon'>
  121. <i className='fa fa-calendar calendar-color' />
  122. </div>
  123. <div
  124. className='sidebar__navigation__workspace__item__submenu__dropdown__showdropdown'
  125. aria-haspopup='true'
  126. aria-expanded='false'
  127. >
  128. <div className='dropdown__title' id='navbarDropdown'>
  129. <div className='dropdown__title__text'>
  130. Calendrier
  131. </div>
  132. </div>
  133. </div>
  134. </li>
  135. </ul>
  136. </AnimateHeight>
  137. </li>
  138. )
  139. }
  140. export default WorkspaceListItem
  141. WorkspaceListItem.propTypes = {
  142. number: PropTypes.number.isRequired,
  143. name: PropTypes.string.isRequired,
  144. onClickTitle: PropTypes.func,
  145. onClickAllContent: PropTypes.func,
  146. isOpen: PropTypes.bool
  147. }
  148. WorkspaceListItem.defaultProps = {
  149. onClickTitle: () => {},
  150. onClickAllContent: () => {},
  151. isOpen: false
  152. }