mirror of
https://github.com/neon443/StickerSlack.git
synced 2026-03-11 05:19:13 +00:00
update ui
This commit is contained in:
@@ -15,96 +15,88 @@ struct ContentView: View {
|
|||||||
|
|
||||||
var body: some View {
|
var body: some View {
|
||||||
NavigationView {
|
NavigationView {
|
||||||
TabView {
|
List {
|
||||||
List {
|
Button("none") {
|
||||||
TextField("", text: $searchTerm)
|
hoarder.filterEmojis(byCategory: .none, searchTerm: searchTerm)
|
||||||
.onChange(of: searchTerm) { _ in
|
}
|
||||||
hoarder.filterEmojis(by: searchTerm)
|
|
||||||
|
Button("downloaded") {
|
||||||
|
hoarder.filterEmojis(byCategory: .downloaded, searchTerm: searchTerm)
|
||||||
|
}
|
||||||
|
|
||||||
|
Button("not downloaded") {
|
||||||
|
hoarder.filterEmojis(byCategory: .notDownloaded, searchTerm: searchTerm)
|
||||||
|
}
|
||||||
|
|
||||||
|
Button("delete all images") {
|
||||||
|
Task.detached {
|
||||||
|
await hoarder.deleteAllStickers()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Text("\(hoarder.filteredEmojis.count) Emoji")
|
||||||
|
|
||||||
|
ForEach($hoarder.filteredEmojis, id: \.self) { $emoji in
|
||||||
|
HStack {
|
||||||
|
EmojiPreview(
|
||||||
|
hoarder: hoarder,
|
||||||
|
emoji: emoji
|
||||||
|
)
|
||||||
|
.frame(maxWidth: 100, maxHeight: 100)
|
||||||
|
Spacer()
|
||||||
|
Button("", systemImage: "checkmark") {
|
||||||
|
if let sticker = emoji.sticker {
|
||||||
|
if sticker.validate() {
|
||||||
|
print("validation of \(emoji.name) succeeded")
|
||||||
|
Haptic.success.trigger()
|
||||||
|
} else {
|
||||||
|
print("validation of \(emoji.name) failed")
|
||||||
|
Haptic.error.trigger()
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
.autocorrectionDisabled()
|
.buttonStyle(.plain)
|
||||||
.textFieldStyle(.roundedBorder)
|
if emoji.isLocal {
|
||||||
|
Button("", systemImage: "trash") {
|
||||||
Button("none") {
|
emoji.deleteImage()
|
||||||
hoarder.filterEmojis(byCategory: .none, searchTerm: searchTerm)
|
emoji.refresh()
|
||||||
}
|
}
|
||||||
|
.buttonStyle(.plain)
|
||||||
Button("downloaded") {
|
} else {
|
||||||
hoarder.filterEmojis(byCategory: .downloaded, searchTerm: searchTerm)
|
Button("", systemImage: "arrow.down.circle") {
|
||||||
}
|
Task.detached {
|
||||||
|
try? await emoji.downloadImage()
|
||||||
Button("not downloaded") {
|
await MainActor.run {
|
||||||
hoarder.filterEmojis(byCategory: .notDownloaded, searchTerm: searchTerm)
|
emoji.refresh()
|
||||||
}
|
|
||||||
|
|
||||||
Button("delete all images") {
|
|
||||||
Task.detached {
|
|
||||||
await hoarder.deleteAllStickers()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Text("\(hoarder.filteredEmojis.count) Emoji")
|
|
||||||
|
|
||||||
ForEach($hoarder.filteredEmojis, id: \.self) { $emoji in
|
|
||||||
HStack {
|
|
||||||
EmojiPreview(
|
|
||||||
hoarder: hoarder,
|
|
||||||
emoji: emoji
|
|
||||||
)
|
|
||||||
.frame(maxWidth: 100, maxHeight: 100)
|
|
||||||
Spacer()
|
|
||||||
Button("", systemImage: "checkmark") {
|
|
||||||
if let sticker = emoji.sticker {
|
|
||||||
if sticker.validate() {
|
|
||||||
print("validation of \(emoji.name) succeeded")
|
|
||||||
Haptic.success.trigger()
|
|
||||||
} else {
|
|
||||||
print("validation of \(emoji.name) failed")
|
|
||||||
Haptic.error.trigger()
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.buttonStyle(.plain)
|
.buttonStyle(.plain)
|
||||||
if emoji.isLocal {
|
|
||||||
Button("", systemImage: "trash") {
|
|
||||||
emoji.deleteImage()
|
|
||||||
emoji.refresh()
|
|
||||||
}
|
|
||||||
.buttonStyle(.plain)
|
|
||||||
} else {
|
|
||||||
Button("", systemImage: "arrow.down.circle") {
|
|
||||||
Task.detached {
|
|
||||||
try? await emoji.downloadImage()
|
|
||||||
await MainActor.run {
|
|
||||||
emoji.refresh()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.buttonStyle(.plain)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
.swipeActions(edge: .trailing, allowsFullSwipe: true) {
|
}
|
||||||
if emoji.isLocal {
|
.swipeActions(edge: .trailing, allowsFullSwipe: true) {
|
||||||
Button("Remove", systemImage: "trash") {
|
if emoji.isLocal {
|
||||||
emoji.deleteImage()
|
Button("Remove", systemImage: "trash") {
|
||||||
emoji.refresh()
|
emoji.deleteImage()
|
||||||
}
|
emoji.refresh()
|
||||||
.tint(.red)
|
|
||||||
}
|
}
|
||||||
|
.tint(.red)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.refreshable {
|
}
|
||||||
Task.detached {
|
.navigationTitle("StickerSlack")
|
||||||
await hoarder.refreshDB()
|
.onChange(of: searchTerm) { _ in
|
||||||
await hoarder.filterEmojis(by: searchTerm)
|
hoarder.filterEmojis(by: searchTerm)
|
||||||
}
|
}
|
||||||
}
|
.refreshable {
|
||||||
.searchable(text: $searchTerm)
|
Task.detached {
|
||||||
.tabItem {
|
await hoarder.refreshDB()
|
||||||
Label("home", systemImage: "house")
|
await hoarder.filterEmojis(by: searchTerm)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
.searchable(text: $searchTerm, placement: .automatic)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user