Skip to content

Commit

Permalink
Merge pull request #262 from NYTimes/feature/interstial-views
Browse files Browse the repository at this point in the history
Support Interstitial Views
  • Loading branch information
craighowarth authored May 1, 2018
2 parents 5c4cf7f + 136441d commit 21eaf16
Show file tree
Hide file tree
Showing 21 changed files with 409 additions and 111 deletions.
10 changes: 8 additions & 2 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,18 @@

Changes for users of the library currently on `develop`:

- Fixed some tests, added tests for NYTPhotoViewerSinglePhotoDataSource
- Fixed a strict warning and a subscripting bug in NYTPhotoViewerArrayDataSource.m
- Added support for interstitial views

## [2.0.0](https://github.com/NYTimes/NYTPhotoViewer/releases/tag/2.0.0)

Changes for users of the library in 2.0.0:

- Expose a data-source-oriented API for PhotosViewController ([#226](https://github.com/NYTimes/NYTPhotoViewer/pull/226))
- A data source no longer has to handle out-of-bounds indexes ([#227](https://github.com/NYTimes/NYTPhotoViewer/pull/227))
- The data source is not retained ([#227](https://github.com/NYTimes/NYTPhotoViewer/pull/227))
- Respect safe areas for iOS 11 support
- Fixed some tests, added tests for NYTPhotoViewerSinglePhotoDataSource
- Fixed a strict warning and a subscripting bug in NYTPhotoViewerArrayDataSource.m

## [1.2.0](https://github.com/NYTimes/NYTPhotoViewer/releases/tag/1.2.0)

Expand Down
19 changes: 0 additions & 19 deletions Example-Swift/Photo.swift

This file was deleted.

14 changes: 11 additions & 3 deletions Example-Swift/PhotoBox.swift
Original file line number Diff line number Diff line change
Expand Up @@ -12,10 +12,10 @@ import NYTPhotoViewer
/// A box allowing NYTPhotoViewer to consume Swift value types from our codebase.
final class NYTPhotoBox: NSObject, NYTPhoto {

let value: Photo
let value: PhotoItem

init(_ photo: Photo) {
value = photo
init(_ photoItem: PhotoItem) {
value = photoItem
}

// MARK: NYTPhoto
Expand All @@ -24,6 +24,14 @@ final class NYTPhotoBox: NSObject, NYTPhoto {
var imageData: Data?
var placeholderImage: UIImage?

var isPhoto: Bool {
return value.itemType == .image
}

var isView: Bool {
return value.itemType == .view
}

var attributedCaptionTitle: NSAttributedString?

var attributedCaptionSummary: NSAttributedString? {
Expand Down
34 changes: 34 additions & 0 deletions Example-Swift/PhotoItem.swift
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
//
// PhotoItem.swift
// NYTPhotoViewer
//
// Created by Chris Dzombak on 2/2/17.
// Copyright © 2017 NYTimes. All rights reserved.
//

import UIKit

/// A photo item can either be an image or a view
enum PhotoItemType {
case image
case view
}

/// A photo may often be represented in a Swift application as a value type.
struct PhotoItem {
// This would usually be a URL, but for this demo we load images from the bundle.
let name: String
let summary: String
let credit: String
let itemType: PhotoItemType
let identifier: Int

init(name: String = "", summary: String = "", credit: String = "", itemType: PhotoItemType, identifier: Int) {
self.name = name
self.summary = summary
self.credit = credit
self.itemType = itemType
self.identifier = identifier
}

}
33 changes: 27 additions & 6 deletions Example-Swift/PhotoViewerCoordinator.swift
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
import NYTPhotoViewer

/// Coordinates interaction between the application's data layer and the photo viewer component.
final class PhotoViewerCoordinator: NYTPhotoViewerDataSource {
final class PhotoViewerCoordinator: NSObject, NYTPhotoViewerDataSource {
let slideshow: [NYTPhotoBox]
let provider: PhotosProvider

Expand All @@ -20,23 +20,43 @@ final class PhotoViewerCoordinator: NYTPhotoViewerDataSource {
init(provider: PhotosProvider) {
self.provider = provider
self.slideshow = provider.fetchDemoSlideshow().map { NYTPhotoBox($0) }
super.init()
self.fetchPhotos()
}

func fetchPhotos() {
for box in slideshow {
provider.fetchPhoto(named: box.value.name, then: { [weak self] (result) in
box.image = result
self?.photoViewer.update(box)
})
if box.isPhoto {
provider.fetchPhoto(named: box.value.name, then: { [weak self] (result) in
box.image = result
self?.photoViewer.update(box)
})
}
}
}

// MARK: NYTPhotoViewerDataSource

@objc
var numberOfPhotos: NSNumber? {
return NSNumber(integerLiteral: slideshow.count)
return NSNumber(integerLiteral: slideshow.filter({ $0.isPhoto }).count)
}

@objc
func numberOfInterstitialViews() -> NSNumber {
return NSNumber(integerLiteral: slideshow.filter({ $0.isView }).count)
}

@objc
func isPhoto(at idx: Int) -> Bool {
guard idx < slideshow.count else { return false }
return slideshow[idx].isPhoto
}

@objc
func isInterstitialView(at idx: Int) -> Bool {
guard idx < slideshow.count else { return false }
return slideshow[idx].isView
}

@objc
Expand All @@ -48,6 +68,7 @@ final class PhotoViewerCoordinator: NYTPhotoViewerDataSource {
@objc
func photo(at index: Int) -> NYTPhoto? {
guard index < slideshow.count else { return nil }
guard slideshow[index].isPhoto else { return nil }
return slideshow[index]
}
}
12 changes: 8 additions & 4 deletions Example-Swift/PhotosProvider.swift
Original file line number Diff line number Diff line change
Expand Up @@ -10,11 +10,11 @@ import UIKit

/// A component of your data layer, which might load photos from the cache or network.
final class PhotosProvider {
typealias Slideshow = [Photo]
typealias Slideshow = [PhotoItem]

/// Simulate a synchronous fetch of a slideshow, perhaps from a local database.
func fetchDemoSlideshow() -> Slideshow {
return (0...4).map { demoPhoto(identifier: $0) }
return (0...7).map { [2,5].contains($0) ? demoView(identifier: $0) : demoPhoto(identifier: $0) }
}

/// Simulate fetching a photo from the network.
Expand All @@ -29,7 +29,7 @@ final class PhotosProvider {
}

extension PhotosProvider {
fileprivate func demoPhoto(identifier: Int) -> Photo {
fileprivate func demoPhoto(identifier: Int) -> PhotoItem {
let photoName: String
let photoSummary: String
let photoCredit: String
Expand All @@ -44,6 +44,10 @@ extension PhotosProvider {
photoCredit = "Photo: Nic Lehoux"
}

return Photo(name: photoName, summary: photoSummary, credit: photoCredit, identifier: identifier)
return PhotoItem(name: photoName, summary: photoSummary, credit: photoCredit, itemType: .image, identifier: identifier)
}

fileprivate func demoView(identifier: Int) -> PhotoItem {
return PhotoItem(itemType: .view, identifier: identifier)
}
}
11 changes: 11 additions & 0 deletions Example-Swift/ViewController.swift
Original file line number Diff line number Diff line change
Expand Up @@ -68,4 +68,15 @@ extension ViewController: NYTPhotosViewControllerDelegate {
func photosViewControllerDidDismiss(_ photosViewController: NYTPhotosViewController) {
photoViewerCoordinator = nil
}

func photosViewController(_ photosViewController: NYTPhotosViewController, interstitialViewAt index: UInt) -> UIView {
let redView = UIView(frame: CGRect(origin: .zero, size: CGSize(width: photosViewController.view.frame.width, height: 200)))
redView.backgroundColor = .red
redView.autoresizingMask = [.flexibleWidth]
return redView
}

func photosViewController(_ photosViewController: NYTPhotosViewController, didNavigateToInterstialView view: UIView, at index: UInt) {
view.backgroundColor = .blue
}
}
26 changes: 16 additions & 10 deletions NYTPhotoViewer.xcodeproj/project.pbxproj
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@
1110845D1C87682300699670 /* NYTScalingImageView.m in Sources */ = {isa = PBXBuildFile; fileRef = 111084441C87682300699670 /* NYTScalingImageView.m */; };
1110845E1C87682300699670 /* NYTPhoto.h in Headers */ = {isa = PBXBuildFile; fileRef = 111084461C87682300699670 /* NYTPhoto.h */; settings = {ATTRIBUTES = (Public, ); }; };
1110845F1C87682300699670 /* NYTPhotoCaptionViewLayoutWidthHinting.h in Headers */ = {isa = PBXBuildFile; fileRef = 111084471C87682300699670 /* NYTPhotoCaptionViewLayoutWidthHinting.h */; settings = {ATTRIBUTES = (Public, ); }; };
111084601C87682300699670 /* NYTPhotoContainer.h in Headers */ = {isa = PBXBuildFile; fileRef = 111084481C87682300699670 /* NYTPhotoContainer.h */; settings = {ATTRIBUTES = (Public, ); }; };
111084601C87682300699670 /* NYTPhotoViewerContainer.h in Headers */ = {isa = PBXBuildFile; fileRef = 111084481C87682300699670 /* NYTPhotoViewerContainer.h */; settings = {ATTRIBUTES = (Public, ); }; };
111084611C87682300699670 /* NYTPhotoViewerDataSource.h in Headers */ = {isa = PBXBuildFile; fileRef = 111084491C87682300699670 /* NYTPhotoViewerDataSource.h */; settings = {ATTRIBUTES = (Public, ); }; };
111084621C87682300699670 /* NSBundle+NYTPhotoViewer.h in Headers */ = {isa = PBXBuildFile; fileRef = 1110844B1C87682300699670 /* NSBundle+NYTPhotoViewer.h */; settings = {ATTRIBUTES = (Public, ); }; };
111084631C87682300699670 /* NSBundle+NYTPhotoViewer.m in Sources */ = {isa = PBXBuildFile; fileRef = 1110844C1C87682300699670 /* NSBundle+NYTPhotoViewer.m */; };
Expand Down Expand Up @@ -78,7 +78,7 @@
11FBDA9D1C87753200018169 /* NYTScalingImageView.m in Sources */ = {isa = PBXBuildFile; fileRef = 111084441C87682300699670 /* NYTScalingImageView.m */; };
11FBDA9E1C87753200018169 /* NYTPhoto.h in Headers */ = {isa = PBXBuildFile; fileRef = 111084461C87682300699670 /* NYTPhoto.h */; settings = {ATTRIBUTES = (Public, ); }; };
11FBDA9F1C87753200018169 /* NYTPhotoCaptionViewLayoutWidthHinting.h in Headers */ = {isa = PBXBuildFile; fileRef = 111084471C87682300699670 /* NYTPhotoCaptionViewLayoutWidthHinting.h */; settings = {ATTRIBUTES = (Public, ); }; };
11FBDAA01C87753200018169 /* NYTPhotoContainer.h in Headers */ = {isa = PBXBuildFile; fileRef = 111084481C87682300699670 /* NYTPhotoContainer.h */; settings = {ATTRIBUTES = (Public, ); }; };
11FBDAA01C87753200018169 /* NYTPhotoViewerContainer.h in Headers */ = {isa = PBXBuildFile; fileRef = 111084481C87682300699670 /* NYTPhotoViewerContainer.h */; settings = {ATTRIBUTES = (Public, ); }; };
11FBDAA11C87753200018169 /* NYTPhotoViewerDataSource.h in Headers */ = {isa = PBXBuildFile; fileRef = 111084491C87682300699670 /* NYTPhotoViewerDataSource.h */; settings = {ATTRIBUTES = (Public, ); }; };
11FBDAA21C87753200018169 /* NSBundle+NYTPhotoViewer.h in Headers */ = {isa = PBXBuildFile; fileRef = 1110844B1C87682300699670 /* NSBundle+NYTPhotoViewer.h */; settings = {ATTRIBUTES = (Public, ); }; };
11FBDAA31C87753200018169 /* NSBundle+NYTPhotoViewer.m in Sources */ = {isa = PBXBuildFile; fileRef = 1110844C1C87682300699670 /* NSBundle+NYTPhotoViewer.m */; };
Expand All @@ -95,7 +95,8 @@
11FBDAFF1C877F8000018169 /* giphy.gif in Resources */ = {isa = PBXBuildFile; fileRef = 111084851C876B0400699670 /* giphy.gif */; };
1AFC4D301FE01B9000FDF949 /* NYTPhotoViewerArrayDataSourceTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 111084271C8767BA00699670 /* NYTPhotoViewerArrayDataSourceTests.m */; };
1AFC4D321FE01EFA00FDF949 /* NYTPhotoViewerSinglePhotoDataSourceTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 1AFC4D311FE01EFA00FDF949 /* NYTPhotoViewerSinglePhotoDataSourceTests.m */; };
9371A73C1E438B9C00A8F2EF /* Photo.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9371A73B1E438B9C00A8F2EF /* Photo.swift */; };
2A4D6135208683990092ED17 /* NYTInterstitialViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = 2A4D6134208683990092ED17 /* NYTInterstitialViewController.m */; };
9371A73C1E438B9C00A8F2EF /* PhotoItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9371A73B1E438B9C00A8F2EF /* PhotoItem.swift */; };
9371A7441E438BCE00A8F2EF /* PhotoBox.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9371A7431E438BCE00A8F2EF /* PhotoBox.swift */; };
9371A7461E43D61E00A8F2EF /* PhotoViewerCoordinator.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9371A7451E43D61E00A8F2EF /* PhotoViewerCoordinator.swift */; };
93F45B181E3BB5610093DB93 /* NYTPhotoViewerSinglePhotoDataSource.h in Headers */ = {isa = PBXBuildFile; fileRef = 93F45B161E3BB5610093DB93 /* NYTPhotoViewerSinglePhotoDataSource.h */; settings = {ATTRIBUTES = (Public, ); }; };
Expand Down Expand Up @@ -264,7 +265,7 @@
111084441C87682300699670 /* NYTScalingImageView.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = NYTScalingImageView.m; sourceTree = "<group>"; };
111084461C87682300699670 /* NYTPhoto.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = NYTPhoto.h; sourceTree = "<group>"; };
111084471C87682300699670 /* NYTPhotoCaptionViewLayoutWidthHinting.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = NYTPhotoCaptionViewLayoutWidthHinting.h; sourceTree = "<group>"; };
111084481C87682300699670 /* NYTPhotoContainer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = NYTPhotoContainer.h; sourceTree = "<group>"; };
111084481C87682300699670 /* NYTPhotoViewerContainer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = NYTPhotoViewerContainer.h; sourceTree = "<group>"; };
111084491C87682300699670 /* NYTPhotoViewerDataSource.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = NYTPhotoViewerDataSource.h; sourceTree = "<group>"; };
1110844B1C87682300699670 /* NSBundle+NYTPhotoViewer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = "NSBundle+NYTPhotoViewer.h"; sourceTree = "<group>"; };
1110844C1C87682300699670 /* NSBundle+NYTPhotoViewer.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = "NSBundle+NYTPhotoViewer.m"; sourceTree = "<group>"; };
Expand Down Expand Up @@ -295,7 +296,9 @@
11FBDAF01C877C8B00018169 /* PhotosProvider.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = PhotosProvider.swift; sourceTree = "<group>"; };
11FBDAFC1C877D9A00018169 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = Base; path = Base.lproj/LaunchScreen.xib; sourceTree = "<group>"; };
1AFC4D311FE01EFA00FDF949 /* NYTPhotoViewerSinglePhotoDataSourceTests.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = NYTPhotoViewerSinglePhotoDataSourceTests.m; sourceTree = "<group>"; };
9371A73B1E438B9C00A8F2EF /* Photo.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = Photo.swift; sourceTree = "<group>"; };
2A4D6134208683990092ED17 /* NYTInterstitialViewController.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = NYTInterstitialViewController.m; sourceTree = "<group>"; };
2A4D613C208683B80092ED17 /* NYTInterstitialViewController.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = NYTInterstitialViewController.h; sourceTree = "<group>"; };
9371A73B1E438B9C00A8F2EF /* PhotoItem.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = PhotoItem.swift; sourceTree = "<group>"; };
9371A7431E438BCE00A8F2EF /* PhotoBox.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = PhotoBox.swift; sourceTree = "<group>"; };
9371A7451E43D61E00A8F2EF /* PhotoViewerCoordinator.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = PhotoViewerCoordinator.swift; sourceTree = "<group>"; };
93F45B161E3BB5610093DB93 /* NYTPhotoViewerSinglePhotoDataSource.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = NYTPhotoViewerSinglePhotoDataSource.h; sourceTree = "<group>"; };
Expand Down Expand Up @@ -391,6 +394,8 @@
111084401C87682300699670 /* NYTPhotoTransitionController.m */,
111084411C87682300699670 /* NYTPhotoViewController.h */,
111084421C87682300699670 /* NYTPhotoViewController.m */,
2A4D613C208683B80092ED17 /* NYTInterstitialViewController.h */,
2A4D6134208683990092ED17 /* NYTInterstitialViewController.m */,
111084371C87682300699670 /* NYTPhotoViewerArrayDataSource.h */,
111084381C87682300699670 /* NYTPhotoViewerArrayDataSource.m */,
93F45B161E3BB5610093DB93 /* NYTPhotoViewerSinglePhotoDataSource.h */,
Expand Down Expand Up @@ -425,7 +430,7 @@
children = (
111084461C87682300699670 /* NYTPhoto.h */,
111084471C87682300699670 /* NYTPhotoCaptionViewLayoutWidthHinting.h */,
111084481C87682300699670 /* NYTPhotoContainer.h */,
111084481C87682300699670 /* NYTPhotoViewerContainer.h */,
111084491C87682300699670 /* NYTPhotoViewerDataSource.h */,
);
path = Protocols;
Expand Down Expand Up @@ -506,7 +511,7 @@
9371A7451E43D61E00A8F2EF /* PhotoViewerCoordinator.swift */,
11FBDAF01C877C8B00018169 /* PhotosProvider.swift */,
9371A7431E438BCE00A8F2EF /* PhotoBox.swift */,
9371A73B1E438B9C00A8F2EF /* Photo.swift */,
9371A73B1E438B9C00A8F2EF /* PhotoItem.swift */,
11FBDAE21C877BD600018169 /* Main.storyboard */,
11FBDAFB1C877D9A00018169 /* LaunchScreen.xib */,
11FBDAEA1C877BD600018169 /* Info.plist */,
Expand All @@ -523,7 +528,7 @@
files = (
111084621C87682300699670 /* NSBundle+NYTPhotoViewer.h in Headers */,
111084541C87682300699670 /* NYTPhotosViewController.h in Headers */,
111084601C87682300699670 /* NYTPhotoContainer.h in Headers */,
111084601C87682300699670 /* NYTPhotoViewerContainer.h in Headers */,
1110844E1C87682300699670 /* NYTPhotoDismissalInteractionController.h in Headers */,
111084611C87682300699670 /* NYTPhotoViewerDataSource.h in Headers */,
1110845A1C87682300699670 /* NYTPhotoViewController.h in Headers */,
Expand All @@ -545,7 +550,7 @@
buildActionMask = 2147483647;
files = (
11FBDA981C87753200018169 /* NYTPhotoTransitionController.h in Headers */,
11FBDAA01C87753200018169 /* NYTPhotoContainer.h in Headers */,
11FBDAA01C87753200018169 /* NYTPhotoViewerContainer.h in Headers */,
11FBDA9C1C87753200018169 /* NYTScalingImageView.h in Headers */,
11FBDA921C87753200018169 /* NYTPhotosOverlayView.h in Headers */,
11FBDA8E1C87753200018169 /* NYTPhotoDismissalInteractionController.h in Headers */,
Expand Down Expand Up @@ -828,6 +833,7 @@
isa = PBXSourcesBuildPhase;
buildActionMask = 2147483647;
files = (
2A4D6135208683990092ED17 /* NYTInterstitialViewController.m in Sources */,
111084591C87682300699670 /* NYTPhotoTransitionController.m in Sources */,
111084631C87682300699670 /* NSBundle+NYTPhotoViewer.m in Sources */,
111084551C87682300699670 /* NYTPhotosViewController.m in Sources */,
Expand Down Expand Up @@ -896,7 +902,7 @@
11FBDADF1C877BD600018169 /* AppDelegate.swift in Sources */,
9371A7461E43D61E00A8F2EF /* PhotoViewerCoordinator.swift in Sources */,
11FBDAF11C877C8B00018169 /* PhotosProvider.swift in Sources */,
9371A73C1E438B9C00A8F2EF /* Photo.swift in Sources */,
9371A73C1E438B9C00A8F2EF /* PhotoItem.swift in Sources */,
);
runOnlyForDeploymentPostprocessing = 0;
};
Expand Down
31 changes: 31 additions & 0 deletions NYTPhotoViewer/NYTInterstitialViewController.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
//
// NYTInterstitialViewController.h
// NYTPhotoViewer
//
// Created by Howarth, Craig on 4/17/18.
// Copyright © 2018 NYTimes. All rights reserved.
//

@import UIKit;
#import "NYTPhotoViewerContainer.h"

NS_ASSUME_NONNULL_BEGIN

/**
* The view controller controlling the display of a interstitial view.
*/
@interface NYTInterstitialViewController : UIViewController <NYTPhotoViewerContainer>

/**
* The designated initializer that takes an interstitial view.
*
* @param view The view object that this view controller manages.
* @param itemIndex The index of this view controller in the photo viewer collection.
*
* @return A fully initialized object.
*/
- (instancetype)initWithView:(nullable UIView *)view itemIndex:(NSUInteger)itemIndex NS_DESIGNATED_INITIALIZER;

@end

NS_ASSUME_NONNULL_END
Loading

0 comments on commit 21eaf16

Please sign in to comment.