UNPKG

@sendbird/uikit-react-native

Version:

Sendbird UIKit for React Native: A feature-rich and customizable chat UI kit with messaging, channel management, and user authentication.

78 lines 2.26 kB
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } import React from 'react'; import { getDownscaleSize } from '@sendbird/uikit-utils'; import SBUUtils from '../libs/SBUUtils'; import expoBackwardUtils from '../utils/expoBackwardUtils'; const createExpoMediaService = _ref => { let { avModule, thumbnailModule, imageManipulator, fsModule } = _ref; return { VideoComponent(_ref2) { let { source, resizeMode, onLoad, ...props } = _ref2; // FIXME: type error https://github.com/expo/expo/issues/17101 // @ts-ignore return /*#__PURE__*/React.createElement(avModule.Video, _extends({}, props, { source: source, resizeMode: resizeMode, onLoad: onLoad, useNativeControls: true })); }, async getVideoThumbnail(_ref3) { let { url, quality, timeMills } = _ref3; try { const { uri } = await thumbnailModule.getThumbnailAsync(url, { quality, time: timeMills }); return { path: uri }; } catch { return null; } }, async compressImage(_ref4) { let { maxWidth, maxHeight, compressionRate = 1, uri } = _ref4; const originSize = await SBUUtils.getImageSize(uri); const resizingSize = getDownscaleSize(originSize, { width: maxWidth, height: maxHeight }); const { uri: compressedURI } = await imageManipulator.manipulateAsync(uri, [{ resize: resizingSize }], { compress: Math.min(Math.max(0, compressionRate), 1) }); const fileInfo = await fsModule.getInfoAsync(uri); return { uri: compressedURI, size: expoBackwardUtils.toFileSize(fileInfo) }; } }; }; export default createExpoMediaService; //# sourceMappingURL=createMediaService.expo.js.map