AdminMarkDownContainer.js 4.2 KB

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