cc998e7c61
- Add a default App and ApiToken for each user, that is used by the front-end - Add an API route to update an article (CSRF had to be disabled because of a bug in rocket_csrf) - Use AJAX to publish and edit articles in the new editor, instead of weird hacks with HTML forms
98 lines
4.7 KiB
HTML
98 lines
4.7 KiB
HTML
@use templates::base;
|
|
@use templates::partials::image_select;
|
|
@use template_utils::*;
|
|
@use validator::{ValidationErrors, ValidationErrorsKind};
|
|
@use std::borrow::Cow;
|
|
@use plume_models::medias::*;
|
|
@use plume_models::blogs::Blog;
|
|
@use plume_models::posts::Post;
|
|
@use routes::posts::NewPostForm;
|
|
@use routes::*;
|
|
|
|
@(ctx: BaseContext, title: String, blog: Blog, editing: bool, form: &NewPostForm, is_draft: bool, article: Option<Post>, errors: ValidationErrors, medias: Vec<Media>, content_len: u64, api_token: String)
|
|
|
|
@:base(ctx, title.clone(), {}, {}, {
|
|
<script>
|
|
window.blog_id = @blog.id
|
|
window.api_token = '@api_token'
|
|
@if editing {
|
|
window.editing = true
|
|
window.post_id = @article.clone().unwrap().id
|
|
} else {
|
|
window.editing = false
|
|
}
|
|
</script>
|
|
<div id="plume-editor" style="display: none;" dir="auto">
|
|
<header>
|
|
<a href="#" id="close-editor">@i18n!(ctx.1, "Classic editor (any changes will be lost)")</a>
|
|
<p id="char-count">@content_len</p>
|
|
</header>
|
|
<article id="edition-area">
|
|
<h1 contenteditable id="editor-title" data-placeholder="@i18n!(ctx.1, "Type your title")">@form.title</h1>
|
|
<h2 contenteditable id="editor-subtitle" data-placeholder="@i18n!(ctx.1, "Type a subtitle or a summary")">@form.subtitle</h2>
|
|
<p contenteditable id="editor-default-paragraph" data-placeholder="@i18n!(ctx.1, "Write your article. You can use Markdown.")">@form.content</p>
|
|
</article>
|
|
<aside id="plume-editor-aside" style="display: none;">
|
|
<div id="options-page">
|
|
<button id="publish" class="button">@i18n!(ctx.1, "Publish")</button>
|
|
|
|
@input!(ctx.1, tags (optional text), "Tags, separated by commas", form, errors.clone(), "")
|
|
@input!(ctx.1, license (optional text), "License", "Leave it empty to reserve all rights", form, errors.clone(), "")
|
|
@:image_select(ctx, "cover", i18n!(ctx.1, "Illustration"), true, medias.clone(), form.cover)
|
|
</div>
|
|
<div id="publish-page" style="display: none">
|
|
<a href="#" id="cancel-publish">@i18n!(ctx.1, "Cancel")</a>
|
|
<p>@i18n!(ctx.1, "You are about to publish this article in {}"; &blog.title)</p>
|
|
<button id="confirm-publish" class="button">@i18n!(ctx.1, "Confirm publication")</button>
|
|
<button id="save-draft" class="button secondary">@i18n!(ctx.1, "Save as draft")</button>
|
|
</div>
|
|
</aside>
|
|
</div>
|
|
|
|
@if let Some(article) = article {
|
|
<form id="plume-fallback-editor" class="new-post" method="post" action="@uri!(posts::update: blog = blog.actor_id, slug = &article.slug)" content-size="@content_len">
|
|
} else {
|
|
<form id="plume-fallback-editor" class="new-post" method="post" action="@uri!(posts::new: blog = blog.actor_id)" content-size="@content_len">
|
|
}
|
|
<h1 id="plume-editor-title" dir="auto">@title</h1>
|
|
|
|
@input!(ctx.1, title (text), "Title", form, errors.clone(), "required")
|
|
@input!(ctx.1, subtitle (optional text), "Subtitle", form, errors.clone(), "")
|
|
|
|
@if let Some(ValidationErrorsKind::Field(errs)) = errors.clone().errors().get("content") {
|
|
@format!(r#"<p class="error">{}</p>"#, errs[0].message.clone().unwrap_or_else(|| Cow::from("Unknown error")))
|
|
}
|
|
|
|
<label for="editor-content" dir="auto">@i18n!(ctx.1, "Content")<small>@i18n!(ctx.1, "Markdown syntax is supported")</small></label>
|
|
<textarea id="editor-content" name="content" rows="20" dir="auto">@Html(&form.content)</textarea>
|
|
<small id="editor-left" dir="auto">@content_len</small>
|
|
<p dir="auto">
|
|
@i18n!(ctx.1, "You can upload media to your gallery, and then copy their Markdown code into your articles to insert them.")
|
|
<a href="@uri!(medias::new)">@i18n!(ctx.1, "Upload media")</a>
|
|
</p>
|
|
|
|
@input!(ctx.1, tags (optional text), "Tags, separated by commas", form, errors.clone(), "")
|
|
|
|
@input!(ctx.1, license (optional text), "License", "Leave it empty to reserve all rights", form, errors, "")
|
|
|
|
@:image_select(ctx, "cover", i18n!(ctx.1, "Illustration"), true, medias, form.cover)
|
|
|
|
@if is_draft {
|
|
<label for="draft" dir="auto">
|
|
<input type="checkbox" name="draft" id="draft" checked>
|
|
@i18n!(ctx.1, "This is a draft, don't publish it yet.")
|
|
</label>
|
|
}
|
|
|
|
@if editing {
|
|
<input type="submit" value="@i18n!(ctx.1, "Update")" />
|
|
} else {
|
|
@if is_draft {
|
|
<input type="submit" value="@i18n!(ctx.1, "Update, or publish")" />
|
|
} else {
|
|
<input type="submit" value="@i18n!(ctx.1, "Publish your post")" />
|
|
}
|
|
}
|
|
</form>
|
|
})
|