diff --git a/package/src/components/Attachment/AudioAttachment.tsx b/package/src/components/Attachment/AudioAttachment.tsx index eb4d7e9f16..9109159594 100644 --- a/package/src/components/Attachment/AudioAttachment.tsx +++ b/package/src/components/Attachment/AudioAttachment.tsx @@ -36,6 +36,7 @@ export type AudioAttachmentProps = { */ export const AudioAttachment = (props: AudioAttachmentProps) => { const [width, setWidth] = useState(0); + const [progressControlTextWidth, setProgressControlTextWidth] = useState(0); const [currentSpeed, setCurrentSpeed] = useState(1.0); const soundRef = React.useRef(null); const { @@ -228,9 +229,6 @@ export const AudioAttachment = (props: AudioAttachmentProps) => { return ( { - setWidth(nativeEvent.layout.width); - }} style={[ styles.container, { @@ -256,7 +254,12 @@ export const AudioAttachment = (props: AudioAttachmentProps) => { )} - + { + setWidth(nativeEvent.layout.width); + }} + style={[styles.leftContainer, leftContainer]} + > { styles.filenameText, { color: black, - width: - 16 - // 16 = horizontal padding - 40 - // 40 = file icon size - 24 - // 24 = close icon size - 24, // 24 = internal padding }, I18nManager.isRTL ? { writingDirection: 'rtl' } : { writingDirection: 'ltr' }, filenameText, @@ -290,7 +288,12 @@ export const AudioAttachment = (props: AudioAttachmentProps) => { uri={item.file.uri} /> )} - + { + setProgressControlTextWidth(nativeEvent.layout.width); + }} + style={[styles.progressDurationText, { color: grey_dark }, progressDurationText]} + > {progressDuration} {!hideProgressBar && ( @@ -316,7 +319,7 @@ export const AudioAttachment = (props: AudioAttachmentProps) => { onProgressDrag={handleProgressDrag} progress={item.progress as number} testID='progress-control' - width={width / 2} + width={width - progressControlTextWidth} /> )} @@ -365,35 +368,33 @@ const styles = StyleSheet.create({ fontSize: 14, fontWeight: 'bold', paddingBottom: 12, - paddingLeft: 8, }, leftContainer: { justifyContent: 'space-around', + marginHorizontal: 16, + width: '60%', }, playPauseButton: { alignItems: 'center', alignSelf: 'center', borderRadius: 50, - display: 'flex', elevation: 4, justifyContent: 'center', - paddingVertical: 2, + padding: 2, shadowOffset: { height: 2, width: 0, }, shadowOpacity: 0.23, shadowRadius: 2.62, - width: 36, }, progressControlContainer: {}, progressDurationText: { fontSize: 12, - paddingLeft: 10, - paddingRight: 8, + marginRight: 4, }, rightContainer: { - marginLeft: 10, + marginLeft: 'auto', }, speedChangeButton: { alignItems: 'center', @@ -401,6 +402,7 @@ const styles = StyleSheet.create({ borderRadius: 50, elevation: 4, justifyContent: 'center', + paddingHorizontal: 10, paddingVertical: 5, shadowOffset: { height: 2, @@ -408,7 +410,6 @@ const styles = StyleSheet.create({ }, shadowOpacity: 0.23, shadowRadius: 2.62, - width: 36, }, speedChangeButtonText: { fontSize: 12, diff --git a/package/src/utils/getTrimmedAttachmentTitle.ts b/package/src/utils/getTrimmedAttachmentTitle.ts index 59079851b0..e798d5f4cd 100644 --- a/package/src/utils/getTrimmedAttachmentTitle.ts +++ b/package/src/utils/getTrimmedAttachmentTitle.ts @@ -1,5 +1,13 @@ +import { lookup } from 'mime-types'; + export const getTrimmedAttachmentTitle = (title?: string) => { if (!title) return ''; - const lastIndexOfDot = title.lastIndexOf('.'); - return title.length < 12 ? title : title.slice(0, 12) + '...' + title.slice(lastIndexOfDot); + + const mimeType = lookup(title); + if (mimeType) { + const lastIndexOfDot = title.lastIndexOf('.'); + return title.length < 12 ? title : title.slice(0, 12) + '...' + title.slice(lastIndexOfDot); + } else { + return title; + } };