diff --git a/src/main/scala/plugin/PluginSystem.scala b/src/main/scala/plugin/PluginSystem.scala
index db46a3d..1bda872 100644
--- a/src/main/scala/plugin/PluginSystem.scala
+++ b/src/main/scala/plugin/PluginSystem.scala
@@ -2,37 +2,48 @@
import app.Context
import javax.servlet.http.{HttpServletResponse, HttpServletRequest}
+import javax.script.ScriptEngineManager
/**
* Provides extension points to plug-ins.
*/
object PluginSystem {
- private val repositoryMenuList = scala.collection.mutable.ListBuffer[Menu]()
- private val globalMenuList = scala.collection.mutable.ListBuffer[Menu]()
+ private val repositoryMenuList = scala.collection.mutable.ListBuffer[RepositoryMenu]()
+ private val globalMenuList = scala.collection.mutable.ListBuffer[GlobalMenu]()
private val actionList = scala.collection.mutable.ListBuffer[Action]()
- case class Menu(label: String, url: String, icon: String, condition: Context => Boolean)
+ case class GlobalMenu(label: String, url: String, icon: String, condition: Context => Boolean)
+ case class RepositoryMenu(label: String, name: String, url: String, icon: String, condition: Context => Boolean)
case class Action(path: String, function: (HttpServletRequest, HttpServletResponse) => Any)
- def addRepositoryMenu(label: String, url: String, icon: String = "")(condition: Context => Boolean): Unit = {
- repositoryMenuList += Menu(label, url, icon, condition)
+ def addRepositoryMenu(label: String, name: String, url: String, icon: String = "")(condition: Context => Boolean): Unit = {
+ repositoryMenuList += RepositoryMenu(label, name, url, icon, condition)
}
def addGlobalMenu(label: String, url: String, icon: String = "")(condition: Context => Boolean): Unit = {
- globalMenuList += Menu(label, url, icon, condition)
+ globalMenuList += GlobalMenu(label, url, icon, condition)
}
def addAction(path: String)(function: (HttpServletRequest, HttpServletResponse) => Any): Unit = {
actionList += Action(path, function)
}
- lazy val repositoryMenus: List[Menu] = repositoryMenuList.toList
- lazy val globalMenus: List[Menu] = globalMenuList.toList
+ def evaluateJavaScript(script: String): Unit = {
+ val engine = new ScriptEngineManager().getEngineByName("JavaScript")
+ engine.eval(script)
+ }
+
+ lazy val repositoryMenus: List[RepositoryMenu] = repositoryMenuList.toList
+ lazy val globalMenus: List[GlobalMenu] = globalMenuList.toList
lazy val actions: List[Action] = actionList.toList
// TODO This is a test
- addGlobalMenu("Google", "http://www.google.co.jp/"){ context => context.loginAccount.isDefined }
+ addGlobalMenu("Google", "http://www.google.co.jp/", "")
+ { context => context.loginAccount.isDefined }
+
+ addRepositoryMenu("Board", "board", "/board", "")
+ { context => true}
addAction("/hello"){ (request, response) =>
"Hello World!"
diff --git a/src/main/twirl/main.scala.html b/src/main/twirl/main.scala.html
index 2889fbb..21bdc43 100644
--- a/src/main/twirl/main.scala.html
+++ b/src/main/twirl/main.scala.html
@@ -62,7 +62,7 @@
@plugin.PluginSystem.globalMenus.map { menu =>
@if(menu.condition(context)){
- @menu.label
+ @if(menu.icon.nonEmpty){} else {@menu.label}
}
}
@if(loginAccount.get.isAdmin){
@@ -72,7 +72,7 @@
} else {
@plugin.PluginSystem.globalMenus.map { menu =>
@if(menu.condition(context)){
- @menu.label
+ @if(menu.icon.nonEmpty){
} else {@menu.label}
}
}
Sign in
diff --git a/src/main/twirl/menu.scala.html b/src/main/twirl/menu.scala.html
index 49860cf..9b1581f 100644
--- a/src/main/twirl/menu.scala.html
+++ b/src/main/twirl/menu.scala.html
@@ -23,6 +23,13 @@
}
+@sidemenuPlugin(path: String, name: String, label: String, icon: String) = {
+