2022-12-03 06:15:33 +01:00
|
|
|
//
|
|
|
|
// FolderItem.swift
|
|
|
|
// Browse
|
|
|
|
//
|
|
|
|
// Created by Javier Cicchelli on 02/12/2022.
|
|
|
|
// Copyright © 2022 Röck+Cöde. All rights reserved.
|
|
|
|
//
|
|
|
|
|
2022-12-14 23:57:20 +01:00
|
|
|
import DataModels
|
2022-12-03 06:15:33 +01:00
|
|
|
import SwiftUI
|
|
|
|
|
|
|
|
struct FolderItem: View {
|
|
|
|
|
|
|
|
// MARK: Properties
|
|
|
|
|
2022-12-16 17:20:19 +01:00
|
|
|
let item: any FileSystemItem
|
2022-12-14 23:57:20 +01:00
|
|
|
let select: ActionClosure
|
|
|
|
let delete: ActionClosure
|
2022-12-03 06:15:33 +01:00
|
|
|
|
|
|
|
// MARK: Body
|
|
|
|
|
|
|
|
var body: some View {
|
2022-12-14 01:43:31 +01:00
|
|
|
Button {
|
2022-12-14 23:57:20 +01:00
|
|
|
select()
|
2022-12-14 01:43:31 +01:00
|
|
|
} label: {
|
|
|
|
HStack(spacing: 16) {
|
|
|
|
Image.folder
|
|
|
|
.icon(size: 32)
|
|
|
|
.foregroundColor(.red)
|
|
|
|
|
|
|
|
Text(item.name)
|
|
|
|
.itemName()
|
|
|
|
|
|
|
|
Image.chevronRight
|
|
|
|
.icon(size: 16)
|
|
|
|
.foregroundColor(.secondary)
|
|
|
|
.font(.headline)
|
|
|
|
}
|
|
|
|
.padding(.vertical, 8)
|
2022-12-03 06:15:33 +01:00
|
|
|
}
|
2022-12-14 00:44:01 +01:00
|
|
|
.swipeActions(
|
|
|
|
edge: .trailing,
|
|
|
|
allowsFullSwipe: true
|
|
|
|
) {
|
|
|
|
Button {
|
2022-12-14 23:57:20 +01:00
|
|
|
delete()
|
2022-12-14 00:44:01 +01:00
|
|
|
} label: {
|
|
|
|
Label {
|
|
|
|
Text(
|
|
|
|
"browse.swipe_action.delete_item.text",
|
|
|
|
bundle: .module
|
|
|
|
)
|
|
|
|
} icon: {
|
|
|
|
Image.trash
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.tint(.red)
|
|
|
|
}
|
2022-12-03 06:15:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2022-12-03 06:56:38 +01:00
|
|
|
// MARK: - Image+Constants
|
2022-12-03 06:15:33 +01:00
|
|
|
|
|
|
|
private extension Image {
|
|
|
|
static let folder = Image(systemName: "folder.fill")
|
|
|
|
static let chevronRight = Image(systemName: "chevron.right")
|
|
|
|
}
|
|
|
|
|
|
|
|
// MARK: - Previews
|
|
|
|
|
|
|
|
struct BrowseItem_Previews: PreviewProvider {
|
|
|
|
static var previews: some View {
|
2022-12-14 00:44:01 +01:00
|
|
|
FolderItem(item: Folder(
|
|
|
|
id: "1234567890",
|
|
|
|
name: "Some folder name goes in here..."
|
2022-12-14 23:57:20 +01:00
|
|
|
)) {
|
|
|
|
// select closure.
|
|
|
|
} delete: {
|
|
|
|
// delete closure.
|
2022-12-14 00:44:01 +01:00
|
|
|
}
|
|
|
|
.previewDisplayName("Folder item")
|
2022-12-03 06:15:33 +01:00
|
|
|
|
2022-12-14 00:44:01 +01:00
|
|
|
FolderItem(item: Folder(
|
|
|
|
id: "1234567890",
|
|
|
|
name: "Some very, extremely long folder name goes in here..."
|
2022-12-14 23:57:20 +01:00
|
|
|
)) {
|
|
|
|
// select closure.
|
|
|
|
} delete: {
|
|
|
|
// delete closure.
|
2022-12-14 00:44:01 +01:00
|
|
|
}
|
|
|
|
.previewDisplayName("Folder item with long name")
|
2022-12-03 06:15:33 +01:00
|
|
|
}
|
|
|
|
}
|