Add EasyMDE support for release content editor (#14744)
* Add easyMDE(simpleMDE) support for release content editor Signed-off-by: a1012112796 <1012112796@qq.com>
This commit is contained in:
parent
7bf61a89d3
commit
5d2b7ba639
3 changed files with 34 additions and 2 deletions
|
@ -210,6 +210,8 @@ func LatestRelease(ctx *context.Context) {
|
||||||
func NewRelease(ctx *context.Context) {
|
func NewRelease(ctx *context.Context) {
|
||||||
ctx.Data["Title"] = ctx.Tr("repo.release.new_release")
|
ctx.Data["Title"] = ctx.Tr("repo.release.new_release")
|
||||||
ctx.Data["PageIsReleaseList"] = true
|
ctx.Data["PageIsReleaseList"] = true
|
||||||
|
ctx.Data["RequireSimpleMDE"] = true
|
||||||
|
ctx.Data["RequireTribute"] = true
|
||||||
ctx.Data["tag_target"] = ctx.Repo.Repository.DefaultBranch
|
ctx.Data["tag_target"] = ctx.Repo.Repository.DefaultBranch
|
||||||
if tagName := ctx.Query("tag"); len(tagName) > 0 {
|
if tagName := ctx.Query("tag"); len(tagName) > 0 {
|
||||||
rel, err := models.GetRelease(ctx.Repo.Repository.ID, tagName)
|
rel, err := models.GetRelease(ctx.Repo.Repository.ID, tagName)
|
||||||
|
@ -235,6 +237,8 @@ func NewReleasePost(ctx *context.Context) {
|
||||||
form := web.GetForm(ctx).(*auth.NewReleaseForm)
|
form := web.GetForm(ctx).(*auth.NewReleaseForm)
|
||||||
ctx.Data["Title"] = ctx.Tr("repo.release.new_release")
|
ctx.Data["Title"] = ctx.Tr("repo.release.new_release")
|
||||||
ctx.Data["PageIsReleaseList"] = true
|
ctx.Data["PageIsReleaseList"] = true
|
||||||
|
ctx.Data["RequireSimpleMDE"] = true
|
||||||
|
ctx.Data["RequireTribute"] = true
|
||||||
|
|
||||||
if ctx.HasError() {
|
if ctx.HasError() {
|
||||||
ctx.HTML(200, tplReleaseNew)
|
ctx.HTML(200, tplReleaseNew)
|
||||||
|
@ -313,6 +317,8 @@ func EditRelease(ctx *context.Context) {
|
||||||
ctx.Data["Title"] = ctx.Tr("repo.release.edit_release")
|
ctx.Data["Title"] = ctx.Tr("repo.release.edit_release")
|
||||||
ctx.Data["PageIsReleaseList"] = true
|
ctx.Data["PageIsReleaseList"] = true
|
||||||
ctx.Data["PageIsEditRelease"] = true
|
ctx.Data["PageIsEditRelease"] = true
|
||||||
|
ctx.Data["RequireSimpleMDE"] = true
|
||||||
|
ctx.Data["RequireTribute"] = true
|
||||||
ctx.Data["IsAttachmentEnabled"] = setting.Attachment.Enabled
|
ctx.Data["IsAttachmentEnabled"] = setting.Attachment.Enabled
|
||||||
upload.AddUploadContext(ctx, "release")
|
upload.AddUploadContext(ctx, "release")
|
||||||
|
|
||||||
|
@ -343,6 +349,8 @@ func EditReleasePost(ctx *context.Context) {
|
||||||
ctx.Data["Title"] = ctx.Tr("repo.release.edit_release")
|
ctx.Data["Title"] = ctx.Tr("repo.release.edit_release")
|
||||||
ctx.Data["PageIsReleaseList"] = true
|
ctx.Data["PageIsReleaseList"] = true
|
||||||
ctx.Data["PageIsEditRelease"] = true
|
ctx.Data["PageIsEditRelease"] = true
|
||||||
|
ctx.Data["RequireSimpleMDE"] = true
|
||||||
|
ctx.Data["RequireTribute"] = true
|
||||||
|
|
||||||
tagName := ctx.Params("*")
|
tagName := ctx.Params("*")
|
||||||
rel, err := models.GetRelease(ctx.Repo.Repository.ID, tagName)
|
rel, err := models.GetRelease(ctx.Repo.Repository.ID, tagName)
|
||||||
|
|
|
@ -44,9 +44,18 @@
|
||||||
<label>{{.i18n.Tr "repo.release.title"}}</label>
|
<label>{{.i18n.Tr "repo.release.title"}}</label>
|
||||||
<input name="title" placeholder="{{.i18n.Tr "repo.release.title"}}" value="{{.title}}" autofocus required maxlength="255">
|
<input name="title" placeholder="{{.i18n.Tr "repo.release.title"}}" value="{{.title}}" autofocus required maxlength="255">
|
||||||
</div>
|
</div>
|
||||||
<div class="field">
|
<div class="field content-editor">
|
||||||
<label>{{.i18n.Tr "repo.release.content"}}</label>
|
<label>{{.i18n.Tr "repo.release.content"}}</label>
|
||||||
<textarea name="content">{{.content}}</textarea>
|
<div class="ui top tabular menu" data-write="write" data-preview="preview">
|
||||||
|
<a class="active write item" data-tab="write">{{$.i18n.Tr "write"}}</a>
|
||||||
|
<a class="preview item" data-tab="preview" data-url="{{$.Repository.APIURL}}/markdown" data-context="{{$.RepoLink}}">{{$.i18n.Tr "preview"}}</a>
|
||||||
|
</div>
|
||||||
|
<div class="ui bottom active tab" data-tab="write">
|
||||||
|
<textarea name="content">{{.content}}</textarea>
|
||||||
|
</div>
|
||||||
|
<div class="ui bottom tab markdown" data-tab="preview">
|
||||||
|
{{$.i18n.Tr "loading"}}
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{{if .IsAttachmentEnabled}}
|
{{if .IsAttachmentEnabled}}
|
||||||
<div class="field">
|
<div class="field">
|
||||||
|
|
|
@ -1734,6 +1734,20 @@ async function initEditor() {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function initReleaseEditor() {
|
||||||
|
const $editor = $('.repository.new.release .content-editor');
|
||||||
|
if ($editor.length === 0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
const $textarea = $editor.find('textarea');
|
||||||
|
attachTribute($textarea.get(), {mentions: false, emoji: true});
|
||||||
|
const $files = $editor.parent().find('.files');
|
||||||
|
const $simplemde = setCommentSimpleMDE($textarea);
|
||||||
|
initCommentPreviewTab($editor);
|
||||||
|
initSimpleMDEImagePaste($simplemde, $files);
|
||||||
|
}
|
||||||
|
|
||||||
function initOrganization() {
|
function initOrganization() {
|
||||||
if ($('.organization').length === 0) {
|
if ($('.organization').length === 0) {
|
||||||
return;
|
return;
|
||||||
|
@ -2653,6 +2667,7 @@ $(document).ready(async () => {
|
||||||
initTableSort();
|
initTableSort();
|
||||||
initNotificationsTable();
|
initNotificationsTable();
|
||||||
initPullRequestMergeInstruction();
|
initPullRequestMergeInstruction();
|
||||||
|
initReleaseEditor();
|
||||||
|
|
||||||
const routes = {
|
const routes = {
|
||||||
'div.user.settings': initUserSettings,
|
'div.user.settings': initUserSettings,
|
||||||
|
|
Reference in a new issue