UNPKG

@selfcommunity/react-ui

Version:

React UI Components to integrate a Community created with SelfCommunity Platform.

149 lines (148 loc) • 10.8 kB
"use strict"; 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;