import React from 'react';
import ReactDOM from 'react-dom';
import { Provider } from 'unstated';
import { I18nextProvider } from 'react-i18next';
import loggerFactory from '@alias/logger';
import ErrorBoundary from './components/ErrorBoudary';
import SearchPage from './components/SearchPage';
import TagsList from './components/TagsList';
import PageEditor from './components/PageEditor';
import PagePathNavForEditor from './components/PageEditor/PagePathNavForEditor';
import EditorNavbarBottom from './components/PageEditor/EditorNavbarBottom';
import { defaultEditorOptions, defaultPreviewOptions } from './components/PageEditor/OptionsSelector';
import PageEditorByHackmd from './components/PageEditorByHackmd';
import Page from './components/Page';
import PageHistory from './components/PageHistory';
import PageComments from './components/PageComments';
import PageTimeline from './components/PageTimeline';
import CommentEditorLazyRenderer from './components/PageComment/CommentEditorLazyRenderer';
import PageManagement from './components/Page/PageManagement';
import TrashPageAlert from './components/Page/TrashPageAlert';
import PageAttachment from './components/PageAttachment';
import PageStatusAlert from './components/PageStatusAlert';
import RecentCreated from './components/RecentCreated/RecentCreated';
import MyBookmarkList from './components/MyBookmarkList/MyBookmarkList';
import MyDraftList from './components/MyDraftList/MyDraftList';
import SeenUserList from './components/User/SeenUserList';
import LikerList from './components/User/LikerList';
import TableOfContents from './components/TableOfContents';
import PersonalSettings from './components/Me/PersonalSettings';
import NavigationContainer from './services/NavigationContainer';
import PageContainer from './services/PageContainer';
import CommentContainer from './services/CommentContainer';
import EditorContainer from './services/EditorContainer';
import TagContainer from './services/TagContainer';
import GrowiSubNavigation from './components/Navbar/GrowiSubNavigation';
import GrowiSubNavigationSwitcher from './components/Navbar/GrowiSubNavigationSwitcher';
import PersonalContainer from './services/PersonalContainer';
import { appContainer, componentMappings } from './base';
const logger = loggerFactory('growi:cli:app');
appContainer.initContents();
const { i18n } = appContainer;
const websocketContainer = appContainer.getContainer('WebsocketContainer');
// create unstated container instance
const navigationContainer = new NavigationContainer(appContainer);
const pageContainer = new PageContainer(appContainer);
const commentContainer = new CommentContainer(appContainer);
const editorContainer = new EditorContainer(appContainer, defaultEditorOptions, defaultPreviewOptions);
const tagContainer = new TagContainer(appContainer);
const personalContainer = new PersonalContainer(appContainer);
const injectableContainers = [
appContainer, websocketContainer, navigationContainer, pageContainer, commentContainer, editorContainer, tagContainer, personalContainer,
];
logger.info('unstated containers have been initialized');
/**
* define components
* key: id of element
* value: React Element
*/
Object.assign(componentMappings, {
'search-page': ,
// 'revision-history': ,
'tags-page': ,
'grw-page-status-alert-container': ,
'trash-page-alert': ,
'page-timeline': ,
'personal-setting': ,
});
// additional definitions if data exists
if (pageContainer.state.pageId != null) {
Object.assign(componentMappings, {
'page-comments-list': ,
'page-comment-write': ,
'page-attachment': ,
'page-management': ,
'revision-toc': ,
'seen-user-list': ,
'liker-list': ,
'user-bookmark-list': ,
'user-created-list': ,
'user-draft-list': ,
});
}
if (pageContainer.state.path != null) {
Object.assign(componentMappings, {
// eslint-disable-next-line quote-props
'page': ,
'grw-subnav-container': ,
'grw-subnav-switcher-container': ,
});
}
// additional definitions if user is logged in
if (appContainer.currentUser != null) {
Object.assign(componentMappings, {
'page-editor': ,
'page-editor-path-nav': ,
'page-editor-navbar-bottom-container': ,
});
if (pageContainer.state.pageId != null) {
Object.assign(componentMappings, {
'page-editor-with-hackmd': ,
});
}
}
Object.keys(componentMappings).forEach((key) => {
const elem = document.getElementById(key);
if (elem) {
ReactDOM.render(
{componentMappings[key]}
,
elem,
);
}
});
// うわーもうー (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'),
);
});
// initialize scrollpos-styler
ScrollPosStyler.init();