Skip to content

Commit

Permalink
CR: Made readingOrder optional and added conditional test when using …
Browse files Browse the repository at this point in the history
…it instead of setting it to publication.readingOrder.
  • Loading branch information
chrfalch committed Aug 29, 2023
1 parent 24c51f8 commit 4a9cda6
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 12 deletions.
13 changes: 6 additions & 7 deletions Sources/Navigator/EPUB/EPUBNavigatorViewController.swift
Original file line number Diff line number Diff line change
Expand Up @@ -228,7 +228,7 @@ open class EPUBNavigatorViewController: UIViewController,
}

private let initialLocation: Locator?
private let readingOrder: [Link]
private let readingOrder: [Link]?

private let viewModel: EPUBNavigatorViewModel
private var publication: Publication { viewModel.publication }
Expand All @@ -238,7 +238,7 @@ open class EPUBNavigatorViewController: UIViewController,
public convenience init(
publication: Publication,
initialLocation: Locator?,
readingOrder: [Link]? = nil,
readingOrder: [Link]?,
config: Configuration = .init(),
httpServer: HTTPServer
) throws {
Expand Down Expand Up @@ -277,10 +277,10 @@ open class EPUBNavigatorViewController: UIViewController,
userSettings = config.userSettings
}

private init(viewModel: EPUBNavigatorViewModel, initialLocation: Locator?, readingOrder: [Link]? = nil) {
private init(viewModel: EPUBNavigatorViewModel, initialLocation: Locator?, readingOrder: [Link]?) {
self.viewModel = viewModel
self.initialLocation = initialLocation
self.readingOrder = readingOrder ?? viewModel.publication.readingOrder
self.readingOrder = readingOrder

super.init(nibName: nil, bundle: nil)

Expand Down Expand Up @@ -532,7 +532,7 @@ open class EPUBNavigatorViewController: UIViewController,
return nil
}

return readingOrder.firstIndex(withHREF: spreads[currentSpreadIndex].left.href)
return (readingOrder ?? viewModel.publication.readingOrder).firstIndex(withHREF: spreads[currentSpreadIndex].left.href)
}

private let reloadSpreadsCompletions = CompletionList()
Expand Down Expand Up @@ -643,8 +643,7 @@ open class EPUBNavigatorViewController: UIViewController,
// The positions are not always available, for example a Readium WebPub doesn't have any
// unless a Publication Positions Web Service is provided.
if
let index = readingOrder.firstIndex(withHREF: href),
// FIXME: If readingOrder is provided we might need to do something different here:
let index = (readingOrder ?? viewModel.publication.readingOrder).firstIndex(withHREF: href),
let positionList = Optional(publication.positionsByReadingOrder[index]),
positionList.count > 0
{
Expand Down
10 changes: 5 additions & 5 deletions Sources/Navigator/EPUB/EPUBSpread.swift
Original file line number Diff line number Diff line change
Expand Up @@ -117,15 +117,15 @@ struct EPUBSpread: Loggable {
/// - publication: The Publication to build the spreads for.
/// - readingProgression: Reading progression direction used to layout the pages.
/// - spread: Indicates whether two pages are displayed side-by-side.
static func makeSpreads(for publication: Publication, readingOrder: [Link], readingProgression: ReadingProgression, spread: Bool) -> [EPUBSpread] {
static func makeSpreads(for publication: Publication, readingOrder: [Link]?, readingProgression: ReadingProgression, spread: Bool) -> [EPUBSpread] {
spread
? makeTwoPagesSpreads(for: publication, readingOrder: readingOrder, readingProgression: readingProgression)
: makeOnePageSpreads(for: publication, readingOrder: readingOrder, readingProgression: readingProgression)
}

/// Builds a list of one-page spreads for the given Publication.
private static func makeOnePageSpreads(for publication: Publication, readingOrder: [Link], readingProgression: ReadingProgression) -> [EPUBSpread] {
readingOrder.map {
private static func makeOnePageSpreads(for publication: Publication, readingOrder: [Link]?, readingProgression: ReadingProgression) -> [EPUBSpread] {
(readingOrder ?? publication.readingOrder).map {
EPUBSpread(
spread: false,
links: [$0],
Expand All @@ -136,7 +136,7 @@ struct EPUBSpread: Loggable {
}

/// Builds a list of two-page spreads for the given Publication.
private static func makeTwoPagesSpreads(for publication: Publication, readingOrder: [Link], readingProgression: ReadingProgression) -> [EPUBSpread] {
private static func makeTwoPagesSpreads(for publication: Publication, readingOrder: [Link]?, readingProgression: ReadingProgression) -> [EPUBSpread] {
/// Builds two-pages spreads from a list of links and a spread accumulator.
func makeSpreads(for links: [Link], in spreads: [EPUBSpread] = []) -> [EPUBSpread] {
var links = links
Expand Down Expand Up @@ -185,7 +185,7 @@ struct EPUBSpread: Loggable {
}
}

return makeSpreads(for: readingOrder)
return makeSpreads(for: readingOrder ?? publication.readingOrder)
}
}

Expand Down

0 comments on commit 4a9cda6

Please sign in to comment.