KFImageOptions.swift 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. //
  2. // KFImageOptions.swift
  3. // Kingfisher
  4. //
  5. // Created by onevcat on 2020/12/20.
  6. //
  7. // Copyright (c) 2020 Wei Wang <onevcat@gmail.com>
  8. //
  9. // Permission is hereby granted, free of charge, to any person obtaining a copy
  10. // of this software and associated documentation files (the "Software"), to deal
  11. // in the Software without restriction, including without limitation the rights
  12. // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  13. // copies of the Software, and to permit persons to whom the Software is
  14. // furnished to do so, subject to the following conditions:
  15. //
  16. // The above copyright notice and this permission notice shall be included in
  17. // all copies or substantial portions of the Software.
  18. //
  19. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  20. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  21. // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  22. // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  23. // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  24. // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  25. // THE SOFTWARE.
  26. import SwiftUI
  27. // MARK: - KFImage creating.
  28. @available(iOS 13.0, OSX 10.15, tvOS 13.0, watchOS 6.0, *)
  29. extension KFImage {
  30. public static func source(
  31. _ source: Source, isLoaded: Binding<Bool> = .constant(false)
  32. ) -> KFImage
  33. {
  34. KFImage(source: source, isLoaded: isLoaded)
  35. }
  36. public static func resource(
  37. _ resource: Resource, isLoaded: Binding<Bool> = .constant(false)
  38. ) -> KFImage
  39. {
  40. .source(.network(resource), isLoaded: isLoaded)
  41. }
  42. public static func url(
  43. _ url: URL, cacheKey: String? = nil, isLoaded: Binding<Bool> = .constant(false)
  44. ) -> KFImage
  45. {
  46. source(.network(ImageResource(downloadURL: url, cacheKey: cacheKey)), isLoaded: isLoaded)
  47. }
  48. public static func dataProvider(
  49. _ provider: ImageDataProvider, isLoaded: Binding<Bool> = .constant(false)
  50. ) -> KFImage
  51. {
  52. source(.provider(provider), isLoaded: isLoaded)
  53. }
  54. public static func data(
  55. _ data: Data, cacheKey: String, isLoaded: Binding<Bool> = .constant(false)
  56. ) -> KFImage
  57. {
  58. source(.provider(RawImageDataProvider(data: data, cacheKey: cacheKey)), isLoaded: isLoaded)
  59. }
  60. }
  61. @available(iOS 13.0, OSX 10.15, tvOS 13.0, watchOS 6.0, *)
  62. extension KFImage {
  63. /// Sets a placeholder `View` which shows when loading the image.
  64. /// - Parameter content: A view that describes the placeholder.
  65. /// - Returns: A `KFImage` view that contains `content` as its placeholder.
  66. public func placeholder<Content: View>(@ViewBuilder _ content: () -> Content) -> KFImage {
  67. let v = content()
  68. var result = self
  69. result.placeholder = AnyView(v)
  70. return result
  71. }
  72. /// Sets cancelling the download task bound to `self` when the view disappearing.
  73. /// - Parameter flag: Whether cancel the task or not.
  74. /// - Returns: A `KFImage` view that cancels downloading task when disappears.
  75. public func cancelOnDisappear(_ flag: Bool) -> KFImage {
  76. var result = self
  77. result.cancelOnDisappear = flag
  78. return result
  79. }
  80. }