/* eslint-disable max-len */
import React from 'react';
import ReactDOM from 'react-dom';
import { Provider } from 'unstated';
import { I18nextProvider } from 'react-i18next';
import loggerFactory from '@alias/logger';
import Xss from '@commons/service/xss';
import HeaderSearchBox from './components/HeaderSearchBox';
import SearchPage from './components/SearchPage';
import TagsList from './components/TagsList';
import PageEditor from './components/PageEditor';
// eslint-disable-next-line import/no-duplicates
import OptionsSelector from './components/PageEditor/OptionsSelector';
// eslint-disable-next-line import/no-duplicates
import { defaultEditorOptions, defaultPreviewOptions } from './components/PageEditor/OptionsSelector';
import SavePageControls from './components/SavePageControls';
import PageEditorByHackmd from './components/PageEditorByHackmd';
import Page from './components/Page';
import PageHistory from './components/PageHistory';
import PageComments from './components/PageComments';
import CommentEditorLazyRenderer from './components/PageComment/CommentEditorLazyRenderer';
import PageAttachment from './components/PageAttachment';
import PageStatusAlert from './components/PageStatusAlert';
import RevisionPath from './components/Page/RevisionPath';
import TagLabels from './components/Page/TagLabels';
import BookmarkButton from './components/BookmarkButton';
import LikeButton from './components/LikeButton';
import PagePathAutoComplete from './components/PagePathAutoComplete';
import RecentCreated from './components/RecentCreated/RecentCreated';
import StaffCredit from './components/StaffCredit/StaffCredit';
import MyDraftList from './components/MyDraftList/MyDraftList';
import UserPictureList from './components/User/UserPictureList';
import CustomCssEditor from './components/Admin/CustomCssEditor';
import CustomScriptEditor from './components/Admin/CustomScriptEditor';
import CustomHeaderEditor from './components/Admin/CustomHeaderEditor';
import AdminRebuildSearch from './components/Admin/AdminRebuildSearch';
import UserGroupPage from './components/Admin/UserGroup/UserGroupPage';
import FullTextSearchManagement from './components/Admin/FullTextSearchManagement/FullTextSearchPage';
import AppContainer from './services/AppContainer';
import PageContainer from './services/PageContainer';
import CommentContainer from './services/CommentContainer';
import EditorContainer from './services/EditorContainer';
import TagContainer from './services/TagContainer';
import WebsocketContainer from './services/WebsocketContainer';
const logger = loggerFactory('growi:app');
if (!window) {
window = {};
}
// setup xss library
const xss = new Xss();
window.xss = xss;
// create unstated container instance
const appContainer = new AppContainer();
const websocketContainer = new WebsocketContainer(appContainer);
const pageContainer = new PageContainer(appContainer);
const commentContainer = new CommentContainer(appContainer);
const editorContainer = new EditorContainer(appContainer, defaultEditorOptions, defaultPreviewOptions);
const tagContainer = new TagContainer(appContainer);
const injectableContainers = [
appContainer, websocketContainer, pageContainer, commentContainer, editorContainer, tagContainer,
];
logger.info('unstated containers have been initialized');
appContainer.initPlugins();
appContainer.injectToWindow();
const i18n = appContainer.i18n;
/**
* define components
* key: id of element
* value: React Element
*/
let componentMappings = {
'search-top': ,
'search-sidebar': ,
'search-page': ,
// 'revision-history': ,
'tags-page': ,
'create-page-name-input': ,
'page-editor': ,
'page-editor-options-selector': ,
'page-status-alert': ,
'save-page-controls': ,
'user-created-list': ,
'user-draft-list': ,
'staff-credit': ,
};
// additional definitions if data exists
if (pageContainer.state.pageId != null) {
componentMappings = Object.assign({
'page-editor-with-hackmd': ,
'page-comments-list': ,
'page-attachment': ,
'page-comment-write': ,
'like-button': ,
'seen-user-list': ,
'liker-list': ,
'bookmark-button': ,
'bookmark-button-lg': ,
'rename-page-name-input': ,
'duplicate-page-name-input': ,
'admin-rebuild-search': ,
}, componentMappings);
}
if (pageContainer.state.path != null) {
componentMappings = Object.assign({
// eslint-disable-next-line quote-props
'page': ,
'revision-path': ,
'tag-label': ,
}, componentMappings);
}
Object.keys(componentMappings).forEach((key) => {
const elem = document.getElementById(key);
if (elem) {
ReactDOM.render(
{componentMappings[key]}
,
elem,
);
}
});
// render for admin
const customCssEditorElem = document.getElementById('custom-css-editor');
if (customCssEditorElem != null) {
// get input[type=hidden] element
const customCssInputElem = document.getElementById('inputCustomCss');
ReactDOM.render(
,
customCssEditorElem,
);
}
const customScriptEditorElem = document.getElementById('custom-script-editor');
if (customScriptEditorElem != null) {
// get input[type=hidden] element
const customScriptInputElem = document.getElementById('inputCustomScript');
ReactDOM.render(
,
customScriptEditorElem,
);
}
const customHeaderEditorElem = document.getElementById('custom-header-editor');
if (customHeaderEditorElem != null) {
// get input[type=hidden] element
const customHeaderInputElem = document.getElementById('inputCustomHeader');
ReactDOM.render(
,
customHeaderEditorElem,
);
}
const adminUserGroupPageElem = document.getElementById('admin-user-group-page');
if (adminUserGroupPageElem != null) {
const isAclEnabled = adminUserGroupPageElem.getAttribute('data-isAclEnabled') === 'true';
ReactDOM.render(
,
adminUserGroupPageElem,
);
}
const adminFullTextSearchManagementElem = document.getElementById('admin-full-text-search-management');
if (adminFullTextSearchManagementElem != null) {
ReactDOM.render(
,
adminFullTextSearchManagementElem,
);
}
// うわーもうー (commented by Crowi team -- 2018.03.23 Yuki Takei)
$('a[data-toggle="tab"][href="#revision-history"]').on('show.bs.tab', () => {
ReactDOM.render(
, document.getElementById('revision-history'),
);
});