DEV: Update chat-composer-uploads uppy usage (#29339)

This commit is contained in:
David Taylor 2024-10-23 10:07:54 +01:00 committed by GitHub
parent 51a32de45e
commit 52016e4596
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 68 additions and 63 deletions

View File

@ -200,12 +200,10 @@ export default class UppyUpload {
},
});
if (this.config.uploadDropTargetOptions) {
const resolvedDropTargetOptions = this.#resolvedDropTargetOptions;
if (resolvedDropTargetOptions) {
// DropTarget is a UI plugin, only preprocessors must call _useUploadPlugin
this.uppyWrapper.uppyInstance.use(
DropTarget,
this.config.uploadDropTargetOptions
);
this.uppyWrapper.uppyInstance.use(DropTarget, resolvedDropTargetOptions);
}
this.uppyWrapper.uppyInstance.on("progress", (progress) => {
@ -533,6 +531,14 @@ export default class UppyUpload {
}
}
get #resolvedDropTargetOptions() {
if (typeof this.config.uploadDropTargetOptions === "function") {
return this.config.uploadDropTargetOptions();
} else {
return this.config.uploadDropTargetOptions;
}
}
#reset() {
this.uppyWrapper.uppyInstance?.cancelAll();
Object.assign(this, {

View File

@ -21,4 +21,5 @@
@allowMultiple={{true}}
@fileInputId={{this.fileUploadElementId}}
@fileInputClass="hidden-upload-field"
@registerFileInput={{this.uppyUpload.setup}}
/>

View File

@ -1,38 +1,74 @@
import Component from "@ember/component";
import { action } from "@ember/object";
import { getOwner } from "@ember/owner";
import { service } from "@ember/service";
import { classNames } from "@ember-decorators/component";
import UppyUpload from "discourse/lib/uppy/uppy-upload";
import UppyMediaOptimization from "discourse/lib/uppy-media-optimization-plugin";
import { clipboardHelpers } from "discourse/lib/utilities";
import UppyUploadMixin from "discourse/mixins/uppy-upload";
import { cloneJSON } from "discourse-common/lib/object";
import discourseComputed, { bind } from "discourse-common/utils/decorators";
import { bind } from "discourse-common/utils/decorators";
@classNames("chat-composer-uploads")
export default class ChatComposerUploads extends Component.extend(
UppyUploadMixin
) {
export default class ChatComposerUploads extends Component {
@service mediaOptimizationWorker;
@service chatStateManager;
id = "chat-composer-uploader";
type = "chat-composer";
uppyUpload = new UppyUpload(getOwner(this), {
id: "chat-composer-uploader",
type: "chat-composer",
useMultipartUploadsIfAvailable: true,
uppyReady: () => {
if (this.siteSettings.composer_media_optimization_image_enabled) {
this.uppyUpload.uppyWrapper.useUploadPlugin(UppyMediaOptimization, {
optimizeFn: (data, opts) =>
this.mediaOptimizationWorker.optimizeImage(data, opts),
runParallel: !this.site.isMobileDevice,
});
}
this.uppyUpload.uppyWrapper.onPreProcessProgress((file) => {
const inProgressUpload = this.inProgressUploads.findBy("id", file.id);
if (!inProgressUpload?.processing) {
inProgressUpload?.set("processing", true);
}
});
this.uppyUpload.uppyWrapper.onPreProcessComplete((file) => {
const inProgressUpload = this.inProgressUploads.findBy("id", file.id);
inProgressUpload?.set("processing", false);
});
},
uploadDone: (upload) => {
this.uploads.pushObject(upload);
this._triggerUploadsChanged();
},
uploadDropTargetOptions: () => ({
target: this.uploadDropZone || document.body,
}),
onProgressUploadsChanged: () => {
this._triggerUploadsChanged(this.uploads, {
inProgressUploadsCount: this.inProgressUploads?.length,
});
},
});
existingUploads = null;
uploads = null;
useMultipartUploadsIfAvailable = true;
uploadDropZone = null;
init() {
super.init(...arguments);
this.setProperties({
fileInputSelector: `#${this.fileUploadElementId}`,
});
get inProgressUploads() {
return this.uppyUpload.inProgressUploads;
}
didReceiveAttrs() {
super.didReceiveAttrs(...arguments);
if (this.inProgressUploads?.length > 0) {
this._uppyInstance?.cancelAll();
this.uppyUpload.uppyWrapper.uppyInstance?.cancelAll();
}
this.set(
@ -56,19 +92,13 @@ export default class ChatComposerUploads extends Component.extend(
);
}
uploadDone(upload) {
this.uploads.pushObject(upload);
this._triggerUploadsChanged();
}
@discourseComputed("uploads.length", "inProgressUploads.length")
showUploadsContainer(uploadsCount, inProgressUploadsCount) {
return uploadsCount > 0 || inProgressUploadsCount > 0;
get showUploadsContainer() {
return this.get("uploads.length") > 0 || this.inProgressUploads.length > 0;
}
@action
cancelUploading(upload) {
this.appEvents.trigger(`upload-mixin:${this.id}:cancel-upload`, {
this.uppyUpload.cancelSingleUpload({
fileId: upload.id,
});
this.removeUpload(upload);
@ -80,34 +110,6 @@ export default class ChatComposerUploads extends Component.extend(
this._triggerUploadsChanged();
}
_uploadDropTargetOptions() {
return {
target: this.uploadDropZone || document.body,
};
}
_uppyReady() {
if (this.siteSettings.composer_media_optimization_image_enabled) {
this.uppyUpload.uppyWrapper.useUploadPlugin(UppyMediaOptimization, {
optimizeFn: (data, opts) =>
this.mediaOptimizationWorker.optimizeImage(data, opts),
runParallel: !this.site.isMobileDevice,
});
}
this.uppyUpload.uppyWrapper.onPreProcessProgress((file) => {
const inProgressUpload = this.inProgressUploads.findBy("id", file.id);
if (!inProgressUpload?.processing) {
inProgressUpload?.set("processing", true);
}
});
this.uppyUpload.uppyWrapper.onPreProcessComplete((file) => {
const inProgressUpload = this.inProgressUploads.findBy("id", file.id);
inProgressUpload?.set("processing", false);
});
}
@bind
_pasteEventListener(event) {
if (document.activeElement !== this.composerInputEl) {
@ -124,15 +126,11 @@ export default class ChatComposerUploads extends Component.extend(
}
if (event && event.clipboardData && event.clipboardData.files) {
this._addFiles([...event.clipboardData.files], { pasted: true });
}
}
onProgressUploadsChanged() {
this._triggerUploadsChanged(this.uploads, {
inProgressUploadsCount: this.inProgressUploads?.length,
this.uppyUpload.addFiles([...event.clipboardData.files], {
pasted: true,
});
}
}
_triggerUploadsChanged() {
this.onUploadChanged?.(this.uploads, {