From 097b9404b5cb4dffda07b15f30f915bb09488eee Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marcel=20M=C3=BCller?= Date: Sun, 4 Feb 2024 19:57:12 +0100 Subject: [PATCH] Correctly show file captions with urls MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Marcel Müller --- NextcloudTalk/BaseChatViewController.swift | 3 +- NextcloudTalk/FileMessageTableViewCell.m | 6 ++ .../Unit/UnitChatCellTest.swift | 68 ++++++++++++------- 3 files changed, 52 insertions(+), 25 deletions(-) diff --git a/NextcloudTalk/BaseChatViewController.swift b/NextcloudTalk/BaseChatViewController.swift index 20872623d..84efdf650 100644 --- a/NextcloudTalk/BaseChatViewController.swift +++ b/NextcloudTalk/BaseChatViewController.swift @@ -2619,7 +2619,8 @@ import QuickLook height += 40 // reactionsView(40) } - if message.containsURL() { + // File cells currently can't show the reference view + if message.containsURL(), message.file() == nil { height += 105 } diff --git a/NextcloudTalk/FileMessageTableViewCell.m b/NextcloudTalk/FileMessageTableViewCell.m index a537bf2dc..4305aac71 100644 --- a/NextcloudTalk/FileMessageTableViewCell.m +++ b/NextcloudTalk/FileMessageTableViewCell.m @@ -215,6 +215,12 @@ - (void)setupForMessage:(NCChatMessage *)message withLastCommonReadMessage:(NSIn self.messageId = message.messageId; self.message = message; + if ([message.message isEqualToString:@"{file}"]) { + self.bodyTextView.dataDetectorTypes = UIDataDetectorTypeNone; + } else { + self.bodyTextView.dataDetectorTypes = UIDataDetectorTypeAll; + } + NSDate *date = [[NSDate alloc] initWithTimeIntervalSince1970:message.timestamp]; self.dateLabel.text = [NCUtils getTimeFromDate:date]; diff --git a/NextcloudTalkTests/Unit/UnitChatCellTest.swift b/NextcloudTalkTests/Unit/UnitChatCellTest.swift index 351c37525..e5b809218 100644 --- a/NextcloudTalkTests/Unit/UnitChatCellTest.swift +++ b/NextcloudTalkTests/Unit/UnitChatCellTest.swift @@ -27,6 +27,30 @@ final class UnitChatCellTest: TestBaseRealm { var baseController: BaseChatViewController! var testMessage: NCChatMessage! + let fileMessageParameters = """ +{ + "actor": { + "type": "user", + "id": "admin", + "name": "admin" + }, + "file": { + "type": "file", + "id": "9", + "name": "photo-1517603250781-c4eac1449a80.jpeg", + "size": 444676, + "path": "Media/photo-1517603250781-c4eac1449a80.jpeg", + "link": "https://nextcloud-mm.local/index.php/f/9", + "etag": "60fb4ececc370787b1cdc5623ff4a189", + "permissions": 27, + "mimetype": "image/jpeg", + "preview-available": "yes", + "width": 1491, + "height": 837 + } +} +""" + override func setUpWithError() throws { try super.setUpWithError() @@ -154,35 +178,31 @@ final class UnitChatCellTest: TestBaseRealm { } func testCellWithFileHeight() { - testMessage.messageParametersJSONString = """ -{ - "actor": { - "type": "user", - "id": "admin", - "name": "admin" - }, - "file": { - "type": "file", - "id": "9", - "name": "photo-1517603250781-c4eac1449a80.jpeg", - "size": 444676, - "path": "Media/photo-1517603250781-c4eac1449a80.jpeg", - "link": "https://nextcloud-mm.local/index.php/f/9", - "etag": "60fb4ececc370787b1cdc5623ff4a189", - "permissions": 27, - "mimetype": "image/jpeg", - "preview-available": "yes", - "width": 1491, - "height": 837 - } -} -""" - + // Test without file caption + testMessage.messageParametersJSONString = fileMessageParameters testMessage.message = "{file}" XCTAssertEqual(baseController.getCellHeight(for: testMessage, with: 300), 190.0) + } + func testCellWithFileCaptionHeight() { + testMessage.messageParametersJSONString = fileMessageParameters testMessage.message = "File caption..." XCTAssertEqual(baseController.getCellHeight(for: testMessage, with: 300), 210.0) + } + + func testCellWithFileCaptionUrlHeight() { + updateCapabilities { cap in + cap.referenceApiSupported = true + } + + testMessage.messageParametersJSONString = fileMessageParameters + testMessage.message = "File caption... https://nextcloud.com" + XCTAssertEqual(baseController.getCellHeight(for: testMessage, with: 300), 210.0) + } + + func testCellWithFileAndQuoteHeight() { + testMessage.messageParametersJSONString = fileMessageParameters + testMessage.message = "File caption..." // Add an existing message to the database let existingMessage = NCChatMessage()