All Downloads are FREE. Search and download functionalities are using the official Maven repository.

laika.helium.generate.DownloadPageGenerator.scala Maven / Gradle / Ivy

/*
 * Copyright 2012-2020 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package laika.helium.generate

import cats.data.Kleisli
import cats.syntax.all._
import cats.effect.Sync
import laika.ast.Path.Root
import laika.ast.{Block, BlockSequence, Document, Image, InternalTarget, Paragraph, Path, RootElement, SpanLink, Style, Text, Title, TitledBlock}
import laika.config.{ConfigException, LaikaKeys}
import laika.helium.config.DownloadPage
import laika.io.config.SiteConfig
import laika.io.model.ParsedTree
import laika.rewrite.nav.{CoverImages, Selections}
import laika.theme.Theme.TreeProcessor

private[helium] object DownloadPageGenerator {

  def generate[F[_]: Sync](pageConfig: DownloadPage): TreeProcessor[F] = {

    val refPath: Path = Root / "downloads"

    def downloadAST (link: Path, title: String, coverImage: Option[Path]): TitledBlock = TitledBlock(Seq(
      Text(title)
    ), coverImage.map(img => Paragraph(Image(InternalTarget(img).relativeTo(refPath), alt = Some(title)))).toSeq ++ Seq(
      Paragraph(SpanLink(InternalTarget(link).relativeTo(refPath))("Download"))
    ))

    Kleisli[F, ParsedTree[F], ParsedTree[F]] { tree =>

      val treeWithDownloadPage = for {
        epubCoverImages  <- CoverImages.forEPUB(tree.root.config)
        pdfCoverImages   <- CoverImages.forPDF(tree.root.config)
        artifactBaseName <- tree.root.config.get[String](LaikaKeys.artifactBaseName, "download")
        downloadPath     <- SiteConfig.downloadPath(tree.root.config)
        combinations     <- Selections.createCombinationsConfig(tree.root.config)
      } yield {

        val downloads: Seq[Block] =
          if (combinations.isEmpty) {
            val epubLink = downloadPath / s"$artifactBaseName.epub"
            val pdfLink = downloadPath / s"$artifactBaseName.pdf"
            val epubAST = if (pageConfig.includeEPUB) Seq(downloadAST(epubLink, "EPUB", epubCoverImages.default)) else Nil
            val pdfAST = if (pageConfig.includePDF) Seq(downloadAST(pdfLink, "PDF", pdfCoverImages.default)) else Nil
            Seq(BlockSequence(epubAST ++ pdfAST).withStyle("downloads"))
          }
          else combinations.map { combination =>
            val baseTitle = combination.map(_.label).mkString(" - ")
            val classifier = combination.map(_.name).mkString("-")
            val epubLink = downloadPath / s"$artifactBaseName-$classifier.epub"
            val pdfLink = downloadPath / s"$artifactBaseName-$classifier.pdf"
            val epubAST = if (pageConfig.includeEPUB)
              Seq(downloadAST(epubLink, baseTitle + " (EPUB)", epubCoverImages.getImageFor(classifier))) else Nil
            val pdfAST = if (pageConfig.includePDF)
              Seq(downloadAST(pdfLink, baseTitle + " (PDF)", pdfCoverImages.getImageFor(classifier))) else Nil
            BlockSequence(epubAST ++ pdfAST).withStyle("downloads")
          }
        val blocks = Title(pageConfig.title).withOptions(Style.title) +: pageConfig.description.map(Paragraph(_)).toSeq ++: downloads
        val doc = Document(Root / "downloads.gen", RootElement(blocks), config = tree.root.config.withValue("helium.markupEditLinks", false).build)
        tree.copy(
          root = tree.root.copy(
            tree = tree.root.tree.copy(
              content = doc +: tree.root.tree.content,
            )
          )
        )
      }
      
      Sync[F].fromEither(treeWithDownloadPage.leftMap(ConfigException.apply))
    }
  }
  
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy