@selfcommunity/react-ui
Version:
React UI Components to integrate a Community created with SelfCommunity Platform.
149 lines (148 loc) • 10.8 kB
JavaScript
Object.defineProperty(exports, "__esModule", { value: true });
exports.createVideoThumbnail = exports.createThumbnail = exports.createDocumentThumbnail = exports.createAudioThumbnail = exports.isSupportedVideoFormat = exports.audioPlaceHolder = exports.documentPlaceholder = exports.videoPlaceholder = exports.pdfImagePlaceholder = void 0;
const types_1 = require("@selfcommunity/types");
exports.pdfImagePlaceholder = '';
exports.videoPlaceholder = '';
exports.documentPlaceholder = '';
exports.audioPlaceHolder = '';
const MAX_WIDTH = 1920;
function isSupportedVideoFormat(filename) {
const extension = filename.split('.').pop().toLowerCase();
const supportedFormats = ['mp4', 'webm', 'ogv', 'mp3', 'm3u8', 'mpd'];
return supportedFormats.includes(extension);
}
exports.isSupportedVideoFormat = isSupportedVideoFormat;
function dataURLtoFile(dataUrl, file) {
let arr = dataUrl.split(','), mime = arr[0].match(/:(.*?);/)[1], bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
const _fileName = file.file && file.file.type.startsWith(types_1.SCMessageFileType.DOCUMENT) ? file.file.name.replace(/(\.[^.]+)$/, '.jpeg') : file.name;
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
return new File([u8arr], _fileName, { type: mime });
}
function createAudioThumbnail(file) {
return new Promise(function (resolve, reject) {
try {
resolve(dataURLtoFile(exports.audioPlaceHolder, file));
}
catch (e) {
reject(e);
console.log(e);
}
});
}
exports.createAudioThumbnail = createAudioThumbnail;
function createDocumentThumbnail(url, file) {
const pdfjsLib = require('pdfjs-dist/webpack');
return new Promise(function (resolve, reject) {
try {
if (!file.file.name.endsWith('.pdf')) {
resolve(dataURLtoFile(exports.documentPlaceholder, file));
}
else {
const canvas = document.createElement('canvas');
const ctx = canvas.getContext('2d');
// Load the PDF file
pdfjsLib
.getDocument(url)
.promise.then((pdf) => {
// Get the first page of the PDF
return pdf.getPage(1);
})
.then((page) => {
// Set the canvas dimensions to match the PDF page dimensions
const viewport = page.getViewport({ scale: 1 });
canvas.width = viewport.width;
canvas.height = viewport.height;
// Render the PDF page onto the canvas
const renderContext = {
canvasContext: ctx,
viewport: viewport
};
return page.render(renderContext).promise;
})
.then(() => {
// Convert the canvas to an image
const thumbnailUrl = canvas.toDataURL('image/jpeg', 1);
// Resolve the Promise with the generated value
resolve(dataURLtoFile(thumbnailUrl, file));
})
.catch((error) => {
console.error('Error converting PDF to JPEG:', error);
reject(error);
return Promise.reject(error);
});
}
}
catch (e) {
reject(e);
console.log(e);
}
});
}
exports.createDocumentThumbnail = createDocumentThumbnail;
function createThumbnail(file) {
return new Promise(function (resolve, reject) {
try {
const reader = new FileReader();
reader.onload = (event) => {
let img = new Image();
img.onload = function () {
const canvas = document.createElement('canvas');
const ctx = canvas.getContext('2d');
canvas.width = MAX_WIDTH;
//to keep aspect ratio
const scaleSize = MAX_WIDTH / img.width;
canvas.height = img.height * scaleSize;
// Draw the canvas
ctx.drawImage(img, 0, 0, canvas.width, canvas.height);
const thumbnailData = canvas.toDataURL('image/jpeg', 0.5);
// Resolve the Promise with the generated value
resolve(dataURLtoFile(thumbnailData, file));
};
img.src = event.target.result;
};
reader.onerror = reject;
reader.readAsDataURL(file);
}
catch (e) {
reject(e);
console.log(e);
}
});
}
exports.createThumbnail = createThumbnail;
function createVideoThumbnail(fileUrl, file) {
return new Promise(function (resolve, reject) {
try {
const video = document.createElement('video');
video.src = fileUrl;
video.crossOrigin = '*';
if (!isSupportedVideoFormat(file.file.name)) {
resolve(dataURLtoFile(exports.videoPlaceholder, file));
}
else {
video.addEventListener('seeked', function () {
const canvas = document.createElement('canvas');
canvas.width = MAX_WIDTH;
//to keep aspect ratio
const scaleSize = MAX_WIDTH / video.videoWidth;
canvas.height = video.videoHeight * scaleSize;
const ctx = canvas.getContext('2d');
// Draw the canvas
ctx.drawImage(video, 0, 0, canvas.width, canvas.height);
const thumbnailUrl = canvas.toDataURL('image/jpeg', 0.5);
// Resolve the Promise with the generated value
resolve(dataURLtoFile(thumbnailUrl, file));
});
}
video.currentTime = 1;
}
catch (e) {
reject(e);
console.log(e);
}
});
}
exports.createVideoThumbnail = createVideoThumbnail;
;