CustomizeLayoutForm.jsx 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. import React from 'react';
  2. import PropTypes from 'prop-types';
  3. import { withTranslation } from 'react-i18next';
  4. import { createSubscribedElement } from '../../UnstatedUtils';
  5. import AppContainer from '../../../services/AppContainer';
  6. import AdminCustomizeContainer from '../../../services/AdminCustomizeContainer';
  7. class CustomizeLayoutForm extends React.Component {
  8. growiLayout() {
  9. const { adminCustomizeContainer } = this.props;
  10. return (
  11. <div className="col-sm-4">
  12. <h4>
  13. <div className="radio radio-primary">
  14. <input
  15. type="radio"
  16. id="radioLayoutGrowi"
  17. checked={adminCustomizeContainer.state.layoutType === 'growi'}
  18. onChange={() => adminCustomizeContainer.switchLayoutType('growi')}
  19. />
  20. <label htmlFor="radioLayoutGrowi">
  21. GROWI Enhanced Layout <small className="text-success">(Recommended)</small>
  22. </label>
  23. </div>
  24. </h4>
  25. <a href="/images/admin/customize/layout-crowi-plus.gif" className="ss-container">
  26. <img src="/images/admin/customize/layout-crowi-plus-thumb.gif" width="240px" />
  27. </a>
  28. <h4>Simple and Clear</h4>
  29. <ul>
  30. {/* TODO i18n */}
  31. <li>Full screen layout and thin margins/paddings</li>
  32. <li>Show and post comments at the bottom of the page</li>
  33. <li>Affix Table-of-contents</li>
  34. </ul>
  35. </div>
  36. );
  37. }
  38. kibelaLayout() {
  39. const { adminCustomizeContainer } = this.props;
  40. return (
  41. <div className="col-sm-4">
  42. <h4>
  43. <div className="radio radio-primary">
  44. <input
  45. type="radio"
  46. id="radioLayoutKibela"
  47. checked={adminCustomizeContainer.state.layoutType === 'kibela'}
  48. onChange={() => adminCustomizeContainer.switchLayoutType('kibela')}
  49. />
  50. <label htmlFor="radioLayoutKibela">
  51. Kibela Like Layout
  52. </label>
  53. </div>
  54. </h4>
  55. <a href="/images/admin/customize/layout-kibela.gif" className="ss-container">
  56. <img src="/images/admin/customize/layout-kibela-thumb.gif" width="240px" />
  57. </a>
  58. <h4>Easy Viewing Structure</h4>
  59. <ul>
  60. {/* TODO i18n */}
  61. <li>Center aligned contents</li>
  62. <li>Show and post comments at the bottom of the page</li>
  63. <li>Affix Table-of-contents</li>
  64. </ul>
  65. </div>
  66. );
  67. }
  68. classicLayout() {
  69. const { adminCustomizeContainer } = this.props;
  70. return (
  71. <div className="col-sm-4">
  72. <h4>
  73. <div className="radio radio-primary">
  74. <input
  75. type="radio"
  76. id="radioLayoutCrowi"
  77. checked={adminCustomizeContainer.state.layoutType === 'crowi'}
  78. onChange={() => adminCustomizeContainer.switchLayoutType('crowi')}
  79. />
  80. <label htmlFor="radioLayoutCrowi">
  81. Crowi Classic Layout
  82. </label>
  83. </div>
  84. </h4>
  85. <a href="/images/admin/customize/layout-classic.gif" className="ss-container">
  86. <img src="/images/admin/customize/layout-classic-thumb.gif" width="240px" />
  87. </a>
  88. <h4>Separated Functions</h4>
  89. <ul>
  90. {/* TODO i18n */}
  91. <li>Collapsible Sidebar</li>
  92. <li>Show and post comments in Sidebar</li>
  93. <li>Collapsible Table-of-contents</li>
  94. </ul>
  95. </div>
  96. );
  97. }
  98. render() {
  99. return (
  100. <form>
  101. {this.growiLayout()}
  102. {this.kibelaLayout()}
  103. {this.classicLayout()}
  104. </form>
  105. );
  106. }
  107. }
  108. const CustomizeLayoutFormWrapper = (props) => {
  109. return createSubscribedElement(CustomizeLayoutForm, props, [AppContainer, AdminCustomizeContainer]);
  110. };
  111. CustomizeLayoutForm.propTypes = {
  112. t: PropTypes.func.isRequired, // i18next
  113. appContainer: PropTypes.instanceOf(AppContainer).isRequired,
  114. adminCustomizeContainer: PropTypes.instanceOf(AdminCustomizeContainer).isRequired,
  115. };
  116. export default withTranslation()(CustomizeLayoutFormWrapper);