\n *\n * @extends {Container} unstated Container\n */\n\nclass CommentContainer extends unstated__WEBPACK_IMPORTED_MODULE_0__[\"Container\"] {\n constructor(appContainer) {\n super();\n this.appContainer = appContainer;\n this.appContainer.registerContainer(this);\n const mainContent = document.querySelector('#content-main');\n\n if (mainContent == null) {\n logger.debug('#content-main element is not exists');\n return;\n }\n\n this.state = {\n comments: [],\n // settings shared among all of CommentEditor\n isSlackEnabled: false,\n slackChannels: mainContent.getAttribute('data-slack-channels') || ''\n };\n this.retrieveComments = this.retrieveComments.bind(this);\n this.checkAndUpdateImageOfCommentAuthers = this.checkAndUpdateImageOfCommentAuthers.bind(this);\n }\n /**\n * Workaround for the mangling in production build to break constructor.name\n */\n\n\n static getClassName() {\n return 'CommentContainer';\n }\n\n getPageContainer() {\n return this.appContainer.getContainer('PageContainer');\n }\n\n findAndSplice(comment) {\n const comments = this.state.comments;\n const index = comments.indexOf(comment);\n\n if (index < 0) {\n return;\n }\n\n comments.splice(index, 1);\n this.setState({\n comments\n });\n }\n /**\n * Load data of comments and store them in state\n */\n\n\n async retrieveComments() {\n const {\n pageId\n } = this.getPageContainer().state; // get data (desc order array)\n\n const res = await this.appContainer.apiGet('/comments.get', {\n page_id: pageId\n });\n\n if (res.ok) {\n const comments = res.comments;\n this.setState({\n comments\n });\n this.checkAndUpdateImageOfCommentAuthers(comments);\n }\n }\n\n async checkAndUpdateImageOfCommentAuthers(comments) {\n const noImageCacheUserIds = comments.filter(comment => {\n const {\n creator\n } = comment;\n return creator != null && creator.imageUrlCached == null;\n }).map(comment => {\n return comment.creator._id;\n });\n\n if (noImageCacheUserIds.length === 0) {\n return;\n }\n\n try {\n await this.appContainer.apiv3Put('/users/update.imageUrlCache', {\n userIds: noImageCacheUserIds\n });\n } catch (err) {\n // Error alert doesn't apear, because user don't need to notice this error.\n logger.error(err);\n }\n }\n /**\n * Load data of comments and rerender \n */\n\n\n postComment(comment, isMarkdown, replyTo, isSlackEnabled, slackChannels) {\n const {\n pageId,\n revisionId\n } = this.getPageContainer().state;\n return this.appContainer.apiPost('/comments.add', {\n commentForm: {\n comment,\n page_id: pageId,\n revision_id: revisionId,\n is_markdown: isMarkdown,\n replyTo\n },\n slackNotificationForm: {\n isSlackEnabled,\n slackChannels\n }\n }).then(res => {\n if (res.ok) {\n return this.retrieveComments();\n }\n });\n }\n /**\n * Load data of comments and rerender \n */\n\n\n putComment(comment, isMarkdown, commentId, author) {\n const {\n pageId,\n revisionId\n } = this.getPageContainer().state;\n return this.appContainer.apiPost('/comments.update', {\n commentForm: {\n comment,\n page_id: pageId,\n revision_id: revisionId,\n is_markdown: isMarkdown,\n comment_id: commentId,\n author\n }\n }).then(res => {\n if (res.ok) {\n return this.retrieveComments();\n }\n });\n }\n\n deleteComment(comment) {\n return this.appContainer.apiPost('/comments.remove', {\n comment_id: comment._id\n }).then(res => {\n if (res.ok) {\n this.findAndSplice(comment);\n }\n });\n }\n\n uploadAttachment(file) {\n const {\n pageId,\n pagePath\n } = this.getPageContainer().state;\n const endpoint = '/attachments.add';\n const formData = new FormData();\n formData.append('_csrf', this.appContainer.csrfToken);\n formData.append('file', file);\n formData.append('path', pagePath);\n formData.append('page_id', pageId);\n return this.appContainer.apiPost(endpoint, formData);\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvY2xpZW50L2pzL3NlcnZpY2VzL0NvbW1lbnRDb250YWluZXIuanMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvY2xpZW50L2pzL3NlcnZpY2VzL0NvbW1lbnRDb250YWluZXIuanM/N2FhZCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb250YWluZXIgfSBmcm9tICd1bnN0YXRlZCc7XG5cbmltcG9ydCBsb2dnZXJGYWN0b3J5IGZyb20gJ0BhbGlhcy9sb2dnZXInO1xuXG5jb25zdCBsb2dnZXIgPSBsb2dnZXJGYWN0b3J5KCdncm93aTpzZXJ2aWNlczpDb21tZW50Q29udGFpbmVyJyk7XG5cbi8qKlxuICpcbiAqIEBhdXRob3IgWXVraSBUYWtlaSA8eXVraUB3ZXNlZWsuY28uanA+XG4gKlxuICogQGV4dGVuZHMge0NvbnRhaW5lcn0gdW5zdGF0ZWQgQ29udGFpbmVyXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENvbW1lbnRDb250YWluZXIgZXh0ZW5kcyBDb250YWluZXIge1xuXG4gIGNvbnN0cnVjdG9yKGFwcENvbnRhaW5lcikge1xuICAgIHN1cGVyKCk7XG5cbiAgICB0aGlzLmFwcENvbnRhaW5lciA9IGFwcENvbnRhaW5lcjtcbiAgICB0aGlzLmFwcENvbnRhaW5lci5yZWdpc3RlckNvbnRhaW5lcih0aGlzKTtcblxuICAgIGNvbnN0IG1haW5Db250ZW50ID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvcignI2NvbnRlbnQtbWFpbicpO1xuXG4gICAgaWYgKG1haW5Db250ZW50ID09IG51bGwpIHtcbiAgICAgIGxvZ2dlci5kZWJ1ZygnI2NvbnRlbnQtbWFpbiBlbGVtZW50IGlzIG5vdCBleGlzdHMnKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICB0aGlzLnN0YXRlID0ge1xuICAgICAgY29tbWVudHM6IFtdLFxuXG4gICAgICAvLyBzZXR0aW5ncyBzaGFyZWQgYW1vbmcgYWxsIG9mIENvbW1lbnRFZGl0b3JcbiAgICAgIGlzU2xhY2tFbmFibGVkOiBmYWxzZSxcbiAgICAgIHNsYWNrQ2hhbm5lbHM6IG1haW5Db250ZW50LmdldEF0dHJpYnV0ZSgnZGF0YS1zbGFjay1jaGFubmVscycpIHx8ICcnLFxuICAgIH07XG5cbiAgICB0aGlzLnJldHJpZXZlQ29tbWVudHMgPSB0aGlzLnJldHJpZXZlQ29tbWVudHMuYmluZCh0aGlzKTtcbiAgICB0aGlzLmNoZWNrQW5kVXBkYXRlSW1hZ2VPZkNvbW1lbnRBdXRoZXJzID0gdGhpcy5jaGVja0FuZFVwZGF0ZUltYWdlT2ZDb21tZW50QXV0aGVycy5iaW5kKHRoaXMpO1xuICB9XG5cbiAgLyoqXG4gICAqIFdvcmthcm91bmQgZm9yIHRoZSBtYW5nbGluZyBpbiBwcm9kdWN0aW9uIGJ1aWxkIHRvIGJyZWFrIGNvbnN0cnVjdG9yLm5hbWVcbiAgICovXG4gIHN0YXRpYyBnZXRDbGFzc05hbWUoKSB7XG4gICAgcmV0dXJuICdDb21tZW50Q29udGFpbmVyJztcbiAgfVxuXG4gIGdldFBhZ2VDb250YWluZXIoKSB7XG4gICAgcmV0dXJuIHRoaXMuYXBwQ29udGFpbmVyLmdldENvbnRhaW5lcignUGFnZUNvbnRhaW5lcicpO1xuICB9XG5cbiAgZmluZEFuZFNwbGljZShjb21tZW50KSB7XG4gICAgY29uc3QgY29tbWVudHMgPSB0aGlzLnN0YXRlLmNvbW1lbnRzO1xuXG4gICAgY29uc3QgaW5kZXggPSBjb21tZW50cy5pbmRleE9mKGNvbW1lbnQpO1xuICAgIGlmIChpbmRleCA8IDApIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgY29tbWVudHMuc3BsaWNlKGluZGV4LCAxKTtcblxuICAgIHRoaXMuc2V0U3RhdGUoeyBjb21tZW50cyB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBMb2FkIGRhdGEgb2YgY29tbWVudHMgYW5kIHN0b3JlIHRoZW0gaW4gc3RhdGVcbiAgICovXG4gIGFzeW5jIHJldHJpZXZlQ29tbWVudHMoKSB7XG4gICAgY29uc3QgeyBwYWdlSWQgfSA9IHRoaXMuZ2V0UGFnZUNvbnRhaW5lcigpLnN0YXRlO1xuXG4gICAgLy8gZ2V0IGRhdGEgKGRlc2Mgb3JkZXIgYXJyYXkpXG4gICAgY29uc3QgcmVzID0gYXdhaXQgdGhpcy5hcHBDb250YWluZXIuYXBpR2V0KCcvY29tbWVudHMuZ2V0JywgeyBwYWdlX2lkOiBwYWdlSWQgfSk7XG4gICAgaWYgKHJlcy5vaykge1xuICAgICAgY29uc3QgY29tbWVudHMgPSByZXMuY29tbWVudHM7XG4gICAgICB0aGlzLnNldFN0YXRlKHsgY29tbWVudHMgfSk7XG5cbiAgICAgIHRoaXMuY2hlY2tBbmRVcGRhdGVJbWFnZU9mQ29tbWVudEF1dGhlcnMoY29tbWVudHMpO1xuICAgIH1cbiAgfVxuXG4gIGFzeW5jIGNoZWNrQW5kVXBkYXRlSW1hZ2VPZkNvbW1lbnRBdXRoZXJzKGNvbW1lbnRzKSB7XG4gICAgY29uc3Qgbm9JbWFnZUNhY2hlVXNlcklkcyA9IGNvbW1lbnRzLmZpbHRlcigoY29tbWVudCkgPT4ge1xuICAgICAgY29uc3QgeyBjcmVhdG9yIH0gPSBjb21tZW50O1xuICAgICAgcmV0dXJuIGNyZWF0b3IgIT0gbnVsbCAmJiBjcmVhdG9yLmltYWdlVXJsQ2FjaGVkID09IG51bGw7XG4gICAgfSkubWFwKChjb21tZW50KSA9PiB7XG4gICAgICByZXR1cm4gY29tbWVudC5jcmVhdG9yLl9pZDtcbiAgICB9KTtcblxuICAgIGlmIChub0ltYWdlQ2FjaGVVc2VySWRzLmxlbmd0aCA9PT0gMCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHRyeSB7XG4gICAgICBhd2FpdCB0aGlzLmFwcENvbnRhaW5lci5hcGl2M1B1dCgnL3VzZXJzL3VwZGF0ZS5pbWFnZVVybENhY2hlJywgeyB1c2VySWRzOiBub0ltYWdlQ2FjaGVVc2VySWRzIH0pO1xuICAgIH1cbiAgICBjYXRjaCAoZXJyKSB7XG4gICAgICAvLyBFcnJvciBhbGVydCBkb2Vzbid0IGFwZWFyLCBiZWNhdXNlIHVzZXIgZG9uJ3QgbmVlZCB0byBub3RpY2UgdGhpcyBlcnJvci5cbiAgICAgIGxvZ2dlci5lcnJvcihlcnIpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBMb2FkIGRhdGEgb2YgY29tbWVudHMgYW5kIHJlcmVuZGVyIDxQYWdlQ29tbWVudHMgLz5cbiAgICovXG4gIHBvc3RDb21tZW50KGNvbW1lbnQsIGlzTWFya2Rvd24sIHJlcGx5VG8sIGlzU2xhY2tFbmFibGVkLCBzbGFja0NoYW5uZWxzKSB7XG4gICAgY29uc3QgeyBwYWdlSWQsIHJldmlzaW9uSWQgfSA9IHRoaXMuZ2V0UGFnZUNvbnRhaW5lcigpLnN0YXRlO1xuXG4gICAgcmV0dXJuIHRoaXMuYXBwQ29udGFpbmVyLmFwaVBvc3QoJy9jb21tZW50cy5hZGQnLCB7XG4gICAgICBjb21tZW50Rm9ybToge1xuICAgICAgICBjb21tZW50LFxuICAgICAgICBwYWdlX2lkOiBwYWdlSWQsXG4gICAgICAgIHJldmlzaW9uX2lkOiByZXZpc2lvbklkLFxuICAgICAgICBpc19tYXJrZG93bjogaXNNYXJrZG93bixcbiAgICAgICAgcmVwbHlUbyxcbiAgICAgIH0sXG4gICAgICBzbGFja05vdGlmaWNhdGlvbkZvcm06IHtcbiAgICAgICAgaXNTbGFja0VuYWJsZWQsXG4gICAgICAgIHNsYWNrQ2hhbm5lbHMsXG4gICAgICB9LFxuICAgIH0pXG4gICAgICAudGhlbigocmVzKSA9PiB7XG4gICAgICAgIGlmIChyZXMub2spIHtcbiAgICAgICAgICByZXR1cm4gdGhpcy5yZXRyaWV2ZUNvbW1lbnRzKCk7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIExvYWQgZGF0YSBvZiBjb21tZW50cyBhbmQgcmVyZW5kZXIgPFBhZ2VDb21tZW50cyAvPlxuICAgKi9cbiAgcHV0Q29tbWVudChjb21tZW50LCBpc01hcmtkb3duLCBjb21tZW50SWQsIGF1dGhvcikge1xuICAgIGNvbnN0IHsgcGFnZUlkLCByZXZpc2lvbklkIH0gPSB0aGlzLmdldFBhZ2VDb250YWluZXIoKS5zdGF0ZTtcblxuICAgIHJldHVybiB0aGlzLmFwcENvbnRhaW5lci5hcGlQb3N0KCcvY29tbWVudHMudXBkYXRlJywge1xuICAgICAgY29tbWVudEZvcm06IHtcbiAgICAgICAgY29tbWVudCxcbiAgICAgICAgcGFnZV9pZDogcGFnZUlkLFxuICAgICAgICByZXZpc2lvbl9pZDogcmV2aXNpb25JZCxcbiAgICAgICAgaXNfbWFya2Rvd246IGlzTWFya2Rvd24sXG4gICAgICAgIGNvbW1lbnRfaWQ6IGNvbW1lbnRJZCxcbiAgICAgICAgYXV0aG9yLFxuICAgICAgfSxcbiAgICB9KVxuICAgICAgLnRoZW4oKHJlcykgPT4ge1xuICAgICAgICBpZiAocmVzLm9rKSB7XG4gICAgICAgICAgcmV0dXJuIHRoaXMucmV0cmlldmVDb21tZW50cygpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgfVxuXG4gIGRlbGV0ZUNvbW1lbnQoY29tbWVudCkge1xuICAgIHJldHVybiB0aGlzLmFwcENvbnRhaW5lci5hcGlQb3N0KCcvY29tbWVudHMucmVtb3ZlJywgeyBjb21tZW50X2lkOiBjb21tZW50Ll9pZCB9KVxuICAgICAgLnRoZW4oKHJlcykgPT4ge1xuICAgICAgICBpZiAocmVzLm9rKSB7XG4gICAgICAgICAgdGhpcy5maW5kQW5kU3BsaWNlKGNvbW1lbnQpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgfVxuXG4gIHVwbG9hZEF0dGFjaG1lbnQoZmlsZSkge1xuICAgIGNvbnN0IHsgcGFnZUlkLCBwYWdlUGF0aCB9ID0gdGhpcy5nZXRQYWdlQ29udGFpbmVyKCkuc3RhdGU7XG5cbiAgICBjb25zdCBlbmRwb2ludCA9ICcvYXR0YWNobWVudHMuYWRkJztcbiAgICBjb25zdCBmb3JtRGF0YSA9IG5ldyBGb3JtRGF0YSgpO1xuICAgIGZvcm1EYXRhLmFwcGVuZCgnX2NzcmYnLCB0aGlzLmFwcENvbnRhaW5lci5jc3JmVG9rZW4pO1xuICAgIGZvcm1EYXRhLmFwcGVuZCgnZmlsZScsIGZpbGUpO1xuICAgIGZvcm1EYXRhLmFwcGVuZCgncGF0aCcsIHBhZ2VQYXRoKTtcbiAgICBmb3JtRGF0YS5hcHBlbmQoJ3BhZ2VfaWQnLCBwYWdlSWQpO1xuXG4gICAgcmV0dXJuIHRoaXMuYXBwQ29udGFpbmVyLmFwaVBvc3QoZW5kcG9pbnQsIGZvcm1EYXRhKTtcbiAgfVxuXG59XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUVBO0FBRUE7QUFFQTs7Ozs7OztBQU1BO0FBRUE7QUFDQTtBQUVBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFMQTtBQVFBO0FBQ0E7QUFDQTtBQUVBOzs7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFFQTtBQUFBO0FBQUE7QUFDQTtBQUVBOzs7OztBQUdBO0FBQ0E7QUFBQTtBQUFBO0FBQ0E7QUFFQTtBQUFBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUFBO0FBQUE7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFBQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFFQTs7Ozs7QUFHQTtBQUNBO0FBQUE7QUFBQTtBQUFBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFMQTtBQU9BO0FBQ0E7QUFDQTtBQUZBO0FBUkE7QUFjQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7Ozs7O0FBR0E7QUFDQTtBQUFBO0FBQUE7QUFBQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFOQTtBQURBO0FBV0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQUE7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFBQTtBQUFBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBN0pBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/client/js/services/CommentContainer.js\n");
/***/ }),
/***/ "./src/client/js/services/EditorContainer.js":
/*!***************************************************!*\
!*** ./src/client/js/services/EditorContainer.js ***!
\***************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return EditorContainer; });\n/* harmony import */ var unstated__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! unstated */ \"./node_modules/unstated/lib/unstated.es.js\");\n/* harmony import */ var _alias_logger__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @alias/logger */ \"./src/lib/service/logger/index.js\");\n/* harmony import */ var _alias_logger__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_alias_logger__WEBPACK_IMPORTED_MODULE_1__);\n\n\nconst logger = _alias_logger__WEBPACK_IMPORTED_MODULE_1___default()('growi:services:EditorContainer');\n/**\n * Service container related to options for Editor/Preview\n * @extends {Container} unstated Container\n */\n\nclass EditorContainer extends unstated__WEBPACK_IMPORTED_MODULE_0__[\"Container\"] {\n constructor(appContainer, defaultEditorOptions, defaultPreviewOptions) {\n super();\n this.appContainer = appContainer;\n this.appContainer.registerContainer(this);\n const mainContent = document.querySelector('#content-main');\n\n if (mainContent == null) {\n logger.debug('#content-main element is not exists');\n return;\n }\n\n this.state = {\n tags: null,\n isSlackEnabled: false,\n slackChannels: mainContent.getAttribute('data-slack-channels') || '',\n grant: 1,\n // default: public\n grantGroupId: null,\n grantGroupName: null,\n editorOptions: {},\n previewOptions: {},\n indentSize: this.appContainer.config.adminPreferredIndentSize || 4\n };\n this.isSetBeforeunloadEventHandler = false;\n this.initStateGrant();\n this.initDrafts();\n this.initEditorOptions('editorOptions', 'editorOptions', defaultEditorOptions);\n this.initEditorOptions('previewOptions', 'previewOptions', defaultPreviewOptions);\n }\n /**\n * Workaround for the mangling in production build to break constructor.name\n */\n\n\n static getClassName() {\n return 'EditorContainer';\n }\n /**\n * initialize state for page permission\n */\n\n\n initStateGrant() {\n const mainContent = document.getElementById('content-main');\n\n if (mainContent == null) {\n logger.debug('#content-main element is not exists');\n return;\n }\n\n this.state.grant = +mainContent.getAttribute('data-page-grant');\n const grantGroupId = mainContent.getAttribute('data-page-grant-group');\n\n if (grantGroupId != null && grantGroupId.length > 0) {\n this.state.grantGroupId = grantGroupId;\n this.state.grantGroupName = mainContent.getAttribute('data-page-grant-group-name');\n }\n }\n /**\n * initialize state for drafts\n */\n\n\n initDrafts() {\n this.drafts = {}; // restore data from localStorage\n\n const contents = window.localStorage.drafts;\n\n if (contents != null) {\n try {\n this.drafts = JSON.parse(contents);\n } catch (e) {\n window.localStorage.removeItem('drafts');\n }\n }\n\n if (this.state.pageId == null) {\n const draft = this.findDraft(this.state.path);\n\n if (draft != null) {\n this.state.markdown = draft;\n }\n }\n }\n\n initEditorOptions(stateKey, localStorageKey, defaultOptions) {\n // load from localStorage\n const optsStr = window.localStorage[localStorageKey];\n let loadedOpts = {}; // JSON.parseparse\n\n if (optsStr != null) {\n try {\n loadedOpts = JSON.parse(optsStr);\n } catch (e) {\n this.localStorage.removeItem(localStorageKey);\n }\n } // set to state obj\n\n\n this.state[stateKey] = Object.assign(defaultOptions, loadedOpts);\n }\n\n saveOptsToLocalStorage() {\n window.localStorage.setItem('editorOptions', JSON.stringify(this.state.editorOptions));\n window.localStorage.setItem('previewOptions', JSON.stringify(this.state.previewOptions));\n }\n\n setCaretLine(line) {\n const pageEditor = this.appContainer.getComponentInstance('PageEditor');\n\n if (pageEditor != null) {\n pageEditor.setCaretLine(line);\n }\n }\n\n focusToEditor() {\n const pageEditor = this.appContainer.getComponentInstance('PageEditor');\n\n if (pageEditor != null) {\n pageEditor.focusToEditor();\n }\n }\n\n getCurrentOptionsToSave() {\n const opt = {\n isSlackEnabled: this.state.isSlackEnabled,\n slackChannels: this.state.slackChannels,\n grant: this.state.grant,\n pageTags: this.state.tags\n };\n\n if (this.state.grantGroupId != null) {\n opt.grantUserGroupId = this.state.grantGroupId;\n }\n\n return opt;\n } // See https://developer.mozilla.org/en-US/docs/Web/API/WindowEventHandlers/onbeforeunload#example\n\n\n showUnsavedWarning(e) {\n // Cancel the event\n e.preventDefault(); // display browser default message\n\n e.returnValue = '';\n return '';\n }\n\n disableUnsavedWarning() {\n window.removeEventListener('beforeunload', this.showUnsavedWarning);\n this.isSetBeforeunloadEventHandler = false;\n }\n\n enableUnsavedWarning() {\n if (!this.isSetBeforeunloadEventHandler) {\n window.addEventListener('beforeunload', this.showUnsavedWarning);\n this.isSetBeforeunloadEventHandler = true;\n }\n }\n\n clearDraft(path) {\n delete this.drafts[path];\n window.localStorage.setItem('drafts', JSON.stringify(this.drafts));\n }\n\n clearAllDrafts() {\n window.localStorage.removeItem('drafts');\n }\n\n saveDraft(path, body) {\n this.drafts[path] = body;\n window.localStorage.setItem('drafts', JSON.stringify(this.drafts));\n }\n\n findDraft(path) {\n if (this.drafts != null && this.drafts[path]) {\n return this.drafts[path];\n }\n\n return null;\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/client/js/services/EditorContainer.js.js","sources":["webpack:///./src/client/js/services/EditorContainer.js?090a"],"sourcesContent":["import { Container } from 'unstated';\n\nimport loggerFactory from '@alias/logger';\n\nconst logger = loggerFactory('growi:services:EditorContainer');\n\n/**\n * Service container related to options for Editor/Preview\n * @extends {Container} unstated Container\n */\nexport default class EditorContainer extends Container {\n\n  constructor(appContainer, defaultEditorOptions, defaultPreviewOptions) {\n    super();\n\n    this.appContainer = appContainer;\n    this.appContainer.registerContainer(this);\n\n    const mainContent = document.querySelector('#content-main');\n\n    if (mainContent == null) {\n      logger.debug('#content-main element is not exists');\n      return;\n    }\n\n    this.state = {\n      tags: null,\n\n      isSlackEnabled: false,\n      slackChannels: mainContent.getAttribute('data-slack-channels') || '',\n\n      grant: 1, // default: public\n      grantGroupId: null,\n      grantGroupName: null,\n\n      editorOptions: {},\n      previewOptions: {},\n      indentSize: this.appContainer.config.adminPreferredIndentSize || 4,\n    };\n\n    this.isSetBeforeunloadEventHandler = false;\n\n    this.initStateGrant();\n    this.initDrafts();\n\n    this.initEditorOptions('editorOptions', 'editorOptions', defaultEditorOptions);\n    this.initEditorOptions('previewOptions', 'previewOptions', defaultPreviewOptions);\n  }\n\n  /**\n   * Workaround for the mangling in production build to break constructor.name\n   */\n  static getClassName() {\n    return 'EditorContainer';\n  }\n\n  /**\n   * initialize state for page permission\n   */\n  initStateGrant() {\n    const mainContent = document.getElementById('content-main');\n\n    if (mainContent == null) {\n      logger.debug('#content-main element is not exists');\n      return;\n    }\n\n    this.state.grant = +mainContent.getAttribute('data-page-grant');\n\n    const grantGroupId = mainContent.getAttribute('data-page-grant-group');\n    if (grantGroupId != null && grantGroupId.length > 0) {\n      this.state.grantGroupId = grantGroupId;\n      this.state.grantGroupName = mainContent.getAttribute('data-page-grant-group-name');\n    }\n  }\n\n  /**\n   * initialize state for drafts\n   */\n  initDrafts() {\n    this.drafts = {};\n\n    // restore data from localStorage\n    const contents = window.localStorage.drafts;\n    if (contents != null) {\n      try {\n        this.drafts = JSON.parse(contents);\n      }\n      catch (e) {\n        window.localStorage.removeItem('drafts');\n      }\n    }\n\n    if (this.state.pageId == null) {\n      const draft = this.findDraft(this.state.path);\n      if (draft != null) {\n        this.state.markdown = draft;\n      }\n    }\n  }\n\n  initEditorOptions(stateKey, localStorageKey, defaultOptions) {\n    // load from localStorage\n    const optsStr = window.localStorage[localStorageKey];\n\n    let loadedOpts = {};\n    // JSON.parseparse\n    if (optsStr != null) {\n      try {\n        loadedOpts = JSON.parse(optsStr);\n      }\n      catch (e) {\n        this.localStorage.removeItem(localStorageKey);\n      }\n    }\n\n    // set to state obj\n    this.state[stateKey] = Object.assign(defaultOptions, loadedOpts);\n  }\n\n  saveOptsToLocalStorage() {\n    window.localStorage.setItem('editorOptions', JSON.stringify(this.state.editorOptions));\n    window.localStorage.setItem('previewOptions', JSON.stringify(this.state.previewOptions));\n  }\n\n  setCaretLine(line) {\n    const pageEditor = this.appContainer.getComponentInstance('PageEditor');\n    if (pageEditor != null) {\n      pageEditor.setCaretLine(line);\n    }\n  }\n\n  focusToEditor() {\n    const pageEditor = this.appContainer.getComponentInstance('PageEditor');\n    if (pageEditor != null) {\n      pageEditor.focusToEditor();\n    }\n  }\n\n  getCurrentOptionsToSave() {\n    const opt = {\n      isSlackEnabled: this.state.isSlackEnabled,\n      slackChannels: this.state.slackChannels,\n      grant: this.state.grant,\n      pageTags: this.state.tags,\n    };\n\n    if (this.state.grantGroupId != null) {\n      opt.grantUserGroupId = this.state.grantGroupId;\n    }\n\n    return opt;\n  }\n\n  // See https://developer.mozilla.org/en-US/docs/Web/API/WindowEventHandlers/onbeforeunload#example\n  showUnsavedWarning(e) {\n    // Cancel the event\n    e.preventDefault();\n    // display browser default message\n    e.returnValue = '';\n    return '';\n  }\n\n  disableUnsavedWarning() {\n    window.removeEventListener('beforeunload', this.showUnsavedWarning);\n    this.isSetBeforeunloadEventHandler = false;\n  }\n\n  enableUnsavedWarning() {\n    if (!this.isSetBeforeunloadEventHandler) {\n      window.addEventListener('beforeunload', this.showUnsavedWarning);\n      this.isSetBeforeunloadEventHandler = true;\n    }\n  }\n\n  clearDraft(path) {\n    delete this.drafts[path];\n    window.localStorage.setItem('drafts', JSON.stringify(this.drafts));\n  }\n\n  clearAllDrafts() {\n    window.localStorage.removeItem('drafts');\n  }\n\n  saveDraft(path, body) {\n    this.drafts[path] = body;\n    window.localStorage.setItem('drafts', JSON.stringify(this.drafts));\n  }\n\n  findDraft(path) {\n    if (this.drafts != null && this.drafts[path]) {\n      return this.drafts[path];\n    }\n\n    return null;\n  }\n\n}\n"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA;AAEA;AAEA;;;;;AAIA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAAA;AACA;AACA;AAEA;AACA;AACA;AAZA;AAeA;AAEA;AACA;AAEA;AACA;AACA;AAEA;;;;;AAGA;AACA;AACA;AAEA;;;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;;;;;AAGA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAJA;AACA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA1LA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/client/js/services/EditorContainer.js\n");
/***/ }),
/***/ "./src/client/js/services/PageAccessoriesContainer.js":
/*!************************************************************!*\
!*** ./src/client/js/services/PageAccessoriesContainer.js ***!
\************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return PageAccessoriesContainer; });\n/* harmony import */ var unstated__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! unstated */ \"./node_modules/unstated/lib/unstated.es.js\");\n\n/**\n * Service container related to options for Application\n * @extends {Container} unstated Container\n */\n\nclass PageAccessoriesContainer extends unstated__WEBPACK_IMPORTED_MODULE_0__[\"Container\"] {\n constructor(appContainer) {\n super();\n this.appContainer = appContainer;\n this.state = {\n isPageAccessoriesModalShown: false,\n activeTab: '',\n // Prevent unnecessary rendering\n activeComponents: new Set([''])\n };\n this.openPageAccessoriesModal = this.openPageAccessoriesModal.bind(this);\n this.closePageAccessoriesModal = this.closePageAccessoriesModal.bind(this);\n this.switchActiveTab = this.switchActiveTab.bind(this);\n }\n /**\n * Workaround for the mangling in production build to break constructor.name\n */\n\n\n static getClassName() {\n return 'PageAccessoriesContainer';\n }\n\n openPageAccessoriesModal(activeTab) {\n this.setState({\n isPageAccessoriesModalShown: true\n });\n this.switchActiveTab(activeTab);\n }\n\n closePageAccessoriesModal() {\n this.setState({\n isPageAccessoriesModalShown: false,\n activeTab: ''\n });\n }\n\n switchActiveTab(activeTab) {\n this.setState({\n activeTab,\n activeComponents: this.state.activeComponents.add(activeTab)\n });\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvY2xpZW50L2pzL3NlcnZpY2VzL1BhZ2VBY2Nlc3Nvcmllc0NvbnRhaW5lci5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9jbGllbnQvanMvc2VydmljZXMvUGFnZUFjY2Vzc29yaWVzQ29udGFpbmVyLmpzP2FjNGQiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29udGFpbmVyIH0gZnJvbSAndW5zdGF0ZWQnO1xuXG4vKipcbiAqIFNlcnZpY2UgY29udGFpbmVyIHJlbGF0ZWQgdG8gb3B0aW9ucyBmb3IgQXBwbGljYXRpb25cbiAqIEBleHRlbmRzIHtDb250YWluZXJ9IHVuc3RhdGVkIENvbnRhaW5lclxuICovXG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFBhZ2VBY2Nlc3Nvcmllc0NvbnRhaW5lciBleHRlbmRzIENvbnRhaW5lciB7XG5cbiAgY29uc3RydWN0b3IoYXBwQ29udGFpbmVyKSB7XG4gICAgc3VwZXIoKTtcblxuICAgIHRoaXMuYXBwQ29udGFpbmVyID0gYXBwQ29udGFpbmVyO1xuXG4gICAgdGhpcy5zdGF0ZSA9IHtcbiAgICAgIGlzUGFnZUFjY2Vzc29yaWVzTW9kYWxTaG93bjogZmFsc2UsXG4gICAgICBhY3RpdmVUYWI6ICcnLFxuICAgICAgLy8gUHJldmVudCB1bm5lY2Vzc2FyeSByZW5kZXJpbmdcbiAgICAgIGFjdGl2ZUNvbXBvbmVudHM6IG5ldyBTZXQoWycnXSksXG4gICAgfTtcbiAgICB0aGlzLm9wZW5QYWdlQWNjZXNzb3JpZXNNb2RhbCA9IHRoaXMub3BlblBhZ2VBY2Nlc3Nvcmllc01vZGFsLmJpbmQodGhpcyk7XG4gICAgdGhpcy5jbG9zZVBhZ2VBY2Nlc3Nvcmllc01vZGFsID0gdGhpcy5jbG9zZVBhZ2VBY2Nlc3Nvcmllc01vZGFsLmJpbmQodGhpcyk7XG4gICAgdGhpcy5zd2l0Y2hBY3RpdmVUYWIgPSB0aGlzLnN3aXRjaEFjdGl2ZVRhYi5iaW5kKHRoaXMpO1xuICB9XG5cbiAgLyoqXG4gICAqIFdvcmthcm91bmQgZm9yIHRoZSBtYW5nbGluZyBpbiBwcm9kdWN0aW9uIGJ1aWxkIHRvIGJyZWFrIGNvbnN0cnVjdG9yLm5hbWVcbiAgICovXG4gIHN0YXRpYyBnZXRDbGFzc05hbWUoKSB7XG4gICAgcmV0dXJuICdQYWdlQWNjZXNzb3JpZXNDb250YWluZXInO1xuICB9XG5cblxuICBvcGVuUGFnZUFjY2Vzc29yaWVzTW9kYWwoYWN0aXZlVGFiKSB7XG4gICAgdGhpcy5zZXRTdGF0ZSh7XG4gICAgICBpc1BhZ2VBY2Nlc3Nvcmllc01vZGFsU2hvd246IHRydWUsXG4gICAgfSk7XG4gICAgdGhpcy5zd2l0Y2hBY3RpdmVUYWIoYWN0aXZlVGFiKTtcbiAgfVxuXG4gIGNsb3NlUGFnZUFjY2Vzc29yaWVzTW9kYWwoKSB7XG4gICAgdGhpcy5zZXRTdGF0ZSh7XG4gICAgICBpc1BhZ2VBY2Nlc3Nvcmllc01vZGFsU2hvd246IGZhbHNlLFxuICAgICAgYWN0aXZlVGFiOiAnJyxcbiAgICB9KTtcbiAgfVxuXG4gIHN3aXRjaEFjdGl2ZVRhYihhY3RpdmVUYWIpIHtcbiAgICB0aGlzLnNldFN0YXRlKHtcbiAgICAgIGFjdGl2ZVRhYiwgYWN0aXZlQ29tcG9uZW50czogdGhpcy5zdGF0ZS5hY3RpdmVDb21wb25lbnRzLmFkZChhY3RpdmVUYWIpLFxuICAgIH0pO1xuICB9XG5cbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFFQTs7Ozs7QUFLQTtBQUVBO0FBQ0E7QUFFQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFKQTtBQU1BO0FBQ0E7QUFDQTtBQUNBO0FBRUE7Ozs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFEQTtBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFEQTtBQUdBO0FBQ0E7QUE3Q0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/client/js/services/PageAccessoriesContainer.js\n");
/***/ }),
/***/ "./src/client/js/services/PageContainer.js":
/*!*************************************************!*\
!*** ./src/client/js/services/PageContainer.js ***!
\*************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* WEBPACK VAR INJECTION */(function($) {/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return PageContainer; });\n/* harmony import */ var unstated__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! unstated */ \"./node_modules/unstated/lib/unstated.es.js\");\n/* harmony import */ var _alias_logger__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @alias/logger */ \"./src/lib/service/logger/index.js\");\n/* harmony import */ var _alias_logger__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_alias_logger__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var entities__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! entities */ \"./node_modules/entities/lib/index.js\");\n/* harmony import */ var entities__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(entities__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var toastr__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! toastr */ \"./node_modules/toastr/toastr.js\");\n/* harmony import */ var toastr__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(toastr__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _commons_util_path_utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @commons/util/path-utils */ \"./src/lib/util/path-utils.js\");\n/* harmony import */ var _commons_util_path_utils__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_commons_util_path_utils__WEBPACK_IMPORTED_MODULE_4__);\n/* harmony import */ var _util_apiNotification__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../util/apiNotification */ \"./src/client/js/util/apiNotification.js\");\n/* harmony import */ var _util_interceptor_detach_code_blocks__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../util/interceptor/detach-code-blocks */ \"./src/client/js/util/interceptor/detach-code-blocks.js\");\n/* harmony import */ var _util_interceptor_drawio_interceptor__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../util/interceptor/drawio-interceptor */ \"./src/client/js/util/interceptor/drawio-interceptor.js\");\n\n\n\n\n\n\n\n\nconst logger = _alias_logger__WEBPACK_IMPORTED_MODULE_1___default()('growi:services:PageContainer');\n/**\n * Service container related to Page\n * @extends {Container} unstated Container\n */\n\nclass PageContainer extends unstated__WEBPACK_IMPORTED_MODULE_0__[\"Container\"] {\n constructor(appContainer) {\n super();\n this.appContainer = appContainer;\n this.appContainer.registerContainer(this);\n this.state = {};\n const mainContent = document.querySelector('#content-main');\n\n if (mainContent == null) {\n logger.debug('#content-main element is not exists');\n return;\n }\n\n const revisionId = mainContent.getAttribute('data-page-revision-id');\n const path = decodeURI(mainContent.getAttribute('data-path'));\n this.state = {\n // local page data\n markdown: null,\n // will be initialized after initStateMarkdown()\n pageId: mainContent.getAttribute('data-page-id'),\n revisionId,\n revisionCreatedAt: +mainContent.getAttribute('data-page-revision-created'),\n path,\n tocHtml: '',\n isLiked: false,\n isBookmarked: false,\n seenUsers: [],\n seenUserIds: mainContent.getAttribute('data-page-ids-of-seen-users'),\n countOfSeenUsers: mainContent.getAttribute('data-page-count-of-seen-users'),\n likerUsers: [],\n sumOfLikers: 0,\n sumOfBookmarks: 0,\n createdAt: mainContent.getAttribute('data-page-created-at'),\n updatedAt: mainContent.getAttribute('data-page-updated-at'),\n deletedAt: mainContent.getAttribute('data-page-deleted-at') || null,\n isUserPage: JSON.parse(mainContent.getAttribute('data-page-user')) != null,\n isTrashPage: Object(_commons_util_path_utils__WEBPACK_IMPORTED_MODULE_4__[\"isTrashPage\"])(path),\n isDeleted: JSON.parse(mainContent.getAttribute('data-page-is-deleted')),\n isDeletable: JSON.parse(mainContent.getAttribute('data-page-is-deletable')),\n isNotCreatable: JSON.parse(mainContent.getAttribute('data-page-is-not-creatable')),\n isAbleToDeleteCompletely: JSON.parse(mainContent.getAttribute('data-page-is-able-to-delete-completely')),\n isPageExist: mainContent.getAttribute('data-page-id') != null,\n pageUser: JSON.parse(mainContent.getAttribute('data-page-user')),\n tags: null,\n hasChildren: JSON.parse(mainContent.getAttribute('data-page-has-children')),\n templateTagData: mainContent.getAttribute('data-template-tags') || null,\n shareLinksNumber: mainContent.getAttribute('data-share-links-number'),\n shareLinkId: JSON.parse(mainContent.getAttribute('data-share-link-id') || null),\n // latest(on remote) information\n remoteRevisionId: revisionId,\n revisionIdHackmdSynced: mainContent.getAttribute('data-page-revision-id-hackmd-synced') || null,\n lastUpdateUsername: mainContent.getAttribute('data-page-last-update-username') || null,\n deleteUsername: mainContent.getAttribute('data-page-delete-username') || null,\n pageIdOnHackmd: mainContent.getAttribute('data-page-id-on-hackmd') || null,\n hasDraftOnHackmd: !!mainContent.getAttribute('data-page-has-draft-on-hackmd'),\n isHackmdDraftUpdatingInRealtime: false\n }; // parse creator, lastUpdateUser and revisionAuthor\n\n try {\n this.state.creator = JSON.parse(mainContent.getAttribute('data-page-creator'));\n } catch (e) {\n logger.warn('The data of \\'data-page-creator\\' is invalid', e);\n }\n\n try {\n this.state.revisionAuthor = JSON.parse(mainContent.getAttribute('data-page-revision-author'));\n } catch (e) {\n logger.warn('The data of \\'data-page-revision-author\\' is invalid', e);\n }\n\n const {\n interceptorManager\n } = this.appContainer;\n interceptorManager.addInterceptor(new _util_interceptor_detach_code_blocks__WEBPACK_IMPORTED_MODULE_6__[\"DetachCodeBlockInterceptor\"](appContainer), 10); // process as soon as possible\n\n interceptorManager.addInterceptor(new _util_interceptor_drawio_interceptor__WEBPACK_IMPORTED_MODULE_7__[\"DrawioInterceptor\"](appContainer), 20);\n interceptorManager.addInterceptor(new _util_interceptor_detach_code_blocks__WEBPACK_IMPORTED_MODULE_6__[\"RestoreCodeBlockInterceptor\"](appContainer), 900); // process as late as possible\n\n this.initStateMarkdown();\n this.checkAndUpdateImageUrlCached(this.state.likerUsers);\n const {\n isSharedUser\n } = this.appContainer; // see https://dev.growi.org/5fabddf8bbeb1a0048bcb9e9\n\n const isAbleToGetAttachedInformationAboutPages = this.state.isPageExist && !isSharedUser;\n\n if (isAbleToGetAttachedInformationAboutPages) {\n this.retrieveSeenUsers();\n this.retrieveLikeInfo();\n this.retrieveBookmarkInfo();\n }\n\n this.setTocHtml = this.setTocHtml.bind(this);\n this.save = this.save.bind(this);\n this.checkAndUpdateImageUrlCached = this.checkAndUpdateImageUrlCached.bind(this);\n this.addWebSocketEventHandlers = this.addWebSocketEventHandlers.bind(this);\n this.addWebSocketEventHandlers();\n const unlinkPageButton = document.getElementById('unlink-page-button');\n\n if (unlinkPageButton != null) {\n unlinkPageButton.addEventListener('click', async () => {\n try {\n const res = await this.appContainer.apiPost('/pages.unlink', {\n path\n });\n window.location.href = encodeURI(`${res.path}?unlinked=true`);\n } catch (err) {\n Object(_util_apiNotification__WEBPACK_IMPORTED_MODULE_5__[\"toastError\"])(err);\n }\n });\n }\n }\n /**\n * Workaround for the mangling in production build to break constructor.name\n */\n\n\n static getClassName() {\n return 'PageContainer';\n }\n\n get isAbleToOpenPageEditor() {\n const {\n isNotCreatable,\n isTrashPage\n } = this.state;\n const {\n isGuestUser\n } = this.appContainer;\n return !isNotCreatable && !isTrashPage && !isGuestUser;\n }\n /**\n * whether to display reaction buttons\n * ex.) like, bookmark\n */\n\n\n get isAbleToShowPageReactionButtons() {\n const {\n isTrashPage,\n isPageExist\n } = this.state;\n const {\n isSharedUser\n } = this.appContainer;\n return !isTrashPage && isPageExist && !isSharedUser;\n }\n /**\n * whether to display tag labels\n */\n\n\n get isAbleToShowTagLabel() {\n const {\n isUserPage\n } = this.state;\n const {\n isSharedUser\n } = this.appContainer;\n return !isUserPage && !isSharedUser;\n }\n /**\n * whether to display page management\n * ex.) duplicate, rename\n */\n\n\n get isAbleToShowPageManagement() {\n const {\n isPageExist,\n isTrashPage\n } = this.state;\n const {\n isSharedUser\n } = this.appContainer;\n return isPageExist && !isTrashPage && !isSharedUser;\n }\n /**\n * whether to display pageEditorModeManager\n * ex.) view, edit, hackmd\n */\n\n\n get isAbleToShowPageEditorModeManager() {\n const {\n isNotCreatable,\n isTrashPage\n } = this.state;\n const {\n isSharedUser\n } = this.appContainer;\n return !isNotCreatable && !isTrashPage && !isSharedUser;\n }\n /**\n * whether to display pageAuthors\n * ex.) creator, lastUpdateUser\n */\n\n\n get isAbleToShowPageAuthors() {\n const {\n isPageExist,\n isUserPage\n } = this.state;\n return isPageExist && !isUserPage;\n }\n /**\n * whether to like button\n * not displayed on user page\n */\n\n\n get isAbleToShowLikeButton() {\n const {\n isUserPage\n } = this.state;\n const {\n isSharedUser\n } = this.appContainer;\n return !isUserPage && !isSharedUser;\n }\n /**\n * whether to Empty Trash Page\n * not displayed when guest user and not on trash page\n */\n\n\n get isAbleToShowEmptyTrashButton() {\n const {\n currentUser\n } = this.appContainer;\n const {\n path,\n hasChildren\n } = this.state;\n return currentUser != null && currentUser.admin && path === '/trash' && hasChildren;\n }\n /**\n * whether to display trash management buttons\n * ex.) undo, delete completly\n * not displayed when guest user\n */\n\n\n get isAbleToShowTrashPageManagementButtons() {\n const {\n currentUser\n } = this.appContainer;\n const {\n isDeleted\n } = this.state;\n return isDeleted && currentUser != null;\n }\n /**\n * initialize state for markdown data\n */\n\n\n initStateMarkdown() {\n let pageContent = '';\n const rawText = document.getElementById('raw-text-original');\n\n if (rawText) {\n pageContent = rawText.innerHTML;\n }\n\n const markdown = entities__WEBPACK_IMPORTED_MODULE_2__[\"decodeHTML\"](pageContent);\n this.state.markdown = markdown;\n }\n\n async retrieveSeenUsers() {\n const {\n users\n } = await this.appContainer.apiGet('/users.list', {\n user_ids: this.state.seenUserIds\n });\n this.setState({\n seenUsers: users\n });\n this.checkAndUpdateImageUrlCached(users);\n }\n\n async retrieveLikeInfo() {\n const res = await this.appContainer.apiv3Get('/page/like-info', {\n _id: this.state.pageId\n });\n const {\n sumOfLikers,\n isLiked\n } = res.data;\n this.setState({\n sumOfLikers,\n isLiked\n });\n }\n\n async toggleLike() {\n const bool = !this.state.isLiked;\n await this.appContainer.apiv3Put('/page/likes', {\n pageId: this.state.pageId,\n bool\n });\n this.setState({\n isLiked: bool\n });\n return this.retrieveLikeInfo();\n }\n\n async retrieveBookmarkInfo() {\n const response = await this.appContainer.apiv3Get('/bookmarks/info', {\n pageId: this.state.pageId\n });\n this.setState({\n sumOfBookmarks: response.data.sumOfBookmarks,\n isBookmarked: response.data.isBookmarked\n });\n }\n\n async toggleBookmark() {\n const bool = !this.state.isBookmarked;\n await this.appContainer.apiv3Put('/bookmarks', {\n pageId: this.state.pageId,\n bool\n });\n return this.retrieveBookmarkInfo();\n }\n\n async checkAndUpdateImageUrlCached(users) {\n const noImageCacheUsers = users.filter(user => {\n return user.imageUrlCached == null;\n });\n\n if (noImageCacheUsers.length === 0) {\n return;\n }\n\n const noImageCacheUserIds = noImageCacheUsers.map(user => {\n return user.id;\n });\n\n try {\n await this.appContainer.apiv3Put('/users/update.imageUrlCache', {\n userIds: noImageCacheUserIds\n });\n } catch (err) {\n // Error alert doesn't apear, because user don't need to notice this error.\n logger.error(err);\n }\n }\n\n get navigationContainer() {\n return this.appContainer.getContainer('NavigationContainer');\n }\n\n setLatestRemotePageData(s2cMessagePageUpdated) {\n const newState = {\n remoteRevisionId: s2cMessagePageUpdated.revisionId,\n revisionIdHackmdSynced: s2cMessagePageUpdated.revisionIdHackmdSynced,\n lastUpdateUsername: s2cMessagePageUpdated.lastUpdateUsername\n };\n\n if (s2cMessagePageUpdated.hasDraftOnHackmd != null) {\n newState.hasDraftOnHackmd = s2cMessagePageUpdated.hasDraftOnHackmd;\n }\n\n this.setState(newState);\n }\n\n setTocHtml(tocHtml) {\n if (this.state.tocHtml !== tocHtml) {\n this.setState({\n tocHtml\n });\n }\n }\n /**\n * save success handler\n * @param {object} page Page instance\n * @param {Array[Tag]} tags Array of Tag\n * @param {object} revision Revision instance\n */\n\n\n updateStateAfterSave(page, tags, revision) {\n const {\n editorMode\n } = this.navigationContainer.state; // update state of PageContainer\n\n const newState = {\n pageId: page._id,\n revisionId: revision._id,\n revisionCreatedAt: new Date(revision.createdAt).getTime() / 1000,\n remoteRevisionId: revision._id,\n revisionIdHackmdSynced: page.revisionHackmdSynced,\n hasDraftOnHackmd: page.hasDraftOnHackmd,\n markdown: revision.body,\n createdAt: page.createdAt,\n updatedAt: page.updatedAt\n };\n\n if (tags != null) {\n newState.tags = tags;\n }\n\n this.setState(newState); // PageEditor component\n\n const pageEditor = this.appContainer.getComponentInstance('PageEditor');\n\n if (pageEditor != null) {\n if (editorMode !== 'edit') {\n pageEditor.updateEditorValue(newState.markdown);\n }\n } // PageEditorByHackmd component\n\n\n const pageEditorByHackmd = this.appContainer.getComponentInstance('PageEditorByHackmd');\n\n if (pageEditorByHackmd != null) {\n // reset\n if (editorMode !== 'hackmd') {\n pageEditorByHackmd.reset();\n }\n } // hidden input\n\n\n $('input[name=\"revision_id\"]').val(newState.revisionId);\n }\n /**\n * Save page\n * @param {string} markdown\n * @param {object} optionsToSave\n * @return {object} { page: Page, tags: Tag[] }\n */\n\n\n async save(markdown, optionsToSave = {}) {\n const {\n editorMode\n } = this.navigationContainer.state;\n const {\n pageId,\n path\n } = this.state;\n let {\n revisionId\n } = this.state;\n const options = Object.assign({}, optionsToSave);\n\n if (editorMode === 'hackmd') {\n // set option to sync\n options.isSyncRevisionToHackmd = true;\n revisionId = this.state.revisionIdHackmdSynced;\n }\n\n let res;\n\n if (pageId == null) {\n res = await this.createPage(path, markdown, options);\n } else {\n res = await this.updatePage(pageId, revisionId, markdown, options);\n }\n\n this.updateStateAfterSave(res.page, res.tags, res.revision);\n return res;\n }\n\n async saveAndReload(optionsToSave) {\n if (optionsToSave == null) {\n const msg = '\\'saveAndReload\\' requires the \\'optionsToSave\\' param';\n throw new Error(msg);\n }\n\n const {\n editorMode\n } = this.navigationContainer.state;\n\n if (editorMode == null) {\n logger.warn('\\'saveAndReload\\' requires the \\'errorMode\\' param');\n return;\n }\n\n const {\n pageId,\n path\n } = this.state;\n let {\n revisionId\n } = this.state;\n const options = Object.assign({}, optionsToSave);\n let markdown;\n\n if (editorMode === 'hackmd') {\n const pageEditorByHackmd = this.appContainer.getComponentInstance('PageEditorByHackmd');\n markdown = await pageEditorByHackmd.getMarkdown(); // set option to sync\n\n options.isSyncRevisionToHackmd = true;\n revisionId = this.state.revisionIdHackmdSynced;\n } else {\n const pageEditor = this.appContainer.getComponentInstance('PageEditor');\n markdown = pageEditor.getMarkdown();\n }\n\n let res;\n\n if (pageId == null) {\n res = await this.createPage(path, markdown, options);\n } else {\n res = await this.updatePage(pageId, revisionId, markdown, options);\n }\n\n const editorContainer = this.appContainer.getContainer('EditorContainer');\n editorContainer.clearDraft(path);\n window.location.href = path;\n return res;\n }\n\n async createPage(pagePath, markdown, tmpParams) {\n const socketIoContainer = this.appContainer.getContainer('SocketIoContainer'); // clone\n\n const params = Object.assign(tmpParams, {\n socketClientId: socketIoContainer.getSocketClientId(),\n path: pagePath,\n body: markdown\n });\n const res = await this.appContainer.apiv3Post('/pages/', params);\n const {\n page,\n tags,\n revision\n } = res.data;\n return {\n page,\n tags,\n revision\n };\n }\n\n async updatePage(pageId, revisionId, markdown, tmpParams) {\n const socketIoContainer = this.appContainer.getContainer('SocketIoContainer'); // clone\n\n const params = Object.assign(tmpParams, {\n socketClientId: socketIoContainer.getSocketClientId(),\n page_id: pageId,\n revision_id: revisionId,\n body: markdown\n });\n const res = await this.appContainer.apiPost('/pages.update', params);\n\n if (!res.ok) {\n throw new Error(res.error);\n }\n\n return res;\n }\n\n deletePage(isRecursively, isCompletely) {\n const socketIoContainer = this.appContainer.getContainer('SocketIoContainer'); // control flag\n\n const completely = isCompletely ? true : null;\n const recursively = isRecursively ? true : null;\n return this.appContainer.apiPost('/pages.remove', {\n recursively,\n completely,\n page_id: this.state.pageId,\n revision_id: this.state.revisionId,\n socketClientId: socketIoContainer.getSocketClientId()\n });\n }\n\n revertRemove(isRecursively) {\n const socketIoContainer = this.appContainer.getContainer('SocketIoContainer'); // control flag\n\n const recursively = isRecursively ? true : null;\n return this.appContainer.apiPost('/pages.revertRemove', {\n recursively,\n page_id: this.state.pageId,\n socketClientId: socketIoContainer.getSocketClientId()\n });\n }\n\n rename(newPagePath, isRecursively, isRenameRedirect, isRemainMetadata) {\n const socketIoContainer = this.appContainer.getContainer('SocketIoContainer');\n const {\n pageId,\n revisionId,\n path\n } = this.state;\n return this.appContainer.apiv3Put('/pages/rename', {\n revisionId,\n pageId,\n isRecursively,\n isRenameRedirect,\n isRemainMetadata,\n newPagePath,\n path,\n socketClientId: socketIoContainer.getSocketClientId()\n });\n }\n\n showSuccessToastr() {\n toastr__WEBPACK_IMPORTED_MODULE_3__[\"success\"](undefined, 'Saved successfully', {\n closeButton: true,\n progressBar: true,\n newestOnTop: false,\n showDuration: '100',\n hideDuration: '100',\n timeOut: '1200',\n extendedTimeOut: '150'\n });\n }\n\n showErrorToastr(error) {\n toastr__WEBPACK_IMPORTED_MODULE_3__[\"error\"](error.message, 'Error occured', {\n closeButton: true,\n progressBar: true,\n newestOnTop: false,\n showDuration: '100',\n hideDuration: '100',\n timeOut: '3000'\n });\n }\n\n addWebSocketEventHandlers() {\n const pageContainer = this;\n const socketIoContainer = this.appContainer.getContainer('SocketIoContainer');\n const socket = socketIoContainer.getSocket();\n socket.on('page:create', data => {\n // skip if triggered myself\n if (data.socketClientId != null && data.socketClientId === socketIoContainer.getSocketClientId()) {\n return;\n }\n\n logger.debug({\n obj: data\n }, `websocket on 'page:create'`); // eslint-disable-line quotes\n // update remote page data\n\n const {\n s2cMessagePageUpdated\n } = data;\n\n if (s2cMessagePageUpdated.pageId === pageContainer.state.pageId) {\n pageContainer.setLatestRemotePageData(s2cMessagePageUpdated);\n }\n });\n socket.on('page:update', data => {\n // skip if triggered myself\n if (data.socketClientId != null && data.socketClientId === socketIoContainer.getSocketClientId()) {\n return;\n }\n\n logger.debug({\n obj: data\n }, `websocket on 'page:update'`); // eslint-disable-line quotes\n // update remote page data\n\n const {\n s2cMessagePageUpdated\n } = data;\n\n if (s2cMessagePageUpdated.pageId === pageContainer.state.pageId) {\n pageContainer.setLatestRemotePageData(s2cMessagePageUpdated);\n }\n });\n socket.on('page:delete', data => {\n // skip if triggered myself\n if (data.socketClientId != null && data.socketClientId === socketIoContainer.getSocketClientId()) {\n return;\n }\n\n logger.debug({\n obj: data\n }, `websocket on 'page:delete'`); // eslint-disable-line quotes\n // update remote page data\n\n const {\n s2cMessagePageUpdated\n } = data;\n\n if (s2cMessagePageUpdated.pageId === pageContainer.state.pageId) {\n pageContainer.setLatestRemotePageData(s2cMessagePageUpdated);\n }\n });\n socket.on('page:editingWithHackmd', data => {\n // skip if triggered myself\n if (data.socketClientId != null && data.socketClientId === socketIoContainer.getSocketClientId()) {\n return;\n }\n\n logger.debug({\n obj: data\n }, `websocket on 'page:editingWithHackmd'`); // eslint-disable-line quotes\n // update isHackmdDraftUpdatingInRealtime\n\n const {\n s2cMessagePageUpdated\n } = data;\n\n if (s2cMessagePageUpdated.pageId === pageContainer.state.pageId) {\n pageContainer.setState({\n isHackmdDraftUpdatingInRealtime: true\n });\n }\n });\n }\n /* TODO GW-325 */\n\n\n retrieveMyBookmarkList() {}\n\n}\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! jquery */ \"jquery\")))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/client/js/services/PageContainer.js.js","sources":["webpack:///./src/client/js/services/PageContainer.js?39d6"],"sourcesContent":["import { Container } from 'unstated';\n\nimport loggerFactory from '@alias/logger';\n\nimport * as entities from 'entities';\nimport * as toastr from 'toastr';\nimport { isTrashPage } from '@commons/util/path-utils';\nimport { toastError } from '../util/apiNotification';\n\nimport {\n  DetachCodeBlockInterceptor,\n  RestoreCodeBlockInterceptor,\n} from '../util/interceptor/detach-code-blocks';\n\nimport {\n  DrawioInterceptor,\n} from '../util/interceptor/drawio-interceptor';\n\nconst logger = loggerFactory('growi:services:PageContainer');\n\n/**\n * Service container related to Page\n * @extends {Container} unstated Container\n */\nexport default class PageContainer extends Container {\n\n  constructor(appContainer) {\n    super();\n\n    this.appContainer = appContainer;\n    this.appContainer.registerContainer(this);\n\n    this.state = {};\n\n    const mainContent = document.querySelector('#content-main');\n    if (mainContent == null) {\n      logger.debug('#content-main element is not exists');\n      return;\n    }\n\n    const revisionId = mainContent.getAttribute('data-page-revision-id');\n    const path = decodeURI(mainContent.getAttribute('data-path'));\n\n    this.state = {\n      // local page data\n      markdown: null, // will be initialized after initStateMarkdown()\n      pageId: mainContent.getAttribute('data-page-id'),\n      revisionId,\n      revisionCreatedAt: +mainContent.getAttribute('data-page-revision-created'),\n      path,\n      tocHtml: '',\n      isLiked: false,\n      isBookmarked: false,\n      seenUsers: [],\n      seenUserIds: mainContent.getAttribute('data-page-ids-of-seen-users'),\n      countOfSeenUsers: mainContent.getAttribute('data-page-count-of-seen-users'),\n\n      likerUsers: [],\n      sumOfLikers: 0,\n      sumOfBookmarks: 0,\n      createdAt: mainContent.getAttribute('data-page-created-at'),\n      updatedAt: mainContent.getAttribute('data-page-updated-at'),\n      deletedAt: mainContent.getAttribute('data-page-deleted-at') || null,\n\n      isUserPage: JSON.parse(mainContent.getAttribute('data-page-user')) != null,\n      isTrashPage: isTrashPage(path),\n      isDeleted: JSON.parse(mainContent.getAttribute('data-page-is-deleted')),\n      isDeletable: JSON.parse(mainContent.getAttribute('data-page-is-deletable')),\n      isNotCreatable: JSON.parse(mainContent.getAttribute('data-page-is-not-creatable')),\n      isAbleToDeleteCompletely: JSON.parse(mainContent.getAttribute('data-page-is-able-to-delete-completely')),\n      isPageExist: mainContent.getAttribute('data-page-id') != null,\n\n      pageUser: JSON.parse(mainContent.getAttribute('data-page-user')),\n      tags: null,\n      hasChildren: JSON.parse(mainContent.getAttribute('data-page-has-children')),\n      templateTagData: mainContent.getAttribute('data-template-tags') || null,\n      shareLinksNumber: mainContent.getAttribute('data-share-links-number'),\n      shareLinkId: JSON.parse(mainContent.getAttribute('data-share-link-id') || null),\n\n      // latest(on remote) information\n      remoteRevisionId: revisionId,\n      revisionIdHackmdSynced: mainContent.getAttribute('data-page-revision-id-hackmd-synced') || null,\n      lastUpdateUsername: mainContent.getAttribute('data-page-last-update-username') || null,\n      deleteUsername: mainContent.getAttribute('data-page-delete-username') || null,\n      pageIdOnHackmd: mainContent.getAttribute('data-page-id-on-hackmd') || null,\n      hasDraftOnHackmd: !!mainContent.getAttribute('data-page-has-draft-on-hackmd'),\n      isHackmdDraftUpdatingInRealtime: false,\n    };\n\n    // parse creator, lastUpdateUser and revisionAuthor\n    try {\n      this.state.creator = JSON.parse(mainContent.getAttribute('data-page-creator'));\n    }\n    catch (e) {\n      logger.warn('The data of \\'data-page-creator\\' is invalid', e);\n    }\n    try {\n      this.state.revisionAuthor = JSON.parse(mainContent.getAttribute('data-page-revision-author'));\n    }\n    catch (e) {\n      logger.warn('The data of \\'data-page-revision-author\\' is invalid', e);\n    }\n\n    const { interceptorManager } = this.appContainer;\n    interceptorManager.addInterceptor(new DetachCodeBlockInterceptor(appContainer), 10); // process as soon as possible\n    interceptorManager.addInterceptor(new DrawioInterceptor(appContainer), 20);\n    interceptorManager.addInterceptor(new RestoreCodeBlockInterceptor(appContainer), 900); // process as late as possible\n\n    this.initStateMarkdown();\n    this.checkAndUpdateImageUrlCached(this.state.likerUsers);\n\n    const { isSharedUser } = this.appContainer;\n\n    // see https://dev.growi.org/5fabddf8bbeb1a0048bcb9e9\n    const isAbleToGetAttachedInformationAboutPages = this.state.isPageExist && !isSharedUser;\n\n    if (isAbleToGetAttachedInformationAboutPages) {\n      this.retrieveSeenUsers();\n      this.retrieveLikeInfo();\n      this.retrieveBookmarkInfo();\n    }\n\n    this.setTocHtml = this.setTocHtml.bind(this);\n    this.save = this.save.bind(this);\n    this.checkAndUpdateImageUrlCached = this.checkAndUpdateImageUrlCached.bind(this);\n    this.addWebSocketEventHandlers = this.addWebSocketEventHandlers.bind(this);\n    this.addWebSocketEventHandlers();\n\n    const unlinkPageButton = document.getElementById('unlink-page-button');\n    if (unlinkPageButton != null) {\n      unlinkPageButton.addEventListener('click', async() => {\n        try {\n          const res = await this.appContainer.apiPost('/pages.unlink', { path });\n          window.location.href = encodeURI(`${res.path}?unlinked=true`);\n        }\n        catch (err) {\n          toastError(err);\n        }\n      });\n    }\n\n  }\n\n  /**\n   * Workaround for the mangling in production build to break constructor.name\n   */\n  static getClassName() {\n    return 'PageContainer';\n  }\n\n\n  get isAbleToOpenPageEditor() {\n    const { isNotCreatable, isTrashPage } = this.state;\n    const { isGuestUser } = this.appContainer;\n\n    return (!isNotCreatable && !isTrashPage && !isGuestUser);\n  }\n\n  /**\n   * whether to display reaction buttons\n   * ex.) like, bookmark\n   */\n  get isAbleToShowPageReactionButtons() {\n    const { isTrashPage, isPageExist } = this.state;\n    const { isSharedUser } = this.appContainer;\n\n    return (!isTrashPage && isPageExist && !isSharedUser);\n  }\n\n  /**\n   * whether to display tag labels\n   */\n  get isAbleToShowTagLabel() {\n    const { isUserPage } = this.state;\n    const { isSharedUser } = this.appContainer;\n\n    return (!isUserPage && !isSharedUser);\n  }\n\n  /**\n   * whether to display page management\n   * ex.) duplicate, rename\n   */\n  get isAbleToShowPageManagement() {\n    const { isPageExist, isTrashPage } = this.state;\n    const { isSharedUser } = this.appContainer;\n\n    return (isPageExist && !isTrashPage && !isSharedUser);\n  }\n\n  /**\n   * whether to display pageEditorModeManager\n   * ex.) view, edit, hackmd\n   */\n  get isAbleToShowPageEditorModeManager() {\n    const { isNotCreatable, isTrashPage } = this.state;\n    const { isSharedUser } = this.appContainer;\n\n    return (!isNotCreatable && !isTrashPage && !isSharedUser);\n  }\n\n  /**\n   * whether to display pageAuthors\n   * ex.) creator, lastUpdateUser\n   */\n  get isAbleToShowPageAuthors() {\n    const { isPageExist, isUserPage } = this.state;\n\n    return (isPageExist && !isUserPage);\n  }\n\n  /**\n   * whether to like button\n   * not displayed on user page\n   */\n  get isAbleToShowLikeButton() {\n    const { isUserPage } = this.state;\n    const { isSharedUser } = this.appContainer;\n\n    return (!isUserPage && !isSharedUser);\n  }\n\n  /**\n   * whether to Empty Trash Page\n   * not displayed when guest user and not on trash page\n   */\n  get isAbleToShowEmptyTrashButton() {\n    const { currentUser } = this.appContainer;\n    const { path, hasChildren } = this.state;\n\n    return (currentUser != null && currentUser.admin && path === '/trash' && hasChildren);\n  }\n\n  /**\n   * whether to display trash management buttons\n   * ex.) undo, delete completly\n   * not displayed when guest user\n   */\n  get isAbleToShowTrashPageManagementButtons() {\n    const { currentUser } = this.appContainer;\n    const { isDeleted } = this.state;\n\n    return (isDeleted && currentUser != null);\n  }\n\n  /**\n   * initialize state for markdown data\n   */\n  initStateMarkdown() {\n    let pageContent = '';\n\n    const rawText = document.getElementById('raw-text-original');\n    if (rawText) {\n      pageContent = rawText.innerHTML;\n    }\n    const markdown = entities.decodeHTML(pageContent);\n\n    this.state.markdown = markdown;\n  }\n\n  async retrieveSeenUsers() {\n    const { users } = await this.appContainer.apiGet('/users.list', { user_ids: this.state.seenUserIds });\n\n    this.setState({ seenUsers: users });\n    this.checkAndUpdateImageUrlCached(users);\n  }\n\n  async retrieveLikeInfo() {\n    const res = await this.appContainer.apiv3Get('/page/like-info', { _id: this.state.pageId });\n    const { sumOfLikers, isLiked } = res.data;\n\n    this.setState({\n      sumOfLikers,\n      isLiked,\n    });\n  }\n\n  async toggleLike() {\n    const bool = !this.state.isLiked;\n    await this.appContainer.apiv3Put('/page/likes', { pageId: this.state.pageId, bool });\n    this.setState({ isLiked: bool });\n\n    return this.retrieveLikeInfo();\n  }\n\n  async retrieveBookmarkInfo() {\n    const response = await this.appContainer.apiv3Get('/bookmarks/info', { pageId: this.state.pageId });\n    this.setState({\n      sumOfBookmarks: response.data.sumOfBookmarks,\n      isBookmarked: response.data.isBookmarked,\n    });\n  }\n\n  async toggleBookmark() {\n    const bool = !this.state.isBookmarked;\n    await this.appContainer.apiv3Put('/bookmarks', { pageId: this.state.pageId, bool });\n    return this.retrieveBookmarkInfo();\n  }\n\n  async checkAndUpdateImageUrlCached(users) {\n    const noImageCacheUsers = users.filter((user) => { return user.imageUrlCached == null });\n    if (noImageCacheUsers.length === 0) {\n      return;\n    }\n\n    const noImageCacheUserIds = noImageCacheUsers.map((user) => { return user.id });\n    try {\n      await this.appContainer.apiv3Put('/users/update.imageUrlCache', { userIds: noImageCacheUserIds });\n    }\n    catch (err) {\n      // Error alert doesn't apear, because user don't need to notice this error.\n      logger.error(err);\n    }\n  }\n\n  get navigationContainer() {\n    return this.appContainer.getContainer('NavigationContainer');\n  }\n\n  setLatestRemotePageData(s2cMessagePageUpdated) {\n    const newState = {\n      remoteRevisionId: s2cMessagePageUpdated.revisionId,\n      revisionIdHackmdSynced: s2cMessagePageUpdated.revisionIdHackmdSynced,\n      lastUpdateUsername: s2cMessagePageUpdated.lastUpdateUsername,\n    };\n\n    if (s2cMessagePageUpdated.hasDraftOnHackmd != null) {\n      newState.hasDraftOnHackmd = s2cMessagePageUpdated.hasDraftOnHackmd;\n    }\n\n    this.setState(newState);\n  }\n\n  setTocHtml(tocHtml) {\n    if (this.state.tocHtml !== tocHtml) {\n      this.setState({ tocHtml });\n    }\n  }\n\n  /**\n   * save success handler\n   * @param {object} page Page instance\n   * @param {Array[Tag]} tags Array of Tag\n   * @param {object} revision Revision instance\n   */\n  updateStateAfterSave(page, tags, revision) {\n    const { editorMode } = this.navigationContainer.state;\n\n    // update state of PageContainer\n    const newState = {\n      pageId: page._id,\n      revisionId: revision._id,\n      revisionCreatedAt: new Date(revision.createdAt).getTime() / 1000,\n      remoteRevisionId: revision._id,\n      revisionIdHackmdSynced: page.revisionHackmdSynced,\n      hasDraftOnHackmd: page.hasDraftOnHackmd,\n      markdown: revision.body,\n      createdAt: page.createdAt,\n      updatedAt: page.updatedAt,\n    };\n    if (tags != null) {\n      newState.tags = tags;\n    }\n    this.setState(newState);\n\n    // PageEditor component\n    const pageEditor = this.appContainer.getComponentInstance('PageEditor');\n    if (pageEditor != null) {\n      if (editorMode !== 'edit') {\n        pageEditor.updateEditorValue(newState.markdown);\n      }\n    }\n    // PageEditorByHackmd component\n    const pageEditorByHackmd = this.appContainer.getComponentInstance('PageEditorByHackmd');\n    if (pageEditorByHackmd != null) {\n      // reset\n      if (editorMode !== 'hackmd') {\n        pageEditorByHackmd.reset();\n      }\n    }\n\n    // hidden input\n    $('input[name=\"revision_id\"]').val(newState.revisionId);\n  }\n\n  /**\n   * Save page\n   * @param {string} markdown\n   * @param {object} optionsToSave\n   * @return {object} { page: Page, tags: Tag[] }\n   */\n  async save(markdown, optionsToSave = {}) {\n    const { editorMode } = this.navigationContainer.state;\n\n    const { pageId, path } = this.state;\n    let { revisionId } = this.state;\n\n    const options = Object.assign({}, optionsToSave);\n\n    if (editorMode === 'hackmd') {\n      // set option to sync\n      options.isSyncRevisionToHackmd = true;\n      revisionId = this.state.revisionIdHackmdSynced;\n    }\n\n    let res;\n    if (pageId == null) {\n      res = await this.createPage(path, markdown, options);\n    }\n    else {\n      res = await this.updatePage(pageId, revisionId, markdown, options);\n    }\n\n    this.updateStateAfterSave(res.page, res.tags, res.revision);\n    return res;\n  }\n\n  async saveAndReload(optionsToSave) {\n    if (optionsToSave == null) {\n      const msg = '\\'saveAndReload\\' requires the \\'optionsToSave\\' param';\n      throw new Error(msg);\n    }\n\n    const { editorMode } = this.navigationContainer.state;\n    if (editorMode == null) {\n      logger.warn('\\'saveAndReload\\' requires the \\'errorMode\\' param');\n      return;\n    }\n\n    const { pageId, path } = this.state;\n    let { revisionId } = this.state;\n\n    const options = Object.assign({}, optionsToSave);\n\n    let markdown;\n    if (editorMode === 'hackmd') {\n      const pageEditorByHackmd = this.appContainer.getComponentInstance('PageEditorByHackmd');\n      markdown = await pageEditorByHackmd.getMarkdown();\n      // set option to sync\n      options.isSyncRevisionToHackmd = true;\n      revisionId = this.state.revisionIdHackmdSynced;\n    }\n    else {\n      const pageEditor = this.appContainer.getComponentInstance('PageEditor');\n      markdown = pageEditor.getMarkdown();\n    }\n\n    let res;\n    if (pageId == null) {\n      res = await this.createPage(path, markdown, options);\n    }\n    else {\n      res = await this.updatePage(pageId, revisionId, markdown, options);\n    }\n\n    const editorContainer = this.appContainer.getContainer('EditorContainer');\n    editorContainer.clearDraft(path);\n    window.location.href = path;\n\n    return res;\n  }\n\n  async createPage(pagePath, markdown, tmpParams) {\n    const socketIoContainer = this.appContainer.getContainer('SocketIoContainer');\n\n    // clone\n    const params = Object.assign(tmpParams, {\n      socketClientId: socketIoContainer.getSocketClientId(),\n      path: pagePath,\n      body: markdown,\n    });\n\n    const res = await this.appContainer.apiv3Post('/pages/', params);\n    const { page, tags, revision } = res.data;\n\n    return { page, tags, revision };\n  }\n\n  async updatePage(pageId, revisionId, markdown, tmpParams) {\n    const socketIoContainer = this.appContainer.getContainer('SocketIoContainer');\n\n    // clone\n    const params = Object.assign(tmpParams, {\n      socketClientId: socketIoContainer.getSocketClientId(),\n      page_id: pageId,\n      revision_id: revisionId,\n      body: markdown,\n    });\n\n    const res = await this.appContainer.apiPost('/pages.update', params);\n    if (!res.ok) {\n      throw new Error(res.error);\n    }\n    return res;\n  }\n\n  deletePage(isRecursively, isCompletely) {\n    const socketIoContainer = this.appContainer.getContainer('SocketIoContainer');\n\n    // control flag\n    const completely = isCompletely ? true : null;\n    const recursively = isRecursively ? true : null;\n\n    return this.appContainer.apiPost('/pages.remove', {\n      recursively,\n      completely,\n      page_id: this.state.pageId,\n      revision_id: this.state.revisionId,\n      socketClientId: socketIoContainer.getSocketClientId(),\n    });\n\n  }\n\n  revertRemove(isRecursively) {\n    const socketIoContainer = this.appContainer.getContainer('SocketIoContainer');\n\n    // control flag\n    const recursively = isRecursively ? true : null;\n\n    return this.appContainer.apiPost('/pages.revertRemove', {\n      recursively,\n      page_id: this.state.pageId,\n      socketClientId: socketIoContainer.getSocketClientId(),\n    });\n  }\n\n  rename(newPagePath, isRecursively, isRenameRedirect, isRemainMetadata) {\n    const socketIoContainer = this.appContainer.getContainer('SocketIoContainer');\n    const { pageId, revisionId, path } = this.state;\n\n    return this.appContainer.apiv3Put('/pages/rename', {\n      revisionId,\n      pageId,\n      isRecursively,\n      isRenameRedirect,\n      isRemainMetadata,\n      newPagePath,\n      path,\n      socketClientId: socketIoContainer.getSocketClientId(),\n    });\n  }\n\n  showSuccessToastr() {\n    toastr.success(undefined, 'Saved successfully', {\n      closeButton: true,\n      progressBar: true,\n      newestOnTop: false,\n      showDuration: '100',\n      hideDuration: '100',\n      timeOut: '1200',\n      extendedTimeOut: '150',\n    });\n  }\n\n  showErrorToastr(error) {\n    toastr.error(error.message, 'Error occured', {\n      closeButton: true,\n      progressBar: true,\n      newestOnTop: false,\n      showDuration: '100',\n      hideDuration: '100',\n      timeOut: '3000',\n    });\n  }\n\n  addWebSocketEventHandlers() {\n    const pageContainer = this;\n    const socketIoContainer = this.appContainer.getContainer('SocketIoContainer');\n    const socket = socketIoContainer.getSocket();\n\n    socket.on('page:create', (data) => {\n      // skip if triggered myself\n      if (data.socketClientId != null && data.socketClientId === socketIoContainer.getSocketClientId()) {\n        return;\n      }\n\n      logger.debug({ obj: data }, `websocket on 'page:create'`); // eslint-disable-line quotes\n\n      // update remote page data\n      const { s2cMessagePageUpdated } = data;\n      if (s2cMessagePageUpdated.pageId === pageContainer.state.pageId) {\n        pageContainer.setLatestRemotePageData(s2cMessagePageUpdated);\n      }\n    });\n\n    socket.on('page:update', (data) => {\n      // skip if triggered myself\n      if (data.socketClientId != null && data.socketClientId === socketIoContainer.getSocketClientId()) {\n        return;\n      }\n\n      logger.debug({ obj: data }, `websocket on 'page:update'`); // eslint-disable-line quotes\n\n      // update remote page data\n      const { s2cMessagePageUpdated } = data;\n      if (s2cMessagePageUpdated.pageId === pageContainer.state.pageId) {\n        pageContainer.setLatestRemotePageData(s2cMessagePageUpdated);\n      }\n    });\n\n    socket.on('page:delete', (data) => {\n      // skip if triggered myself\n      if (data.socketClientId != null && data.socketClientId === socketIoContainer.getSocketClientId()) {\n        return;\n      }\n\n      logger.debug({ obj: data }, `websocket on 'page:delete'`); // eslint-disable-line quotes\n\n      // update remote page data\n      const { s2cMessagePageUpdated } = data;\n      if (s2cMessagePageUpdated.pageId === pageContainer.state.pageId) {\n        pageContainer.setLatestRemotePageData(s2cMessagePageUpdated);\n      }\n    });\n\n    socket.on('page:editingWithHackmd', (data) => {\n      // skip if triggered myself\n      if (data.socketClientId != null && data.socketClientId === socketIoContainer.getSocketClientId()) {\n        return;\n      }\n\n      logger.debug({ obj: data }, `websocket on 'page:editingWithHackmd'`); // eslint-disable-line quotes\n\n      // update isHackmdDraftUpdatingInRealtime\n      const { s2cMessagePageUpdated } = data;\n      if (s2cMessagePageUpdated.pageId === pageContainer.state.pageId) {\n        pageContainer.setState({ isHackmdDraftUpdatingInRealtime: true });\n      }\n    });\n\n  }\n\n  /* TODO GW-325 */\n  retrieveMyBookmarkList() {\n  }\n\n}\n"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA;AAEA;AACA;AACA;AACA;AAEA;AAKA;AAIA;AAEA;;;;;AAIA;AAEA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA3CA;AACA;AA8CA;AACA;AACA;AAEA;AACA;AACA;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;;;;;AAGA;AACA;AACA;AACA;AAEA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAEA;AACA;AAEA;;;;;;AAIA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAEA;AACA;AAEA;;;;;AAGA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AAEA;AACA;AAEA;;;;;;AAIA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAEA;AACA;AAEA;;;;;;AAIA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAEA;AACA;AAEA;;;;;;AAIA;AACA;AAAA;AAAA;AAAA;AAEA;AACA;AAEA;;;;;;AAIA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AAEA;AACA;AAEA;;;;;;AAIA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AAEA;AACA;AAEA;;;;;;;AAKA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AAEA;AACA;AAEA;;;;;AAGA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AAAA;AAEA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AAEA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAEA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AAAA;AACA;AAAA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AAEA;;;;;;;;AAMA;AACA;AAAA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AATA;AACA;AAUA;AACA;AACA;AACA;AAAA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;;;;AAMA;AACA;AAAA;AAAA;AAEA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAEA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAHA;AAMA;AACA;AAAA;AAAA;AAAA;AAAA;AAEA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAJA;AAOA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AALA;AAQA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AARA;AAUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAPA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AANA;AAQA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAEA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAEA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAEA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAEA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AACA;AAAA;AAAA;AACA;AACA;AAEA;AAEA;AACA;AACA;AADA;AACA;AAlmBA;A","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/client/js/services/PageContainer.js\n");
/***/ }),
/***/ "./src/client/js/services/PageHistoryContainer.js":
/*!********************************************************!*\
!*** ./src/client/js/services/PageHistoryContainer.js ***!
\********************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return PageHistoryContainer; });\n/* harmony import */ var unstated__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! unstated */ \"./node_modules/unstated/lib/unstated.es.js\");\n/* harmony import */ var _alias_logger__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @alias/logger */ \"./src/lib/service/logger/index.js\");\n/* harmony import */ var _alias_logger__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_alias_logger__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _util_apiNotification__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../util/apiNotification */ \"./src/client/js/util/apiNotification.js\");\n\n\n\nconst logger = _alias_logger__WEBPACK_IMPORTED_MODULE_1___default()('growi:PageHistoryContainer');\n/**\n * Service container for personal settings page (PageHistory.jsx)\n * @extends {Container} unstated Container\n */\n\nclass PageHistoryContainer extends unstated__WEBPACK_IMPORTED_MODULE_0__[\"Container\"] {\n constructor(appContainer, pageContainer) {\n super();\n this.appContainer = appContainer;\n this.pageContainer = pageContainer;\n this.dummyRevisions = 0;\n this.state = {\n errorMessage: null,\n // set dummy rivisions for using suspense\n revisions: this.dummyRevisions,\n latestRevision: this.dummyRevisions,\n oldestRevision: this.dummyRevisions,\n diffOpened: {},\n totalPages: 0,\n activePage: 1,\n pagingLimit: 10\n };\n this.retrieveRevisions = this.retrieveRevisions.bind(this);\n this.getPreviousRevision = this.getPreviousRevision.bind(this);\n this.fetchPageRevisionBody = this.fetchPageRevisionBody.bind(this);\n }\n /**\n * Workaround for the mangling in production build to break constructor.name\n */\n\n\n static getClassName() {\n return 'PageHistoryContainer';\n }\n /**\n * syncRevisions of selectedPage\n * @param {number} selectedPage\n */\n\n\n async retrieveRevisions(selectedPage) {\n const {\n pageId,\n shareLinkId\n } = this.pageContainer.state;\n const {\n pagingLimit\n } = this.state;\n const page = selectedPage;\n const pagingLimitForApiParam = pagingLimit + 1;\n\n if (!pageId) {\n return;\n } // Get one more for the bottom display\n\n\n const res = await this.appContainer.apiv3Get('/revisions/list', {\n pageId,\n shareLinkId,\n page,\n limit: pagingLimitForApiParam\n });\n const rev = res.data.docs; // set Pagination state\n\n this.setState({\n activePage: selectedPage,\n totalPages: res.data.totalDocs,\n pagingLimit\n });\n const diffOpened = {};\n let lastId = rev.length - 1; // If the number of rev count is the same, the last rev is for diff display, so exclude it.\n\n if (rev.length > pagingLimit) {\n lastId = rev.length - 2;\n }\n\n res.data.docs.forEach((revision, i) => {\n const user = revision.author;\n\n if (user) {\n rev[i].author = user;\n }\n\n if (i === 0 || i === lastId) {\n diffOpened[revision._id] = true;\n } else {\n diffOpened[revision._id] = false;\n }\n });\n this.setState({\n revisions: rev\n });\n this.setState({\n diffOpened\n });\n\n if (selectedPage === 1) {\n this.setState({\n latestRevision: rev[0]\n });\n }\n\n if (selectedPage === res.data.totalPages) {\n this.setState({\n oldestRevision: rev[lastId]\n });\n } // load 0, and last default\n\n\n if (rev[0]) {\n this.fetchPageRevisionBody(rev[0]);\n }\n\n if (rev[1]) {\n this.fetchPageRevisionBody(rev[1]);\n }\n\n if (lastId !== 0 && lastId !== 1 && rev[lastId]) {\n this.fetchPageRevisionBody(rev[lastId]);\n }\n\n return;\n }\n\n getPreviousRevision(currentRevision) {\n let cursor = null;\n\n for (const revision of this.state.revisions) {\n // comparing ObjectId\n // eslint-disable-next-line eqeqeq\n if (cursor && cursor._id == currentRevision._id) {\n cursor = revision;\n break;\n }\n\n cursor = revision;\n }\n\n return cursor;\n }\n /**\n * fetch page revision body by revision in argument\n * @param {object} revision\n */\n\n\n async fetchPageRevisionBody(revision) {\n const {\n pageId,\n shareLinkId\n } = this.pageContainer.state;\n\n if (revision.body) {\n return;\n }\n\n try {\n const res = await this.appContainer.apiv3Get(`/revisions/${revision._id}`, {\n pageId,\n shareLinkId\n });\n this.setState({\n revisions: this.state.revisions.map(rev => {\n // comparing ObjectId\n // eslint-disable-next-line eqeqeq\n if (rev._id == res.data.revision._id) {\n return res.data.revision;\n }\n\n return rev;\n })\n });\n } catch (err) {\n Object(_util_apiNotification__WEBPACK_IMPORTED_MODULE_2__[\"toastError\"])(err);\n this.setState({\n errorMessage: err.message\n });\n logger.error(err);\n }\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvY2xpZW50L2pzL3NlcnZpY2VzL1BhZ2VIaXN0b3J5Q29udGFpbmVyLmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vLy4vc3JjL2NsaWVudC9qcy9zZXJ2aWNlcy9QYWdlSGlzdG9yeUNvbnRhaW5lci5qcz80YWRlIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnRhaW5lciB9IGZyb20gJ3Vuc3RhdGVkJztcblxuaW1wb3J0IGxvZ2dlckZhY3RvcnkgZnJvbSAnQGFsaWFzL2xvZ2dlcic7XG5cbmltcG9ydCB7IHRvYXN0RXJyb3IgfSBmcm9tICcuLi91dGlsL2FwaU5vdGlmaWNhdGlvbic7XG5cbmNvbnN0IGxvZ2dlciA9IGxvZ2dlckZhY3RvcnkoJ2dyb3dpOlBhZ2VIaXN0b3J5Q29udGFpbmVyJyk7XG5cbi8qKlxuICogU2VydmljZSBjb250YWluZXIgZm9yIHBlcnNvbmFsIHNldHRpbmdzIHBhZ2UgKFBhZ2VIaXN0b3J5LmpzeClcbiAqIEBleHRlbmRzIHtDb250YWluZXJ9IHVuc3RhdGVkIENvbnRhaW5lclxuICovXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBQYWdlSGlzdG9yeUNvbnRhaW5lciBleHRlbmRzIENvbnRhaW5lciB7XG5cbiAgY29uc3RydWN0b3IoYXBwQ29udGFpbmVyLCBwYWdlQ29udGFpbmVyKSB7XG4gICAgc3VwZXIoKTtcblxuICAgIHRoaXMuYXBwQ29udGFpbmVyID0gYXBwQ29udGFpbmVyO1xuICAgIHRoaXMucGFnZUNvbnRhaW5lciA9IHBhZ2VDb250YWluZXI7XG4gICAgdGhpcy5kdW1teVJldmlzaW9ucyA9IDA7XG5cbiAgICB0aGlzLnN0YXRlID0ge1xuICAgICAgZXJyb3JNZXNzYWdlOiBudWxsLFxuXG4gICAgICAvLyBzZXQgZHVtbXkgcml2aXNpb25zIGZvciB1c2luZyBzdXNwZW5zZVxuICAgICAgcmV2aXNpb25zOiB0aGlzLmR1bW15UmV2aXNpb25zLFxuICAgICAgbGF0ZXN0UmV2aXNpb246IHRoaXMuZHVtbXlSZXZpc2lvbnMsXG4gICAgICBvbGRlc3RSZXZpc2lvbjogdGhpcy5kdW1teVJldmlzaW9ucyxcbiAgICAgIGRpZmZPcGVuZWQ6IHt9LFxuXG4gICAgICB0b3RhbFBhZ2VzOiAwLFxuICAgICAgYWN0aXZlUGFnZTogMSxcbiAgICAgIHBhZ2luZ0xpbWl0OiAxMCxcbiAgICB9O1xuXG4gICAgdGhpcy5yZXRyaWV2ZVJldmlzaW9ucyA9IHRoaXMucmV0cmlldmVSZXZpc2lvbnMuYmluZCh0aGlzKTtcbiAgICB0aGlzLmdldFByZXZpb3VzUmV2aXNpb24gPSB0aGlzLmdldFByZXZpb3VzUmV2aXNpb24uYmluZCh0aGlzKTtcbiAgICB0aGlzLmZldGNoUGFnZVJldmlzaW9uQm9keSA9IHRoaXMuZmV0Y2hQYWdlUmV2aXNpb25Cb2R5LmJpbmQodGhpcyk7XG4gIH1cblxuICAvKipcbiAgICogV29ya2Fyb3VuZCBmb3IgdGhlIG1hbmdsaW5nIGluIHByb2R1Y3Rpb24gYnVpbGQgdG8gYnJlYWsgY29uc3RydWN0b3IubmFtZVxuICAgKi9cbiAgc3RhdGljIGdldENsYXNzTmFtZSgpIHtcbiAgICByZXR1cm4gJ1BhZ2VIaXN0b3J5Q29udGFpbmVyJztcbiAgfVxuXG4gIC8qKlxuICAgKiBzeW5jUmV2aXNpb25zIG9mIHNlbGVjdGVkUGFnZVxuICAgKiBAcGFyYW0ge251bWJlcn0gc2VsZWN0ZWRQYWdlXG4gICAqL1xuICBhc3luYyByZXRyaWV2ZVJldmlzaW9ucyhzZWxlY3RlZFBhZ2UpIHtcbiAgICBjb25zdCB7IHBhZ2VJZCwgc2hhcmVMaW5rSWQgfSA9IHRoaXMucGFnZUNvbnRhaW5lci5zdGF0ZTtcbiAgICBjb25zdCB7IHBhZ2luZ0xpbWl0IH0gPSB0aGlzLnN0YXRlO1xuICAgIGNvbnN0IHBhZ2UgPSBzZWxlY3RlZFBhZ2U7XG4gICAgY29uc3QgcGFnaW5nTGltaXRGb3JBcGlQYXJhbSA9IHBhZ2luZ0xpbWl0ICsgMTtcblxuICAgIGlmICghcGFnZUlkKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgLy8gR2V0IG9uZSBtb3JlIGZvciB0aGUgYm90dG9tIGRpc3BsYXlcbiAgICBjb25zdCByZXMgPSBhd2FpdCB0aGlzLmFwcENvbnRhaW5lci5hcGl2M0dldCgnL3JldmlzaW9ucy9saXN0Jywge1xuICAgICAgcGFnZUlkLCBzaGFyZUxpbmtJZCwgcGFnZSwgbGltaXQ6IHBhZ2luZ0xpbWl0Rm9yQXBpUGFyYW0sXG4gICAgfSk7XG4gICAgY29uc3QgcmV2ID0gcmVzLmRhdGEuZG9jcztcbiAgICAvLyBzZXQgUGFnaW5hdGlvbiBzdGF0ZVxuICAgIHRoaXMuc2V0U3RhdGUoe1xuICAgICAgYWN0aXZlUGFnZTogc2VsZWN0ZWRQYWdlLFxuICAgICAgdG90YWxQYWdlczogcmVzLmRhdGEudG90YWxEb2NzLFxuICAgICAgcGFnaW5nTGltaXQsXG4gICAgfSk7XG5cbiAgICBjb25zdCBkaWZmT3BlbmVkID0ge307XG5cbiAgICBsZXQgbGFzdElkID0gcmV2Lmxlbmd0aCAtIDE7XG5cbiAgICAvLyBJZiB0aGUgbnVtYmVyIG9mIHJldiBjb3VudCBpcyB0aGUgc2FtZSwgdGhlIGxhc3QgcmV2IGlzIGZvciBkaWZmIGRpc3BsYXksIHNvIGV4Y2x1ZGUgaXQuXG4gICAgaWYgKHJldi5sZW5ndGggPiBwYWdpbmdMaW1pdCkge1xuICAgICAgbGFzdElkID0gcmV2Lmxlbmd0aCAtIDI7XG4gICAgfVxuXG4gICAgcmVzLmRhdGEuZG9jcy5mb3JFYWNoKChyZXZpc2lvbiwgaSkgPT4ge1xuICAgICAgY29uc3QgdXNlciA9IHJldmlzaW9uLmF1dGhvcjtcbiAgICAgIGlmICh1c2VyKSB7XG4gICAgICAgIHJldltpXS5hdXRob3IgPSB1c2VyO1xuICAgICAgfVxuXG4gICAgICBpZiAoaSA9PT0gMCB8fCBpID09PSBsYXN0SWQpIHtcbiAgICAgICAgZGlmZk9wZW5lZFtyZXZpc2lvbi5faWRdID0gdHJ1ZTtcbiAgICAgIH1cbiAgICAgIGVsc2Uge1xuICAgICAgICBkaWZmT3BlbmVkW3JldmlzaW9uLl9pZF0gPSBmYWxzZTtcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIHRoaXMuc2V0U3RhdGUoeyByZXZpc2lvbnM6IHJldiB9KTtcbiAgICB0aGlzLnNldFN0YXRlKHsgZGlmZk9wZW5lZCB9KTtcblxuICAgIGlmIChzZWxlY3RlZFBhZ2UgPT09IDEpIHtcbiAgICAgIHRoaXMuc2V0U3RhdGUoeyBsYXRlc3RSZXZpc2lvbjogcmV2WzBdIH0pO1xuICAgIH1cblxuICAgIGlmIChzZWxlY3RlZFBhZ2UgPT09IHJlcy5kYXRhLnRvdGFsUGFnZXMpIHtcbiAgICAgIHRoaXMuc2V0U3RhdGUoeyBvbGRlc3RSZXZpc2lvbjogcmV2W2xhc3RJZF0gfSk7XG4gICAgfVxuXG4gICAgLy8gbG9hZCAwLCBhbmQgbGFzdCBkZWZhdWx0XG4gICAgaWYgKHJldlswXSkge1xuICAgICAgdGhpcy5mZXRjaFBhZ2VSZXZpc2lvbkJvZHkocmV2WzBdKTtcbiAgICB9XG4gICAgaWYgKHJldlsxXSkge1xuICAgICAgdGhpcy5mZXRjaFBhZ2VSZXZpc2lvbkJvZHkocmV2WzFdKTtcbiAgICB9XG4gICAgaWYgKGxhc3RJZCAhPT0gMCAmJiBsYXN0SWQgIT09IDEgJiYgcmV2W2xhc3RJZF0pIHtcbiAgICAgIHRoaXMuZmV0Y2hQYWdlUmV2aXNpb25Cb2R5KHJldltsYXN0SWRdKTtcbiAgICB9XG5cbiAgICByZXR1cm47XG4gIH1cblxuICBnZXRQcmV2aW91c1JldmlzaW9uKGN1cnJlbnRSZXZpc2lvbikge1xuICAgIGxldCBjdXJzb3IgPSBudWxsO1xuICAgIGZvciAoY29uc3QgcmV2aXNpb24gb2YgdGhpcy5zdGF0ZS5yZXZpc2lvbnMpIHtcbiAgICAgIC8vIGNvbXBhcmluZyBPYmplY3RJZFxuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGVxZXFlcVxuICAgICAgaWYgKGN1cnNvciAmJiBjdXJzb3IuX2lkID09IGN1cnJlbnRSZXZpc2lvbi5faWQpIHtcbiAgICAgICAgY3Vyc29yID0gcmV2aXNpb247XG4gICAgICAgIGJyZWFrO1xuICAgICAgfVxuXG4gICAgICBjdXJzb3IgPSByZXZpc2lvbjtcbiAgICB9XG5cbiAgICByZXR1cm4gY3Vyc29yO1xuICB9XG5cbiAgLyoqXG4gICAqIGZldGNoIHBhZ2UgcmV2aXNpb24gYm9keSBieSByZXZpc2lvbiBpbiBhcmd1bWVudFxuICAgKiBAcGFyYW0ge29iamVjdH0gcmV2aXNpb25cbiAgICovXG4gIGFzeW5jIGZldGNoUGFnZVJldmlzaW9uQm9keShyZXZpc2lvbikge1xuICAgIGNvbnN0IHsgcGFnZUlkLCBzaGFyZUxpbmtJZCB9ID0gdGhpcy5wYWdlQ29udGFpbmVyLnN0YXRlO1xuXG4gICAgaWYgKHJldmlzaW9uLmJvZHkpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICB0cnkge1xuICAgICAgY29uc3QgcmVzID0gYXdhaXQgdGhpcy5hcHBDb250YWluZXIuYXBpdjNHZXQoYC9yZXZpc2lvbnMvJHtyZXZpc2lvbi5faWR9YCwgeyBwYWdlSWQsIHNoYXJlTGlua0lkIH0pO1xuICAgICAgdGhpcy5zZXRTdGF0ZSh7XG4gICAgICAgIHJldmlzaW9uczogdGhpcy5zdGF0ZS5yZXZpc2lvbnMubWFwKChyZXYpID0+IHtcbiAgICAgICAgICAvLyBjb21wYXJpbmcgT2JqZWN0SWRcbiAgICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgZXFlcWVxXG4gICAgICAgICAgaWYgKHJldi5faWQgPT0gcmVzLmRhdGEucmV2aXNpb24uX2lkKSB7XG4gICAgICAgICAgICByZXR1cm4gcmVzLmRhdGEucmV2aXNpb247XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgcmV0dXJuIHJldjtcbiAgICAgICAgfSksXG4gICAgICB9KTtcbiAgICB9XG4gICAgY2F0Y2ggKGVycikge1xuICAgICAgdG9hc3RFcnJvcihlcnIpO1xuICAgICAgdGhpcy5zZXRTdGF0ZSh7IGVycm9yTWVzc2FnZTogZXJyLm1lc3NhZ2UgfSk7XG4gICAgICBsb2dnZXIuZXJyb3IoZXJyKTtcbiAgICB9XG4gIH1cblxuXG59XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBRUE7QUFFQTtBQUVBO0FBRUE7Ozs7O0FBSUE7QUFFQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFYQTtBQWNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7Ozs7O0FBR0E7QUFDQTtBQUNBO0FBRUE7Ozs7OztBQUlBO0FBQ0E7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQUE7QUFBQTtBQURBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBSEE7QUFNQTtBQUVBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBRUE7QUFBQTtBQUFBO0FBQ0E7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7Ozs7OztBQUlBO0FBQ0E7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBVEE7QUFXQTtBQUVBO0FBQ0E7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUE1SkEiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/client/js/services/PageHistoryContainer.js\n");
/***/ }),
/***/ "./src/client/js/services/PersonalContainer.js":
/*!*****************************************************!*\
!*** ./src/client/js/services/PersonalContainer.js ***!
\*****************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return PersonalContainer; });\n/* harmony import */ var unstated__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! unstated */ \"./node_modules/unstated/lib/unstated.es.js\");\n/* harmony import */ var _alias_logger__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @alias/logger */ \"./src/lib/service/logger/index.js\");\n/* harmony import */ var _alias_logger__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_alias_logger__WEBPACK_IMPORTED_MODULE_1__);\n\n // eslint-disable-next-line no-unused-vars\n\nconst logger = _alias_logger__WEBPACK_IMPORTED_MODULE_1___default()('growi:services:PersonalContainer');\nconst DEFAULT_IMAGE = '/images/icons/user.svg';\n/**\n * Service container for personal settings page (PersonalSettings.jsx)\n * @extends {Container} unstated Container\n */\n\nclass PersonalContainer extends unstated__WEBPACK_IMPORTED_MODULE_0__[\"Container\"] {\n constructor(appContainer) {\n super();\n this.appContainer = appContainer;\n this.state = {\n retrieveError: null,\n name: '',\n email: '',\n registrationWhiteList: this.appContainer.getConfig().registrationWhiteList,\n isEmailPublished: false,\n lang: 'en_US',\n isGravatarEnabled: false,\n isUploadedPicture: false,\n uploadedPictureSrc: this.getUploadedPictureSrc(this.appContainer.currentUser),\n externalAccounts: [],\n apiToken: ''\n };\n }\n /**\n * Workaround for the mangling in production build to break constructor.name\n */\n\n\n static getClassName() {\n return 'PersonalContainer';\n }\n /**\n * retrieve personal data\n */\n\n\n async retrievePersonalData() {\n try {\n const response = await this.appContainer.apiv3.get('/personal-setting/');\n const {\n currentUser\n } = response.data;\n this.setState({\n name: currentUser.name,\n email: currentUser.email,\n isEmailPublished: currentUser.isEmailPublished,\n lang: currentUser.lang,\n isGravatarEnabled: currentUser.isGravatarEnabled,\n apiToken: currentUser.apiToken\n });\n } catch (err) {\n this.setState({\n retrieveError: err\n });\n logger.error(err);\n throw new Error('Failed to fetch personal data');\n }\n }\n /**\n * define a function for uploaded picture\n */\n\n\n getUploadedPictureSrc(user) {\n if (user == null) {\n return DEFAULT_IMAGE;\n }\n\n if (user.image) {\n this.setState({\n isUploadedPicture: true\n });\n return user.image;\n }\n\n if (user.imageAttachment != null) {\n this.setState({\n isUploadedPicture: true\n });\n return user.imageAttachment.filePathProxied;\n }\n\n return DEFAULT_IMAGE;\n }\n /**\n * retrieve external accounts that linked me\n */\n\n\n async retrieveExternalAccounts() {\n try {\n const response = await this.appContainer.apiv3.get('/personal-setting/external-accounts');\n const {\n externalAccounts\n } = response.data;\n this.setState({\n externalAccounts\n });\n } catch (err) {\n this.setState({\n retrieveError: err\n });\n logger.error(err);\n throw new Error('Failed to fetch external accounts');\n }\n }\n /**\n * Change name\n */\n\n\n changeName(inputValue) {\n this.setState({\n name: inputValue\n });\n }\n /**\n * Change email\n */\n\n\n changeEmail(inputValue) {\n this.setState({\n email: inputValue\n });\n }\n /**\n * Change isEmailPublished\n */\n\n\n changeIsEmailPublished(boolean) {\n this.setState({\n isEmailPublished: boolean\n });\n }\n /**\n * Change lang\n */\n\n\n changeLang(lang) {\n this.setState({\n lang\n });\n }\n /**\n * Change isGravatarEnabled\n */\n\n\n changeIsGravatarEnabled(boolean) {\n this.setState({\n isGravatarEnabled: boolean\n });\n }\n /**\n * Update basic info\n * @memberOf PersonalContainer\n * @return {Array} basic info\n */\n\n\n async updateBasicInfo() {\n try {\n const response = await this.appContainer.apiv3.put('/personal-setting/', {\n name: this.state.name,\n email: this.state.email,\n isEmailPublished: this.state.isEmailPublished,\n lang: this.state.lang\n });\n const {\n updatedUser\n } = response.data;\n this.setState({\n name: updatedUser.name,\n email: updatedUser.email,\n isEmailPublished: updatedUser.isEmailPublished,\n lang: updatedUser.lang\n });\n } catch (err) {\n this.setState({\n retrieveError: err\n });\n logger.error(err);\n throw new Error('Failed to update personal data');\n }\n }\n /**\n * Update profile image\n * @memberOf PersonalContainer\n */\n\n\n async updateProfileImage() {\n try {\n const response = await this.appContainer.apiv3.put('/personal-setting/image-type', {\n isGravatarEnabled: this.state.isGravatarEnabled\n });\n const {\n userData\n } = response.data;\n this.setState({\n isGravatarEnabled: userData.isGravatarEnabled\n });\n } catch (err) {\n this.setState({\n retrieveError: err\n });\n logger.error(err);\n throw new Error('Failed to update profile image');\n }\n }\n /**\n * Upload image\n */\n\n\n async uploadAttachment(file) {\n try {\n const formData = new FormData();\n formData.append('file', file);\n formData.append('_csrf', this.appContainer.csrfToken);\n const response = await this.appContainer.apiPost('/attachments.uploadProfileImage', formData);\n this.setState({\n isUploadedPicture: true,\n uploadedPictureSrc: response.attachment.filePathProxied\n });\n } catch (err) {\n this.setState({\n retrieveError: err\n });\n logger.error(err);\n throw new Error('Failed to upload profile image');\n }\n }\n /**\n * Delete image\n */\n\n\n async deleteProfileImage() {\n try {\n await this.appContainer.apiPost('/attachments.removeProfileImage', {\n _csrf: this.appContainer.csrfToken\n });\n this.setState({\n isUploadedPicture: false,\n uploadedPictureSrc: DEFAULT_IMAGE\n });\n } catch (err) {\n this.setState({\n retrieveError: err\n });\n logger.error(err);\n throw new Error('Failed to delete profile image');\n }\n }\n /**\n * Associate LDAP account\n */\n\n\n async associateLdapAccount(account) {\n try {\n await this.appContainer.apiv3.put('/personal-setting/associate-ldap', account);\n } catch (err) {\n this.setState({\n retrieveError: err\n });\n logger.error(err);\n throw new Error('Failed to associate ldap account');\n }\n }\n /**\n * Disassociate LDAP account\n */\n\n\n async disassociateLdapAccount(account) {\n try {\n await this.appContainer.apiv3.put('/personal-setting/disassociate-ldap', account);\n } catch (err) {\n this.setState({\n retrieveError: err\n });\n logger.error(err);\n throw new Error('Failed to disassociate ldap account');\n }\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/client/js/services/PersonalContainer.js.js","sources":["webpack:///./src/client/js/services/PersonalContainer.js?7d8e"],"sourcesContent":["import { Container } from 'unstated';\n\nimport loggerFactory from '@alias/logger';\n\n// eslint-disable-next-line no-unused-vars\nconst logger = loggerFactory('growi:services:PersonalContainer');\n\nconst DEFAULT_IMAGE = '/images/icons/user.svg';\n\n/**\n * Service container for personal settings page (PersonalSettings.jsx)\n * @extends {Container} unstated Container\n */\nexport default class PersonalContainer extends Container {\n\n  constructor(appContainer) {\n    super();\n\n    this.appContainer = appContainer;\n\n    this.state = {\n      retrieveError: null,\n      name: '',\n      email: '',\n      registrationWhiteList: this.appContainer.getConfig().registrationWhiteList,\n      isEmailPublished: false,\n      lang: 'en_US',\n      isGravatarEnabled: false,\n      isUploadedPicture: false,\n      uploadedPictureSrc: this.getUploadedPictureSrc(this.appContainer.currentUser),\n      externalAccounts: [],\n      apiToken: '',\n    };\n\n  }\n\n  /**\n   * Workaround for the mangling in production build to break constructor.name\n   */\n  static getClassName() {\n    return 'PersonalContainer';\n  }\n\n  /**\n   * retrieve personal data\n   */\n  async retrievePersonalData() {\n    try {\n      const response = await this.appContainer.apiv3.get('/personal-setting/');\n      const { currentUser } = response.data;\n      this.setState({\n        name: currentUser.name,\n        email: currentUser.email,\n        isEmailPublished: currentUser.isEmailPublished,\n        lang: currentUser.lang,\n        isGravatarEnabled: currentUser.isGravatarEnabled,\n        apiToken: currentUser.apiToken,\n      });\n    }\n    catch (err) {\n      this.setState({ retrieveError: err });\n      logger.error(err);\n      throw new Error('Failed to fetch personal data');\n    }\n  }\n\n  /**\n   * define a function for uploaded picture\n   */\n  getUploadedPictureSrc(user) {\n    if (user == null) {\n      return DEFAULT_IMAGE;\n    }\n    if (user.image) {\n      this.setState({ isUploadedPicture: true });\n      return user.image;\n    }\n    if (user.imageAttachment != null) {\n      this.setState({ isUploadedPicture: true });\n      return user.imageAttachment.filePathProxied;\n    }\n\n    return DEFAULT_IMAGE;\n  }\n\n  /**\n   * retrieve external accounts that linked me\n   */\n  async retrieveExternalAccounts() {\n    try {\n      const response = await this.appContainer.apiv3.get('/personal-setting/external-accounts');\n      const { externalAccounts } = response.data;\n\n      this.setState({ externalAccounts });\n    }\n    catch (err) {\n      this.setState({ retrieveError: err });\n      logger.error(err);\n      throw new Error('Failed to fetch external accounts');\n    }\n  }\n\n  /**\n   * Change name\n   */\n  changeName(inputValue) {\n    this.setState({ name: inputValue });\n  }\n\n  /**\n   * Change email\n   */\n  changeEmail(inputValue) {\n    this.setState({ email: inputValue });\n  }\n\n  /**\n   * Change isEmailPublished\n   */\n  changeIsEmailPublished(boolean) {\n    this.setState({ isEmailPublished: boolean });\n  }\n\n  /**\n   * Change lang\n   */\n  changeLang(lang) {\n    this.setState({ lang });\n  }\n\n  /**\n   * Change isGravatarEnabled\n   */\n  changeIsGravatarEnabled(boolean) {\n    this.setState({ isGravatarEnabled: boolean });\n  }\n\n  /**\n   * Update basic info\n   * @memberOf PersonalContainer\n   * @return {Array} basic info\n   */\n  async updateBasicInfo() {\n    try {\n      const response = await this.appContainer.apiv3.put('/personal-setting/', {\n        name: this.state.name,\n        email: this.state.email,\n        isEmailPublished: this.state.isEmailPublished,\n        lang: this.state.lang,\n      });\n      const { updatedUser } = response.data;\n\n      this.setState({\n        name: updatedUser.name,\n        email: updatedUser.email,\n        isEmailPublished: updatedUser.isEmailPublished,\n        lang: updatedUser.lang,\n      });\n    }\n    catch (err) {\n      this.setState({ retrieveError: err });\n      logger.error(err);\n      throw new Error('Failed to update personal data');\n    }\n  }\n\n  /**\n   * Update profile image\n   * @memberOf PersonalContainer\n   */\n  async updateProfileImage() {\n    try {\n      const response = await this.appContainer.apiv3.put('/personal-setting/image-type', {\n        isGravatarEnabled: this.state.isGravatarEnabled,\n      });\n      const { userData } = response.data;\n      this.setState({\n        isGravatarEnabled: userData.isGravatarEnabled,\n      });\n    }\n    catch (err) {\n      this.setState({ retrieveError: err });\n      logger.error(err);\n      throw new Error('Failed to update profile image');\n    }\n  }\n\n  /**\n   * Upload image\n   */\n  async uploadAttachment(file) {\n    try {\n      const formData = new FormData();\n      formData.append('file', file);\n      formData.append('_csrf', this.appContainer.csrfToken);\n      const response = await this.appContainer.apiPost('/attachments.uploadProfileImage', formData);\n      this.setState({ isUploadedPicture: true, uploadedPictureSrc: response.attachment.filePathProxied });\n    }\n    catch (err) {\n      this.setState({ retrieveError: err });\n      logger.error(err);\n      throw new Error('Failed to upload profile image');\n    }\n  }\n\n  /**\n   * Delete image\n   */\n  async deleteProfileImage() {\n    try {\n      await this.appContainer.apiPost('/attachments.removeProfileImage', { _csrf: this.appContainer.csrfToken });\n      this.setState({ isUploadedPicture: false, uploadedPictureSrc: DEFAULT_IMAGE });\n    }\n    catch (err) {\n      this.setState({ retrieveError: err });\n      logger.error(err);\n      throw new Error('Failed to delete profile image');\n    }\n  }\n\n  /**\n   * Associate LDAP account\n   */\n  async associateLdapAccount(account) {\n    try {\n      await this.appContainer.apiv3.put('/personal-setting/associate-ldap', account);\n    }\n    catch (err) {\n      this.setState({ retrieveError: err });\n      logger.error(err);\n      throw new Error('Failed to associate ldap account');\n    }\n  }\n\n  /**\n   * Disassociate LDAP account\n   */\n  async disassociateLdapAccount(account) {\n    try {\n      await this.appContainer.apiv3.put('/personal-setting/disassociate-ldap', account);\n    }\n    catch (err) {\n      this.setState({ retrieveError: err });\n      logger.error(err);\n      throw new Error('Failed to disassociate ldap account');\n    }\n  }\n\n}\n"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA;AACA;AAEA;AAEA;AAEA;;;;;AAIA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAXA;AAcA;AAEA;;;;;AAGA;AACA;AACA;AAEA;;;;;AAGA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AANA;AAQA;AAEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAEA;;;;;AAGA;AACA;AACA;AACA;AACA;AAAA;AACA;AAAA;AAAA;AACA;AACA;AACA;AAAA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;AAGA;AACA;AACA;AACA;AAAA;AAAA;AAEA;AAAA;AAAA;AACA;AAEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAEA;;;;;AAGA;AACA;AAAA;AAAA;AACA;AAEA;;;;;AAGA;AACA;AAAA;AAAA;AACA;AAEA;;;;;AAGA;AACA;AAAA;AAAA;AACA;AAEA;;;;;AAGA;AACA;AAAA;AAAA;AACA;AAEA;;;;;AAGA;AACA;AAAA;AAAA;AACA;AAEA;;;;;;;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AAJA;AAMA;AAAA;AAAA;AAEA;AACA;AACA;AACA;AACA;AAJA;AAMA;AAEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAEA;;;;;;AAIA;AACA;AACA;AACA;AADA;AAGA;AAAA;AAAA;AACA;AACA;AADA;AAGA;AAEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAEA;;;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AAEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAEA;;;;;AAGA;AACA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AACA;AAEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAEA;;;;;AAGA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAEA;;;;;AAGA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AA1OA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/client/js/services/PersonalContainer.js\n");
/***/ }),
/***/ "./src/client/js/services/RevisionComparerContainer.js":
/*!*************************************************************!*\
!*** ./src/client/js/services/RevisionComparerContainer.js ***!
\*************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return RevisionComparerContainer; });\n/* harmony import */ var unstated__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! unstated */ \"./node_modules/unstated/lib/unstated.es.js\");\n/* harmony import */ var _alias_logger__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @alias/logger */ \"./src/lib/service/logger/index.js\");\n/* harmony import */ var _alias_logger__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_alias_logger__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _util_apiNotification__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../util/apiNotification */ \"./src/client/js/util/apiNotification.js\");\n\n\n\nconst logger = _alias_logger__WEBPACK_IMPORTED_MODULE_1___default()('growi:PageHistoryContainer');\n/**\n * Service container for personal settings page (RevisionCompare.jsx)\n * @extends {Container} unstated Container\n */\n\nclass RevisionComparerContainer extends unstated__WEBPACK_IMPORTED_MODULE_0__[\"Container\"] {\n constructor(appContainer, pageContainer) {\n super();\n this.appContainer = appContainer;\n this.pageContainer = pageContainer;\n this.state = {\n errMessage: null,\n sourceRevision: null,\n targetRevision: null,\n latestRevision: null\n };\n this.initRevisions = this.initRevisions.bind(this);\n }\n /**\n * Workaround for the mangling in production build to break constructor.name\n */\n\n\n static getClassName() {\n return 'RevisionComparerContainer';\n }\n /**\n * Initialize the revisions\n */\n\n\n async initRevisions() {\n const latestRevision = await this.fetchLatestRevision();\n const [sourceRevisionId, targetRevisionId] = this.getRevisionIDsToCompareAsParam();\n const sourceRevision = sourceRevisionId ? await this.fetchRevision(sourceRevisionId) : latestRevision;\n const targetRevision = targetRevisionId ? await this.fetchRevision(targetRevisionId) : latestRevision;\n const compareWithLatest = targetRevisionId ? false : this.state.compareWithLatest;\n this.setState({\n sourceRevision,\n targetRevision,\n latestRevision,\n compareWithLatest\n });\n }\n /**\n * Get the IDs of the comparison source and target from \"window.location\" as an array\n */\n\n\n getRevisionIDsToCompareAsParam() {\n const searchParams = {};\n\n for (const param of (_window$location$sear = window.location.search) === null || _window$location$sear === void 0 ? void 0 : (_window$location$sear2 = _window$location$sear.substr(1)) === null || _window$location$sear2 === void 0 ? void 0 : _window$location$sear2.split('&')) {\n var _window$location$sear, _window$location$sear2;\n\n const [k, v] = param.split('=');\n searchParams[k] = v;\n }\n\n if (!searchParams.compare) {\n return [];\n }\n\n return searchParams.compare.split('...') || [];\n }\n /**\n * Fetch the latest revision\n */\n\n\n async fetchLatestRevision() {\n const {\n pageId,\n shareLinkId\n } = this.pageContainer.state;\n\n try {\n const res = await this.appContainer.apiv3Get('/revisions/list', {\n pageId,\n shareLinkId,\n page: 1,\n limit: 1\n });\n return res.data.docs[0];\n } catch (err) {\n Object(_util_apiNotification__WEBPACK_IMPORTED_MODULE_2__[\"toastError\"])(err);\n this.setState({\n errorMessage: err.message\n });\n logger.error(err);\n }\n\n return null;\n }\n /**\n * Fetch the revision of the specified ID\n * @param {string} revision ID\n */\n\n\n async fetchRevision(revisionId) {\n const {\n pageId,\n shareLinkId\n } = this.pageContainer.state;\n\n try {\n const res = await this.appContainer.apiv3Get(`/revisions/${revisionId}`, {\n pageId,\n shareLinkId\n });\n return res.data.revision;\n } catch (err) {\n Object(_util_apiNotification__WEBPACK_IMPORTED_MODULE_2__[\"toastError\"])(err);\n this.setState({\n errorMessage: err.message\n });\n logger.error(err);\n }\n\n return null;\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvY2xpZW50L2pzL3NlcnZpY2VzL1JldmlzaW9uQ29tcGFyZXJDb250YWluZXIuanMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvY2xpZW50L2pzL3NlcnZpY2VzL1JldmlzaW9uQ29tcGFyZXJDb250YWluZXIuanM/Njk0ZSJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb250YWluZXIgfSBmcm9tICd1bnN0YXRlZCc7XG5cbmltcG9ydCBsb2dnZXJGYWN0b3J5IGZyb20gJ0BhbGlhcy9sb2dnZXInO1xuXG5pbXBvcnQgeyB0b2FzdEVycm9yIH0gZnJvbSAnLi4vdXRpbC9hcGlOb3RpZmljYXRpb24nO1xuXG5jb25zdCBsb2dnZXIgPSBsb2dnZXJGYWN0b3J5KCdncm93aTpQYWdlSGlzdG9yeUNvbnRhaW5lcicpO1xuXG4vKipcbiAqIFNlcnZpY2UgY29udGFpbmVyIGZvciBwZXJzb25hbCBzZXR0aW5ncyBwYWdlIChSZXZpc2lvbkNvbXBhcmUuanN4KVxuICogQGV4dGVuZHMge0NvbnRhaW5lcn0gdW5zdGF0ZWQgQ29udGFpbmVyXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFJldmlzaW9uQ29tcGFyZXJDb250YWluZXIgZXh0ZW5kcyBDb250YWluZXIge1xuXG4gIGNvbnN0cnVjdG9yKGFwcENvbnRhaW5lciwgcGFnZUNvbnRhaW5lcikge1xuICAgIHN1cGVyKCk7XG5cbiAgICB0aGlzLmFwcENvbnRhaW5lciA9IGFwcENvbnRhaW5lcjtcbiAgICB0aGlzLnBhZ2VDb250YWluZXIgPSBwYWdlQ29udGFpbmVyO1xuXG4gICAgdGhpcy5zdGF0ZSA9IHtcbiAgICAgIGVyck1lc3NhZ2U6IG51bGwsXG5cbiAgICAgIHNvdXJjZVJldmlzaW9uOiBudWxsLFxuICAgICAgdGFyZ2V0UmV2aXNpb246IG51bGwsXG4gICAgICBsYXRlc3RSZXZpc2lvbjogbnVsbCxcbiAgICB9O1xuXG4gICAgdGhpcy5pbml0UmV2aXNpb25zID0gdGhpcy5pbml0UmV2aXNpb25zLmJpbmQodGhpcyk7XG4gIH1cblxuICAvKipcbiAgICogV29ya2Fyb3VuZCBmb3IgdGhlIG1hbmdsaW5nIGluIHByb2R1Y3Rpb24gYnVpbGQgdG8gYnJlYWsgY29uc3RydWN0b3IubmFtZVxuICAgKi9cbiAgc3RhdGljIGdldENsYXNzTmFtZSgpIHtcbiAgICByZXR1cm4gJ1JldmlzaW9uQ29tcGFyZXJDb250YWluZXInO1xuICB9XG5cbiAgLyoqXG4gICAqIEluaXRpYWxpemUgdGhlIHJldmlzaW9uc1xuICAgKi9cbiAgYXN5bmMgaW5pdFJldmlzaW9ucygpIHtcbiAgICBjb25zdCBsYXRlc3RSZXZpc2lvbiA9IGF3YWl0IHRoaXMuZmV0Y2hMYXRlc3RSZXZpc2lvbigpO1xuXG4gICAgY29uc3QgW3NvdXJjZVJldmlzaW9uSWQsIHRhcmdldFJldmlzaW9uSWRdID0gdGhpcy5nZXRSZXZpc2lvbklEc1RvQ29tcGFyZUFzUGFyYW0oKTtcbiAgICBjb25zdCBzb3VyY2VSZXZpc2lvbiA9IHNvdXJjZVJldmlzaW9uSWQgPyBhd2FpdCB0aGlzLmZldGNoUmV2aXNpb24oc291cmNlUmV2aXNpb25JZCkgOiBsYXRlc3RSZXZpc2lvbjtcbiAgICBjb25zdCB0YXJnZXRSZXZpc2lvbiA9IHRhcmdldFJldmlzaW9uSWQgPyBhd2FpdCB0aGlzLmZldGNoUmV2aXNpb24odGFyZ2V0UmV2aXNpb25JZCkgOiBsYXRlc3RSZXZpc2lvbjtcbiAgICBjb25zdCBjb21wYXJlV2l0aExhdGVzdCA9IHRhcmdldFJldmlzaW9uSWQgPyBmYWxzZSA6IHRoaXMuc3RhdGUuY29tcGFyZVdpdGhMYXRlc3Q7XG5cbiAgICB0aGlzLnNldFN0YXRlKHtcbiAgICAgIHNvdXJjZVJldmlzaW9uLCB0YXJnZXRSZXZpc2lvbiwgbGF0ZXN0UmV2aXNpb24sIGNvbXBhcmVXaXRoTGF0ZXN0LFxuICAgIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCB0aGUgSURzIG9mIHRoZSBjb21wYXJpc29uIHNvdXJjZSBhbmQgdGFyZ2V0IGZyb20gXCJ3aW5kb3cubG9jYXRpb25cIiBhcyBhbiBhcnJheVxuICAgKi9cbiAgZ2V0UmV2aXNpb25JRHNUb0NvbXBhcmVBc1BhcmFtKCkge1xuICAgIGNvbnN0IHNlYXJjaFBhcmFtcyA9IHt9O1xuICAgIGZvciAoY29uc3QgcGFyYW0gb2Ygd2luZG93LmxvY2F0aW9uLnNlYXJjaD8uc3Vic3RyKDEpPy5zcGxpdCgnJicpKSB7XG4gICAgICBjb25zdCBbaywgdl0gPSBwYXJhbS5zcGxpdCgnPScpO1xuICAgICAgc2VhcmNoUGFyYW1zW2tdID0gdjtcbiAgICB9XG4gICAgaWYgKCFzZWFyY2hQYXJhbXMuY29tcGFyZSkge1xuICAgICAgcmV0dXJuIFtdO1xuICAgIH1cblxuICAgIHJldHVybiBzZWFyY2hQYXJhbXMuY29tcGFyZS5zcGxpdCgnLi4uJykgfHwgW107XG4gIH1cblxuICAvKipcbiAgICogRmV0Y2ggdGhlIGxhdGVzdCByZXZpc2lvblxuICAgKi9cbiAgYXN5bmMgZmV0Y2hMYXRlc3RSZXZpc2lvbigpIHtcbiAgICBjb25zdCB7IHBhZ2VJZCwgc2hhcmVMaW5rSWQgfSA9IHRoaXMucGFnZUNvbnRhaW5lci5zdGF0ZTtcblxuICAgIHRyeSB7XG4gICAgICBjb25zdCByZXMgPSBhd2FpdCB0aGlzLmFwcENvbnRhaW5lci5hcGl2M0dldCgnL3JldmlzaW9ucy9saXN0Jywge1xuICAgICAgICBwYWdlSWQsIHNoYXJlTGlua0lkLCBwYWdlOiAxLCBsaW1pdDogMSxcbiAgICAgIH0pO1xuICAgICAgcmV0dXJuIHJlcy5kYXRhLmRvY3NbMF07XG4gICAgfVxuICAgIGNhdGNoIChlcnIpIHtcbiAgICAgIHRvYXN0RXJyb3IoZXJyKTtcbiAgICAgIHRoaXMuc2V0U3RhdGUoeyBlcnJvck1lc3NhZ2U6IGVyci5tZXNzYWdlIH0pO1xuICAgICAgbG9nZ2VyLmVycm9yKGVycik7XG4gICAgfVxuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgLyoqXG4gICAqIEZldGNoIHRoZSByZXZpc2lvbiBvZiB0aGUgc3BlY2lmaWVkIElEXG4gICAqIEBwYXJhbSB7c3RyaW5nfSByZXZpc2lvbiBJRFxuICAgKi9cbiAgYXN5bmMgZmV0Y2hSZXZpc2lvbihyZXZpc2lvbklkKSB7XG4gICAgY29uc3QgeyBwYWdlSWQsIHNoYXJlTGlua0lkIH0gPSB0aGlzLnBhZ2VDb250YWluZXIuc3RhdGU7XG5cbiAgICB0cnkge1xuICAgICAgY29uc3QgcmVzID0gYXdhaXQgdGhpcy5hcHBDb250YWluZXIuYXBpdjNHZXQoYC9yZXZpc2lvbnMvJHtyZXZpc2lvbklkfWAsIHtcbiAgICAgICAgcGFnZUlkLCBzaGFyZUxpbmtJZCxcbiAgICAgIH0pO1xuICAgICAgcmV0dXJuIHJlcy5kYXRhLnJldmlzaW9uO1xuICAgIH1cbiAgICBjYXRjaCAoZXJyKSB7XG4gICAgICB0b2FzdEVycm9yKGVycik7XG4gICAgICB0aGlzLnNldFN0YXRlKHsgZXJyb3JNZXNzYWdlOiBlcnIubWVzc2FnZSB9KTtcbiAgICAgIGxvZ2dlci5lcnJvcihlcnIpO1xuICAgIH1cbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG59XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBRUE7QUFFQTtBQUVBO0FBRUE7Ozs7O0FBSUE7QUFFQTtBQUNBO0FBRUE7QUFDQTtBQUVBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFMQTtBQVFBO0FBQ0E7QUFFQTs7Ozs7QUFHQTtBQUNBO0FBQ0E7QUFFQTs7Ozs7QUFHQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQUE7QUFBQTtBQUFBO0FBREE7QUFHQTtBQUVBOzs7OztBQUdBO0FBQ0E7QUFDQTtBQUFBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7Ozs7O0FBR0E7QUFDQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFBQTtBQUFBO0FBREE7QUFHQTtBQUNBO0FBRUE7QUFDQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBRUE7Ozs7OztBQUlBO0FBQ0E7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBREE7QUFHQTtBQUNBO0FBRUE7QUFDQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFsR0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/client/js/services/RevisionComparerContainer.js\n");
/***/ }),
/***/ "./src/client/js/services/TagContainer.js":
/*!************************************************!*\
!*** ./src/client/js/services/TagContainer.js ***!
\************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return TagContainer; });\n/* harmony import */ var unstated__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! unstated */ \"./node_modules/unstated/lib/unstated.es.js\");\n/* harmony import */ var _alias_logger__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @alias/logger */ \"./src/lib/service/logger/index.js\");\n/* harmony import */ var _alias_logger__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_alias_logger__WEBPACK_IMPORTED_MODULE_1__);\n\n\nconst logger = _alias_logger__WEBPACK_IMPORTED_MODULE_1___default()('growi:services:TagContainer');\n/**\n * Service container related to Tag\n * @extends {Container} unstated Container\n */\n\nclass TagContainer extends unstated__WEBPACK_IMPORTED_MODULE_0__[\"Container\"] {\n constructor(appContainer) {\n super();\n this.appContainer = appContainer;\n this.appContainer.registerContainer(this);\n this.init();\n }\n /**\n * Workaround for the mangling in production build to break constructor.name\n */\n\n\n static getClassName() {\n return 'TagContainer';\n }\n /**\n * retrieve tags data\n * !! This method should be invoked after PageContainer and EditorContainer has been initialized !!\n */\n\n\n async init() {\n const pageContainer = this.appContainer.getContainer('PageContainer');\n const editorContainer = this.appContainer.getContainer('EditorContainer');\n\n if (Object.keys(pageContainer.state).length === 0) {\n logger.debug('There is no need to initialize TagContainer because this is not a Page');\n return;\n }\n\n const {\n pageId,\n templateTagData,\n shareLinkId\n } = pageContainer.state;\n\n if (shareLinkId != null) {\n return;\n }\n\n let tags = []; // when the page exists or shared page\n\n if (pageId != null && shareLinkId == null) {\n const res = await this.appContainer.apiGet('/pages.getPageTag', {\n pageId\n });\n tags = res.tags;\n } // when the page not exist\n else if (templateTagData != null) {\n tags = templateTagData.split(',').filter(str => {\n return str !== ''; // filter empty values\n });\n }\n\n logger.debug('tags data has been initialized');\n pageContainer.setState({\n tags\n });\n editorContainer.setState({\n tags\n });\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvY2xpZW50L2pzL3NlcnZpY2VzL1RhZ0NvbnRhaW5lci5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9jbGllbnQvanMvc2VydmljZXMvVGFnQ29udGFpbmVyLmpzP2FjYzkiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29udGFpbmVyIH0gZnJvbSAndW5zdGF0ZWQnO1xuXG5pbXBvcnQgbG9nZ2VyRmFjdG9yeSBmcm9tICdAYWxpYXMvbG9nZ2VyJztcblxuY29uc3QgbG9nZ2VyID0gbG9nZ2VyRmFjdG9yeSgnZ3Jvd2k6c2VydmljZXM6VGFnQ29udGFpbmVyJyk7XG5cbi8qKlxuICogU2VydmljZSBjb250YWluZXIgcmVsYXRlZCB0byBUYWdcbiAqIEBleHRlbmRzIHtDb250YWluZXJ9IHVuc3RhdGVkIENvbnRhaW5lclxuICovXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBUYWdDb250YWluZXIgZXh0ZW5kcyBDb250YWluZXIge1xuXG4gIGNvbnN0cnVjdG9yKGFwcENvbnRhaW5lcikge1xuICAgIHN1cGVyKCk7XG5cbiAgICB0aGlzLmFwcENvbnRhaW5lciA9IGFwcENvbnRhaW5lcjtcbiAgICB0aGlzLmFwcENvbnRhaW5lci5yZWdpc3RlckNvbnRhaW5lcih0aGlzKTtcblxuICAgIHRoaXMuaW5pdCgpO1xuICB9XG5cbiAgLyoqXG4gICAqIFdvcmthcm91bmQgZm9yIHRoZSBtYW5nbGluZyBpbiBwcm9kdWN0aW9uIGJ1aWxkIHRvIGJyZWFrIGNvbnN0cnVjdG9yLm5hbWVcbiAgICovXG4gIHN0YXRpYyBnZXRDbGFzc05hbWUoKSB7XG4gICAgcmV0dXJuICdUYWdDb250YWluZXInO1xuICB9XG5cbiAgLyoqXG4gICAqIHJldHJpZXZlIHRhZ3MgZGF0YVxuICAgKiAhISBUaGlzIG1ldGhvZCBzaG91bGQgYmUgaW52b2tlZCBhZnRlciBQYWdlQ29udGFpbmVyIGFuZCBFZGl0b3JDb250YWluZXIgaGFzIGJlZW4gaW5pdGlhbGl6ZWQgISFcbiAgICovXG4gIGFzeW5jIGluaXQoKSB7XG4gICAgY29uc3QgcGFnZUNvbnRhaW5lciA9IHRoaXMuYXBwQ29udGFpbmVyLmdldENvbnRhaW5lcignUGFnZUNvbnRhaW5lcicpO1xuICAgIGNvbnN0IGVkaXRvckNvbnRhaW5lciA9IHRoaXMuYXBwQ29udGFpbmVyLmdldENvbnRhaW5lcignRWRpdG9yQ29udGFpbmVyJyk7XG5cbiAgICBpZiAoT2JqZWN0LmtleXMocGFnZUNvbnRhaW5lci5zdGF0ZSkubGVuZ3RoID09PSAwKSB7XG4gICAgICBsb2dnZXIuZGVidWcoJ1RoZXJlIGlzIG5vIG5lZWQgdG8gaW5pdGlhbGl6ZSBUYWdDb250YWluZXIgYmVjYXVzZSB0aGlzIGlzIG5vdCBhIFBhZ2UnKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCB7IHBhZ2VJZCwgdGVtcGxhdGVUYWdEYXRhLCBzaGFyZUxpbmtJZCB9ID0gcGFnZUNvbnRhaW5lci5zdGF0ZTtcblxuICAgIGlmIChzaGFyZUxpbmtJZCAhPSBudWxsKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgbGV0IHRhZ3MgPSBbXTtcbiAgICAvLyB3aGVuIHRoZSBwYWdlIGV4aXN0cyBvciBzaGFyZWQgcGFnZVxuICAgIGlmIChwYWdlSWQgIT0gbnVsbCAmJiBzaGFyZUxpbmtJZCA9PSBudWxsKSB7XG4gICAgICBjb25zdCByZXMgPSBhd2FpdCB0aGlzLmFwcENvbnRhaW5lci5hcGlHZXQoJy9wYWdlcy5nZXRQYWdlVGFnJywgeyBwYWdlSWQgfSk7XG4gICAgICB0YWdzID0gcmVzLnRhZ3M7XG4gICAgfVxuICAgIC8vIHdoZW4gdGhlIHBhZ2Ugbm90IGV4aXN0XG4gICAgZWxzZSBpZiAodGVtcGxhdGVUYWdEYXRhICE9IG51bGwpIHtcbiAgICAgIHRhZ3MgPSB0ZW1wbGF0ZVRhZ0RhdGEuc3BsaXQoJywnKS5maWx0ZXIoKHN0cikgPT4ge1xuICAgICAgICByZXR1cm4gc3RyICE9PSAnJzsgLy8gZmlsdGVyIGVtcHR5IHZhbHVlc1xuICAgICAgfSk7XG4gICAgfVxuXG4gICAgbG9nZ2VyLmRlYnVnKCd0YWdzIGRhdGEgaGFzIGJlZW4gaW5pdGlhbGl6ZWQnKTtcblxuICAgIHBhZ2VDb250YWluZXIuc2V0U3RhdGUoeyB0YWdzIH0pO1xuICAgIGVkaXRvckNvbnRhaW5lci5zZXRTdGF0ZSh7IHRhZ3MgfSk7XG4gIH1cblxufVxuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFFQTtBQUVBO0FBRUE7Ozs7O0FBSUE7QUFFQTtBQUNBO0FBRUE7QUFDQTtBQUVBO0FBQ0E7QUFFQTs7Ozs7QUFHQTtBQUNBO0FBQ0E7QUFFQTs7Ozs7O0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBSEE7QUFNQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUFBO0FBQUE7QUFDQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBdkRBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/client/js/services/TagContainer.js\n");
/***/ }),
/***/ "./src/client/js/util/codemirror/gfm-growi.mode.js":
/*!*********************************************************!*\
!*** ./src/client/js/util/codemirror/gfm-growi.mode.js ***!
\*********************************************************/
/*! no static exports found */
/***/ (function(module, exports) {
eval("// https://discuss.codemirror.net/t/cm-header-margin-padding-height/75/5\nwindow.CodeMirror.defineMode('gfm-growi', (cmConfig, modeCfg) => {\n // based on Markdown (GitHub-flavour) mode\n // https://codemirror.net/doc/manual.html#option_mode\n // https://codemirror.net/mode/index.html\n modeCfg.name = 'gfm';\n modeCfg.highlightFormatting = true;\n const mode = window.CodeMirror.getMode(cmConfig, modeCfg);\n const origToken = mode.token;\n\n mode.token = function (stream, state) {\n let classes = origToken(stream, state) || ''; // https://regex101.com/r/Fep0w2/1\n\n classes = classes.replace(/(^| )header(\\S*)/g, '$1header$2 line-grw-cm-header-line');\n return /^\\s*$/.test(classes) ? null : classes;\n };\n\n return mode;\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvY2xpZW50L2pzL3V0aWwvY29kZW1pcnJvci9nZm0tZ3Jvd2kubW9kZS5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9jbGllbnQvanMvdXRpbC9jb2RlbWlycm9yL2dmbS1ncm93aS5tb2RlLmpzP2E1ZWQiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gaHR0cHM6Ly9kaXNjdXNzLmNvZGVtaXJyb3IubmV0L3QvY20taGVhZGVyLW1hcmdpbi1wYWRkaW5nLWhlaWdodC83NS81XG53aW5kb3cuQ29kZU1pcnJvci5kZWZpbmVNb2RlKCdnZm0tZ3Jvd2knLCAoY21Db25maWcsIG1vZGVDZmcpID0+IHtcbiAgLy8gYmFzZWQgb24gTWFya2Rvd24gKEdpdEh1Yi1mbGF2b3VyKSBtb2RlXG4gIC8vIGh0dHBzOi8vY29kZW1pcnJvci5uZXQvZG9jL21hbnVhbC5odG1sI29wdGlvbl9tb2RlXG4gIC8vIGh0dHBzOi8vY29kZW1pcnJvci5uZXQvbW9kZS9pbmRleC5odG1sXG4gIG1vZGVDZmcubmFtZSA9ICdnZm0nO1xuICBtb2RlQ2ZnLmhpZ2hsaWdodEZvcm1hdHRpbmcgPSB0cnVlO1xuICBjb25zdCBtb2RlID0gd2luZG93LkNvZGVNaXJyb3IuZ2V0TW9kZShjbUNvbmZpZywgbW9kZUNmZyk7XG5cbiAgY29uc3Qgb3JpZ1Rva2VuID0gbW9kZS50b2tlbjtcbiAgbW9kZS50b2tlbiA9IGZ1bmN0aW9uKHN0cmVhbSwgc3RhdGUpIHtcbiAgICBsZXQgY2xhc3NlcyA9IG9yaWdUb2tlbihzdHJlYW0sIHN0YXRlKSB8fCAnJztcbiAgICAvLyBodHRwczovL3JlZ2V4MTAxLmNvbS9yL0ZlcDB3Mi8xXG4gICAgY2xhc3NlcyA9IGNsYXNzZXMucmVwbGFjZSgvKF58ICloZWFkZXIoXFxTKikvZywgJyQxaGVhZGVyJDIgbGluZS1ncnctY20taGVhZGVyLWxpbmUnKTtcbiAgICByZXR1cm4gL15cXHMqJC8udGVzdChjbGFzc2VzKSA/IG51bGwgOiBjbGFzc2VzO1xuICB9O1xuXG4gIHJldHVybiBtb2RlO1xufSk7XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/client/js/util/codemirror/gfm-growi.mode.js\n");
/***/ }),
/***/ "./src/client/js/util/codemirror/update-display-util.ext.js":
/*!******************************************************************!*\
!*** ./src/client/js/util/codemirror/update-display-util.ext.js ***!
\******************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var codemirror_src_line_saw_special_spans__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! codemirror/src/line/saw_special_spans */ \"./node_modules/codemirror/src/line/saw_special_spans.js\");\n/* harmony import */ var codemirror_src_line_utils_line__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! codemirror/src/line/utils_line */ \"./node_modules/codemirror/src/line/utils_line.js\");\n/* harmony import */ var codemirror_src_line_spans__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! codemirror/src/line/spans */ \"./node_modules/codemirror/src/line/spans.js\");\n/* harmony import */ var codemirror_src_display_update_display__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! codemirror/src/display/update_display */ \"./node_modules/codemirror/src/display/update_display.js\");\n/* harmony import */ var codemirror_src_display_view_tracking__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! codemirror/src/display/view_tracking */ \"./node_modules/codemirror/src/display/view_tracking.js\");\n\n\n\n\n\n\nclass UpdateDisplayUtil {\n /**\n * Transplant 'updateDisplayIfNeeded' method to fix weseek/growi#703\n *\n * @see https://github.com/weseek/growi/issues/703\n * @see https://github.com/codemirror/CodeMirror/blob/5.42.0/src/display/update_display.js#L125\n *\n * @param {CodeMirror} cm\n */\n static forceUpdateViewOffset(cm) {\n const doc = cm.doc;\n const display = cm.display;\n const update = new codemirror_src_display_update_display__WEBPACK_IMPORTED_MODULE_3__[\"DisplayUpdate\"](cm, cm.getViewport()); // Compute a suitable new viewport (from & to)\n\n const end = doc.first + doc.size;\n let from = Math.max(update.visible.from - cm.options.viewportMargin, doc.first);\n let to = Math.min(end, update.visible.to + cm.options.viewportMargin);\n if (display.viewFrom < from && from - display.viewFrom < 20) from = Math.max(doc.first, display.viewFrom);\n if (display.viewTo > to && display.viewTo - to < 20) to = Math.min(end, display.viewTo);\n\n if (codemirror_src_line_saw_special_spans__WEBPACK_IMPORTED_MODULE_0__[\"sawCollapsedSpans\"]) {\n from = Object(codemirror_src_line_spans__WEBPACK_IMPORTED_MODULE_2__[\"visualLineNo\"])(cm.doc, from);\n to = Object(codemirror_src_line_spans__WEBPACK_IMPORTED_MODULE_2__[\"visualLineEndNo\"])(cm.doc, to);\n }\n\n Object(codemirror_src_display_view_tracking__WEBPACK_IMPORTED_MODULE_4__[\"adjustView\"])(cm, from, to);\n display.viewOffset = Object(codemirror_src_line_spans__WEBPACK_IMPORTED_MODULE_2__[\"heightAtLine\"])(Object(codemirror_src_line_utils_line__WEBPACK_IMPORTED_MODULE_1__[\"getLine\"])(doc, display.viewFrom));\n }\n\n}\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (UpdateDisplayUtil);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvY2xpZW50L2pzL3V0aWwvY29kZW1pcnJvci91cGRhdGUtZGlzcGxheS11dGlsLmV4dC5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9jbGllbnQvanMvdXRpbC9jb2RlbWlycm9yL3VwZGF0ZS1kaXNwbGF5LXV0aWwuZXh0LmpzP2RjNjEiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc2F3Q29sbGFwc2VkU3BhbnMgfSBmcm9tICdjb2RlbWlycm9yL3NyYy9saW5lL3Nhd19zcGVjaWFsX3NwYW5zJztcbmltcG9ydCB7IGdldExpbmUgfSBmcm9tICdjb2RlbWlycm9yL3NyYy9saW5lL3V0aWxzX2xpbmUnO1xuaW1wb3J0IHsgaGVpZ2h0QXRMaW5lLCB2aXN1YWxMaW5lRW5kTm8sIHZpc3VhbExpbmVObyB9IGZyb20gJ2NvZGVtaXJyb3Ivc3JjL2xpbmUvc3BhbnMnO1xuaW1wb3J0IHsgRGlzcGxheVVwZGF0ZSB9IGZyb20gJ2NvZGVtaXJyb3Ivc3JjL2Rpc3BsYXkvdXBkYXRlX2Rpc3BsYXknO1xuaW1wb3J0IHsgYWRqdXN0VmlldyB9IGZyb20gJ2NvZGVtaXJyb3Ivc3JjL2Rpc3BsYXkvdmlld190cmFja2luZyc7XG5cbmNsYXNzIFVwZGF0ZURpc3BsYXlVdGlsIHtcblxuICAvKipcbiAgICogVHJhbnNwbGFudCAndXBkYXRlRGlzcGxheUlmTmVlZGVkJyBtZXRob2QgdG8gZml4IHdlc2Vlay9ncm93aSM3MDNcbiAgICpcbiAgICogQHNlZSBodHRwczovL2dpdGh1Yi5jb20vd2VzZWVrL2dyb3dpL2lzc3Vlcy83MDNcbiAgICogQHNlZSBodHRwczovL2dpdGh1Yi5jb20vY29kZW1pcnJvci9Db2RlTWlycm9yL2Jsb2IvNS40Mi4wL3NyYy9kaXNwbGF5L3VwZGF0ZV9kaXNwbGF5LmpzI0wxMjVcbiAgICpcbiAgICogQHBhcmFtIHtDb2RlTWlycm9yfSBjbVxuICAgKi9cbiAgc3RhdGljIGZvcmNlVXBkYXRlVmlld09mZnNldChjbSkge1xuICAgIGNvbnN0IGRvYyA9IGNtLmRvYztcbiAgICBjb25zdCBkaXNwbGF5ID0gY20uZGlzcGxheTtcblxuICAgIGNvbnN0IHVwZGF0ZSA9IG5ldyBEaXNwbGF5VXBkYXRlKGNtLCBjbS5nZXRWaWV3cG9ydCgpKTtcblxuICAgIC8vIENvbXB1dGUgYSBzdWl0YWJsZSBuZXcgdmlld3BvcnQgKGZyb20gJiB0bylcbiAgICBjb25zdCBlbmQgPSBkb2MuZmlyc3QgKyBkb2Muc2l6ZTtcbiAgICBsZXQgZnJvbSA9IE1hdGgubWF4KHVwZGF0ZS52aXNpYmxlLmZyb20gLSBjbS5vcHRpb25zLnZpZXdwb3J0TWFyZ2luLCBkb2MuZmlyc3QpO1xuICAgIGxldCB0byA9IE1hdGgubWluKGVuZCwgdXBkYXRlLnZpc2libGUudG8gKyBjbS5vcHRpb25zLnZpZXdwb3J0TWFyZ2luKTtcbiAgICBpZiAoZGlzcGxheS52aWV3RnJvbSA8IGZyb20gJiYgZnJvbSAtIGRpc3BsYXkudmlld0Zyb20gPCAyMCkgZnJvbSA9IE1hdGgubWF4KGRvYy5maXJzdCwgZGlzcGxheS52aWV3RnJvbSk7XG4gICAgaWYgKGRpc3BsYXkudmlld1RvID4gdG8gJiYgZGlzcGxheS52aWV3VG8gLSB0byA8IDIwKSB0byA9IE1hdGgubWluKGVuZCwgZGlzcGxheS52aWV3VG8pO1xuICAgIGlmIChzYXdDb2xsYXBzZWRTcGFucykge1xuICAgICAgZnJvbSA9IHZpc3VhbExpbmVObyhjbS5kb2MsIGZyb20pO1xuICAgICAgdG8gPSB2aXN1YWxMaW5lRW5kTm8oY20uZG9jLCB0byk7XG4gICAgfVxuICAgIGFkanVzdFZpZXcoY20sIGZyb20sIHRvKTtcblxuICAgIGRpc3BsYXkudmlld09mZnNldCA9IGhlaWdodEF0TGluZShnZXRMaW5lKGRvYywgZGlzcGxheS52aWV3RnJvbSkpO1xuICB9XG5cbn1cblxuXG5leHBvcnQgZGVmYXVsdCBVcGRhdGVEaXNwbGF5VXRpbDtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTs7Ozs7Ozs7QUFRQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBRUE7QUFDQTtBQUNBO0FBOUJBO0FBQ0E7QUFpQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/client/js/util/codemirror/update-display-util.ext.js\n");
/***/ }),
/***/ "./src/client/js/util/interceptor/detach-code-blocks.js":
/*!**************************************************************!*\
!*** ./src/client/js/util/interceptor/detach-code-blocks.js ***!
\**************************************************************/
/*! exports provided: DetachCodeBlockInterceptor, RestoreCodeBlockInterceptor */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"DetachCodeBlockInterceptor\", function() { return DetachCodeBlockInterceptor; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"RestoreCodeBlockInterceptor\", function() { return RestoreCodeBlockInterceptor; });\n/* harmony import */ var growi_commons__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! growi-commons */ \"./node_modules/growi-commons/src/index.js\");\n/* harmony import */ var growi_commons__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(growi_commons__WEBPACK_IMPORTED_MODULE_0__);\n\n\nclass DetachCodeBlockUtil {\n static createReplaceStr(replaceId) {\n return `${replaceId}`;\n }\n\n}\n/**\n * The interceptor that detach code blocks\n */\n\n\nclass DetachCodeBlockInterceptor extends growi_commons__WEBPACK_IMPORTED_MODULE_0__[\"BasicInterceptor\"] {\n constructor(crowi) {\n super();\n this.logger = __webpack_require__(/*! @alias/logger */ \"./src/lib/service/logger/index.js\")('growi:DetachCodeBlockInterceptor');\n this.crowi = crowi;\n this.crowiForJquery = crowi.getCrowiForJquery();\n }\n /**\n * @inheritdoc\n */\n\n\n isInterceptWhen(contextName) {\n return /^prePreProcess|prePostProcess$/.test(contextName);\n }\n\n getTargetKey(contextName) {\n if (contextName === 'prePreProcess') {\n return 'markdown';\n }\n\n if (contextName === 'prePostProcess') {\n return 'parsedHTML';\n }\n }\n /**\n * @inheritdoc\n */\n\n\n process(contextName, ...args) {\n this.logger.debug(`processing: 'contextName'=${contextName}`);\n const context = Object.assign(args[0]); // clone\n\n const targetKey = this.getTargetKey(contextName);\n const currentPagePath = context.currentPagePath; // eslint-disable-line no-unused-vars\n\n context.dcbContextMap = {}; // see: https://regex101.com/r/8PAEcC/5\n // eslint-disable-next-line max-len\n\n context[targetKey] = context[targetKey].replace(/(^(```|~~~)(.|[\\r\\n])*?(```|~~~)$)|(`[^\\r\\n]*?`)|((.|[\\r\\n])*?<\\/pre>)|(]*>(.|[\\r\\n])*?<\\/pre>)/gm, all => {\n // create ID\n const replaceId = `dcb-${this.createRandomStr(8)}`;\n this.logger.debug(`'replaceId'=${replaceId} : `, all); // register to context\n\n const dcbContext = {};\n dcbContext.content = all;\n dcbContext.substituteContent = DetachCodeBlockUtil.createReplaceStr(replaceId);\n context.dcbContextMap[replaceId] = dcbContext; // return substituteContent\n\n return dcbContext.substituteContent;\n }); // resolve\n\n return Promise.resolve(context);\n }\n /**\n * @see http://qiita.com/ryounagaoka/items/4736c225bdd86a74d59c\n *\n * @param {number} length\n * @return random strings\n */\n\n\n createRandomStr(length) {\n const bag = 'abcdefghijklmnopqrstuvwxyz0123456789';\n let generated = '';\n\n for (let i = 0; i < length; i++) {\n generated += bag[Math.floor(Math.random() * bag.length)];\n }\n\n return generated;\n }\n\n}\n/**\n * The interceptor that restore detached code blocks\n */\n\nclass RestoreCodeBlockInterceptor extends growi_commons__WEBPACK_IMPORTED_MODULE_0__[\"BasicInterceptor\"] {\n constructor(crowi) {\n super();\n this.logger = __webpack_require__(/*! @alias/logger */ \"./src/lib/service/logger/index.js\")('growi:DetachCodeBlockInterceptor');\n this.crowi = crowi;\n this.crowiForJquery = crowi.getCrowiForJquery();\n }\n /**\n * @inheritdoc\n */\n\n\n isInterceptWhen(contextName) {\n return /^postPreProcess|preRenderHtml|preRenderPreviewHtml|preRenderCommentHtml|preRenderCommentPreviewHtml$/.test(contextName);\n }\n\n getTargetKey(contextName) {\n if (contextName === 'postPreProcess') {\n return 'markdown';\n }\n\n if (contextName === 'preRenderHtml' || contextName === 'preRenderPreviewHtml' || contextName === 'preRenderCommentHtml' || contextName === 'preRenderCommentPreviewHtml') {\n return 'parsedHTML';\n }\n }\n /**\n * @inheritdoc\n */\n\n\n process(contextName, ...args) {\n this.logger.debug(`processing: 'contextName'=${contextName}`);\n const context = Object.assign(args[0]); // clone\n\n const targetKey = this.getTargetKey(contextName); // forEach keys of dcbContextMap\n\n Object.keys(context.dcbContextMap).forEach(replaceId => {\n // get context object from context\n const dcbContext = context.dcbContextMap[replaceId]; // replace it with content by using getter function so that the doller sign does not work\n // see: https://github.com/weseek/growi/issues/285\n\n context[targetKey] = context[targetKey].replace(dcbContext.substituteContent, () => {\n return dcbContext.content;\n });\n }); // resolve\n\n return Promise.resolve(context);\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvY2xpZW50L2pzL3V0aWwvaW50ZXJjZXB0b3IvZGV0YWNoLWNvZGUtYmxvY2tzLmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vLy4vc3JjL2NsaWVudC9qcy91dGlsL2ludGVyY2VwdG9yL2RldGFjaC1jb2RlLWJsb2Nrcy5qcz9jNjViIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhc2ljSW50ZXJjZXB0b3IgfSBmcm9tICdncm93aS1jb21tb25zJztcblxuY2xhc3MgRGV0YWNoQ29kZUJsb2NrVXRpbCB7XG5cbiAgc3RhdGljIGNyZWF0ZVJlcGxhY2VTdHIocmVwbGFjZUlkKSB7XG4gICAgcmV0dXJuIGA8cHJlIGNsYXNzPVwiZGV0YWNoZWQtY29kZS1ibG9ja1wiPiR7cmVwbGFjZUlkfTwvcHJlPmA7XG4gIH1cblxufVxuXG4vKipcbiAqIFRoZSBpbnRlcmNlcHRvciB0aGF0IGRldGFjaCBjb2RlIGJsb2Nrc1xuICovXG5leHBvcnQgY2xhc3MgRGV0YWNoQ29kZUJsb2NrSW50ZXJjZXB0b3IgZXh0ZW5kcyBCYXNpY0ludGVyY2VwdG9yIHtcblxuICBjb25zdHJ1Y3Rvcihjcm93aSkge1xuICAgIHN1cGVyKCk7XG4gICAgdGhpcy5sb2dnZXIgPSByZXF1aXJlKCdAYWxpYXMvbG9nZ2VyJykoJ2dyb3dpOkRldGFjaENvZGVCbG9ja0ludGVyY2VwdG9yJyk7XG5cbiAgICB0aGlzLmNyb3dpID0gY3Jvd2k7XG4gICAgdGhpcy5jcm93aUZvckpxdWVyeSA9IGNyb3dpLmdldENyb3dpRm9ySnF1ZXJ5KCk7XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXRkb2NcbiAgICovXG4gIGlzSW50ZXJjZXB0V2hlbihjb250ZXh0TmFtZSkge1xuICAgIHJldHVybiAvXnByZVByZVByb2Nlc3N8cHJlUG9zdFByb2Nlc3MkLy50ZXN0KGNvbnRleHROYW1lKTtcbiAgfVxuXG4gIGdldFRhcmdldEtleShjb250ZXh0TmFtZSkge1xuICAgIGlmIChjb250ZXh0TmFtZSA9PT0gJ3ByZVByZVByb2Nlc3MnKSB7XG4gICAgICByZXR1cm4gJ21hcmtkb3duJztcbiAgICB9XG4gICAgaWYgKGNvbnRleHROYW1lID09PSAncHJlUG9zdFByb2Nlc3MnKSB7XG4gICAgICByZXR1cm4gJ3BhcnNlZEhUTUwnO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBAaW5oZXJpdGRvY1xuICAgKi9cbiAgcHJvY2Vzcyhjb250ZXh0TmFtZSwgLi4uYXJncykge1xuICAgIHRoaXMubG9nZ2VyLmRlYnVnKGBwcm9jZXNzaW5nOiAnY29udGV4dE5hbWUnPSR7Y29udGV4dE5hbWV9YCk7XG5cbiAgICBjb25zdCBjb250ZXh0ID0gT2JqZWN0LmFzc2lnbihhcmdzWzBdKTsgLy8gY2xvbmVcbiAgICBjb25zdCB0YXJnZXRLZXkgPSB0aGlzLmdldFRhcmdldEtleShjb250ZXh0TmFtZSk7XG4gICAgY29uc3QgY3VycmVudFBhZ2VQYXRoID0gY29udGV4dC5jdXJyZW50UGFnZVBhdGg7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgbm8tdW51c2VkLXZhcnNcblxuICAgIGNvbnRleHQuZGNiQ29udGV4dE1hcCA9IHt9O1xuXG4gICAgLy8gc2VlOiBodHRwczovL3JlZ2V4MTAxLmNvbS9yLzhQQUVjQy81XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG1heC1sZW5cbiAgICBjb250ZXh0W3RhcmdldEtleV0gPSBjb250ZXh0W3RhcmdldEtleV0ucmVwbGFjZSgvKF4oYGBgfH5+fikoLnxbXFxyXFxuXSkqPyhgYGB8fn5+KSQpfChgW15cXHJcXG5dKj9gKXwoPHByZT4oLnxbXFxyXFxuXSkqPzxcXC9wcmU+KXwoPHByZVxcc1tePl0qPigufFtcXHJcXG5dKSo/PFxcL3ByZT4pL2dtLCAoYWxsKSA9PiB7XG4gICAgICAvLyBjcmVhdGUgSURcbiAgICAgIGNvbnN0IHJlcGxhY2VJZCA9IGBkY2ItJHt0aGlzLmNyZWF0ZVJhbmRvbVN0cig4KX1gO1xuICAgICAgdGhpcy5sb2dnZXIuZGVidWcoYCdyZXBsYWNlSWQnPSR7cmVwbGFjZUlkfSA6IGAsIGFsbCk7XG5cbiAgICAgIC8vIHJlZ2lzdGVyIHRvIGNvbnRleHRcbiAgICAgIGNvbnN0IGRjYkNvbnRleHQgPSB7fTtcbiAgICAgIGRjYkNvbnRleHQuY29udGVudCA9IGFsbDtcbiAgICAgIGRjYkNvbnRleHQuc3Vic3RpdHV0ZUNvbnRlbnQgPSBEZXRhY2hDb2RlQmxvY2tVdGlsLmNyZWF0ZVJlcGxhY2VTdHIocmVwbGFjZUlkKTtcbiAgICAgIGNvbnRleHQuZGNiQ29udGV4dE1hcFtyZXBsYWNlSWRdID0gZGNiQ29udGV4dDtcblxuICAgICAgLy8gcmV0dXJuIHN1YnN0aXR1dGVDb250ZW50XG4gICAgICByZXR1cm4gZGNiQ29udGV4dC5zdWJzdGl0dXRlQ29udGVudDtcbiAgICB9KTtcblxuICAgIC8vIHJlc29sdmVcbiAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKGNvbnRleHQpO1xuICB9XG5cbiAgLyoqXG4gICAqIEBzZWUgaHR0cDovL3FpaXRhLmNvbS9yeW91bmFnYW9rYS9pdGVtcy80NzM2YzIyNWJkZDg2YTc0ZDU5Y1xuICAgKlxuICAgKiBAcGFyYW0ge251bWJlcn0gbGVuZ3RoXG4gICAqIEByZXR1cm4gcmFuZG9tIHN0cmluZ3NcbiAgICovXG4gIGNyZWF0ZVJhbmRvbVN0cihsZW5ndGgpIHtcbiAgICBjb25zdCBiYWcgPSAnYWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXowMTIzNDU2Nzg5JztcbiAgICBsZXQgZ2VuZXJhdGVkID0gJyc7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBsZW5ndGg7IGkrKykge1xuICAgICAgZ2VuZXJhdGVkICs9IGJhZ1tNYXRoLmZsb29yKE1hdGgucmFuZG9tKCkgKiBiYWcubGVuZ3RoKV07XG4gICAgfVxuICAgIHJldHVybiBnZW5lcmF0ZWQ7XG4gIH1cblxufVxuXG5cbi8qKlxuICogVGhlIGludGVyY2VwdG9yIHRoYXQgcmVzdG9yZSBkZXRhY2hlZCBjb2RlIGJsb2Nrc1xuICovXG5leHBvcnQgY2xhc3MgUmVzdG9yZUNvZGVCbG9ja0ludGVyY2VwdG9yIGV4dGVuZHMgQmFzaWNJbnRlcmNlcHRvciB7XG5cbiAgY29uc3RydWN0b3IoY3Jvd2kpIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMubG9nZ2VyID0gcmVxdWlyZSgnQGFsaWFzL2xvZ2dlcicpKCdncm93aTpEZXRhY2hDb2RlQmxvY2tJbnRlcmNlcHRvcicpO1xuXG4gICAgdGhpcy5jcm93aSA9IGNyb3dpO1xuICAgIHRoaXMuY3Jvd2lGb3JKcXVlcnkgPSBjcm93aS5nZXRDcm93aUZvckpxdWVyeSgpO1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbmhlcml0ZG9jXG4gICAqL1xuICBpc0ludGVyY2VwdFdoZW4oY29udGV4dE5hbWUpIHtcbiAgICByZXR1cm4gL15wb3N0UHJlUHJvY2Vzc3xwcmVSZW5kZXJIdG1sfHByZVJlbmRlclByZXZpZXdIdG1sfHByZVJlbmRlckNvbW1lbnRIdG1sfHByZVJlbmRlckNvbW1lbnRQcmV2aWV3SHRtbCQvLnRlc3QoY29udGV4dE5hbWUpO1xuICB9XG5cbiAgZ2V0VGFyZ2V0S2V5KGNvbnRleHROYW1lKSB7XG4gICAgaWYgKGNvbnRleHROYW1lID09PSAncG9zdFByZVByb2Nlc3MnKSB7XG4gICAgICByZXR1cm4gJ21hcmtkb3duJztcbiAgICB9XG4gICAgaWYgKGNvbnRleHROYW1lID09PSAncHJlUmVuZGVySHRtbCcgfHwgY29udGV4dE5hbWUgPT09ICdwcmVSZW5kZXJQcmV2aWV3SHRtbCdcbiAgICAgICAgfHwgY29udGV4dE5hbWUgPT09ICdwcmVSZW5kZXJDb21tZW50SHRtbCcgfHwgY29udGV4dE5hbWUgPT09ICdwcmVSZW5kZXJDb21tZW50UHJldmlld0h0bWwnKSB7XG4gICAgICByZXR1cm4gJ3BhcnNlZEhUTUwnO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBAaW5oZXJpdGRvY1xuICAgKi9cbiAgcHJvY2Vzcyhjb250ZXh0TmFtZSwgLi4uYXJncykge1xuICAgIHRoaXMubG9nZ2VyLmRlYnVnKGBwcm9jZXNzaW5nOiAnY29udGV4dE5hbWUnPSR7Y29udGV4dE5hbWV9YCk7XG5cbiAgICBjb25zdCBjb250ZXh0ID0gT2JqZWN0LmFzc2lnbihhcmdzWzBdKTsgLy8gY2xvbmVcbiAgICBjb25zdCB0YXJnZXRLZXkgPSB0aGlzLmdldFRhcmdldEtleShjb250ZXh0TmFtZSk7XG5cbiAgICAvLyBmb3JFYWNoIGtleXMgb2YgZGNiQ29udGV4dE1hcFxuICAgIE9iamVjdC5rZXlzKGNvbnRleHQuZGNiQ29udGV4dE1hcCkuZm9yRWFjaCgocmVwbGFjZUlkKSA9PiB7XG4gICAgICAvLyBnZXQgY29udGV4dCBvYmplY3QgZnJvbSBjb250ZXh0XG4gICAgICBjb25zdCBkY2JDb250ZXh0ID0gY29udGV4dC5kY2JDb250ZXh0TWFwW3JlcGxhY2VJZF07XG5cbiAgICAgIC8vIHJlcGxhY2UgaXQgd2l0aCBjb250ZW50IGJ5IHVzaW5nIGdldHRlciBmdW5jdGlvbiBzbyB0aGF0IHRoZSBkb2xsZXIgc2lnbiBkb2VzIG5vdCB3b3JrXG4gICAgICAvLyBzZWU6IGh0dHBzOi8vZ2l0aHViLmNvbS93ZXNlZWsvZ3Jvd2kvaXNzdWVzLzI4NVxuICAgICAgY29udGV4dFt0YXJnZXRLZXldID0gY29udGV4dFt0YXJnZXRLZXldLnJlcGxhY2UoZGNiQ29udGV4dC5zdWJzdGl0dXRlQ29udGVudCwgKCkgPT4geyByZXR1cm4gZGNiQ29udGV4dC5jb250ZW50IH0pO1xuICAgIH0pO1xuXG4gICAgLy8gcmVzb2x2ZVxuICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoY29udGV4dCk7XG4gIH1cblxufVxuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFMQTtBQVFBOzs7OztBQUdBO0FBRUE7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBRUE7Ozs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFFQTs7Ozs7QUFHQTtBQUNBO0FBRUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBR0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUVBOzs7Ozs7OztBQU1BO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUF6RUE7QUE2RUE7Ozs7QUFHQTtBQUVBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUVBOzs7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBRUE7QUFDQTtBQUNBO0FBRUE7Ozs7O0FBR0E7QUFDQTtBQUVBO0FBQ0E7QUFBQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBR0E7QUFDQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFqREEiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/client/js/util/interceptor/detach-code-blocks.js\n");
/***/ }),
/***/ "./src/client/js/util/interceptor/drawio-interceptor.js":
/*!**************************************************************!*\
!*** ./src/client/js/util/interceptor/drawio-interceptor.js ***!
\**************************************************************/
/*! exports provided: DrawioInterceptor */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"DrawioInterceptor\", function() { return DrawioInterceptor; });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"./node_modules/react/index.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var react_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react-dom */ \"./node_modules/react-dom/index.js\");\n/* harmony import */ var react_dom__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react_dom__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var unstated__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! unstated */ \"./node_modules/unstated/lib/unstated.es.js\");\n/* harmony import */ var growi_commons__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! growi-commons */ \"./node_modules/growi-commons/src/index.js\");\n/* harmony import */ var growi_commons__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(growi_commons__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _components_Drawio__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../components/Drawio */ \"./src/client/js/components/Drawio.jsx\");\n/* eslint-disable import/prefer-default-export */\n\n\n\n\n\n/**\n * The interceptor for draw.io\n *\n * replace draw.io tag (render by markdown-it-drawio-viewer) to a React target element\n */\n\nclass DrawioInterceptor extends growi_commons__WEBPACK_IMPORTED_MODULE_3__[\"BasicInterceptor\"] {\n constructor(appContainer) {\n super();\n this.previousPreviewContext = null;\n this.appContainer = appContainer;\n }\n /**\n * @inheritdoc\n */\n\n\n isInterceptWhen(contextName) {\n return contextName === 'preRenderHtml' || contextName === 'preRenderPreviewHtml' || contextName === 'postRenderHtml' || contextName === 'postRenderPreviewHtml';\n }\n /**\n * @inheritdoc\n */\n\n\n isProcessableParallel() {\n return false;\n }\n /**\n * @inheritdoc\n */\n\n\n async process(contextName, ...args) {\n const context = Object.assign(args[0]); // clone\n\n if (contextName === 'preRenderHtml' || contextName === 'preRenderPreviewHtml') {\n return this.drawioPreRender(contextName, context);\n }\n\n if (contextName === 'postRenderHtml' || contextName === 'postRenderPreviewHtml') {\n this.drawioPostRender(contextName, context);\n return;\n }\n }\n /**\n * @inheritdoc\n */\n\n\n createRandomStr(length) {\n const bag = 'abcdefghijklmnopqrstuvwxyz0123456789';\n let generated = '';\n\n for (let i = 0; i < length; i++) {\n generated += bag[Math.floor(Math.random() * bag.length)];\n }\n\n return generated;\n }\n /**\n * @inheritdoc\n */\n\n\n drawioPreRender(contextName, context) {\n const div = document.createElement('div');\n div.innerHTML = context.parsedHTML;\n context.DrawioMap = {};\n Array.from(div.querySelectorAll('.mxgraph')).forEach(element => {\n const domId = `mxgraph-${this.createRandomStr(8)}`;\n context.DrawioMap[domId] = {\n rangeLineNumberOfMarkdown: {\n beginLineNumber: element.parentNode.dataset.beginLineNumberOfMarkdown,\n endLineNumber: element.parentNode.dataset.endLineNumberOfMarkdown\n },\n contentHtml: element.outerHTML\n };\n element.outerHTML = ``;\n });\n context.parsedHTML = div.innerHTML; // unmount\n\n if (contextName === 'preRenderPreviewHtml') {\n this.unmountPreviousReactDOMs(context);\n } // resolve\n\n\n return context;\n }\n /**\n * @inheritdoc\n */\n\n\n drawioPostRender(contextName, context) {\n const isPreview = contextName === 'postRenderPreviewHtml';\n Object.keys(context.DrawioMap).forEach(domId => {\n const elem = document.getElementById(domId);\n\n if (elem) {\n this.renderReactDOM(context.DrawioMap[domId], elem, isPreview);\n }\n });\n }\n /**\n * @inheritdoc\n */\n\n\n renderReactDOM(drawioMapEntry, elem, isPreview) {\n react_dom__WEBPACK_IMPORTED_MODULE_1___default.a.render( // eslint-disable-next-line react/jsx-filename-extension\n react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(unstated__WEBPACK_IMPORTED_MODULE_2__[\"Provider\"], {\n inject: [this.appContainer]\n }, react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(_components_Drawio__WEBPACK_IMPORTED_MODULE_4__[\"default\"], {\n drawioContent: drawioMapEntry.contentHtml,\n isPreview: isPreview,\n rangeLineNumberOfMarkdown: drawioMapEntry.rangeLineNumberOfMarkdown\n })), elem);\n }\n /**\n * @inheritdoc\n */\n\n\n unmountPreviousReactDOMs(newContext) {\n if (this.previousPreviewContext != null) {\n Array.from(document.querySelectorAll('.mxgraph')).forEach(element => {\n react_dom__WEBPACK_IMPORTED_MODULE_1___default.a.unmountComponentAtNode(element);\n });\n }\n\n this.previousPreviewContext = newContext;\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvY2xpZW50L2pzL3V0aWwvaW50ZXJjZXB0b3IvZHJhd2lvLWludGVyY2VwdG9yLmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vLy4vc3JjL2NsaWVudC9qcy91dGlsL2ludGVyY2VwdG9yL2RyYXdpby1pbnRlcmNlcHRvci5qcz85MTczIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIGltcG9ydC9wcmVmZXItZGVmYXVsdC1leHBvcnQgKi9cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUmVhY3RET00gZnJvbSAncmVhY3QtZG9tJztcbmltcG9ydCB7IFByb3ZpZGVyIH0gZnJvbSAndW5zdGF0ZWQnO1xuaW1wb3J0IHsgQmFzaWNJbnRlcmNlcHRvciB9IGZyb20gJ2dyb3dpLWNvbW1vbnMnO1xuXG5pbXBvcnQgRHJhd2lvIGZyb20gJy4uLy4uL2NvbXBvbmVudHMvRHJhd2lvJztcblxuLyoqXG4gKiBUaGUgaW50ZXJjZXB0b3IgZm9yIGRyYXcuaW9cbiAqXG4gKiAgcmVwbGFjZSBkcmF3LmlvIHRhZyAocmVuZGVyIGJ5IG1hcmtkb3duLWl0LWRyYXdpby12aWV3ZXIpIHRvIGEgUmVhY3QgdGFyZ2V0IGVsZW1lbnRcbiAqL1xuZXhwb3J0IGNsYXNzIERyYXdpb0ludGVyY2VwdG9yIGV4dGVuZHMgQmFzaWNJbnRlcmNlcHRvciB7XG5cbiAgY29uc3RydWN0b3IoYXBwQ29udGFpbmVyKSB7XG4gICAgc3VwZXIoKTtcblxuICAgIHRoaXMucHJldmlvdXNQcmV2aWV3Q29udGV4dCA9IG51bGw7XG4gICAgdGhpcy5hcHBDb250YWluZXIgPSBhcHBDb250YWluZXI7XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXRkb2NcbiAgICovXG4gIGlzSW50ZXJjZXB0V2hlbihjb250ZXh0TmFtZSkge1xuICAgIHJldHVybiAoXG4gICAgICBjb250ZXh0TmFtZSA9PT0gJ3ByZVJlbmRlckh0bWwnXG4gICAgICB8fCBjb250ZXh0TmFtZSA9PT0gJ3ByZVJlbmRlclByZXZpZXdIdG1sJ1xuICAgICAgfHwgY29udGV4dE5hbWUgPT09ICdwb3N0UmVuZGVySHRtbCdcbiAgICAgIHx8IGNvbnRleHROYW1lID09PSAncG9zdFJlbmRlclByZXZpZXdIdG1sJ1xuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXRkb2NcbiAgICovXG4gIGlzUHJvY2Vzc2FibGVQYXJhbGxlbCgpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXRkb2NcbiAgICovXG4gIGFzeW5jIHByb2Nlc3MoY29udGV4dE5hbWUsIC4uLmFyZ3MpIHtcbiAgICBjb25zdCBjb250ZXh0ID0gT2JqZWN0LmFzc2lnbihhcmdzWzBdKTsgLy8gY2xvbmVcblxuICAgIGlmIChjb250ZXh0TmFtZSA9PT0gJ3ByZVJlbmRlckh0bWwnIHx8IGNvbnRleHROYW1lID09PSAncHJlUmVuZGVyUHJldmlld0h0bWwnKSB7XG4gICAgICByZXR1cm4gdGhpcy5kcmF3aW9QcmVSZW5kZXIoY29udGV4dE5hbWUsIGNvbnRleHQpO1xuICAgIH1cblxuICAgIGlmIChjb250ZXh0TmFtZSA9PT0gJ3Bvc3RSZW5kZXJIdG1sJyB8fCBjb250ZXh0TmFtZSA9PT0gJ3Bvc3RSZW5kZXJQcmV2aWV3SHRtbCcpIHtcbiAgICAgIHRoaXMuZHJhd2lvUG9zdFJlbmRlcihjb250ZXh0TmFtZSwgY29udGV4dCk7XG4gICAgICByZXR1cm47XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEBpbmhlcml0ZG9jXG4gICAqL1xuICBjcmVhdGVSYW5kb21TdHIobGVuZ3RoKSB7XG4gICAgY29uc3QgYmFnID0gJ2FiY2RlZmdoaWprbG1ub3BxcnN0dXZ3eHl6MDEyMzQ1Njc4OSc7XG4gICAgbGV0IGdlbmVyYXRlZCA9ICcnO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgbGVuZ3RoOyBpKyspIHtcbiAgICAgIGdlbmVyYXRlZCArPSBiYWdbTWF0aC5mbG9vcihNYXRoLnJhbmRvbSgpICogYmFnLmxlbmd0aCldO1xuICAgIH1cbiAgICByZXR1cm4gZ2VuZXJhdGVkO1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbmhlcml0ZG9jXG4gICAqL1xuICBkcmF3aW9QcmVSZW5kZXIoY29udGV4dE5hbWUsIGNvbnRleHQpIHtcbiAgICBjb25zdCBkaXYgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdkaXYnKTtcbiAgICBkaXYuaW5uZXJIVE1MID0gY29udGV4dC5wYXJzZWRIVE1MO1xuXG4gICAgY29udGV4dC5EcmF3aW9NYXAgPSB7fTtcbiAgICBBcnJheS5mcm9tKGRpdi5xdWVyeVNlbGVjdG9yQWxsKCcubXhncmFwaCcpKS5mb3JFYWNoKChlbGVtZW50KSA9PiB7XG4gICAgICBjb25zdCBkb21JZCA9IGBteGdyYXBoLSR7dGhpcy5jcmVhdGVSYW5kb21TdHIoOCl9YDtcblxuICAgICAgY29udGV4dC5EcmF3aW9NYXBbZG9tSWRdID0ge1xuICAgICAgICByYW5nZUxpbmVOdW1iZXJPZk1hcmtkb3duOiB7XG4gICAgICAgICAgYmVnaW5MaW5lTnVtYmVyOiBlbGVtZW50LnBhcmVudE5vZGUuZGF0YXNldC5iZWdpbkxpbmVOdW1iZXJPZk1hcmtkb3duLFxuICAgICAgICAgIGVuZExpbmVOdW1iZXI6IGVsZW1lbnQucGFyZW50Tm9kZS5kYXRhc2V0LmVuZExpbmVOdW1iZXJPZk1hcmtkb3duLFxuICAgICAgICB9LFxuICAgICAgICBjb250ZW50SHRtbDogZWxlbWVudC5vdXRlckhUTUwsXG4gICAgICB9O1xuICAgICAgZWxlbWVudC5vdXRlckhUTUwgPSBgPGRpdiBpZD1cIiR7ZG9tSWR9XCI+PC9kaXY+YDtcbiAgICB9KTtcbiAgICBjb250ZXh0LnBhcnNlZEhUTUwgPSBkaXYuaW5uZXJIVE1MO1xuXG4gICAgLy8gdW5tb3VudFxuICAgIGlmIChjb250ZXh0TmFtZSA9PT0gJ3ByZVJlbmRlclByZXZpZXdIdG1sJykge1xuICAgICAgdGhpcy51bm1vdW50UHJldmlvdXNSZWFjdERPTXMoY29udGV4dCk7XG4gICAgfVxuXG4gICAgLy8gcmVzb2x2ZVxuICAgIHJldHVybiBjb250ZXh0O1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbmhlcml0ZG9jXG4gICAqL1xuICBkcmF3aW9Qb3N0UmVuZGVyKGNvbnRleHROYW1lLCBjb250ZXh0KSB7XG4gICAgY29uc3QgaXNQcmV2aWV3ID0gKGNvbnRleHROYW1lID09PSAncG9zdFJlbmRlclByZXZpZXdIdG1sJyk7XG5cbiAgICBPYmplY3Qua2V5cyhjb250ZXh0LkRyYXdpb01hcCkuZm9yRWFjaCgoZG9tSWQpID0+IHtcbiAgICAgIGNvbnN0IGVsZW0gPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZChkb21JZCk7XG4gICAgICBpZiAoZWxlbSkge1xuICAgICAgICB0aGlzLnJlbmRlclJlYWN0RE9NKGNvbnRleHQuRHJhd2lvTWFwW2RvbUlkXSwgZWxlbSwgaXNQcmV2aWV3KTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBAaW5oZXJpdGRvY1xuICAgKi9cbiAgcmVuZGVyUmVhY3RET00oZHJhd2lvTWFwRW50cnksIGVsZW0sIGlzUHJldmlldykge1xuICAgIFJlYWN0RE9NLnJlbmRlcihcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSByZWFjdC9qc3gtZmlsZW5hbWUtZXh0ZW5zaW9uXG4gICAgICA8UHJvdmlkZXIgaW5qZWN0PXtbdGhpcy5hcHBDb250YWluZXJdfT5cbiAgICAgICAgPERyYXdpb1xuICAgICAgICAgIGRyYXdpb0NvbnRlbnQ9e2RyYXdpb01hcEVudHJ5LmNvbnRlbnRIdG1sfVxuICAgICAgICAgIGlzUHJldmlldz17aXNQcmV2aWV3fVxuICAgICAgICAgIHJhbmdlTGluZU51bWJlck9mTWFya2Rvd249e2RyYXdpb01hcEVudHJ5LnJhbmdlTGluZU51bWJlck9mTWFya2Rvd259XG4gICAgICAgIC8+XG4gICAgICA8L1Byb3ZpZGVyPixcbiAgICAgIGVsZW0sXG4gICAgKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBAaW5oZXJpdGRvY1xuICAgKi9cbiAgdW5tb3VudFByZXZpb3VzUmVhY3RET01zKG5ld0NvbnRleHQpIHtcbiAgICBpZiAodGhpcy5wcmV2aW91c1ByZXZpZXdDb250ZXh0ICE9IG51bGwpIHtcbiAgICAgIEFycmF5LmZyb20oZG9jdW1lbnQucXVlcnlTZWxlY3RvckFsbCgnLm14Z3JhcGgnKSkuZm9yRWFjaCgoZWxlbWVudCkgPT4ge1xuICAgICAgICBSZWFjdERPTS51bm1vdW50Q29tcG9uZW50QXROb2RlKGVsZW1lbnQpO1xuICAgICAgfSk7XG4gICAgfVxuXG4gICAgdGhpcy5wcmV2aW91c1ByZXZpZXdDb250ZXh0ID0gbmV3Q29udGV4dDtcbiAgfVxuXG59XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBRUE7Ozs7OztBQUtBO0FBRUE7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUVBOzs7OztBQUdBO0FBQ0E7QUFNQTtBQUVBOzs7OztBQUdBO0FBQ0E7QUFDQTtBQUVBOzs7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBOzs7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBRUE7Ozs7O0FBR0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFGQTtBQUlBO0FBTEE7QUFPQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7Ozs7O0FBR0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTs7Ozs7QUFHQTtBQUNBO0FBRUE7QUFBQTtBQUFBO0FBRUE7QUFDQTtBQUNBO0FBSEE7QUFRQTtBQUVBOzs7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBbElBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/client/js/util/interceptor/drawio-interceptor.js\n");
/***/ }),
/***/ "./src/client/js/util/locale-utils.js":
/*!********************************************!*\
!*** ./src/client/js/util/locale-utils.js ***!
\********************************************/
/*! no static exports found */
/***/ (function(module, exports) {
eval("// https://docs.google.com/spreadsheets/d/1FoYdyEraEQuWofzbYCDPKN7EdKgS_2ZrsDrOA8scgwQ\nconst DIAGRAMS_NET_LANG_MAP = {\n ja_JP: 'ja',\n zh_CN: 'zh'\n};\n\nconst getDiagramsNetLangCode = lang => {\n return DIAGRAMS_NET_LANG_MAP[lang];\n};\n\nmodule.exports = {\n getDiagramsNetLangCode\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvY2xpZW50L2pzL3V0aWwvbG9jYWxlLXV0aWxzLmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vLy4vc3JjL2NsaWVudC9qcy91dGlsL2xvY2FsZS11dGlscy5qcz8wNDY4Il0sInNvdXJjZXNDb250ZW50IjpbIi8vIGh0dHBzOi8vZG9jcy5nb29nbGUuY29tL3NwcmVhZHNoZWV0cy9kLzFGb1lkeUVyYUVRdVdvZnpiWUNEUEtON0VkS2dTXzJacnNEck9BOHNjZ3dRXG5jb25zdCBESUFHUkFNU19ORVRfTEFOR19NQVAgPSB7XG4gIGphX0pQOiAnamEnLFxuICB6aF9DTjogJ3poJyxcbn07XG5cbmNvbnN0IGdldERpYWdyYW1zTmV0TGFuZ0NvZGUgPSAobGFuZykgPT4ge1xuICByZXR1cm4gRElBR1JBTVNfTkVUX0xBTkdfTUFQW2xhbmddO1xufTtcblxubW9kdWxlLmV4cG9ydHMgPSB7XG4gIGdldERpYWdyYW1zTmV0TGFuZ0NvZGUsXG59O1xuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBQ0E7QUFJQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFEQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/client/js/util/locale-utils.js\n");
/***/ }),
/***/ "./src/lib/components/PagePathHierarchicalLink.jsx":
/*!*********************************************************!*\
!*** ./src/lib/components/PagePathHierarchicalLink.jsx ***!
\*********************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"./node_modules/react/index.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! prop-types */ \"./node_modules/prop-types/index.js\");\n/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(prop_types__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var url_join__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! url-join */ \"./node_modules/url-join/lib/url-join.js\");\n/* harmony import */ var url_join__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(url_join__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _models_linked_page_path__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../models/linked-page-path */ \"./src/lib/models/linked-page-path.js\");\n/* harmony import */ var _models_linked_page_path__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_models_linked_page_path__WEBPACK_IMPORTED_MODULE_3__);\n\n\n\n\n\nconst PagePathHierarchicalLink = props => {\n var _linkedPagePath$paren;\n\n const {\n linkedPagePath,\n basePath,\n isInTrash\n } = props; // render root element\n\n if (linkedPagePath.isRoot) {\n if (basePath != null) {\n return null;\n }\n\n return isInTrash ? react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(react__WEBPACK_IMPORTED_MODULE_0___default.a.Fragment, null, react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(\"span\", {\n className: \"path-segment\"\n }, react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(\"a\", {\n href: \"/trash\"\n }, react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(\"i\", {\n className: \"icon-trash\"\n }))), react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(\"span\", {\n className: \"separator\"\n }, react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(\"a\", {\n href: \"/\"\n }, \"/\"))) : react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(react__WEBPACK_IMPORTED_MODULE_0___default.a.Fragment, null, react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(\"span\", {\n className: \"path-segment\"\n }, react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(\"a\", {\n href: \"/\"\n }, react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(\"i\", {\n className: \"icon-home\"\n }), react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(\"span\", {\n className: \"separator\"\n }, \"/\"))));\n }\n\n const isParentExists = linkedPagePath.parent != null;\n const isParentRoot = (_linkedPagePath$paren = linkedPagePath.parent) === null || _linkedPagePath$paren === void 0 ? void 0 : _linkedPagePath$paren.isRoot;\n const isSeparatorRequired = isParentExists && !isParentRoot;\n const href = encodeURI(url_join__WEBPACK_IMPORTED_MODULE_2___default()(basePath || '/', linkedPagePath.href)); // eslint-disable-next-line react/prop-types\n\n const RootElm = ({\n children\n }) => {\n return props.isInnerElem ? react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(react__WEBPACK_IMPORTED_MODULE_0___default.a.Fragment, null, children) : react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(\"span\", {\n className: \"grw-page-path-hierarchical-link d-inline-block text-break\"\n }, children);\n };\n\n return react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(RootElm, null, isParentExists && react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(PagePathHierarchicalLink, {\n linkedPagePath: linkedPagePath.parent,\n basePath: basePath,\n isInTrash: isInTrash || linkedPagePath.isInTrash,\n isInnerElem: true\n }), isSeparatorRequired && react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(\"span\", {\n className: \"separator\"\n }, \"/\"), react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(\"a\", {\n className: \"page-segment\",\n href: href\n }, linkedPagePath.pathName));\n};\n\nPagePathHierarchicalLink.propTypes = {\n linkedPagePath: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.instanceOf(_models_linked_page_path__WEBPACK_IMPORTED_MODULE_3___default.a).isRequired,\n basePath: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n isInTrash: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n // !!INTERNAL USE ONLY!!\n isInnerElem: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool\n};\n/* harmony default export */ __webpack_exports__[\"default\"] = (PagePathHierarchicalLink);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbGliL2NvbXBvbmVudHMvUGFnZVBhdGhIaWVyYXJjaGljYWxMaW5rLmpzeC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9saWIvY29tcG9uZW50cy9QYWdlUGF0aEhpZXJhcmNoaWNhbExpbmsuanN4P2RlZDAiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5cbmltcG9ydCB1cmxqb2luIGZyb20gJ3VybC1qb2luJztcblxuaW1wb3J0IExpbmtlZFBhZ2VQYXRoIGZyb20gJy4uL21vZGVscy9saW5rZWQtcGFnZS1wYXRoJztcblxuXG5jb25zdCBQYWdlUGF0aEhpZXJhcmNoaWNhbExpbmsgPSAocHJvcHMpID0+IHtcbiAgY29uc3QgeyBsaW5rZWRQYWdlUGF0aCwgYmFzZVBhdGgsIGlzSW5UcmFzaCB9ID0gcHJvcHM7XG5cbiAgLy8gcmVuZGVyIHJvb3QgZWxlbWVudFxuICBpZiAobGlua2VkUGFnZVBhdGguaXNSb290KSB7XG4gICAgaWYgKGJhc2VQYXRoICE9IG51bGwpIHtcbiAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIHJldHVybiBpc0luVHJhc2hcbiAgICAgID8gKFxuICAgICAgICA8PlxuICAgICAgICAgIDxzcGFuIGNsYXNzTmFtZT1cInBhdGgtc2VnbWVudFwiPlxuICAgICAgICAgICAgPGEgaHJlZj1cIi90cmFzaFwiPjxpIGNsYXNzTmFtZT1cImljb24tdHJhc2hcIj48L2k+PC9hPlxuICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgICA8c3BhbiBjbGFzc05hbWU9XCJzZXBhcmF0b3JcIj48YSBocmVmPVwiL1wiPi88L2E+PC9zcGFuPlxuICAgICAgICA8Lz5cbiAgICAgIClcbiAgICAgIDogKFxuICAgICAgICA8PlxuICAgICAgICAgIDxzcGFuIGNsYXNzTmFtZT1cInBhdGgtc2VnbWVudFwiPlxuICAgICAgICAgICAgPGEgaHJlZj1cIi9cIj5cbiAgICAgICAgICAgICAgPGkgY2xhc3NOYW1lPVwiaWNvbi1ob21lXCI+PC9pPlxuICAgICAgICAgICAgICA8c3BhbiBjbGFzc05hbWU9XCJzZXBhcmF0b3JcIj4vPC9zcGFuPlxuICAgICAgICAgICAgPC9hPlxuICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgPC8+XG4gICAgICApO1xuICB9XG5cbiAgY29uc3QgaXNQYXJlbnRFeGlzdHMgPSBsaW5rZWRQYWdlUGF0aC5wYXJlbnQgIT0gbnVsbDtcbiAgY29uc3QgaXNQYXJlbnRSb290ID0gbGlua2VkUGFnZVBhdGgucGFyZW50Py5pc1Jvb3Q7XG4gIGNvbnN0IGlzU2VwYXJhdG9yUmVxdWlyZWQgPSBpc1BhcmVudEV4aXN0cyAmJiAhaXNQYXJlbnRSb290O1xuXG4gIGNvbnN0IGhyZWYgPSBlbmNvZGVVUkkodXJsam9pbihiYXNlUGF0aCB8fCAnLycsIGxpbmtlZFBhZ2VQYXRoLmhyZWYpKTtcblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgcmVhY3QvcHJvcC10eXBlc1xuICBjb25zdCBSb290RWxtID0gKHsgY2hpbGRyZW4gfSkgPT4ge1xuICAgIHJldHVybiBwcm9wcy5pc0lubmVyRWxlbVxuICAgICAgPyA8PntjaGlsZHJlbn08Lz5cbiAgICAgIDogPHNwYW4gY2xhc3NOYW1lPVwiZ3J3LXBhZ2UtcGF0aC1oaWVyYXJjaGljYWwtbGluayBkLWlubGluZS1ibG9jayB0ZXh0LWJyZWFrXCI+e2NoaWxkcmVufTwvc3Bhbj47XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8Um9vdEVsbT5cbiAgICAgIHsgaXNQYXJlbnRFeGlzdHMgJiYgKFxuICAgICAgICA8UGFnZVBhdGhIaWVyYXJjaGljYWxMaW5rIGxpbmtlZFBhZ2VQYXRoPXtsaW5rZWRQYWdlUGF0aC5wYXJlbnR9IGJhc2VQYXRoPXtiYXNlUGF0aH0gaXNJblRyYXNoPXtpc0luVHJhc2ggfHwgbGlua2VkUGFnZVBhdGguaXNJblRyYXNofSBpc0lubmVyRWxlbSAvPlxuICAgICAgKSB9XG4gICAgICB7IGlzU2VwYXJhdG9yUmVxdWlyZWQgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9XCJzZXBhcmF0b3JcIj4vPC9zcGFuPlxuICAgICAgKSB9XG5cbiAgICAgIDxhIGNsYXNzTmFtZT1cInBhZ2Utc2VnbWVudFwiIGhyZWY9e2hyZWZ9PntsaW5rZWRQYWdlUGF0aC5wYXRoTmFtZX08L2E+XG4gICAgPC9Sb290RWxtPlxuICApO1xufTtcblxuUGFnZVBhdGhIaWVyYXJjaGljYWxMaW5rLnByb3BUeXBlcyA9IHtcbiAgbGlua2VkUGFnZVBhdGg6IFByb3BUeXBlcy5pbnN0YW5jZU9mKExpbmtlZFBhZ2VQYXRoKS5pc1JlcXVpcmVkLFxuICBiYXNlUGF0aDogUHJvcFR5cGVzLnN0cmluZyxcbiAgaXNJblRyYXNoOiBQcm9wVHlwZXMuYm9vbCxcblxuICAvLyAhIUlOVEVSTkFMIFVTRSBPTkxZISFcbiAgaXNJbm5lckVsZW06IFByb3BUeXBlcy5ib29sLFxufTtcblxuZXhwb3J0IGRlZmF1bHQgUGFnZVBhdGhIaWVyYXJjaGljYWxMaW5rO1xuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBRUE7QUFFQTtBQUNBO0FBRUE7QUFBQTtBQUNBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBR0E7QUFBQTtBQUNBO0FBQUE7QUFBQTtBQUFBO0FBRUE7QUFBQTtBQUFBO0FBQUE7QUFLQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBS0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFFQTtBQUFBO0FBQUE7QUFDQTtBQUVBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFHQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBR0E7QUFBQTtBQUdBO0FBQUE7QUFBQTtBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFOQTtBQVNBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/lib/components/PagePathHierarchicalLink.jsx\n");
/***/ }),
/***/ "./src/lib/models/linked-page-path.js":
/*!********************************************!*\
!*** ./src/lib/models/linked-page-path.js ***!
\********************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
eval("const {\n pathUtils\n} = __webpack_require__(/*! growi-commons */ \"./node_modules/growi-commons/src/index.js\");\n\nconst {\n isTrashPage\n} = __webpack_require__(/*! @commons/util/path-utils */ \"./src/lib/util/path-utils.js\");\n\nconst DevidedPagePath = __webpack_require__(/*! ./devided-page-path */ \"./src/lib/models/devided-page-path.js\");\n/**\n * Linked Array Structured PagePath Model\n */\n\n\nclass LinkedPagePath {\n constructor(path, skipNormalize = false) {\n const pagePath = new DevidedPagePath(path, skipNormalize);\n this.path = path;\n this.pathName = pagePath.latter;\n this.isRoot = pagePath.isRoot;\n this.parent = pagePath.isRoot ? null : new LinkedPagePath(pagePath.former, true);\n }\n\n get href() {\n if (this.isRoot) {\n return '';\n }\n\n return pathUtils.normalizePath(`${this.parent.href}/${this.pathName}`);\n }\n\n get isInTrash() {\n return isTrashPage(this.path);\n }\n\n}\n\nmodule.exports = LinkedPagePath;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbGliL21vZGVscy9saW5rZWQtcGFnZS1wYXRoLmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vLy4vc3JjL2xpYi9tb2RlbHMvbGlua2VkLXBhZ2UtcGF0aC5qcz9jNjg5Il0sInNvdXJjZXNDb250ZW50IjpbImNvbnN0IHsgcGF0aFV0aWxzIH0gPSByZXF1aXJlKCdncm93aS1jb21tb25zJyk7XG5jb25zdCB7IGlzVHJhc2hQYWdlIH0gPSByZXF1aXJlKCdAY29tbW9ucy91dGlsL3BhdGgtdXRpbHMnKTtcblxuY29uc3QgRGV2aWRlZFBhZ2VQYXRoID0gcmVxdWlyZSgnLi9kZXZpZGVkLXBhZ2UtcGF0aCcpO1xuXG4vKipcbiAqIExpbmtlZCBBcnJheSBTdHJ1Y3R1cmVkIFBhZ2VQYXRoIE1vZGVsXG4gKi9cbmNsYXNzIExpbmtlZFBhZ2VQYXRoIHtcblxuICBjb25zdHJ1Y3RvcihwYXRoLCBza2lwTm9ybWFsaXplID0gZmFsc2UpIHtcblxuICAgIGNvbnN0IHBhZ2VQYXRoID0gbmV3IERldmlkZWRQYWdlUGF0aChwYXRoLCBza2lwTm9ybWFsaXplKTtcblxuICAgIHRoaXMucGF0aCA9IHBhdGg7XG4gICAgdGhpcy5wYXRoTmFtZSA9IHBhZ2VQYXRoLmxhdHRlcjtcbiAgICB0aGlzLmlzUm9vdCA9IHBhZ2VQYXRoLmlzUm9vdDtcbiAgICB0aGlzLnBhcmVudCA9IHBhZ2VQYXRoLmlzUm9vdFxuICAgICAgPyBudWxsXG4gICAgICA6IG5ldyBMaW5rZWRQYWdlUGF0aChwYWdlUGF0aC5mb3JtZXIsIHRydWUpO1xuXG4gIH1cblxuICBnZXQgaHJlZigpIHtcbiAgICBpZiAodGhpcy5pc1Jvb3QpIHtcbiAgICAgIHJldHVybiAnJztcbiAgICB9XG5cbiAgICByZXR1cm4gcGF0aFV0aWxzLm5vcm1hbGl6ZVBhdGgoYCR7dGhpcy5wYXJlbnQuaHJlZn0vJHt0aGlzLnBhdGhOYW1lfWApO1xuICB9XG5cbiAgZ2V0IGlzSW5UcmFzaCgpIHtcbiAgICByZXR1cm4gaXNUcmFzaFBhZ2UodGhpcy5wYXRoKTtcbiAgfVxuXG59XG5cbm1vZHVsZS5leHBvcnRzID0gTGlua2VkUGFnZVBhdGg7XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUVBOzs7OztBQUdBO0FBRUE7QUFFQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQTFCQTtBQUNBO0FBNEJBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/lib/models/linked-page-path.js\n");
/***/ }),
/***/ 0:
/*!**********************!*\
!*** util (ignored) ***!
\**********************/
/*! no static exports found */
/***/ (function(module, exports) {
eval("/* (ignored) *///# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy91dGlsIChpZ25vcmVkKT9lZjdjIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIChpZ25vcmVkKSAqLyJdLCJtYXBwaW5ncyI6IkFBQUEiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///0\n");
/***/ }),
/***/ 1:
/*!********************!*\
!*** ws (ignored) ***!
\********************/
/*! no static exports found */
/***/ (function(module, exports) {
eval("/* (ignored) *///# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy93cyAoaWdub3JlZCk/OTIwYiJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiAoaWdub3JlZCkgKi8iXSwibWFwcGluZ3MiOiJBQUFBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///1\n");
/***/ }),
/***/ "jquery":
/*!*************************!*\
!*** external "jQuery" ***!
\*************************/
/*! no static exports found */
/***/ (function(module, exports) {
eval("module.exports = jQuery;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoianF1ZXJ5LmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vL2V4dGVybmFsIFwialF1ZXJ5XCI/Y2QwYyJdLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IGpRdWVyeTsiXSwibWFwcGluZ3MiOiJBQUFBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///jquery\n");
/***/ })
/******/ });