Compare commits
No commits in common. "f106cc78bb25c71e97b78e7b4cad6482e5bcec80" and "dbdf1d39bd579ff1c72e95f6ca5ea4d1ee00dd20" have entirely different histories.
f106cc78bb
...
dbdf1d39bd
|
@ -35,7 +35,8 @@ public class Hashtag: Codable {
|
||||||
throw DecodingError.dataCorruptedError(forKey: .url, in: container, debugDescription: "unable to convert WebURL \(s?.debugDescription ?? "nil") to URL")
|
throw DecodingError.dataCorruptedError(forKey: .url, in: container, debugDescription: "unable to convert WebURL \(s?.debugDescription ?? "nil") to URL")
|
||||||
}
|
}
|
||||||
} catch {
|
} catch {
|
||||||
self.url = try container.decode(URL.self, forKey: .url)
|
let s = try? container.decode(String.self, forKey: .url)
|
||||||
|
throw DecodingError.dataCorruptedError(forKey: .url, in: container, debugDescription: "unable to decode WebURL from \(s?.debugDescription ?? "nil")")
|
||||||
}
|
}
|
||||||
self.history = try container.decodeIfPresent([History].self, forKey: .history)
|
self.history = try container.decodeIfPresent([History].self, forKey: .history)
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,33 +8,14 @@
|
||||||
|
|
||||||
import Foundation
|
import Foundation
|
||||||
import WebURL
|
import WebURL
|
||||||
import WebURLFoundationExtras
|
|
||||||
|
|
||||||
public class Mention: Codable {
|
public class Mention: Codable {
|
||||||
public let url: URL
|
public let url: WebURL
|
||||||
public let username: String
|
public let username: String
|
||||||
public let acct: String
|
public let acct: String
|
||||||
/// The instance-local ID of the user being mentioned.
|
/// The instance-local ID of the user being mentioned.
|
||||||
public let id: String
|
public let id: String
|
||||||
|
|
||||||
public required init(from decoder: Decoder) throws {
|
|
||||||
let container = try decoder.container(keyedBy: CodingKeys.self)
|
|
||||||
self.username = try container.decode(String.self, forKey: .username)
|
|
||||||
self.acct = try container.decode(String.self, forKey: .acct)
|
|
||||||
self.id = try container.decode(String.self, forKey: .id)
|
|
||||||
do {
|
|
||||||
let webURL = try container.decode(WebURL.self, forKey: .url)
|
|
||||||
if let url = URL(webURL) {
|
|
||||||
self.url = url
|
|
||||||
} else {
|
|
||||||
let s = try? container.decode(String.self, forKey: .url)
|
|
||||||
throw DecodingError.dataCorruptedError(forKey: .url, in: container, debugDescription: "unable to convert WebURL \(s?.debugDescription ?? "nil") to URL")
|
|
||||||
}
|
|
||||||
} catch {
|
|
||||||
self.url = try container.decode(URL.self, forKey: .url)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private enum CodingKeys: String, CodingKey {
|
private enum CodingKeys: String, CodingKey {
|
||||||
case url
|
case url
|
||||||
case username
|
case username
|
||||||
|
|
|
@ -21,10 +21,6 @@ public class Notification: Decodable {
|
||||||
self.id = try container.decode(String.self, forKey: .id)
|
self.id = try container.decode(String.self, forKey: .id)
|
||||||
if let kind = try? container.decode(Kind.self, forKey: .kind) {
|
if let kind = try? container.decode(Kind.self, forKey: .kind) {
|
||||||
self.kind = kind
|
self.kind = kind
|
||||||
} else if let s = try? container.decode(String.self, forKey: .kind),
|
|
||||||
s == "status" {
|
|
||||||
// represent notifications of other people posting as regular mentions for now
|
|
||||||
self.kind = .mention
|
|
||||||
} else {
|
} else {
|
||||||
self.kind = .unknown
|
self.kind = .unknown
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,20 +0,0 @@
|
||||||
//
|
|
||||||
// URLTests.swift
|
|
||||||
//
|
|
||||||
//
|
|
||||||
// Created by Shadowfacts on 5/17/22.
|
|
||||||
//
|
|
||||||
|
|
||||||
import XCTest
|
|
||||||
import WebURL
|
|
||||||
import WebURLFoundationExtras
|
|
||||||
|
|
||||||
class URLTests: XCTestCase {
|
|
||||||
|
|
||||||
func testDecodeURL() {
|
|
||||||
print(WebURL(URL(string: "https://xn--baw-joa.social/@unituebingen")!))
|
|
||||||
let url = WebURL("https://xn--baw-joa.social/@unituebingen")
|
|
||||||
print(url)
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -108,12 +108,10 @@ class ContentTextView: LinkTextView, BaseEmojiLabel {
|
||||||
// screws up its determination of the line height making multiple lines of emojis squash together
|
// screws up its determination of the line height making multiple lines of emojis squash together
|
||||||
attributed.append(NSAttributedString(string: "\n", attributes: [.font: defaultFont]))
|
attributed.append(NSAttributedString(string: "\n", attributes: [.font: defaultFont]))
|
||||||
case "a":
|
case "a":
|
||||||
let href = try! node.attr("href")
|
if let link = try? node.attr("href"),
|
||||||
if let webURL = WebURL(href),
|
let webURL = WebURL(link),
|
||||||
let url = URL(webURL) {
|
let url = URL(webURL) {
|
||||||
attributed.addAttribute(.link, value: url, range: attributed.fullRange)
|
attributed.addAttribute(.link, value: url, range: attributed.fullRange)
|
||||||
} else if let url = URL(string: href) {
|
|
||||||
attributed.addAttribute(.link, value: url, range: attributed.fullRange)
|
|
||||||
}
|
}
|
||||||
case "p":
|
case "p":
|
||||||
attributed.append(NSAttributedString(string: "\n\n", attributes: [.font: defaultFont]))
|
attributed.append(NSAttributedString(string: "\n\n", attributes: [.font: defaultFont]))
|
||||||
|
|
|
@ -27,7 +27,7 @@ class StatusContentTextView: ContentTextView {
|
||||||
let status = mastodonController.persistentContainer.status(for: statusID) {
|
let status = mastodonController.persistentContainer.status(for: statusID) {
|
||||||
mention = status.mentions.first { (mention) in
|
mention = status.mentions.first { (mention) in
|
||||||
// Mastodon and Pleroma include the @ in the <a> text, GNU Social does not
|
// Mastodon and Pleroma include the @ in the <a> text, GNU Social does not
|
||||||
(text.dropFirst() == mention.username || text == mention.username) && url.host == mention.url.host!
|
(text.dropFirst() == mention.username || text == mention.username) && url.host == mention.url.host!.serialized
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
mention = nil
|
mention = nil
|
||||||
|
|
Loading…
Reference in New Issue