@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.
74 lines • 2.07 kB
JavaScript
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
import React from 'react';
import { getDownscaleSize } from '@sendbird/uikit-utils';
import SBUUtils from '../libs/SBUUtils';
import expoBackwardUtils from '../utils/expoBackwardUtils';
const createExpoMediaService = ({
avModule,
thumbnailModule,
imageManipulator,
fsModule
}) => {
return {
VideoComponent({
source,
resizeMode,
onLoad,
...props
}) {
// 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({
url,
quality,
timeMills
}) {
try {
const {
uri
} = await thumbnailModule.getThumbnailAsync(url, {
quality,
time: timeMills
});
return {
path: uri
};
} catch {
return null;
}
},
async compressImage({
maxWidth,
maxHeight,
compressionRate = 1,
uri
}) {
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