forked from mirrors/forgejo
This adds pasted images to the dropzone to provide the same experience as when using the dropzone. This gives the possibility to preview and delete the image. Additionally it provides a copy button to copy the markdown code for inserting the image. Removed the old implementation in `repo-legacy.js` and generalized everything in `common-global.js` as common implementation. Replaced old jquery code with plain JS. Fixes #4588
70 lines
2.4 KiB
Go
70 lines
2.4 KiB
Go
// Copyright 2021 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package convert
|
|
|
|
import (
|
|
"mime"
|
|
"path/filepath"
|
|
|
|
repo_model "forgejo.org/models/repo"
|
|
api "forgejo.org/modules/structs"
|
|
)
|
|
|
|
func WebAssetDownloadURL(repo *repo_model.Repository, attach *repo_model.Attachment) string {
|
|
if attach.ExternalURL != "" {
|
|
return attach.ExternalURL
|
|
}
|
|
|
|
return attach.DownloadURL()
|
|
}
|
|
|
|
func APIAssetDownloadURL(repo *repo_model.Repository, attach *repo_model.Attachment) string {
|
|
return attach.DownloadURL()
|
|
}
|
|
|
|
// ToWebAttachment converts models.Attachment to api.WebAttachment for API usage
|
|
func ToWebAttachment(repo *repo_model.Repository, a *repo_model.Attachment) *api.WebAttachment {
|
|
attachment := toAttachment(repo, a, WebAssetDownloadURL)
|
|
return &api.WebAttachment{
|
|
Attachment: attachment,
|
|
MimeType: mime.TypeByExtension(filepath.Ext(attachment.Name)),
|
|
}
|
|
}
|
|
|
|
// ToAPIAttachment converts models.Attachment to api.Attachment for API usage
|
|
func ToAPIAttachment(repo *repo_model.Repository, a *repo_model.Attachment) *api.Attachment {
|
|
return toAttachment(repo, a, APIAssetDownloadURL)
|
|
}
|
|
|
|
// toAttachment converts models.Attachment to api.Attachment for API usage
|
|
func toAttachment(repo *repo_model.Repository, a *repo_model.Attachment, getDownloadURL func(repo *repo_model.Repository, attach *repo_model.Attachment) string) *api.Attachment {
|
|
var typeName string
|
|
if a.ExternalURL != "" {
|
|
typeName = "external"
|
|
} else {
|
|
typeName = "attachment"
|
|
}
|
|
return &api.Attachment{
|
|
ID: a.ID,
|
|
Name: a.Name,
|
|
Created: a.CreatedUnix.AsTime(),
|
|
DownloadCount: a.DownloadCount,
|
|
Size: a.Size,
|
|
UUID: a.UUID,
|
|
DownloadURL: getDownloadURL(repo, a), // for web request json and api request json, return different download urls
|
|
Type: typeName,
|
|
}
|
|
}
|
|
|
|
func ToAPIAttachments(repo *repo_model.Repository, attachments []*repo_model.Attachment) []*api.Attachment {
|
|
return toAttachments(repo, attachments, APIAssetDownloadURL)
|
|
}
|
|
|
|
func toAttachments(repo *repo_model.Repository, attachments []*repo_model.Attachment, getDownloadURL func(repo *repo_model.Repository, attach *repo_model.Attachment) string) []*api.Attachment {
|
|
converted := make([]*api.Attachment, 0, len(attachments))
|
|
for _, attachment := range attachments {
|
|
converted = append(converted, toAttachment(repo, attachment, getDownloadURL))
|
|
}
|
|
return converted
|
|
}
|