simonnickel/snap-template
> This package is part of the [SNAP](https://github.com/simonnickel/snap) suite.
Motivation
Finishing the last 20% of a project takes 80% of the time.
(Source: Someone on the internet)
The goal of SnapTemplate is to already have the last 20% ready, before you even start the project. The same applies to the first 20% of a project: infrastructure, boilerplate and project setup.
Even if you don't plan to finish the last 60% of it, it allows to test a quick idea with a full app experience around it.
SnapTemplateDemo
An Xcode project with a base setup of SNAP. The app comes with structure, navigation and infrastructure prepared, to quickly setup a new app using the SNAP packages.
Create new App
- Create and clone repository.
- Copy files from snap-app-template and get everything in the correct place.
- Rename project.
1. Rename top item in project navigator. 2. Change bundle identifier.
- Follow setup steps of snap-settings-service.
Template
The Template comes with:
- Infrastructure to define dependencies and configuration of SNAP packages ready to go.
- Boilerplate to define a navigation hierarchy for the app using snap-navigation.
- A base settings screen using snap-settings-service with some theme configuration options.
<img src="/screenshot.png" height="400"> <img src="/screenshot-settings.png" height="400">
Configurations
Info.plist
Added ITSAppUsesNonExemptEncryption key with value NO, see: Complying with Encryption Export Regulations
Build Settings
- Set Swift Language Version to 6 - Enabled Strict Concurrency checking: SWIFT_STRICT_CONCURRENCY = complete;
// TODO:
- Settings Screen
- Settings Header - Contact
- Generic Usage Statistics
- SwiftData with sync
- Widgets using SwiftData (display, edit)
- Release Notes
- Multiple windows
- Localisation (search "// Missing Localisation")
Package Metadata
Repository: simonnickel/snap-template
Default branch: main
README: README.md