mirror of
https://github.com/gitbucket/gitbucket.git
synced 2025-11-07 22:15:51 +01:00
(refs #32)Enable menu icon which is injected by plug-in
This commit is contained in:
@@ -2,37 +2,48 @@ package plugin
|
||||
|
||||
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!"
|
||||
|
||||
Reference in New Issue
Block a user