Merge pull request #532 from RyanRory/doc-with-text

Fix no text shown along with doc type attachments
pull/540/head
RyanZhao 3 years ago committed by GitHub
commit 81fa308f3d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -4,8 +4,7 @@ final class DocumentView : UIView {
private let textColor: UIColor private let textColor: UIColor
// MARK: Settings // MARK: Settings
private static let iconSize: CGFloat = 24 private static let iconImageViewSize: CGSize = CGSize(width: 31, height: 40)
private static let iconImageViewSize: CGFloat = 40
// MARK: Lifecycle // MARK: Lifecycle
init(viewItem: ConversationViewItem, textColor: UIColor) { init(viewItem: ConversationViewItem, textColor: UIColor) {
@ -26,26 +25,33 @@ final class DocumentView : UIView {
private func setUpViewHierarchy() { private func setUpViewHierarchy() {
guard let attachment = viewItem.attachmentStream ?? viewItem.attachmentPointer else { return } guard let attachment = viewItem.attachmentStream ?? viewItem.attachmentPointer else { return }
// Image view // Image view
let iconSize = DocumentView.iconSize let icon = UIImage(named: "File")?.withTint(textColor)
let icon = UIImage(named: "actionsheet_document_black")?.withTint(textColor)?.resizedImage(to: CGSize(width: iconSize, height: iconSize))
let imageView = UIImageView(image: icon) let imageView = UIImageView(image: icon)
imageView.contentMode = .center imageView.contentMode = .center
let iconImageViewSize = DocumentView.iconImageViewSize let iconImageViewSize = DocumentView.iconImageViewSize
imageView.set(.width, to: iconImageViewSize) imageView.set(.width, to: iconImageViewSize.width)
imageView.set(.height, to: iconImageViewSize) imageView.set(.height, to: iconImageViewSize.height)
// Body label // Body label
let titleLabel = UILabel() let titleLabel = UILabel()
titleLabel.lineBreakMode = .byTruncatingTail titleLabel.lineBreakMode = .byTruncatingTail
titleLabel.text = attachment.sourceFilename ?? "File" titleLabel.text = attachment.sourceFilename ?? "File"
titleLabel.textColor = textColor titleLabel.textColor = textColor
titleLabel.font = .systemFont(ofSize: Values.mediumFontSize) titleLabel.font = .systemFont(ofSize: Values.smallFontSize, weight: .light)
// Size label
let sizeLabel = UILabel()
sizeLabel.lineBreakMode = .byTruncatingTail
sizeLabel.text = OWSFormat.formatFileSize(UInt(attachment.byteCount))
sizeLabel.textColor = textColor
sizeLabel.font = .systemFont(ofSize: Values.verySmallFontSize)
// Label stack view
let labelStackView = UIStackView(arrangedSubviews: [ titleLabel, sizeLabel ])
labelStackView.axis = .vertical
// Stack view // Stack view
let stackView = UIStackView(arrangedSubviews: [ imageView, titleLabel ]) let stackView = UIStackView(arrangedSubviews: [ imageView, labelStackView ])
stackView.axis = .horizontal stackView.axis = .horizontal
stackView.spacing = Values.verySmallSpacing
stackView.alignment = .center stackView.alignment = .center
stackView.isLayoutMarginsRelativeArrangement = true
stackView.layoutMargins = UIEdgeInsets(top: 0, leading: 0, bottom: 0, trailing: 12)
addSubview(stackView) addSubview(stackView)
stackView.pin(to: self, withInset: Values.smallSpacing) stackView.pin(to: self)
} }
} }

@ -362,7 +362,6 @@ final class VisibleMessageCell : MessageCell, LinkPreviewViewDelegate {
let maxMessageWidth = VisibleMessageCell.getMaxWidth(for: viewItem) let maxMessageWidth = VisibleMessageCell.getMaxWidth(for: viewItem)
let albumView = MediaAlbumView(mediaCache: cache, items: viewItem.mediaAlbumItems!, isOutgoing: isOutgoing, maxMessageWidth: maxMessageWidth) let albumView = MediaAlbumView(mediaCache: cache, items: viewItem.mediaAlbumItems!, isOutgoing: isOutgoing, maxMessageWidth: maxMessageWidth)
self.albumView = albumView self.albumView = albumView
snContentView.addSubview(albumView)
let size = getSize(for: viewItem) let size = getSize(for: viewItem)
albumView.set(.width, to: size.width) albumView.set(.width, to: size.width)
albumView.set(.height, to: size.height) albumView.set(.height, to: size.height)
@ -398,9 +397,25 @@ final class VisibleMessageCell : MessageCell, LinkPreviewViewDelegate {
Storage.shared.getContact(with: thread.contactSessionID())?.isTrusted != true { Storage.shared.getContact(with: thread.contactSessionID())?.isTrusted != true {
showMediaPlaceholder() showMediaPlaceholder()
} else { } else {
let inset: CGFloat = 12
let maxWidth = VisibleMessageCell.getMaxWidth(for: viewItem) - 2 * inset
// Stack view
let stackView = UIStackView(arrangedSubviews: [])
stackView.axis = .vertical
stackView.spacing = Values.smallSpacing
// Document view
let documentView = DocumentView(viewItem: viewItem, textColor: bodyLabelTextColor) let documentView = DocumentView(viewItem: viewItem, textColor: bodyLabelTextColor)
snContentView.addSubview(documentView) stackView.addArrangedSubview(documentView)
documentView.pin(to: snContentView) // Body text view
if let message = viewItem.interaction as? TSMessage, let body = message.body, body.count > 0,
let delegate = delegate { // delegate should always be set at this point
let bodyTextView = VisibleMessageCell.getBodyTextView(for: viewItem, with: maxWidth, textColor: bodyLabelTextColor, searchText: delegate.lastSearchedText, delegate: self)
self.bodyTextView = bodyTextView
stackView.addArrangedSubview(bodyTextView)
}
// Constraints
snContentView.addSubview(stackView)
stackView.pin(to: snContentView, withInset: inset)
} }
case .deletedMessage: case .deletedMessage:
let deletedMessageView = DeletedMessageView(viewItem: viewItem, textColor: bodyLabelTextColor) let deletedMessageView = DeletedMessageView(viewItem: viewItem, textColor: bodyLabelTextColor)

@ -0,0 +1,12 @@
{
"images" : [
{
"filename" : "doc.pdf",
"idiom" : "universal"
}
],
"info" : {
"author" : "xcode",
"version" : 1
}
}

@ -0,0 +1,12 @@
{
"images" : [
{
"filename" : "doc_large.pdf",
"idiom" : "universal"
}
],
"info" : {
"author" : "xcode",
"version" : 1
}
}

@ -269,7 +269,8 @@ public class MediaMessageView: UIView, OWSAudioPlayerDelegate {
private func createGenericPreview() { private func createGenericPreview() {
var subviews = [UIView]() var subviews = [UIView]()
let imageView = createHeroImageView(imageName: "actionsheet_document_black") let imageView = createHeroImageView(imageName: "FileLarge")
imageView.contentMode = .center
subviews.append(imageView) subviews.append(imageView)
let fileNameLabel = createFileNameLabel() let fileNameLabel = createFileNameLabel()

@ -31,11 +31,11 @@ NS_ASSUME_NONNULL_BEGIN
const unsigned long kOneKilobyte = 1024; const unsigned long kOneKilobyte = 1024;
const unsigned long kOneMegabyte = kOneKilobyte * kOneKilobyte; const unsigned long kOneMegabyte = kOneKilobyte * kOneKilobyte;
if (fileSize > kOneMegabyte * 10) { if (fileSize > kOneMegabyte) {
return [[formatter stringFromNumber:@((int)round(fileSize / (CGFloat)kOneMegabyte))] return [[formatter stringFromNumber:@((double)lround(fileSize * 100 / (CGFloat)kOneMegabyte) / 100)]
stringByAppendingString:@" MB"]; stringByAppendingString:@" MB"];
} else if (fileSize > kOneKilobyte * 10) { } else if (fileSize > kOneKilobyte) {
return [[formatter stringFromNumber:@((int)round(fileSize / (CGFloat)kOneKilobyte))] return [[formatter stringFromNumber:@((double)lround(fileSize * 100 / (CGFloat)kOneKilobyte) / 100)]
stringByAppendingString:@" KB"]; stringByAppendingString:@" KB"];
} else { } else {
return [NSString stringWithFormat:@"%lu Bytes", fileSize]; return [NSString stringWithFormat:@"%lu Bytes", fileSize];

Loading…
Cancel
Save