UNPKG

@sendbird/uikit-react

Version:

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

100 lines (93 loc) 5.81 kB
'use strict'; var _tslib = require('../chunks/bundle-Conb-pOy.js'); var React = require('react'); var ui_Avatar = require('../chunks/bundle-B7KG10z2.js'); var ui_Icon = require('./Icon.js'); var ui_Label = require('../chunks/bundle-zgmRG2KL.js'); var LocalizationContext = require('../chunks/bundle-DPDyqKIJ.js'); var index$1 = require('../chunks/bundle-CHAKEXIJ.js'); var index = require('../chunks/bundle-ptQgj0WJ.js'); var index$2 = require('../chunks/bundle-fYxs1lss.js'); var utils = require('../chunks/bundle-D9d0Qum8.js'); require('./ImageRenderer.js'); require('../chunks/bundle-CkQrhwR6.js'); require('../chunks/bundle-C99t7tzf.js'); require('../chunks/bundle-BbrBawlX.js'); require('../chunks/bundle-Cyl6_qLo.js'); require('../chunks/bundle-CVJwHwWn.js'); require('../chunks/bundle-DQaXgp8o.js'); require('@sendbird/chat/groupChannel'); require('../utils/message/getOutgoingMessageState.js'); require('../chunks/bundle-DAdgL6r8.js'); require('../chunks/bundle-Dobj18FB.js'); require('../chunks/bundle-Cfh78Xnm.js'); function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; } var React__default = /*#__PURE__*/_interopDefaultCompat(React); function getCreatedAt(_a) { var createdAt = _a.createdAt, locale = _a.locale, stringSet = _a.stringSet; var optionalParam = { locale: locale }; if (!createdAt) { return ''; } if (index.isToday(createdAt)) { return index$1.format(createdAt, stringSet.DATE_FORMAT__LAST_MESSAGE_CREATED_AT__TODAY, optionalParam); } if (index.isYesterday(createdAt)) { return stringSet.MESSAGE_STATUS__YESTERDAY; } if (index.isThisYear(createdAt)) { return index$1.format(createdAt, stringSet.DATE_FORMAT__LAST_MESSAGE_CREATED_AT__THIS_YEAR, optionalParam); } return index$1.format(createdAt, stringSet.DATE_FORMAT__LAST_MESSAGE_CREATED_AT__PREVIOUS_YEAR, optionalParam); } function getIconOfFileType(message) { var _a, _b, _c; var fileMessageUrl = (_a = utils.getMessageFirstFileUrl(message)) !== null && _a !== void 0 ? _a : ''; var fileExtension = (_c = (_b = (fileMessageUrl.match(/\.([^.]*?)(?=\?|#|$)/))) === null || _b === void 0 ? void 0 : _b[1]) !== null && _c !== void 0 ? _c : ''; if (/(jpg|jpeg|png)$/i.test(fileExtension)) { return ui_Icon.IconTypes.PHOTO; } else if (/mp4$/i.test(fileExtension) || index$2.isVoiceMessage(message)) { return ui_Icon.IconTypes.PLAY; } else if (/mp3/i.test(fileExtension)) { return ui_Icon.IconTypes.FILE_AUDIO; } else if (/gif/i.test(fileExtension)) { return ui_Icon.IconTypes.GIF; } else { return ui_Icon.IconTypes.FILE_DOCUMENT; } } function MessageSearchFileItem(props) { var className = props.className, message = props.message, selected = props.selected, onClick = props.onClick; var createdAt = message.createdAt; var url = utils.getMessageFirstFileUrl(message); var name = utils.getMessageFirstFileName(message); // @ts-ignore var sender = message.sender || message._sender; var profileUrl = sender.profileUrl, nickname = sender.nickname; var _a = LocalizationContext.useLocalization(), stringSet = _a.stringSet, dateLocale = _a.dateLocale; var isVoiceMsg = index$2.isVoiceMessage(message); var prettyFilename = isVoiceMsg ? stringSet.VOICE_MESSAGE : (name || url); return (React__default.default.createElement("div", { className: _tslib.__spreadArray(_tslib.__spreadArray([], (Array.isArray(className) ? className : [className]), true), [ 'sendbird-message-search-file-item', selected ? 'sendbird-message-search-file-item--selected' : '', ], false).join(' '), onClick: function (e) { e.stopPropagation(); onClick === null || onClick === void 0 ? void 0 : onClick(message); } }, React__default.default.createElement("div", { className: "sendbird-message-search-file-item__left" }, React__default.default.createElement(ui_Avatar.Avatar, { className: "sendbird-message-search-file-item__left__sender-avatar", src: profileUrl, alt: "profile image", width: "56px", height: "56px" })), React__default.default.createElement("div", { className: "sendbird-message-search-file-item__right" }, React__default.default.createElement(ui_Label.Label, { className: "sendbird-message-search-file-item__right__sender-name", type: ui_Label.LabelTypography.SUBTITLE_2, color: ui_Label.LabelColors.ONBACKGROUND_1 }, nickname || stringSet.NO_NAME), React__default.default.createElement("div", { className: "sendbird-message-search-file-item__right__content" }, !isVoiceMsg && (React__default.default.createElement("div", { className: 'sendbird-message-search-file-item__right__content__type-icon' }, React__default.default.createElement(ui_Icon.default, { type: getIconOfFileType(message), fillColor: ui_Icon.IconColors.PRIMARY, width: "18px", height: "18px" }))), React__default.default.createElement(ui_Label.Label, { className: "sendbird-message-search-file-item__right__content__url", type: ui_Label.LabelTypography.BODY_2, color: ui_Label.LabelColors.ONBACKGROUND_1 }, prettyFilename))), React__default.default.createElement(ui_Label.Label, { className: "sendbird-message-search-file-item__message-created-at", type: ui_Label.LabelTypography.CAPTION_3, color: ui_Label.LabelColors.ONBACKGROUND_2 }, getCreatedAt({ createdAt: createdAt, locale: dateLocale, stringSet: stringSet })), React__default.default.createElement("div", { className: "sendbird-message-search-file-item__right-footer" }))); } module.exports = MessageSearchFileItem; //# sourceMappingURL=MessageSearchFileItem.js.map