FEATURE: Move emoji uploader to use uppy (#14814)
This commit changes the emoji uploader to use the UppyUploadMixin, and makes some minor changes to the emoji uploader (tightening the copy for drag and drop and adding a percentage for the upload). Since no other uppy upload mixin components have needed to upload multiple files so far, this necessitated adding a tracker for the in progress uploads so we know when to reset the uploader once all uploads are complete. At the moment, the emoji uploader cannot be used for direct S3 uploads because the admin emoji controller creates other records and does other magic with the emojis. At some point we need to factor this kind of thing into the ExternalUploadManager.transform! action to complete external uploads.
This commit is contained in:
parent
892e33fd93
commit
fac9185421
|
@ -1,12 +1,12 @@
|
|||
import Component from "@ember/component";
|
||||
import UploadMixin from "discourse/mixins/upload";
|
||||
import UppyUploadMixin from "discourse/mixins/uppy-upload";
|
||||
import { action } from "@ember/object";
|
||||
import discourseComputed from "discourse-common/utils/decorators";
|
||||
import { notEmpty } from "@ember/object/computed";
|
||||
|
||||
const DEFAULT_GROUP = "default";
|
||||
|
||||
export default Component.extend(UploadMixin, {
|
||||
export default Component.extend(UppyUploadMixin, {
|
||||
type: "emoji",
|
||||
uploadUrl: "/admin/customize/emojis",
|
||||
hasName: notEmpty("name"),
|
||||
|
@ -15,10 +15,10 @@ export default Component.extend(UploadMixin, {
|
|||
emojiGroups: null,
|
||||
newEmojiGroups: null,
|
||||
tagName: null,
|
||||
preventDirectS3Uploads: true,
|
||||
|
||||
didReceiveAttrs() {
|
||||
this._super(...arguments);
|
||||
|
||||
this.set("newEmojiGroups", this.emojiGroups);
|
||||
},
|
||||
|
||||
|
@ -27,10 +27,6 @@ export default Component.extend(UploadMixin, {
|
|||
return !this.hasName || this.uploading;
|
||||
},
|
||||
|
||||
uploadOptions() {
|
||||
return { sequentialUploads: true };
|
||||
},
|
||||
|
||||
@action
|
||||
createEmojiGroup(group) {
|
||||
this.setProperties({
|
||||
|
|
|
@ -23,6 +23,7 @@ export default Mixin.create({
|
|||
uploadProgress: 0,
|
||||
_uppyInstance: null,
|
||||
autoStartUploads: true,
|
||||
_inProgressUploads: 0,
|
||||
id: null,
|
||||
|
||||
// TODO (martin): currently used for backups to turn on auto upload and PUT/XML requests
|
||||
|
@ -137,22 +138,35 @@ export default Mixin.create({
|
|||
this.set("uploadProgress", progress);
|
||||
});
|
||||
|
||||
this._uppyInstance.on("upload", (data) => {
|
||||
this._inProgressUploads += data.fileIDs.length;
|
||||
});
|
||||
|
||||
this._uppyInstance.on("upload-success", (file, response) => {
|
||||
this._inProgressUploads--;
|
||||
|
||||
if (this.usingS3Uploads) {
|
||||
this.setProperties({ uploading: false, processing: true });
|
||||
this._completeExternalUpload(file)
|
||||
.then((completeResponse) => {
|
||||
this.uploadDone(completeResponse);
|
||||
|
||||
if (this._inProgressUploads === 0) {
|
||||
this._reset();
|
||||
}
|
||||
})
|
||||
.catch((errResponse) => {
|
||||
displayErrorForUpload(errResponse, this.siteSettings, file.name);
|
||||
if (this._inProgressUploads === 0) {
|
||||
this._reset();
|
||||
}
|
||||
});
|
||||
} else {
|
||||
this.uploadDone(response.body);
|
||||
if (this._inProgressUploads === 0) {
|
||||
this._reset();
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
this._uppyInstance.on("upload-error", (file, error, response) => {
|
||||
|
@ -160,7 +174,16 @@ export default Mixin.create({
|
|||
this._reset();
|
||||
});
|
||||
|
||||
if (this.siteSettings.enable_direct_s3_uploads) {
|
||||
// TODO (martin) preventDirectS3Uploads is necessary because some of
|
||||
// the current upload mixin components, for example the emoji uploader,
|
||||
// send the upload to custom endpoints that do fancy things in the rails
|
||||
// controller with the upload or create additional data or records. we
|
||||
// need a nice way to do this on complete-external-upload before we can
|
||||
// allow these other uploaders to go direct to S3.
|
||||
if (
|
||||
this.siteSettings.enable_direct_s3_uploads &&
|
||||
!this.preventDirectS3Uploads
|
||||
) {
|
||||
this._useS3Uploads();
|
||||
} else {
|
||||
this._useXHRUploads();
|
||||
|
|
|
@ -35,7 +35,7 @@
|
|||
<label class="btn btn-default btn-primary {{if addDisabled "disabled"}}">
|
||||
{{#if uploading}}
|
||||
{{d-icon "spinner" class="loading-icon"}}
|
||||
<span>{{i18n "admin.emoji.uploading"}}</span>
|
||||
<span>{{i18n "admin.emoji.uploading"}} {{uploadProgress}}%</span>
|
||||
{{else}}
|
||||
{{d-icon "plus"}}
|
||||
<span>{{i18n "admin.emoji.add"}}</span>
|
||||
|
@ -44,6 +44,7 @@
|
|||
class="hidden-upload-field"
|
||||
disabled={{addDisabled}}
|
||||
type="file"
|
||||
multiple="true"
|
||||
accept=".png,.gif">
|
||||
</label>
|
||||
</div>
|
||||
|
|
|
@ -6,6 +6,9 @@ class Admin::EmojisController < Admin::AdminController
|
|||
render_serialized(Emoji.custom, EmojiSerializer, root: false)
|
||||
end
|
||||
|
||||
# TODO (martin) Figure out a way that this kind of custom logic can
|
||||
# be run in the ExternalUploadManager when a direct S3 upload is completed,
|
||||
# related to preventDirectS3Uploads in the UppyUploadMixin.
|
||||
def create
|
||||
file = params[:file] || params[:files].first
|
||||
name = params[:name] || File.basename(file.original_filename, ".*")
|
||||
|
|
|
@ -5437,7 +5437,7 @@ en:
|
|||
|
||||
emoji:
|
||||
title: "Emoji"
|
||||
help: "Add new emoji that will be available to everyone. (PROTIP: drag & drop multiple files at once)"
|
||||
help: "Add new emoji that will be available to everyone. Drag and drop multiple files at once without entering a name to create emojis using their file names."
|
||||
add: "Add New Emoji"
|
||||
uploading: "Uploading..."
|
||||
name: "Name"
|
||||
|
|
Loading…
Reference in New Issue