From ac9a77160aa6e2325f5f40bd204923a65d286f58 Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Mon, 14 Mar 2022 05:40:38 -0700 Subject: [PATCH 1/7] Remove CSS hack --- .../resources/org/typelevel/sbt/site/helium/site/styles.css | 4 ---- 1 file changed, 4 deletions(-) diff --git a/site/src/main/resources/org/typelevel/sbt/site/helium/site/styles.css b/site/src/main/resources/org/typelevel/sbt/site/helium/site/styles.css index 267c4a84..8d9ff940 100644 --- a/site/src/main/resources/org/typelevel/sbt/site/helium/site/styles.css +++ b/site/src/main/resources/org/typelevel/sbt/site/helium/site/styles.css @@ -3,7 +3,3 @@ header img { width: auto; margin-top: 6px; } - -#sidebar li.nav-header { - margin-top: -20px; -} From 142154805470e57a4895499be159b6333c9e51b4 Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Tue, 15 Mar 2022 09:11:50 -0700 Subject: [PATCH 2/7] Add note about adding unidocs to root aggregate --- docs/site.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/docs/site.md b/docs/site.md index e70467db..f18fd73d 100644 --- a/docs/site.md +++ b/docs/site.md @@ -34,6 +34,7 @@ For example, the sbt-typelevel `VERSION` is `@VERSION@` and `SNAPSHOT_VERSION` i If you generate your API documentation with [sbt-unidoc](https://github.com/sbt/sbt-unidoc), you can use the `TypelevelUnidocPlugin` to publish a Scaladoc-only artifact to Sonatype/Maven alongside your library artifacts. This makes it possible to browse your unidocs at [javadoc.io](https://www.javadoc.io/); for example, the sbt-typelevel [API docs](@API_URL@) are published like this. ```scala +// Make sure to add to your root aggregate so it gets published! lazy val unidoc = project .in(file("unidoc")) .enablePlugins(TypelevelUnidocPlugin) // also enables the ScalaUnidocPlugin @@ -44,4 +45,4 @@ lazy val unidoc = project ### How can I customize my website's appearance? -We refer you to the comprehensive [Laika manual](https://planet42.github.io/Laika/index.html) and specifically the [`laikaTheme` setting](https://planet42.github.io/Laika/0.18/02-running-laika/01-sbt-plugin.html#laikatheme-setting). \ No newline at end of file +We refer you to the comprehensive [Laika manual](https://planet42.github.io/Laika/index.html) and specifically the [`laikaTheme` setting](https://planet42.github.io/Laika/0.18/02-running-laika/01-sbt-plugin.html#laikatheme-setting). From 2b3ed42d8dbd4d9003012c8cdb7bac4a64a4c6ad Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Fri, 18 Mar 2022 15:51:44 +0000 Subject: [PATCH 3/7] Forward doc task to unidoc task --- .../src/main/scala/org/typelevel/sbt/TypelevelUnidocPlugin.scala | 1 + 1 file changed, 1 insertion(+) diff --git a/sonatype/src/main/scala/org/typelevel/sbt/TypelevelUnidocPlugin.scala b/sonatype/src/main/scala/org/typelevel/sbt/TypelevelUnidocPlugin.scala index 1fed8c6f..ec738b83 100644 --- a/sonatype/src/main/scala/org/typelevel/sbt/TypelevelUnidocPlugin.scala +++ b/sonatype/src/main/scala/org/typelevel/sbt/TypelevelUnidocPlugin.scala @@ -30,6 +30,7 @@ object TypelevelUnidocPlugin extends AutoPlugin { import TypelevelSonatypePlugin.javadocioUrl override def projectSettings = Seq( + Compile / doc := (ScalaUnidoc / doc).value, Compile / packageDoc / mappings := (ScalaUnidoc / packageDoc / mappings).value, ThisBuild / apiURL := javadocioUrl.value, mimaPreviousArtifacts := Set.empty, From a3f199a92979deb4ee7ce90878c9eb906e93f6a8 Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Mon, 21 Mar 2022 19:42:33 +0000 Subject: [PATCH 4/7] Enable syntax highlight for Scala 3 automatically --- .../org/typelevel/sbt/TypelevelSitePlugin.scala | 4 +++- .../sbt/site/TypelevelHeliumExtensions.scala | 14 ++++++++++++-- 2 files changed, 15 insertions(+), 3 deletions(-) diff --git a/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala b/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala index 2b1b8a0b..cdaf6f2c 100644 --- a/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala +++ b/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala @@ -37,6 +37,7 @@ import MdocPlugin.autoImport._ import LaikaPlugin.autoImport._ import gha.GenerativePlugin import GenerativePlugin.autoImport._ +import TypelevelKernelPlugin.autoImport._ object TypelevelSitePlugin extends AutoPlugin { @@ -117,7 +118,8 @@ object TypelevelSitePlugin extends AutoPlugin { }, tlSiteHeliumExtensions := TypelevelHeliumExtensions( licenses.value.headOption, - tlSiteRelatedProjects.value + tlSiteRelatedProjects.value, + tlIsScala3.value ), tlSiteApiUrl := { val javadocioUrl = for { diff --git a/site/src/main/scala/org/typelevel/sbt/site/TypelevelHeliumExtensions.scala b/site/src/main/scala/org/typelevel/sbt/site/TypelevelHeliumExtensions.scala index eed5f8ff..08f14a20 100644 --- a/site/src/main/scala/org/typelevel/sbt/site/TypelevelHeliumExtensions.scala +++ b/site/src/main/scala/org/typelevel/sbt/site/TypelevelHeliumExtensions.scala @@ -23,6 +23,7 @@ import laika.config.Config import laika.io.model.InputTree import laika.markdown.github.GitHubFlavor import laika.parse.code.SyntaxHighlighting +import laika.parse.code.languages.DottySyntax import laika.rewrite.DefaultTemplatePath import laika.theme.Theme import laika.theme.ThemeBuilder @@ -32,9 +33,14 @@ import java.net.URL object TypelevelHeliumExtensions { + @deprecated("Use overload with scala3 parameter", "0.4.7") + def apply(license: Option[(String, URL)], related: Seq[(String, URL)]): ThemeProvider = + apply(license, related, false) + def apply( license: Option[(String, URL)], - related: Seq[(String, URL)] + related: Seq[(String, URL)], + scala3: Boolean ): ThemeProvider = new ThemeProvider { def build[F[_]](implicit F: Sync[F]): Resource[F, Theme[F]] = ThemeBuilder[F]("Typelevel Helium Extensions") @@ -49,7 +55,11 @@ object TypelevelHeliumExtensions { Path.Root / "site" / "styles.css" ) ) - .addExtensions(GitHubFlavor, SyntaxHighlighting) + .addExtensions( + GitHubFlavor, + if (scala3) SyntaxHighlighting.withSyntaxBinding("scala", DottySyntax) + else SyntaxHighlighting + ) .addBaseConfig(licenseConfig(license).withFallback(relatedConfig(related))) .build } From af7655b1455a2d3cc513bc0523f1564d2f68e94e Mon Sep 17 00:00:00 2001 From: Scala Steward Date: Tue, 22 Mar 2022 23:27:50 +0100 Subject: [PATCH 5/7] Update sbt-scalajs-crossproject to 1.2.0 --- core/build.sbt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/core/build.sbt b/core/build.sbt index 52b22066..7856f1a8 100644 --- a/core/build.sbt +++ b/core/build.sbt @@ -1,3 +1,3 @@ addSbtPlugin("org.scalameta" % "sbt-scalafmt" % "2.4.6") addSbtPlugin("de.heikoseeberger" % "sbt-header" % "5.6.0") -addSbtPlugin("org.portable-scala" % "sbt-scalajs-crossproject" % "1.1.0") +addSbtPlugin("org.portable-scala" % "sbt-scalajs-crossproject" % "1.2.0") From 890f2970f07cbc4366b8903c4d7cd91584bf46f1 Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Sat, 26 Mar 2022 07:27:38 -0700 Subject: [PATCH 6/7] Use `unidocs` as project name in `unidoc` example --- docs/site.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/site.md b/docs/site.md index f18fd73d..8f5d9b5a 100644 --- a/docs/site.md +++ b/docs/site.md @@ -35,8 +35,8 @@ If you generate your API documentation with [sbt-unidoc](https://github.com/sbt/ ```scala // Make sure to add to your root aggregate so it gets published! -lazy val unidoc = project - .in(file("unidoc")) +lazy val unidocs = project + .in(file("unidocs")) .enablePlugins(TypelevelUnidocPlugin) // also enables the ScalaUnidocPlugin .settings( name := "woozle-docs" From 405fd55fe7a744d41aeaf2cbc384021ec4457eea Mon Sep 17 00:00:00 2001 From: Scala Steward Date: Sun, 27 Mar 2022 18:46:23 +0200 Subject: [PATCH 7/7] Update laika-sbt to 0.18.2 --- site/build.sbt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/site/build.sbt b/site/build.sbt index 218aaa8f..64e5969e 100644 --- a/site/build.sbt +++ b/site/build.sbt @@ -1,2 +1,2 @@ addSbtPlugin("org.scalameta" % "sbt-mdoc" % "2.2.24") -addSbtPlugin("org.planet42" % "laika-sbt" % "0.18.1") +addSbtPlugin("org.planet42" % "laika-sbt" % "0.18.2")