Skip to content

Latest commit

 

History

History
169 lines (145 loc) · 5.39 KB

README.md

File metadata and controls

169 lines (145 loc) · 5.39 KB

sbt-paradox-project-info maven-central-badgegithub-actions-badge

A paradox directive that includes standardised project information in the generated documentation.

Usage

Add the Paradox plug-in as sbt plug-on

addSbtPlugin("com.lightbend.paradox" % "sbt-paradox-project-info" % <latest>)

Create a project info file in project/project-info.conf using HOCON format:

project-info {
  # version is overridden from the `projectInfoVersion` key (which defaults to sbt's project version)
  version: "current"
  scala-versions: ["2.12", "2.13"]
  jdk-versions: ["OpenJDK 8"]
  core {
    title: "The core project"
    // if undefined, sbt's crossScalaVersions are used
    scala-versions: ${project-info.scala-versions}
    jdk-versions: ${project-info.jdk-versions}
    jpms-name: "alpakka.core"
    snapshots: {
      text: "Snapshots are available"
      url: "snapshots.html"
      new-tab: false
    }
    issues: {
      url: "https://github.com/lightbend/sbt-paradox-project-info/issues"
      text: "Github issues"
    }
    release-notes: {
      url: "https://github.com/lightbend/sbt-paradox-project-info/releases"
      text: "Github releases"
    }
    api-docs: [
      {
        text: "Scaladoc"
        url: "https://developer.lightbend.com/docs/api/alpakka/"${project-info.version}"/akka/stream/alpakka/index.html"
      }
    ]
    forums: [
      {
        text: "Lightbend Discuss"
        url: "https://discuss.lightbend.com/c/akka/"
      }
      {
        text: "akka/alpakka-kafka Gitter channel"
        url: "https://gitter.im/akka/alpakka-kafka"
      }
    ]
  }
}

Full Source

Use the @@project-info directive in the Paradox markdown files and reference the project by its sbt projectId (when using the project sbt macro it is the name of the val).

# The Test Kit

@@project-info { projectId="core" }

The quick brown fox...

Example

Readiness Levels

Readiness levels is a convenient way to show the support for different projects. In order to use readiness levels you first need to specify what they mean and how to render them, i.e.

import com.lightbend.paradox.projectinfo._
import com.lightbend.paradox.projectinfo.ParadoxProjectInfoPluginKeys._

readinessLevels ++= Map(
  "Supported" -> new ReadinessLevel {
    val name = "<b>This project is supported</b>"
  },
  "NotSupported" -> new ReadinessLevel {
    val name = "<b>This project is not supported</b>"
  }
)

It's also possible to abstract away the readinessLevels setting into a sbt plugin which is convenient if you are using the same configured levels in multiple projects (typical for an organization/company). For an example of this have a look here.

Then in your project/project-info.conf you can specify these readiness levels using the levels config path, i.e.

project-info {
  # version is overridden from the `projectInfoVersion` key (which defaults to sbt's project version)
  version: "current"
  scala-versions: ["2.12", "2.13"]
  jdk-versions: ["OpenJDK 8"]
  core {
    title: "The core project"
    // if undefined, sbt's crossScalaVersions are used
    scala-versions: ${project-info.scala-versions}
    jdk-versions: ${project-info.jdk-versions}
    jpms-name: "alpakka.core"
    snapshots: {
      text: "Snapshots are available"
      url: "snapshots.html"
      new-tab: false
    }
    issues: {
      url: "https://github.com/lightbend/sbt-paradox-project-info/issues"
      text: "Github issues"
    }
    release-notes: {
      url: "https://github.com/lightbend/sbt-paradox-project-info/releases"
      text: "Github releases"
    }
    api-docs: [
      {
        text: "Scaladoc"
        url: "https://developer.lightbend.com/docs/api/alpakka/"${project-info.version}"/akka/stream/alpakka/index.html"
      }
    ]
    forums: [
      {
        text: "Lightbend Discuss"
        url: "https://discuss.lightbend.com/c/akka/"
      }
      {
        text: "akka/alpakka-kafka Gitter channel"
        url: "https://gitter.im/akka/alpakka-kafka"
      }
    ]
    levels: [
      {
        readiness: Supported
        since: "2018-11-22"
        since-version: "0.22"
      }
      {
        readiness: NotSupported
        since: "2018-08-22"
        since-version: "0.16"
        note: "Alpha level of module"
      }
    ]
  }
}

License

The license is Apache 2.0, see LICENSE.

Maintenance notes

This project is NOT supported under the Lightbend subscription.

Feel free to ping contributors for code review or discussions. Pull requests are very welcome–thanks in advance!