FIX: Empty video thumbnails (#21290)

* FIX: Empty video thumbnails

This fix ensures that topic video thumbnail generation is completed
before the composer is allowed to submit which should prevent some bugs
around missing thumbnails on video topics.

* move callback to on upload-success
This commit is contained in:
Blake Erickson 2023-04-28 12:14:36 -06:00 committed by GitHub
parent 0239e88809
commit 0dea991156
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 26 additions and 28 deletions

View File

@ -325,11 +325,7 @@ export default Mixin.create(ExtendableUploader, UppyS3Multipart, {
cacheShortUploadUrl(upload.short_url, upload); cacheShortUploadUrl(upload.short_url, upload);
// video/mp4, video/webm, video/quicktime, etc. this._generateVideoThumbnail(file, upload.url, () => {
if (file.type.split("/")[0] === "video") {
this._generateVideoThumbnail(file, upload.url);
}
if (this.useUploadPlaceholders) { if (this.useUploadPlaceholders) {
this.appEvents.trigger( this.appEvents.trigger(
`${this.composerEventPrefix}:replace-text`, `${this.composerEventPrefix}:replace-text`,
@ -337,7 +333,6 @@ export default Mixin.create(ExtendableUploader, UppyS3Multipart, {
markdown markdown
); );
} }
this._resetUpload(file, { removePlaceholder: false }); this._resetUpload(file, { removePlaceholder: false });
this.appEvents.trigger( this.appEvents.trigger(
`${this.composerEventPrefix}:upload-success`, `${this.composerEventPrefix}:upload-success`,
@ -353,6 +348,7 @@ export default Mixin.create(ExtendableUploader, UppyS3Multipart, {
} }
}); });
}); });
});
this._uppyInstance.on("upload-error", this._handleUploadError); this._uppyInstance.on("upload-error", this._handleUploadError);

View File

@ -17,9 +17,12 @@ export default Mixin.create(ExtendableUploader, UppyS3Multipart, {
useUploadPlaceholders: true, useUploadPlaceholders: true,
@bind @bind
_generateVideoThumbnail(videoFile, uploadUrl) { _generateVideoThumbnail(videoFile, uploadUrl, callback) {
if (!this.siteSettings.video_thumbnails_enabled) { if (!this.siteSettings.video_thumbnails_enabled) {
return; return callback();
}
if (videoFile.type.split("/")[0] !== "video") {
return callback();
} }
let video = document.createElement("video"); let video = document.createElement("video");
video.src = URL.createObjectURL(videoFile.data); video.src = URL.createObjectURL(videoFile.data);
@ -45,10 +48,7 @@ export default Mixin.create(ExtendableUploader, UppyS3Multipart, {
// A timeout is needed on mobile. // A timeout is needed on mobile.
setTimeout(() => { setTimeout(() => {
ctx.drawImage(video, 0, 0, video.videoWidth, video.videoHeight); ctx.drawImage(video, 0, 0, video.videoWidth, video.videoHeight);
}, 100);
// A timeout is needed on mobile.
setTimeout(() => {
// upload video thumbnail // upload video thumbnail
canvas.toBlob((blob) => { canvas.toBlob((blob) => {
this._uppyInstance = new Uppy({ this._uppyInstance = new Uppy({
@ -77,6 +77,7 @@ export default Mixin.create(ExtendableUploader, UppyS3Multipart, {
this._uppyInstance.on("upload-success", () => { this._uppyInstance.on("upload-success", () => {
this.set("uploading", false); this.set("uploading", false);
callback();
}); });
this._uppyInstance.on("upload-error", (file, error, response) => { this._uppyInstance.on("upload-error", (file, error, response) => {
@ -88,6 +89,7 @@ export default Mixin.create(ExtendableUploader, UppyS3Multipart, {
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.error(message); console.error(message);
this.set("uploading", false); this.set("uploading", false);
callback();
}); });
try { try {