|
|
@@ -8,7 +8,7 @@ import { withTranslation } from 'react-i18next';
|
|
|
import { format } from 'date-fns';
|
|
|
|
|
|
import {
|
|
|
- userPageRoot, isCreatablePage,
|
|
|
+ userPageRoot, isCreatablePage, generateEditorPath,
|
|
|
} from '@commons/util/path-utils';
|
|
|
import { pathUtils } from 'growi-commons';
|
|
|
|
|
|
@@ -76,24 +76,15 @@ const PageCreateModal = (props) => {
|
|
|
* join path, check if creatable, then redirect
|
|
|
* @param {string} paths
|
|
|
*/
|
|
|
- function redirectToEditor(...paths) {
|
|
|
-
|
|
|
- const joinedPath = [...paths]
|
|
|
- .map(str => str.replace(/^\/+|\/+$|\s/g, ''))
|
|
|
- .join('/')
|
|
|
- .replace(/\/$/, '');
|
|
|
-
|
|
|
- if (!isCreatablePage(joinedPath)) {
|
|
|
- toastError(new Error('Invalid characters'));
|
|
|
- return;
|
|
|
- }
|
|
|
+ async function redirectToEditor(...paths) {
|
|
|
|
|
|
try {
|
|
|
- const url = new URL(joinedPath, 'https://dummy');
|
|
|
- window.location.href = `${url.pathname}#edit`;
|
|
|
+ const editorPath = await generateEditorPath(...paths);
|
|
|
+ console.log(editorPath);
|
|
|
+ // window.location.href = `${url.pathname}#edit`;
|
|
|
}
|
|
|
catch (err) {
|
|
|
- toastError(new Error('Invalid path format'));
|
|
|
+ toastError(err);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
@@ -135,7 +126,7 @@ const PageCreateModal = (props) => {
|
|
|
return (
|
|
|
<div className="row">
|
|
|
<fieldset className="col-12 mb-4">
|
|
|
- <h3 className="grw-modal-head pb-2">{ t("Create today's") }</h3>
|
|
|
+ <h3 className="grw-modal-head pb-2">{t("Create today's")}</h3>
|
|
|
|
|
|
<div className="d-sm-flex align-items-center justify-items-between">
|
|
|
|
|
|
@@ -166,7 +157,7 @@ const PageCreateModal = (props) => {
|
|
|
|
|
|
<div className="d-flex justify-content-end mt-1 mt-sm-0">
|
|
|
<button type="button" className="grw-btn-create-page btn btn-outline-primary rounded-pill text-nowrap ml-3" onClick={createTodayPage}>
|
|
|
- <i className="icon-fw icon-doc"></i>{ t('Create') }
|
|
|
+ <i className="icon-fw icon-doc"></i>{t('Create')}
|
|
|
</button>
|
|
|
</div>
|
|
|
|
|
|
@@ -181,7 +172,7 @@ const PageCreateModal = (props) => {
|
|
|
return (
|
|
|
<div className="row">
|
|
|
<fieldset className="col-12 mb-4">
|
|
|
- <h3 className="grw-modal-head pb-2">{ t('Create under') }</h3>
|
|
|
+ <h3 className="grw-modal-head pb-2">{t('Create under')}</h3>
|
|
|
|
|
|
<div className="d-sm-flex align-items-center justify-items-between">
|
|
|
|
|
|
@@ -212,7 +203,7 @@ const PageCreateModal = (props) => {
|
|
|
|
|
|
<div className="d-flex justify-content-end mt-1 mt-sm-0">
|
|
|
<button type="button" className="grw-btn-create-page btn btn-outline-primary rounded-pill text-nowrap ml-3" onClick={createInputPage}>
|
|
|
- <i className="icon-fw icon-doc"></i>{ t('Create') }
|
|
|
+ <i className="icon-fw icon-doc"></i>{t('Create')}
|
|
|
</button>
|
|
|
</div>
|
|
|
|
|
|
@@ -243,12 +234,12 @@ const PageCreateModal = (props) => {
|
|
|
</button>
|
|
|
<div className="dropdown-menu" aria-labelledby="userMenu">
|
|
|
<button className="dropdown-item" type="button" onClick={() => onChangeTemplateHandler('children')}>
|
|
|
- { t('template.children.label') } (_template)<br className="d-block d-md-none" />
|
|
|
- <small className="text-muted text-wrap">- { t('template.children.desc') }</small>
|
|
|
+ {t('template.children.label')} (_template)<br className="d-block d-md-none" />
|
|
|
+ <small className="text-muted text-wrap">- {t('template.children.desc')}</small>
|
|
|
</button>
|
|
|
<button className="dropdown-item" type="button" onClick={() => onChangeTemplateHandler('decendants')}>
|
|
|
- { t('template.decendants.label') } (__template) <br className="d-block d-md-none" />
|
|
|
- <small className="text-muted">- { t('template.decendants.desc') }</small>
|
|
|
+ {t('template.decendants.label')} (__template) <br className="d-block d-md-none" />
|
|
|
+ <small className="text-muted">- {t('template.decendants.desc')}</small>
|
|
|
</button>
|
|
|
</div>
|
|
|
</div>
|
|
|
@@ -259,7 +250,7 @@ const PageCreateModal = (props) => {
|
|
|
className={`grw-btn-create-page btn btn-outline-primary rounded-pill text-nowrap ml-3 ${template == null && 'disabled'}`}
|
|
|
onClick={createTemplatePage}
|
|
|
>
|
|
|
- <i className="icon-fw icon-doc"></i>{ t('Edit') }
|
|
|
+ <i className="icon-fw icon-doc"></i>{t('Edit')}
|
|
|
</button>
|
|
|
</div>
|
|
|
|
|
|
@@ -279,7 +270,7 @@ const PageCreateModal = (props) => {
|
|
|
autoFocus={false}
|
|
|
>
|
|
|
<ModalHeader tag="h4" toggle={navigationContainer.closePageCreateModal} className="bg-primary text-light">
|
|
|
- { t('New Page') }
|
|
|
+ {t('New Page')}
|
|
|
</ModalHeader>
|
|
|
<ModalBody>
|
|
|
{renderCreateTodayForm()}
|