AdminMarkDownContainer.js 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. import { Container } from 'unstated';
  2. import loggerFactory from '@alias/logger';
  3. import { toastError } from '../util/apiNotification';
  4. const logger = loggerFactory('growi:services:AdminMarkdownContainer');
  5. /**
  6. * Service container for admin markdown setting page (MarkDownSetting.jsx)
  7. * @extends {Container} unstated Container
  8. */
  9. export default class AdminMarkDownContainer extends Container {
  10. constructor(appContainer) {
  11. super();
  12. this.appContainer = appContainer;
  13. this.state = {
  14. retrieveError: null,
  15. isEnabledLinebreaks: false,
  16. isEnabledLinebreaksInComments: false,
  17. pageBreakSeparator: 1,
  18. pageBreakCustomSeparator: '',
  19. isEnabledXss: false,
  20. xssOption: 1,
  21. tagWhiteList: '',
  22. attrWhiteList: '',
  23. };
  24. this.switchEnableXss = this.switchEnableXss.bind(this);
  25. }
  26. /**
  27. * Workaround for the mangling in production build to break constructor.name
  28. */
  29. static getClassName() {
  30. return 'AdminMarkDownContainer';
  31. }
  32. /**
  33. * retrieve markdown data
  34. */
  35. async retrieveMarkdownData() {
  36. try {
  37. const response = await this.appContainer.apiv3.get('/markdown-setting/');
  38. const { markdownParams } = response.data;
  39. this.setState({
  40. isEnabledLinebreaks: markdownParams.isEnabledLinebreaks,
  41. isEnabledLinebreaksInComments: markdownParams.isEnabledLinebreaksInComments,
  42. pageBreakSeparator: markdownParams.pageBreakSeparator,
  43. pageBreakCustomSeparator: markdownParams.pageBreakCustomSeparator || '',
  44. isEnabledXss: markdownParams.isEnabledXss,
  45. xssOption: markdownParams.xssOption,
  46. tagWhiteList: markdownParams.tagWhiteList || '',
  47. attrWhiteList: markdownParams.attrWhiteList || '',
  48. });
  49. }
  50. catch (err) {
  51. logger.error(err);
  52. toastError(new Error('Failed to fetch data'));
  53. }
  54. }
  55. /**
  56. * Switch PageBreakSeparator
  57. */
  58. switchPageBreakSeparator(pageBreakSeparator) {
  59. this.setState({ pageBreakSeparator });
  60. }
  61. /**
  62. * Set PageBreakCustomSeparator
  63. */
  64. setPageBreakCustomSeparator(pageBreakCustomSeparator) {
  65. this.setState({ pageBreakCustomSeparator });
  66. }
  67. /**
  68. * Switch enableXss
  69. */
  70. switchEnableXss() {
  71. if (this.state.isEnabledXss) {
  72. this.setState({ xssOption: null });
  73. }
  74. this.setState({ isEnabledXss: !this.state.isEnabledXss });
  75. }
  76. /**
  77. * Update LineBreak Setting
  78. */
  79. async updateLineBreakSetting() {
  80. const response = await this.appContainer.apiv3.put('/markdown-setting/lineBreak', {
  81. isEnabledLinebreaks: this.state.isEnabledLinebreaks,
  82. isEnabledLinebreaksInComments: this.state.isEnabledLinebreaksInComments,
  83. });
  84. return response;
  85. }
  86. /**
  87. * Update Xss Setting
  88. */
  89. async updateXssSetting() {
  90. let { tagWhiteList, attrWhiteList } = this.state;
  91. tagWhiteList = Array.isArray(tagWhiteList) ? tagWhiteList : tagWhiteList.split(',');
  92. attrWhiteList = Array.isArray(attrWhiteList) ? attrWhiteList : attrWhiteList.split(',');
  93. const response = await this.appContainer.apiv3.put('/markdown-setting/xss', {
  94. isEnabledXss: this.state.isEnabledXss,
  95. xssOption: this.state.xssOption,
  96. tagWhiteList,
  97. attrWhiteList,
  98. });
  99. return response;
  100. }
  101. /**
  102. * Update Presentation Setting
  103. */
  104. async updatePresentationSetting() {
  105. const response = await this.appContainer.apiv3.put('/markdown-setting/presentation', {
  106. pageBreakSeparator: this.state.pageBreakSeparator,
  107. pageBreakCustomSeparator: this.state.pageBreakCustomSeparator,
  108. });
  109. this.setState({
  110. pageBreakSeparator: response.data.presentationParams.pageBreakSeparator,
  111. pageBreakCustomSeparator: response.data.presentationParams.pageBreakCustomSeparator,
  112. });
  113. return response;
  114. }
  115. }