mirror of
https://github.com/neon443/StickerSlack.git
synced 2026-03-11 13:26:17 +00:00
implement testdata!
got a list of emojis and urls reanmed slackemojiresponse to emoji
This commit is contained in:
@@ -11,14 +11,14 @@ struct SlackResponse: Codable {
|
||||
var ok: Bool
|
||||
var emoji: [String:String]
|
||||
|
||||
func toEmojiResponse() -> [SlackEmojiResponse] {
|
||||
func toEmojis() -> [Emoji] {
|
||||
return emoji.map {
|
||||
SlackEmojiResponse(name: $0.key, url: $0.value)
|
||||
Emoji(name: $0.key, url: $0.value)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
struct SlackEmojiResponse: Codable {
|
||||
struct Emoji: Codable, Hashable {
|
||||
var name: String
|
||||
var url: String
|
||||
|
||||
|
||||
@@ -12,4 +12,22 @@ import Combine
|
||||
class EmojiHoarder: ObservableObject {
|
||||
private let endpoint: URL = URL(string: "https://slack.com/api/emoji.list")!
|
||||
@Published var kys = ""
|
||||
|
||||
@Published var testBundle: SlackResponse
|
||||
|
||||
init() {
|
||||
self.kys = ""
|
||||
|
||||
guard let testURL = Bundle.main.url(forResource: "testData", withExtension: "json") else {
|
||||
fatalError("")
|
||||
}
|
||||
guard let data = try? Data(contentsOf: testURL) else {
|
||||
self.testBundle = SlackResponse(ok: false, emoji: [:])
|
||||
return
|
||||
}
|
||||
guard let decoded = try? JSONDecoder().decode(SlackResponse.self, from: data) else {
|
||||
fatalError("couldnt decode :sob:")
|
||||
}
|
||||
self.testBundle = decoded
|
||||
}
|
||||
}
|
||||
|
||||
@@ -8,16 +8,25 @@
|
||||
import SwiftUI
|
||||
|
||||
struct ContentView: View {
|
||||
var body: some View {
|
||||
TabView {
|
||||
Text("hi")
|
||||
@StateObject var hoarder: EmojiHoarder = EmojiHoarder()
|
||||
|
||||
var body: some View {
|
||||
NavigationStack {
|
||||
TabView {
|
||||
List {
|
||||
ForEach(hoarder.testBundle.toEmojis(), id: \.self) { emoji in
|
||||
Text(emoji.name)
|
||||
Text(emoji.url)
|
||||
}
|
||||
}
|
||||
.tabItem {
|
||||
Label("home", systemImage: "house")
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#Preview {
|
||||
ContentView()
|
||||
ContentView()
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user