ViewOnAppear.swift 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. //
  2. // ViewOnAppear.swift
  3. // Nextcloud
  4. //
  5. // Created by Aditya Tyagi on 17/03/24.
  6. // Copyright © 2024 Marino Faggiana. All rights reserved.
  7. //
  8. // Author Aditya Tyagi <adityagi02@yahoo.com>
  9. //
  10. // This program is free software: you can redistribute it and/or modify
  11. // it under the terms of the GNU General Public License as published by
  12. // the Free Software Foundation, either version 3 of the License, or
  13. // (at your option) any later version.
  14. //
  15. // This program is distributed in the hope that it will be useful,
  16. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. // GNU General Public License for more details.
  19. //
  20. // You should have received a copy of the GNU General Public License
  21. // along with this program. If not, see <http://www.gnu.org/licenses/>.
  22. //
  23. import Foundation
  24. import SwiftUI
  25. /// A protocol defining methods to handle view appearance events.
  26. protocol ViewOnAppearHandling: ObservableObject {
  27. /// Triggered when the view appears.
  28. func onViewAppear()
  29. }
  30. extension View {
  31. @discardableResult func defaultViewModifier(_ model: some ViewOnAppearHandling) -> some View {
  32. return modifier(DefaultViewModifier(viewModel: model))
  33. }
  34. }
  35. /// A view modifier that automatically calls a view model's `onViewAppear` function when the view appears on screen.
  36. struct DefaultViewModifier<ViewModel: ViewOnAppearHandling>: ViewModifier {
  37. @ObservedObject var viewModel: ViewModel
  38. func body(content: Content) -> some View {
  39. content
  40. .onAppear {
  41. viewModel.onViewAppear() // Call onViewAppear on view appearance
  42. }
  43. }
  44. }