Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -144,3 +144,7 @@ app/assets/uploads
# visual studio workspaces
*.code-workspace
assets/uploads/*

# Swift Package Manager
TuttleMac/.build/
TuttleMac/.swiftpm/
13 changes: 13 additions & 0 deletions TuttleMac/Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
PROJECT_ROOT := $(shell cd .. && pwd)
BINARY := .build/debug/TuttleMac

.PHONY: build run clean

build:
swift build

run: build
cd $(PROJECT_ROOT) && TuttleMac/$(BINARY)

clean:
swift package clean
15 changes: 15 additions & 0 deletions TuttleMac/Package.resolved

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

20 changes: 20 additions & 0 deletions TuttleMac/Package.swift
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
// swift-tools-version: 5.10
import PackageDescription

let package = Package(
name: "TuttleMac",
platforms: [.macOS(.v14)],
dependencies: [
.package(url: "https://github.com/pvieito/PythonKit.git", branch: "master"),
],
targets: [
.executableTarget(
name: "TuttleMac",
dependencies: ["PythonKit"],
path: "Sources/TuttleMac",
swiftSettings: [
.enableExperimentalFeature("StrictConcurrency=minimal"),
]
),
]
)
47 changes: 47 additions & 0 deletions TuttleMac/Sources/TuttleMac/ContentView.swift
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
import SwiftUI

struct ContentView: View {
@State private var selectedItem: SidebarItem? = .dashboard

var body: some View {
NavigationSplitView {
Sidebar(selection: $selectedItem)
.frame(minWidth: 180)
} detail: {
detailView
.frame(maxWidth: .infinity, maxHeight: .infinity)
}
}

@ViewBuilder
private var detailView: some View {
switch selectedItem {
case .dashboard:
DashboardView()
case .timeline:
TimelineView()
case .projects:
ProjectsView()
case .contracts:
ContractsView()
case .clients:
ClientsView()
case .contacts:
ContactsView()
case .invoicing:
InvoicingView()
case .none:
ContentUnavailableView(
"Select an Item",
systemImage: "sidebar.left",
description: Text("Choose a section from the sidebar.")
)
default:
ContentUnavailableView(
selectedItem?.rawValue ?? "Coming Soon",
systemImage: selectedItem?.systemImage ?? "hammer",
description: Text("This section is not yet implemented.")
)
}
}
}
Loading
Loading