summaryrefslogtreecommitdiff
path: root/book/src/main/scala/book
diff options
context:
space:
mode:
Diffstat (limited to 'book/src/main/scala/book')
-rw-r--r--book/src/main/scala/book/Book.scala26
-rw-r--r--book/src/main/scala/book/Main.scala14
2 files changed, 24 insertions, 16 deletions
diff --git a/book/src/main/scala/book/Book.scala b/book/src/main/scala/book/Book.scala
index 9323fff..8b5098d 100644
--- a/book/src/main/scala/book/Book.scala
+++ b/book/src/main/scala/book/Book.scala
@@ -8,7 +8,7 @@ import scalatags.Text.all._
* Created by haoyi on 10/26/14.
*/
object Book {
- val autoResources = Seq(
+ val autoResources = Set(
"META-INF/resources/webjars/highlightjs/8.2-1/highlight.min.js",
"META-INF/resources/webjars/highlightjs/8.2-1/styles/idea.min.css",
"META-INF/resources/webjars/highlightjs/8.2-1/languages/scala.min.js",
@@ -18,38 +18,32 @@ object Book {
"META-INF/resources/webjars/highlightjs/8.2-1/languages/xml.min.js",
"META-INF/resources/webjars/pure/0.5.0/pure-min.css",
"META-INF/resources/webjars/pure/0.5.0/grids-responsive-min.css",
- "META-INF/resources/webjars/font-awesome/4.2.0/css/font-awesome.min.css",
"META-INF/resources/webjars/font-awesome/4.2.0/fonts/FontAwesome.otf",
"META-INF/resources/webjars/font-awesome/4.2.0/fonts/fontawesome-webfont.eot",
"META-INF/resources/webjars/font-awesome/4.2.0/fonts/fontawesome-webfont.svg",
"META-INF/resources/webjars/font-awesome/4.2.0/fonts/fontawesome-webfont.ttf",
"META-INF/resources/webjars/font-awesome/4.2.0/fonts/fontawesome-webfont.woff",
- "META-INF/resources/webjars/react/0.11.1/react.min.js",
"css/side-menu.css",
- "example-fastopt.js",
+ "example-opt.js",
"webpage/weather.js",
"favicon.svg",
"favicon.png"
)
- val manualResources = Seq(
+ val fontAwesomeCss =
+ "META-INF/resources/webjars/font-awesome/4.2.0/css/font-awesome.min.css"
+
+ val manualResources = Set(
"images/javascript-the-good-parts-the-definitive-guide.jpg",
"images/Hello World.png",
"images/Hello World White.png",
"images/Hello World Console.png",
"images/IntelliJ Hello.png",
"images/Dropdown.png",
- "images/Scalatags Downloads.png"
+ "images/Scalatags Downloads.png",
+ fontAwesomeCss
)
- val includes = for(res <- autoResources) yield {
- if (res.endsWith(".js"))
- script(src:=res)
- else if (res.endsWith(".css"))
- link(rel:="stylesheet", href:=res)
- else
- raw("")
- }
val txt = Index()
val data = upickle.write(sect.structure)
@@ -61,8 +55,10 @@ object Book {
meta(charset:="utf-8"),
meta(name:="viewport", content:="width=device-width, initial-scale=1.0"),
link(rel:="shortcut icon", `type`:="image/png", href:="favicon.png"),
+ link(rel:="stylesheet", href:=fontAwesomeCss),
+ link(rel:="stylesheet", href:="styles.css"),
tags2.title("Hands-on Scala.js"),
- includes
+ script(src:="scripts.js")
),
body(
onload:=s"Controller().main($data)",
diff --git a/book/src/main/scala/book/Main.scala b/book/src/main/scala/book/Main.scala
index da9bace..cb8ef99 100644
--- a/book/src/main/scala/book/Main.scala
+++ b/book/src/main/scala/book/Main.scala
@@ -22,10 +22,22 @@ object Main {
write(Book.site, "output/index.html")
- for(res <- Book.autoResources ++ Book.manualResources) {
+ val jsFiles = Book.autoResources.filter(_.endsWith(".js")).toSet
+ val cssFiles = Book.autoResources.filter(_.endsWith(".css")).toSet
+ val miscFiles = Book.autoResources -- cssFiles -- jsFiles
+
+ for(res <- Book.manualResources ++ miscFiles) {
copy(getClass.getResourceAsStream("/" + res), "output/" + res)
}
+ for((resources, dest) <- Seq(jsFiles -> "scripts.js", cssFiles -> "styles.css")) {
+ val blobs = for(res <- resources.iterator) yield {
+ io.Source.fromInputStream(getClass.getResourceAsStream("/"+res)).mkString
+ }
+
+ write(blobs.mkString("\n"), "output/"+dest)
+ }
+
val allNames = {
def rec(n: Tree[String]): Seq[String] = {
n.value +: n.children.flatMap(rec)