mirror of
https://github.com/pointfreeco/swift-composable-architecture.git
synced 2025-12-24 12:14:25 +01:00
* Converted voice memos back to identified array
* update deps
* update docs for DismissEffect
* wip
* Add Sendable conformance to PresentationState (#2086)
* wip
* swift-format
* wip
* wip
* fix some warnings
* docs
* wip
* wip
* Catch some typos in Articles (#2088)
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* docs
* wip
* wip
* docs
* wip
* wip
* wip
* wip
* docs
* docs
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* Fix invalid states count for 3 optionals and typos (#2094)
* wip
* wip
* more dismisseffect docs
* fixed some references
* navigation doc corrections
* more nav docs
* fix cancellation tests in release mode
* wrap some tests in #if DEBUG since they are testing expected failures
* update UUIDs in tests to use shorter initializer
* fixed a todo
* wip
* fix merge errors
* wip
* fix
* wip
* wip
* fixing a bunch of todos
* get rid of rawvalue in StackElementID
* more todos
* NavLinkStore docs
* fix swift 5.6 stuff
* fix some standups tests
* fix
* clean up
* docs fix
* fixes
* wip
* 5.6 fix
* wip
* wip
* dont parallelize tests
* updated demo readmes
* wip
* Use ObservedObject instead of StateObject for alert/dialog modifiers.
* integration tests for bad dismissal behavior
* check for runtime warnings in every integration test
* wip
* wip
* wip
* fix
* wip
* wip
* wip
* wip
* wip
* wip
* Drop a bunch of Hashables.
* some nav bug fixes
* wip
* wip
* wip
* fix
* fix
* wip
* wip
* Simplify recording test.
* add concurrent async test
* fix
* wip
* Refact how detail dismisses itself.
* fix
* 5.6 fix
* wip
* wip
* wip
* wip
* Add TestStore.assert.
* Revert "Add TestStore.assert."
This reverts commit a892cccc66.
* add Ukrainian Readme.md (#2121)
* Add TestStore.assert. (#2123)
* Add TestStore.assert.
* wip
* Update Sources/ComposableArchitecture/TestStore.swift
Co-authored-by: Stephen Celis <stephen@stephencelis.com>
* Update Sources/ComposableArchitecture/Documentation.docc/Extensions/TestStore.md
Co-authored-by: Stephen Celis <stephen@stephencelis.com>
* fix tests
---------
Co-authored-by: Stephen Celis <stephen@stephencelis.com>
* Run swift-format
* push for store.finish and presentation
* wip
* move docs around
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* Add case subscripts
* wip
* wip
* wip
* 5.7-only
* wip
* wip
* wip
* wip
* fix
* revert store.finish task cancellation
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* add test for presentation scope
* wip
* wip
* wip
* wip
* wip
* cleanup
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* Rename ReducerProtocol.swift to Reducer.swift (#2206)
* Hard-deprecate old SwitchStore initializers/overloads
* wip
* wip
* Resolve CaseStudies crash (#2258)
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* Bump timeout for CI
* wip
* wip
---------
Co-authored-by: Jackson Utsch <jutechs@gmail.com>
Co-authored-by: Stephen Celis <stephen@stephencelis.com>
Co-authored-by: 유재호 <y73447jh@gmail.com>
Co-authored-by: Dmytro <barabashdmyto@gmail.com>
Co-authored-by: mbrandonw <mbrandonw@users.noreply.github.com>
99 lines
2.4 KiB
Swift
99 lines
2.4 KiB
Swift
import ComposableArchitecture
|
|
import SwiftUI
|
|
|
|
private let readMe = """
|
|
This screen demonstrates navigation that depends on loading optional data into state.
|
|
|
|
Tapping "Load optional counter" fires off an effect that will load the counter state a second \
|
|
later. When the counter state is present, you will be programmatically presented a sheet that \
|
|
depends on this data.
|
|
"""
|
|
|
|
// MARK: - Feature domain
|
|
|
|
struct LoadThenPresent: Reducer {
|
|
struct State: Equatable {
|
|
@PresentationState var counter: Counter.State?
|
|
var isActivityIndicatorVisible = false
|
|
}
|
|
|
|
enum Action {
|
|
case counter(PresentationAction<Counter.Action>)
|
|
case counterButtonTapped
|
|
case counterPresentationDelayCompleted
|
|
}
|
|
|
|
@Dependency(\.continuousClock) var clock
|
|
|
|
var body: some Reducer<State, Action> {
|
|
Reduce { state, action in
|
|
switch action {
|
|
case .counter:
|
|
return .none
|
|
|
|
case .counterButtonTapped:
|
|
state.isActivityIndicatorVisible = true
|
|
return .run { send in
|
|
try await self.clock.sleep(for: .seconds(1))
|
|
await send(.counterPresentationDelayCompleted)
|
|
}
|
|
|
|
case .counterPresentationDelayCompleted:
|
|
state.isActivityIndicatorVisible = false
|
|
state.counter = Counter.State()
|
|
return .none
|
|
|
|
}
|
|
}
|
|
.ifLet(\.$counter, action: /Action.counter) {
|
|
Counter()
|
|
}
|
|
}
|
|
}
|
|
|
|
// MARK: - Feature view
|
|
|
|
struct LoadThenPresentView: View {
|
|
let store: StoreOf<LoadThenPresent>
|
|
|
|
var body: some View {
|
|
WithViewStore(self.store, observe: { $0 }) { viewStore in
|
|
Form {
|
|
Section {
|
|
AboutView(readMe: readMe)
|
|
}
|
|
Button {
|
|
viewStore.send(.counterButtonTapped)
|
|
} label: {
|
|
HStack {
|
|
Text("Load optional counter")
|
|
if viewStore.isActivityIndicatorVisible {
|
|
Spacer()
|
|
ProgressView()
|
|
}
|
|
}
|
|
}
|
|
}
|
|
.sheet(
|
|
store: store.scope(state: \.$counter, action: LoadThenPresent.Action.counter),
|
|
content: CounterView.init(store:)
|
|
)
|
|
.navigationTitle("Load and present")
|
|
}
|
|
}
|
|
}
|
|
|
|
// MARK: - SwiftUI previews
|
|
|
|
struct LoadThenPresentView_Previews: PreviewProvider {
|
|
static var previews: some View {
|
|
NavigationView {
|
|
LoadThenPresentView(
|
|
store: Store(initialState: LoadThenPresent.State()) {
|
|
LoadThenPresent()
|
|
}
|
|
)
|
|
}
|
|
}
|
|
}
|