mirror of
https://github.com/gitbucket/gitbucket.git
synced 2026-05-09 01:27:04 +02:00
Compare commits
101 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
709fab9ccc | ||
|
|
fd13a2db79 | ||
|
|
840d81f7bd | ||
|
|
5d08f4d339 | ||
|
|
ef48b2d5ef | ||
|
|
f54e4f337f | ||
|
|
743965d3b8 | ||
|
|
0e787eddfd | ||
|
|
442c0d575e | ||
|
|
485516be2e | ||
|
|
6b2fbb3bf0 | ||
|
|
e510b1c26b | ||
|
|
8d35494169 | ||
|
|
cf1504bae7 | ||
|
|
9bb4e473b9 | ||
|
|
d67afebadc | ||
|
|
417886161c | ||
|
|
1b85d511e9 | ||
|
|
45d84f63c1 | ||
|
|
fff60b2704 | ||
|
|
c9339aec9e | ||
|
|
7c98ae1341 | ||
|
|
01c2291715 | ||
|
|
2e03f081d9 | ||
|
|
0cbafdd884 | ||
|
|
d5a9c2c15d | ||
|
|
1496591244 | ||
|
|
f5acce3901 | ||
|
|
5568a0ad8e | ||
|
|
26a18287c7 | ||
|
|
b0f819b9bd | ||
|
|
ebff7baf07 | ||
|
|
cf9a55d896 | ||
|
|
72f7b659f4 | ||
|
|
87192d025b | ||
|
|
fd181b9a0c | ||
|
|
9c4cc12a02 | ||
|
|
44497b559e | ||
|
|
09c50a149b | ||
|
|
88beb68e01 | ||
|
|
0da358311b | ||
|
|
cf97b63dab | ||
|
|
4b5f22144e | ||
|
|
0d342a6863 | ||
|
|
458820a09d | ||
|
|
135c34ef0f | ||
|
|
8187c5a013 | ||
|
|
6ff48c8130 | ||
|
|
d37c70cd8d | ||
|
|
8abf357405 | ||
|
|
c93ac71634 | ||
|
|
408180f071 | ||
|
|
4e98abfe5c | ||
|
|
efbb404bd4 | ||
|
|
66f409bfad | ||
|
|
44ec64fb4b | ||
|
|
fb27bd29e8 | ||
|
|
c26ca9d463 | ||
|
|
8c36ba33f4 | ||
|
|
fe1e18b495 | ||
|
|
29e632af04 | ||
|
|
2b9daae62b | ||
|
|
8a11f85dd1 | ||
|
|
b09c72b106 | ||
|
|
43456e817a | ||
|
|
7876a60106 | ||
|
|
38e71001cb | ||
|
|
a1307b7464 | ||
|
|
fd413d36ad | ||
|
|
509dfc57ca | ||
|
|
95bdd6228e | ||
|
|
fd1430371a | ||
|
|
437f944c6e | ||
|
|
f64b6e10bb | ||
|
|
5925bd3772 | ||
|
|
fe8d4616db | ||
|
|
99b40974c3 | ||
|
|
c463590ede | ||
|
|
82163eebc2 | ||
|
|
f1e427f926 | ||
|
|
c21dcdca80 | ||
|
|
2ce51472c3 | ||
|
|
514b1aeec1 | ||
|
|
3f34622fe0 | ||
|
|
8c6d5b8178 | ||
|
|
1971c29fd0 | ||
|
|
40ca9b6682 | ||
|
|
81aeed6f6c | ||
|
|
bf50b1bf82 | ||
|
|
1094e8ca2d | ||
|
|
860ccce89b | ||
|
|
59e5993eba | ||
|
|
c08627e5d6 | ||
|
|
3e0bb46699 | ||
|
|
9a972e40ef | ||
|
|
99ad0db1f6 | ||
|
|
12d11bc80c | ||
|
|
dc98079b55 | ||
|
|
88f56126a6 | ||
|
|
313c9976c8 | ||
|
|
41e49423b2 |
34
README.md
34
README.md
@@ -49,6 +49,8 @@ GitBucket has the plug-in system to extend GitBucket from outside of GitBucket.
|
|||||||
- [gitbucket-desktopnotify-plugin](https://github.com/yoshiyoshifujii/gitbucket-desktopnotify-plugin)
|
- [gitbucket-desktopnotify-plugin](https://github.com/yoshiyoshifujii/gitbucket-desktopnotify-plugin)
|
||||||
- [gitbucket-commitgraphs-plugin](https://github.com/yoshiyoshifujii/gitbucket-commitgraphs-plugin)
|
- [gitbucket-commitgraphs-plugin](https://github.com/yoshiyoshifujii/gitbucket-commitgraphs-plugin)
|
||||||
- [gitbucket-asciidoctor-plugin](https://github.com/lefou/gitbucket-asciidoctor-plugin)
|
- [gitbucket-asciidoctor-plugin](https://github.com/lefou/gitbucket-asciidoctor-plugin)
|
||||||
|
- [gitbucket-network-plugin](https://github.com/mrkm4ntr/gitbucket-network-plugin)
|
||||||
|
- [gitbucket-emoji-plugin](https://github.com/gitbucket/gitbucket-emoji-plugin)
|
||||||
|
|
||||||
You can find community plugins other than them at [gitbucket community plugins](http://gitbucket-plugins.github.io/).
|
You can find community plugins other than them at [gitbucket community plugins](http://gitbucket-plugins.github.io/).
|
||||||
|
|
||||||
@@ -63,14 +65,41 @@ Support
|
|||||||
|
|
||||||
Release Notes
|
Release Notes
|
||||||
-------------
|
-------------
|
||||||
### 4.1 - 4 Jun 2016
|
### 4.3 - 30 Jul 2016
|
||||||
|
- Emoji support by [gitbucket-emoji-plugin](https://github.com/gitbucket/gitbucket-emoji-plugin)
|
||||||
|
- User name suggestion
|
||||||
|
- Add new web APIs and basic authentication support for API access
|
||||||
|
- Root Endpoint
|
||||||
|
- [List endpoints](https://developer.github.com/v3/#root-endpoint)
|
||||||
|
- [List Branches](https://developer.github.com/v3/repos/branches/#list-branches)
|
||||||
|
- [Get contents](https://developer.github.com/v3/repos/contents/#get-contents)
|
||||||
|
- [Get a Reference](https://developer.github.com/v3/git/refs/#get-a-reference)
|
||||||
|
- [List Collaborators](https://developer.github.com/v3/repos/collaborators/#list-collaborators)
|
||||||
|
- [List user repositories](https://developer.github.com/v3/repos/#list-user-repositories)
|
||||||
|
- [Get a group](https://developer.github.com/v3/orgs/#get-an-organization)
|
||||||
|
- [List group repositories](https://developer.github.com/v3/repos/#list-organization-repositories)
|
||||||
|
- Add new extension points
|
||||||
|
- `assetsMapping` : Supplies resources in plugin classpath as web assets
|
||||||
|
- `suggestionProvider` : Provides suggestion in the Markdown editing textarea
|
||||||
|
- `textDecorator` : Decorate text nodes in HTML which is converted from Markdown
|
||||||
|
|
||||||
|
### 4.2.1 - 3 Jul 2016
|
||||||
|
- Fix migration bug
|
||||||
|
|
||||||
|
This is hotfix for a critical bug in migration. If you are new installation, use 4.2.0. But if you have an exisiting installation and it had been updated to 4.0 from 3.x, you must update to 4.2.1.
|
||||||
|
|
||||||
|
### 4.2 - 2 Jul 2016
|
||||||
|
- New UI based on [AdminLTE](https://github.com/almasaeed2010/AdminLTE)
|
||||||
|
- git gc
|
||||||
|
- Issues and Wiki have been possible to be disabled
|
||||||
|
- SMTP configuration test mail
|
||||||
|
|
||||||
|
### 4.1 - 4 Jun 2016
|
||||||
- Generic ssh user
|
- Generic ssh user
|
||||||
- Improve branch protection UI
|
- Improve branch protection UI
|
||||||
- Default value of pull request title
|
- Default value of pull request title
|
||||||
|
|
||||||
### 4.0 - 30 Apr 2016
|
### 4.0 - 30 Apr 2016
|
||||||
|
|
||||||
- MySQL and PostgreSQL support
|
- MySQL and PostgreSQL support
|
||||||
- Data export and import
|
- Data export and import
|
||||||
- Migration system has been switched to [solidbase](https://github.com/gitbucket/solidbase)
|
- Migration system has been switched to [solidbase](https://github.com/gitbucket/solidbase)
|
||||||
@@ -78,7 +107,6 @@ Release Notes
|
|||||||
**Note:** You can upgrade to GitBucket 4.0 from 3.14. If your GitBucket is 3.13 or before, you have to upgrade 3.14 at first.
|
**Note:** You can upgrade to GitBucket 4.0 from 3.14. If your GitBucket is 3.13 or before, you have to upgrade 3.14 at first.
|
||||||
|
|
||||||
### 3.14 - 30 Apr 2016
|
### 3.14 - 30 Apr 2016
|
||||||
|
|
||||||
- File attachment and search for wiki pages
|
- File attachment and search for wiki pages
|
||||||
- New extension points to add menus
|
- New extension points to add menus
|
||||||
- Content-Type of webhooks has been choosable
|
- Content-Type of webhooks has been choosable
|
||||||
|
|||||||
31
build.sbt
31
build.sbt
@@ -1,8 +1,8 @@
|
|||||||
val Organization = "gitbucket"
|
val Organization = "gitbucket"
|
||||||
val Name = "gitbucket"
|
val Name = "gitbucket"
|
||||||
val GitBucketVersion = "4.1.0"
|
val GitBucketVersion = "4.3.0"
|
||||||
val ScalatraVersion = "2.4.0"
|
val ScalatraVersion = "2.4.1"
|
||||||
val JettyVersion = "9.3.6.v20151106"
|
val JettyVersion = "9.3.9.v20160517"
|
||||||
|
|
||||||
lazy val root = (project in file(".")).enablePlugins(SbtTwirl, JettyPlugin)
|
lazy val root = (project in file(".")).enablePlugins(SbtTwirl, JettyPlugin)
|
||||||
|
|
||||||
@@ -21,43 +21,40 @@ resolvers ++= Seq(
|
|||||||
)
|
)
|
||||||
libraryDependencies ++= Seq(
|
libraryDependencies ++= Seq(
|
||||||
"org.scala-lang.modules" %% "scala-java8-compat" % "0.7.0",
|
"org.scala-lang.modules" %% "scala-java8-compat" % "0.7.0",
|
||||||
"org.eclipse.jgit" % "org.eclipse.jgit.http.server" % "4.1.1.201511131810-r",
|
"org.eclipse.jgit" % "org.eclipse.jgit.http.server" % "4.1.2.201602141800-r",
|
||||||
"org.eclipse.jgit" % "org.eclipse.jgit.archive" % "4.1.1.201511131810-r",
|
"org.eclipse.jgit" % "org.eclipse.jgit.archive" % "4.1.2.201602141800-r",
|
||||||
"org.scalatra" %% "scalatra" % ScalatraVersion,
|
"org.scalatra" %% "scalatra" % ScalatraVersion,
|
||||||
"org.scalatra" %% "scalatra-json" % ScalatraVersion,
|
"org.scalatra" %% "scalatra-json" % ScalatraVersion,
|
||||||
"org.json4s" %% "json4s-jackson" % "3.3.0",
|
"org.json4s" %% "json4s-jackson" % "3.3.0",
|
||||||
"io.github.gitbucket" %% "scalatra-forms" % "1.0.0",
|
"io.github.gitbucket" %% "scalatra-forms" % "1.0.0",
|
||||||
"commons-io" % "commons-io" % "2.4",
|
"commons-io" % "commons-io" % "2.4",
|
||||||
"io.github.gitbucket" % "solidbase" % "1.0.0",
|
"io.github.gitbucket" % "solidbase" % "1.0.0",
|
||||||
"io.github.gitbucket" % "markedj" % "1.0.9-SNAPSHOT",
|
"io.github.gitbucket" % "markedj" % "1.0.9",
|
||||||
"org.apache.commons" % "commons-compress" % "1.10",
|
"org.apache.commons" % "commons-compress" % "1.11",
|
||||||
"org.apache.commons" % "commons-email" % "1.4",
|
"org.apache.commons" % "commons-email" % "1.4",
|
||||||
"org.apache.httpcomponents" % "httpclient" % "4.5.1",
|
"org.apache.httpcomponents" % "httpclient" % "4.5.1",
|
||||||
"org.apache.sshd" % "apache-sshd" % "1.0.0",
|
"org.apache.sshd" % "apache-sshd" % "1.0.0",
|
||||||
"org.apache.tika" % "tika-core" % "1.11",
|
"org.apache.tika" % "tika-core" % "1.13",
|
||||||
"com.typesafe.slick" %% "slick" % "2.1.0",
|
"com.typesafe.slick" %% "slick" % "2.1.0",
|
||||||
"com.novell.ldap" % "jldap" % "2009-10-07",
|
"com.novell.ldap" % "jldap" % "2009-10-07",
|
||||||
"com.h2database" % "h2" % "1.4.190",
|
"com.h2database" % "h2" % "1.4.192",
|
||||||
"mysql" % "mysql-connector-java" % "5.1.38",
|
"mysql" % "mysql-connector-java" % "5.1.39",
|
||||||
"org.postgresql" % "postgresql" % "9.4.1208",
|
"org.postgresql" % "postgresql" % "9.4.1208",
|
||||||
"ch.qos.logback" % "logback-classic" % "1.1.1",
|
"ch.qos.logback" % "logback-classic" % "1.1.7",
|
||||||
"com.zaxxer" % "HikariCP" % "2.4.5",
|
"com.zaxxer" % "HikariCP" % "2.4.6",
|
||||||
"com.typesafe" % "config" % "1.3.0",
|
"com.typesafe" % "config" % "1.3.0",
|
||||||
"com.typesafe.akka" %% "akka-actor" % "2.3.14",
|
"com.typesafe.akka" %% "akka-actor" % "2.3.15",
|
||||||
"fr.brouillard.oss.security.xhub" % "xhub4j-core" % "1.0.0",
|
"fr.brouillard.oss.security.xhub" % "xhub4j-core" % "1.0.0",
|
||||||
"com.enragedginger" %% "akka-quartz-scheduler" % "1.4.0-akka-2.3.x" exclude("c3p0","c3p0"),
|
"com.enragedginger" %% "akka-quartz-scheduler" % "1.4.0-akka-2.3.x" exclude("c3p0","c3p0"),
|
||||||
"org.eclipse.jetty" % "jetty-webapp" % JettyVersion % "provided",
|
"org.eclipse.jetty" % "jetty-webapp" % JettyVersion % "provided",
|
||||||
"javax.servlet" % "javax.servlet-api" % "3.1.0" % "provided",
|
"javax.servlet" % "javax.servlet-api" % "3.1.0" % "provided",
|
||||||
"junit" % "junit" % "4.12" % "test",
|
"junit" % "junit" % "4.12" % "test",
|
||||||
"org.scalatra" %% "scalatra-scalatest" % ScalatraVersion % "test",
|
"org.scalatra" %% "scalatra-scalatest" % ScalatraVersion % "test",
|
||||||
"org.scalaz" %% "scalaz-core" % "7.2.0" % "test",
|
"org.scalaz" %% "scalaz-core" % "7.2.4" % "test",
|
||||||
"com.wix" % "wix-embedded-mysql" % "1.0.3" % "test",
|
"com.wix" % "wix-embedded-mysql" % "1.0.3" % "test",
|
||||||
"ru.yandex.qatools.embed" % "postgresql-embedded" % "1.14" % "test"
|
"ru.yandex.qatools.embed" % "postgresql-embedded" % "1.14" % "test"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Twirl settings
|
|
||||||
play.twirl.sbt.Import.TwirlKeys.templateImports += "gitbucket.core._"
|
|
||||||
|
|
||||||
// Compiler settings
|
// Compiler settings
|
||||||
scalacOptions := Seq("-deprecation", "-language:postfixOps", "-Ybackend:GenBCode", "-Ydelambdafy:method", "-target:jvm-1.8")
|
scalacOptions := Seq("-deprecation", "-language:postfixOps", "-Ybackend:GenBCode", "-Ydelambdafy:method", "-target:jvm-1.8")
|
||||||
javacOptions in compile ++= Seq("-target", "8", "-source", "8")
|
javacOptions in compile ++= Seq("-target", "8", "-source", "8")
|
||||||
|
|||||||
@@ -1,37 +1,54 @@
|
|||||||
Automatic Schema Updating
|
Automatic Schema Updating
|
||||||
========
|
========
|
||||||
GitBucket uses H2 database to manage project and account data. GitBucket updates database schema automatically in the first run after the upgrading.
|
GitBucket updates database schema automatically using [Solidbase](https://github.com/gitbucket/solidbase) in the first run after the upgrading.
|
||||||
|
|
||||||
To release a new version of GitBucket, add the version definition to the [gitbucket.core.servlet.AutoUpdate](https://github.com/gitbucket/gitbucket/blob/master/src/main/scala/gitbucket/core/servlet/AutoUpdate.scala) at first.
|
To release a new version of GitBucket, add the version definition to the [gitbucket.core.GitBucketCoreModule](https://github.com/gitbucket/gitbucket/blob/master/src/main/scala/gitbucket/core/GitBucketCoreModule.scala) at first.
|
||||||
|
|
||||||
```scala
|
```scala
|
||||||
object AutoUpdate {
|
object GitBucketCoreModule extends Module("gitbucket-core",
|
||||||
...
|
new Version("4.0.0",
|
||||||
/**
|
new LiquibaseMigration("update/gitbucket-core_4.0.xml"),
|
||||||
* The history of versions. A head of this sequence is the current GitBucket version.
|
new SqlMigration("update/gitbucket-core_4.0.sql")
|
||||||
*/
|
),
|
||||||
val versions = Seq(
|
new Version("4.1.0"),
|
||||||
Version(1, 0)
|
new Version("4.2.0",
|
||||||
|
new LiquibaseMigration("update/gitbucket-core_4.2.xml")
|
||||||
)
|
)
|
||||||
...
|
|
||||||
```
|
|
||||||
|
|
||||||
Next, add a SQL file which updates database schema into [/src/main/resources/update/](https://github.com/gitbucket/gitbucket/tree/master/src/main/resources/update) as ```MAJOR_MINOR.sql```.
|
|
||||||
|
|
||||||
GitBucket stores the current version to ```GITBUCKET_HOME/version``` and checks it at start-up. If the stored version differs from the actual version, it executes differences of SQL files between the stored version and the actual version. And ```GITBUCKET_HOME/version``` is updated by the actual version.
|
|
||||||
|
|
||||||
We can also add any Scala code for upgrade GitBucket which modifies resources other than database. Override ```Version.update``` like below:
|
|
||||||
|
|
||||||
```scala
|
|
||||||
val versions = Seq(
|
|
||||||
new Version(1, 3){
|
|
||||||
override def update(conn: Connection): Unit = {
|
|
||||||
super.update(conn)
|
|
||||||
// Add any code here!
|
|
||||||
}
|
|
||||||
},
|
|
||||||
Version(1, 2),
|
|
||||||
Version(1, 1),
|
|
||||||
Version(1, 0)
|
|
||||||
)
|
)
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Next, add a XML file which updates database schema into [/src/main/resources/update/](https://github.com/gitbucket/gitbucket/tree/master/src/main/resources/update) with a filenane defined in `GitBucketCoreModule`.
|
||||||
|
|
||||||
|
```xml
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<changeSet>
|
||||||
|
<addColumn tableName="REPOSITORY">
|
||||||
|
<column name="ENABLE_WIKI" type="boolean" nullable="false" defaultValueBoolean="true"/>
|
||||||
|
<column name="ENABLE_ISSUES" type="boolean" nullable="false" defaultValueBoolean="true"/>
|
||||||
|
<column name="EXTERNAL_WIKI_URL" type="varchar(200)" nullable="true"/>
|
||||||
|
<column name="EXTERNAL_ISSUES_URL" type="varchar(200)" nullable="true"/>
|
||||||
|
</addColumn>
|
||||||
|
</changeSet>
|
||||||
|
```
|
||||||
|
|
||||||
|
Solidbase stores the current version to `VERSIONS` table and checks it at start-up. If the stored version differs from the actual version, it executes differences between the stored version and the actual version.
|
||||||
|
|
||||||
|
We can add the SQL file instead of the XML file using `SqlMigration`. It try to load a SQL file from classpath as following order:
|
||||||
|
|
||||||
|
1. Specified path (if specified)
|
||||||
|
2. `${moduleId}_${version}_${database}.sql`
|
||||||
|
3. `${moduleId}_${version}.sql`
|
||||||
|
|
||||||
|
Also we can add any code by extending `Migration`:
|
||||||
|
|
||||||
|
```scala
|
||||||
|
object GitBucketCoreModule extends Module("gitbucket-core",
|
||||||
|
new Version("4.0.0", new Migration(){
|
||||||
|
override def migrate(moduleId: String, version: String, context: java.util.Map[String, String]): Unit = {
|
||||||
|
...
|
||||||
|
}
|
||||||
|
})
|
||||||
|
)
|
||||||
|
```
|
||||||
|
|
||||||
|
See more details [README of Solidbase](https://github.com/gitbucket/solidbase).
|
||||||
|
|||||||
@@ -20,13 +20,13 @@ val JettyVersion = "9.3.6.v20151106"
|
|||||||
|
|
||||||
```scala
|
```scala
|
||||||
object GitBucketCoreModule extends Module("gitbucket-core",
|
object GitBucketCoreModule extends Module("gitbucket-core",
|
||||||
// add new version definition
|
|
||||||
new Version("4.1.0",
|
|
||||||
new LiquibaseMigration("update/gitbucket-core_4.1.xml")
|
|
||||||
),
|
|
||||||
new Version("4.0.0",
|
new Version("4.0.0",
|
||||||
new LiquibaseMigration("update/gitbucket-core_4.0.xml"),
|
new LiquibaseMigration("update/gitbucket-core_4.0.xml"),
|
||||||
new SqlMigration("update/gitbucket-core_4.0.sql")
|
new SqlMigration("update/gitbucket-core_4.0.sql")
|
||||||
|
),
|
||||||
|
// add new version definition
|
||||||
|
new Version("4.1.0",
|
||||||
|
new LiquibaseMigration("update/gitbucket-core_4.1.xml")
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
```
|
```
|
||||||
@@ -41,7 +41,7 @@ Note: Release operation requires [Ant](http://ant.apache.org/) and [Maven](https
|
|||||||
Run `sbt executable`. The release war file and fingerprint are generated into `target/executable/gitbucket.war`.
|
Run `sbt executable`. The release war file and fingerprint are generated into `target/executable/gitbucket.war`.
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$sbt executable
|
$ sbt executable
|
||||||
```
|
```
|
||||||
|
|
||||||
### Deploy assembly jar file
|
### Deploy assembly jar file
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
sbt.version=0.13.9
|
sbt.version=0.13.11
|
||||||
|
|||||||
10
src/main/resources/update/gitbucket-core_4.2.xml
Normal file
10
src/main/resources/update/gitbucket-core_4.2.xml
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<changeSet>
|
||||||
|
<addColumn tableName="REPOSITORY">
|
||||||
|
<column name="ENABLE_ISSUES" type="boolean" nullable="false" defaultValueBoolean="true"/>
|
||||||
|
<column name="EXTERNAL_ISSUES_URL" type="varchar(200)" nullable="true"/>
|
||||||
|
<column name="ENABLE_WIKI" type="boolean" nullable="false" defaultValueBoolean="true"/>
|
||||||
|
<column name="ALLOW_WIKI_EDITING" type="boolean" nullable="false" defaultValueBoolean="false"/>
|
||||||
|
<column name="EXTERNAL_WIKI_URL" type="varchar(200)" nullable="true"/>
|
||||||
|
</addColumn>
|
||||||
|
</changeSet>
|
||||||
@@ -1,7 +1,7 @@
|
|||||||
|
|
||||||
import gitbucket.core.controller._
|
import gitbucket.core.controller._
|
||||||
import gitbucket.core.plugin.PluginRegistry
|
import gitbucket.core.plugin.PluginRegistry
|
||||||
import gitbucket.core.servlet.{AccessTokenAuthenticationFilter, BasicAuthenticationFilter, Database, TransactionFilter}
|
import gitbucket.core.servlet.{ApiAuthenticationFilter, GitAuthenticationFilter, Database, TransactionFilter}
|
||||||
import gitbucket.core.util.Directory
|
import gitbucket.core.util.Directory
|
||||||
|
|
||||||
import java.util.EnumSet
|
import java.util.EnumSet
|
||||||
@@ -15,10 +15,10 @@ class ScalatraBootstrap extends LifeCycle {
|
|||||||
// Register TransactionFilter and BasicAuthenticationFilter at first
|
// Register TransactionFilter and BasicAuthenticationFilter at first
|
||||||
context.addFilter("transactionFilter", new TransactionFilter)
|
context.addFilter("transactionFilter", new TransactionFilter)
|
||||||
context.getFilterRegistration("transactionFilter").addMappingForUrlPatterns(EnumSet.allOf(classOf[DispatcherType]), true, "/*")
|
context.getFilterRegistration("transactionFilter").addMappingForUrlPatterns(EnumSet.allOf(classOf[DispatcherType]), true, "/*")
|
||||||
context.addFilter("basicAuthenticationFilter", new BasicAuthenticationFilter)
|
context.addFilter("gitAuthenticationFilter", new GitAuthenticationFilter)
|
||||||
context.getFilterRegistration("basicAuthenticationFilter").addMappingForUrlPatterns(EnumSet.allOf(classOf[DispatcherType]), true, "/git/*")
|
context.getFilterRegistration("gitAuthenticationFilter").addMappingForUrlPatterns(EnumSet.allOf(classOf[DispatcherType]), true, "/git/*")
|
||||||
context.addFilter("accessTokenAuthenticationFilter", new AccessTokenAuthenticationFilter)
|
context.addFilter("apiAuthenticationFilter", new ApiAuthenticationFilter)
|
||||||
context.getFilterRegistration("accessTokenAuthenticationFilter").addMappingForUrlPatterns(EnumSet.allOf(classOf[DispatcherType]), true, "/api/v3/*")
|
context.getFilterRegistration("apiAuthenticationFilter").addMappingForUrlPatterns(EnumSet.allOf(classOf[DispatcherType]), true, "/api/v3/*")
|
||||||
// Register controllers
|
// Register controllers
|
||||||
context.mount(new AnonymousAccessController, "/*")
|
context.mount(new AnonymousAccessController, "/*")
|
||||||
|
|
||||||
|
|||||||
@@ -4,9 +4,14 @@ import io.github.gitbucket.solidbase.migration.{SqlMigration, LiquibaseMigration
|
|||||||
import io.github.gitbucket.solidbase.model.{Version, Module}
|
import io.github.gitbucket.solidbase.model.{Version, Module}
|
||||||
|
|
||||||
object GitBucketCoreModule extends Module("gitbucket-core",
|
object GitBucketCoreModule extends Module("gitbucket-core",
|
||||||
new Version("4.1.0"),
|
|
||||||
new Version("4.0.0",
|
new Version("4.0.0",
|
||||||
new LiquibaseMigration("update/gitbucket-core_4.0.xml"),
|
new LiquibaseMigration("update/gitbucket-core_4.0.xml"),
|
||||||
new SqlMigration("update/gitbucket-core_4.0.sql")
|
new SqlMigration("update/gitbucket-core_4.0.sql")
|
||||||
)
|
),
|
||||||
|
new Version("4.1.0"),
|
||||||
|
new Version("4.2.0",
|
||||||
|
new LiquibaseMigration("update/gitbucket-core_4.2.xml")
|
||||||
|
),
|
||||||
|
new Version("4.2.1"),
|
||||||
|
new Version("4.3.0")
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -14,3 +14,10 @@ case class ApiBranch(
|
|||||||
"self" -> ApiPath(s"/api/v3/repos/${repositoryName.fullName}/branches/${name}"),
|
"self" -> ApiPath(s"/api/v3/repos/${repositoryName.fullName}/branches/${name}"),
|
||||||
"html" -> ApiPath(s"/${repositoryName.fullName}/tree/${name}"))
|
"html" -> ApiPath(s"/${repositoryName.fullName}/tree/${name}"))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case class ApiBranchCommit(sha: String)
|
||||||
|
|
||||||
|
case class ApiBranchForList(
|
||||||
|
name: String,
|
||||||
|
commit: ApiBranchCommit
|
||||||
|
)
|
||||||
|
|||||||
11
src/main/scala/gitbucket/core/api/ApiContents.scala
Normal file
11
src/main/scala/gitbucket/core/api/ApiContents.scala
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
package gitbucket.core.api
|
||||||
|
|
||||||
|
import gitbucket.core.util.JGitUtil.FileInfo
|
||||||
|
|
||||||
|
case class ApiContents(`type`: String, name: String)
|
||||||
|
|
||||||
|
object ApiContents{
|
||||||
|
def apply(fileInfo: FileInfo): ApiContents =
|
||||||
|
if(fileInfo.isDirectory) ApiContents("dir", fileInfo.name)
|
||||||
|
else ApiContents("file", fileInfo.name)
|
||||||
|
}
|
||||||
3
src/main/scala/gitbucket/core/api/ApiEndPoint.scala
Normal file
3
src/main/scala/gitbucket/core/api/ApiEndPoint.scala
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
package gitbucket.core.api
|
||||||
|
|
||||||
|
case class ApiEndPoint(rate_limit_url: ApiPath = ApiPath("/api/v3/rate_limit"))
|
||||||
5
src/main/scala/gitbucket/core/api/ApiRef.scala
Normal file
5
src/main/scala/gitbucket/core/api/ApiRef.scala
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
package gitbucket.core.api
|
||||||
|
|
||||||
|
case class ApiObject(sha: String)
|
||||||
|
|
||||||
|
case class ApiRef(ref: String, `object`: ApiObject)
|
||||||
@@ -13,6 +13,7 @@ case class ApiUser(
|
|||||||
created_at: Date) {
|
created_at: Date) {
|
||||||
val url = ApiPath(s"/api/v3/users/${login}")
|
val url = ApiPath(s"/api/v3/users/${login}")
|
||||||
val html_url = ApiPath(s"/${login}")
|
val html_url = ApiPath(s"/${login}")
|
||||||
|
val avatar_url = ApiPath(s"/${login}/_avatar")
|
||||||
// val followers_url = ApiPath(s"/api/v3/users/${login}/followers")
|
// val followers_url = ApiPath(s"/api/v3/users/${login}/followers")
|
||||||
// val following_url = ApiPath(s"/api/v3/users/${login}/following{/other_user}")
|
// val following_url = ApiPath(s"/api/v3/users/${login}/following{/other_user}")
|
||||||
// val gists_url = ApiPath(s"/api/v3/users/${login}/gists{/gist_id}")
|
// val gists_url = ApiPath(s"/api/v3/users/${login}/gists{/gist_id}")
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ import gitbucket.core.service.PullRequestService._
|
|||||||
import gitbucket.core.service._
|
import gitbucket.core.service._
|
||||||
import gitbucket.core.util.ControlUtil._
|
import gitbucket.core.util.ControlUtil._
|
||||||
import gitbucket.core.util.Directory._
|
import gitbucket.core.util.Directory._
|
||||||
import gitbucket.core.util.JGitUtil.CommitInfo
|
import gitbucket.core.util.JGitUtil.{CommitInfo, getFileList, getBranches, getDefaultBranch}
|
||||||
import gitbucket.core.util._
|
import gitbucket.core.util._
|
||||||
import gitbucket.core.util.Implicits._
|
import gitbucket.core.util.Implicits._
|
||||||
import org.eclipse.jgit.api.Git
|
import org.eclipse.jgit.api.Git
|
||||||
@@ -54,14 +54,92 @@ trait ApiControllerBase extends ControllerBase {
|
|||||||
with CollaboratorsAuthenticator =>
|
with CollaboratorsAuthenticator =>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* https://developer.github.com/v3/users/#get-a-single-user
|
* https://developer.github.com/v3/#root-endpoint
|
||||||
*/
|
*/
|
||||||
get("/api/v3/users/:userName") {
|
get("/api/v3/") {
|
||||||
getAccountByUserName(params("userName")).map { account =>
|
JsonFormat(ApiEndPoint())
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* https://developer.github.com/v3/orgs/#get-an-organization
|
||||||
|
*/
|
||||||
|
get("/api/v3/orgs/:groupName") {
|
||||||
|
getAccountByUserName(params("groupName")).filter(account => account.isGroupAccount).map { account =>
|
||||||
JsonFormat(ApiUser(account))
|
JsonFormat(ApiUser(account))
|
||||||
} getOrElse NotFound
|
} getOrElse NotFound
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* https://developer.github.com/v3/users/#get-a-single-user
|
||||||
|
*/
|
||||||
|
get("/api/v3/users/:userName") {
|
||||||
|
getAccountByUserName(params("userName")).filterNot(account => account.isGroupAccount).map { account =>
|
||||||
|
JsonFormat(ApiUser(account))
|
||||||
|
} getOrElse NotFound
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* https://developer.github.com/v3/repos/#list-organization-repositories
|
||||||
|
*/
|
||||||
|
get("/api/v3/orgs/:orgName/repos") {
|
||||||
|
JsonFormat(getVisibleRepositories(context.loginAccount, Some(params("orgName"))).map{ r => ApiRepository(r, getAccountByUserName(r.owner).get)})
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* https://developer.github.com/v3/repos/#list-user-repositories
|
||||||
|
*/
|
||||||
|
get("/api/v3/users/:userName/repos") {
|
||||||
|
JsonFormat(getVisibleRepositories(context.loginAccount, Some(params("userName"))).map{ r => ApiRepository(r, getAccountByUserName(r.owner).get)})
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* https://developer.github.com/v3/repos/branches/#list-branches
|
||||||
|
*/
|
||||||
|
get ("/api/v3/repos/:owner/:repo/branches")(referrersOnly { repository =>
|
||||||
|
JsonFormat(JGitUtil.getBranches(
|
||||||
|
owner = repository.owner,
|
||||||
|
name = repository.name,
|
||||||
|
defaultBranch = repository.repository.defaultBranch,
|
||||||
|
origin = repository.repository.originUserName.isEmpty
|
||||||
|
).map { br =>
|
||||||
|
ApiBranchForList(br.name, ApiBranchCommit(br.commitId))
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
/*
|
||||||
|
* https://developer.github.com/v3/repos/contents/#get-contents
|
||||||
|
*/
|
||||||
|
get("/api/v3/repos/:owner/:repo/contents/*")(referrersOnly { repository =>
|
||||||
|
val (id, path) = repository.splitPath(multiParams("splat").head)
|
||||||
|
val refStr = params("ref")
|
||||||
|
using(Git.open(getRepositoryDir(params("owner"), params("repo")))){ git =>
|
||||||
|
if (path.isEmpty) {
|
||||||
|
JsonFormat(getFileList(git, refStr, ".").map{f => ApiContents(f)})
|
||||||
|
} else {
|
||||||
|
JsonFormat(getFileList(git, refStr, path).map{f => ApiContents(f)})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
/*
|
||||||
|
* https://developer.github.com/v3/git/refs/#get-a-reference
|
||||||
|
*/
|
||||||
|
get("/api/v3/repos/:owner/:repo/git/*") (referrersOnly { repository =>
|
||||||
|
val revstr = multiParams("splat").head
|
||||||
|
using(Git.open(getRepositoryDir(params("owner"), params("repo")))) { git =>
|
||||||
|
//JsonFormat( (revstr, git.getRepository().resolve(revstr)) )
|
||||||
|
// getRef is deprecated by jgit-4.2. use exactRef() or findRef()
|
||||||
|
val sha = git.getRepository().getRef(revstr).getObjectId().name()
|
||||||
|
JsonFormat(ApiRef(revstr, ApiObject(sha)))
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
/**
|
||||||
|
* https://developer.github.com/v3/repos/collaborators/#list-collaborators
|
||||||
|
*/
|
||||||
|
get("/api/v3/repos/:owner/:repo/collaborators") (referrersOnly { repository =>
|
||||||
|
JsonFormat(getCollaborators(params("owner"), params("repo")).map(u => ApiUser(getAccountByUserName(u).get)))
|
||||||
|
})
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* https://developer.github.com/v3/users/#get-the-authenticated-user
|
* https://developer.github.com/v3/users/#get-the-authenticated-user
|
||||||
*/
|
*/
|
||||||
@@ -71,6 +149,16 @@ trait ApiControllerBase extends ControllerBase {
|
|||||||
} getOrElse Unauthorized
|
} getOrElse Unauthorized
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List user's own repository
|
||||||
|
* https://developer.github.com/v3/repos/#list-your-repositories
|
||||||
|
*/
|
||||||
|
get("/api/v3/user/repos")(usersOnly{
|
||||||
|
JsonFormat(getVisibleRepositories(context.loginAccount, Option(context.loginAccount.get.userName)).map{
|
||||||
|
r => ApiRepository(r, getAccountByUserName(r.owner).get)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create user repository
|
* Create user repository
|
||||||
* https://developer.github.com/v3/repos/#create
|
* https://developer.github.com/v3/repos/#create
|
||||||
|
|||||||
@@ -204,8 +204,7 @@ trait IssuesControllerBase extends ControllerBase {
|
|||||||
getIssue(repository.owner, repository.name, params("id")) map { x =>
|
getIssue(repository.owner, repository.name, params("id")) map { x =>
|
||||||
if(isEditable(x.userName, x.repositoryName, x.openedUserName)){
|
if(isEditable(x.userName, x.repositoryName, x.openedUserName)){
|
||||||
params.get("dataType") collect {
|
params.get("dataType") collect {
|
||||||
case t if t == "html" => html.editissue(
|
case t if t == "html" => html.editissue(x.content, x.issueId, repository)
|
||||||
x.content, x.issueId, x.userName, x.repositoryName)
|
|
||||||
} getOrElse {
|
} getOrElse {
|
||||||
contentType = formats("json")
|
contentType = formats("json")
|
||||||
org.json4s.jackson.Serialization.write(
|
org.json4s.jackson.Serialization.write(
|
||||||
@@ -232,8 +231,7 @@ trait IssuesControllerBase extends ControllerBase {
|
|||||||
getComment(repository.owner, repository.name, params("id")) map { x =>
|
getComment(repository.owner, repository.name, params("id")) map { x =>
|
||||||
if(isEditable(x.userName, x.repositoryName, x.commentedUserName)){
|
if(isEditable(x.userName, x.repositoryName, x.commentedUserName)){
|
||||||
params.get("dataType") collect {
|
params.get("dataType") collect {
|
||||||
case t if t == "html" => html.editcomment(
|
case t if t == "html" => html.editcomment(x.content, x.commentId, repository)
|
||||||
x.content, x.commentId, x.userName, x.repositoryName)
|
|
||||||
} getOrElse {
|
} getOrElse {
|
||||||
contentType = formats("json")
|
contentType = formats("json")
|
||||||
org.json4s.jackson.Serialization.write(
|
org.json4s.jackson.Serialization.write(
|
||||||
|
|||||||
@@ -27,12 +27,26 @@ trait RepositorySettingsControllerBase extends ControllerBase {
|
|||||||
with OwnerAuthenticator with UsersAuthenticator =>
|
with OwnerAuthenticator with UsersAuthenticator =>
|
||||||
|
|
||||||
// for repository options
|
// for repository options
|
||||||
case class OptionsForm(repositoryName: String, description: Option[String], isPrivate: Boolean)
|
case class OptionsForm(
|
||||||
|
repositoryName: String,
|
||||||
|
description: Option[String],
|
||||||
|
isPrivate: Boolean,
|
||||||
|
enableIssues: Boolean,
|
||||||
|
externalIssuesUrl: Option[String],
|
||||||
|
enableWiki: Boolean,
|
||||||
|
allowWikiEditing: Boolean,
|
||||||
|
externalWikiUrl: Option[String]
|
||||||
|
)
|
||||||
|
|
||||||
val optionsForm = mapping(
|
val optionsForm = mapping(
|
||||||
"repositoryName" -> trim(label("Repository Name", text(required, maxlength(40), identifier, renameRepositoryName))),
|
"repositoryName" -> trim(label("Repository Name" , text(required, maxlength(40), identifier, renameRepositoryName))),
|
||||||
"description" -> trim(label("Description" , optional(text()))),
|
"description" -> trim(label("Description" , optional(text()))),
|
||||||
"isPrivate" -> trim(label("Repository Type", boolean()))
|
"isPrivate" -> trim(label("Repository Type" , boolean())),
|
||||||
|
"enableIssues" -> trim(label("Enable Issues" , boolean())),
|
||||||
|
"externalIssuesUrl" -> trim(label("External Issues URL", optional(text(maxlength(200))))),
|
||||||
|
"enableWiki" -> trim(label("Enable Wiki" , boolean())),
|
||||||
|
"allowWikiEditing" -> trim(label("Allow Wiki Editing" , boolean())),
|
||||||
|
"externalWikiUrl" -> trim(label("External Wiki URL" , optional(text(maxlength(200)))))
|
||||||
)(OptionsForm.apply)
|
)(OptionsForm.apply)
|
||||||
|
|
||||||
// for default branch
|
// for default branch
|
||||||
@@ -92,7 +106,12 @@ trait RepositorySettingsControllerBase extends ControllerBase {
|
|||||||
form.description,
|
form.description,
|
||||||
repository.repository.parentUserName.map { _ =>
|
repository.repository.parentUserName.map { _ =>
|
||||||
repository.repository.isPrivate
|
repository.repository.isPrivate
|
||||||
} getOrElse form.isPrivate
|
} getOrElse form.isPrivate,
|
||||||
|
form.enableIssues,
|
||||||
|
form.externalIssuesUrl,
|
||||||
|
form.enableWiki,
|
||||||
|
form.allowWikiEditing,
|
||||||
|
form.externalWikiUrl
|
||||||
)
|
)
|
||||||
// Change repository name
|
// Change repository name
|
||||||
if(repository.name != form.repositoryName){
|
if(repository.name != form.repositoryName){
|
||||||
@@ -294,7 +313,7 @@ trait RepositorySettingsControllerBase extends ControllerBase {
|
|||||||
* Display the danger zone.
|
* Display the danger zone.
|
||||||
*/
|
*/
|
||||||
get("/:owner/:repository/settings/danger")(ownerOnly {
|
get("/:owner/:repository/settings/danger")(ownerOnly {
|
||||||
html.danger(_)
|
html.danger(_, flash.get("info"))
|
||||||
})
|
})
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -333,6 +352,19 @@ trait RepositorySettingsControllerBase extends ControllerBase {
|
|||||||
redirect(s"/${repository.owner}")
|
redirect(s"/${repository.owner}")
|
||||||
})
|
})
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Run GC
|
||||||
|
*/
|
||||||
|
post("/:owner/:repository/settings/gc")(ownerOnly { repository =>
|
||||||
|
LockUtil.lock(s"${repository.owner}/${repository.name}") {
|
||||||
|
using(Git.open(getRepositoryDir(repository.owner, repository.name))) { git =>
|
||||||
|
git.gc();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
flash += "info" -> "Garbage collection has been executed."
|
||||||
|
redirect(s"/${repository.owner}/${repository.name}/settings/danger")
|
||||||
|
})
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides duplication check for web hook url.
|
* Provides duplication check for web hook url.
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -125,7 +125,7 @@ trait RepositoryViewerControllerBase extends ControllerBase {
|
|||||||
* Displays the file list of the specified path and branch.
|
* Displays the file list of the specified path and branch.
|
||||||
*/
|
*/
|
||||||
get("/:owner/:repository/tree/*")(referrersOnly { repository =>
|
get("/:owner/:repository/tree/*")(referrersOnly { repository =>
|
||||||
val (id, path) = splitPath(repository, multiParams("splat").head)
|
val (id, path) = repository.splitPath(multiParams("splat").head)
|
||||||
if(path.isEmpty){
|
if(path.isEmpty){
|
||||||
fileList(repository, id)
|
fileList(repository, id)
|
||||||
} else {
|
} else {
|
||||||
@@ -137,7 +137,7 @@ trait RepositoryViewerControllerBase extends ControllerBase {
|
|||||||
* Displays the commit list of the specified resource.
|
* Displays the commit list of the specified resource.
|
||||||
*/
|
*/
|
||||||
get("/:owner/:repository/commits/*")(referrersOnly { repository =>
|
get("/:owner/:repository/commits/*")(referrersOnly { repository =>
|
||||||
val (branchName, path) = splitPath(repository, multiParams("splat").head)
|
val (branchName, path) = repository.splitPath(multiParams("splat").head)
|
||||||
val page = params.get("page").flatMap(_.toIntOpt).getOrElse(1)
|
val page = params.get("page").flatMap(_.toIntOpt).getOrElse(1)
|
||||||
|
|
||||||
using(Git.open(getRepositoryDir(repository.owner, repository.name))){ git =>
|
using(Git.open(getRepositoryDir(repository.owner, repository.name))){ git =>
|
||||||
@@ -153,7 +153,7 @@ trait RepositoryViewerControllerBase extends ControllerBase {
|
|||||||
})
|
})
|
||||||
|
|
||||||
get("/:owner/:repository/new/*")(collaboratorsOnly { repository =>
|
get("/:owner/:repository/new/*")(collaboratorsOnly { repository =>
|
||||||
val (branch, path) = splitPath(repository, multiParams("splat").head)
|
val (branch, path) = repository.splitPath(multiParams("splat").head)
|
||||||
val protectedBranch = getProtectedBranchInfo(repository.owner, repository.name, branch).needStatusCheck(context.loginAccount.get.userName)
|
val protectedBranch = getProtectedBranchInfo(repository.owner, repository.name, branch).needStatusCheck(context.loginAccount.get.userName)
|
||||||
html.editor(branch, repository, if(path.length == 0) Nil else path.split("/").toList,
|
html.editor(branch, repository, if(path.length == 0) Nil else path.split("/").toList,
|
||||||
None, JGitUtil.ContentInfo("text", None, Some("UTF-8")),
|
None, JGitUtil.ContentInfo("text", None, Some("UTF-8")),
|
||||||
@@ -161,7 +161,7 @@ trait RepositoryViewerControllerBase extends ControllerBase {
|
|||||||
})
|
})
|
||||||
|
|
||||||
get("/:owner/:repository/edit/*")(collaboratorsOnly { repository =>
|
get("/:owner/:repository/edit/*")(collaboratorsOnly { repository =>
|
||||||
val (branch, path) = splitPath(repository, multiParams("splat").head)
|
val (branch, path) = repository.splitPath(multiParams("splat").head)
|
||||||
val protectedBranch = getProtectedBranchInfo(repository.owner, repository.name, branch).needStatusCheck(context.loginAccount.get.userName)
|
val protectedBranch = getProtectedBranchInfo(repository.owner, repository.name, branch).needStatusCheck(context.loginAccount.get.userName)
|
||||||
|
|
||||||
using(Git.open(getRepositoryDir(repository.owner, repository.name))){ git =>
|
using(Git.open(getRepositoryDir(repository.owner, repository.name))){ git =>
|
||||||
@@ -177,7 +177,7 @@ trait RepositoryViewerControllerBase extends ControllerBase {
|
|||||||
})
|
})
|
||||||
|
|
||||||
get("/:owner/:repository/remove/*")(collaboratorsOnly { repository =>
|
get("/:owner/:repository/remove/*")(collaboratorsOnly { repository =>
|
||||||
val (branch, path) = splitPath(repository, multiParams("splat").head)
|
val (branch, path) = repository.splitPath(multiParams("splat").head)
|
||||||
using(Git.open(getRepositoryDir(repository.owner, repository.name))){ git =>
|
using(Git.open(getRepositoryDir(repository.owner, repository.name))){ git =>
|
||||||
val revCommit = JGitUtil.getRevCommitFromId(git, git.getRepository.resolve(branch))
|
val revCommit = JGitUtil.getRevCommitFromId(git, git.getRepository.resolve(branch))
|
||||||
|
|
||||||
@@ -235,7 +235,7 @@ trait RepositoryViewerControllerBase extends ControllerBase {
|
|||||||
})
|
})
|
||||||
|
|
||||||
get("/:owner/:repository/raw/*")(referrersOnly { repository =>
|
get("/:owner/:repository/raw/*")(referrersOnly { repository =>
|
||||||
val (id, path) = splitPath(repository, multiParams("splat").head)
|
val (id, path) = repository.splitPath(multiParams("splat").head)
|
||||||
using(Git.open(getRepositoryDir(repository.owner, repository.name))){ git =>
|
using(Git.open(getRepositoryDir(repository.owner, repository.name))){ git =>
|
||||||
val revCommit = JGitUtil.getRevCommitFromId(git, git.getRepository.resolve(id))
|
val revCommit = JGitUtil.getRevCommitFromId(git, git.getRepository.resolve(id))
|
||||||
getPathObjectId(git, path, revCommit).flatMap { objectId =>
|
getPathObjectId(git, path, revCommit).flatMap { objectId =>
|
||||||
@@ -253,7 +253,7 @@ trait RepositoryViewerControllerBase extends ControllerBase {
|
|||||||
* Displays the file content of the specified branch or commit.
|
* Displays the file content of the specified branch or commit.
|
||||||
*/
|
*/
|
||||||
val blobRoute = get("/:owner/:repository/blob/*")(referrersOnly { repository =>
|
val blobRoute = get("/:owner/:repository/blob/*")(referrersOnly { repository =>
|
||||||
val (id, path) = splitPath(repository, multiParams("splat").head)
|
val (id, path) = repository.splitPath(multiParams("splat").head)
|
||||||
val raw = params.get("raw").getOrElse("false").toBoolean
|
val raw = params.get("raw").getOrElse("false").toBoolean
|
||||||
using(Git.open(getRepositoryDir(repository.owner, repository.name))){ git =>
|
using(Git.open(getRepositoryDir(repository.owner, repository.name))){ git =>
|
||||||
val revCommit = JGitUtil.getRevCommitFromId(git, git.getRepository.resolve(id))
|
val revCommit = JGitUtil.getRevCommitFromId(git, git.getRepository.resolve(id))
|
||||||
@@ -285,7 +285,7 @@ trait RepositoryViewerControllerBase extends ControllerBase {
|
|||||||
* Blame data.
|
* Blame data.
|
||||||
*/
|
*/
|
||||||
ajaxGet("/:owner/:repository/get-blame/*")(referrersOnly { repository =>
|
ajaxGet("/:owner/:repository/get-blame/*")(referrersOnly { repository =>
|
||||||
val (id, path) = splitPath(repository, multiParams("splat").head)
|
val (id, path) = repository.splitPath(multiParams("splat").head)
|
||||||
contentType = formats("json")
|
contentType = formats("json")
|
||||||
using(Git.open(getRepositoryDir(repository.owner, repository.name))){ git =>
|
using(Git.open(getRepositoryDir(repository.owner, repository.name))){ git =>
|
||||||
val last = git.log.add(git.getRepository.resolve(id)).addPath(path).setMaxCount(1).call.iterator.next.name
|
val last = git.log.add(git.getRepository.resolve(id)).addPath(path).setMaxCount(1).call.iterator.next.name
|
||||||
@@ -376,8 +376,7 @@ trait RepositoryViewerControllerBase extends ControllerBase {
|
|||||||
getCommitComment(repository.owner, repository.name, params("id")) map { x =>
|
getCommitComment(repository.owner, repository.name, params("id")) map { x =>
|
||||||
if(isEditable(x.userName, x.repositoryName, x.commentedUserName)){
|
if(isEditable(x.userName, x.repositoryName, x.commentedUserName)){
|
||||||
params.get("dataType") collect {
|
params.get("dataType") collect {
|
||||||
case t if t == "html" => html.editcomment(
|
case t if t == "html" => html.editcomment(x.content, x.commentId, repository)
|
||||||
x.content, x.commentId, x.userName, x.repositoryName)
|
|
||||||
} getOrElse {
|
} getOrElse {
|
||||||
contentType = formats("json")
|
contentType = formats("json")
|
||||||
org.json4s.jackson.Serialization.write(
|
org.json4s.jackson.Serialization.write(
|
||||||
@@ -527,17 +526,6 @@ trait RepositoryViewerControllerBase extends ControllerBase {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
private def splitPath(repository: RepositoryService.RepositoryInfo, path: String): (String, String) = {
|
|
||||||
val id = repository.branchList.collectFirst {
|
|
||||||
case branch if(path == branch || path.startsWith(branch + "/")) => branch
|
|
||||||
} orElse repository.tags.collectFirst {
|
|
||||||
case tag if(path == tag.name || path.startsWith(tag.name + "/")) => tag.name
|
|
||||||
} getOrElse path.split("/")(0)
|
|
||||||
|
|
||||||
(id, path.substring(id.length).stripPrefix("/"))
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private val readmeFiles = PluginRegistry().renderableExtensions.map { extension =>
|
private val readmeFiles = PluginRegistry().renderableExtensions.map { extension =>
|
||||||
s"readme.${extension}"
|
s"readme.${extension}"
|
||||||
} ++ Seq("readme.txt", "readme")
|
} ++ Seq("readme.txt", "readme")
|
||||||
@@ -691,8 +679,6 @@ trait RepositoryViewerControllerBase extends ControllerBase {
|
|||||||
private def isEditable(owner: String, repository: String, author: String)(implicit context: Context): Boolean =
|
private def isEditable(owner: String, repository: String, author: String)(implicit context: Context): Boolean =
|
||||||
hasWritePermission(owner, repository, context.loginAccount) || author == context.loginAccount.get.userName
|
hasWritePermission(owner, repository, context.loginAccount) || author == context.loginAccount.get.userName
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
override protected def renderUncaughtException(e: Throwable)(implicit request: HttpServletRequest, response: HttpServletResponse): Unit = {
|
override protected def renderUncaughtException(e: Throwable)(implicit request: HttpServletRequest, response: HttpServletResponse): Unit = {
|
||||||
e.printStackTrace()
|
e.printStackTrace()
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,8 +3,8 @@ package gitbucket.core.controller
|
|||||||
import java.io.FileInputStream
|
import java.io.FileInputStream
|
||||||
|
|
||||||
import gitbucket.core.admin.html
|
import gitbucket.core.admin.html
|
||||||
import gitbucket.core.service.{AccountService, SystemSettingsService, RepositoryService}
|
import gitbucket.core.service.{AccountService, RepositoryService, SystemSettingsService}
|
||||||
import gitbucket.core.util.AdminAuthenticator
|
import gitbucket.core.util.{AdminAuthenticator, Mailer}
|
||||||
import gitbucket.core.ssh.SshServer
|
import gitbucket.core.ssh.SshServer
|
||||||
import gitbucket.core.plugin.PluginRegistry
|
import gitbucket.core.plugin.PluginRegistry
|
||||||
import SystemSettingsService._
|
import SystemSettingsService._
|
||||||
@@ -13,7 +13,9 @@ import gitbucket.core.util.ControlUtil._
|
|||||||
import gitbucket.core.util.Directory._
|
import gitbucket.core.util.Directory._
|
||||||
import gitbucket.core.util.StringUtil._
|
import gitbucket.core.util.StringUtil._
|
||||||
import io.github.gitbucket.scalatra.forms._
|
import io.github.gitbucket.scalatra.forms._
|
||||||
import org.apache.commons.io.{IOUtils, FileUtils}
|
import io.github.gitbucket.solidbase.manager.JDBCVersionManager
|
||||||
|
import org.apache.commons.io.{FileUtils, IOUtils}
|
||||||
|
import org.apache.commons.mail.{DefaultAuthenticator, HtmlEmail}
|
||||||
import org.scalatra.i18n.Messages
|
import org.scalatra.i18n.Messages
|
||||||
|
|
||||||
class SystemSettingsController extends SystemSettingsControllerBase
|
class SystemSettingsController extends SystemSettingsControllerBase
|
||||||
@@ -70,11 +72,20 @@ trait SystemSettingsControllerBase extends AccountManagementControllerBase {
|
|||||||
).flatten
|
).flatten
|
||||||
}
|
}
|
||||||
|
|
||||||
private val pluginForm = mapping(
|
private val sendMailForm = mapping(
|
||||||
"pluginId" -> list(trim(label("", text())))
|
"smtp" -> mapping(
|
||||||
)(PluginForm.apply)
|
"host" -> trim(label("SMTP Host", text(required))),
|
||||||
|
"port" -> trim(label("SMTP Port", optional(number()))),
|
||||||
|
"user" -> trim(label("SMTP User", optional(text()))),
|
||||||
|
"password" -> trim(label("SMTP Password", optional(text()))),
|
||||||
|
"ssl" -> trim(label("Enable SSL", optional(boolean()))),
|
||||||
|
"fromAddress" -> trim(label("FROM Address", optional(text()))),
|
||||||
|
"fromName" -> trim(label("FROM Name", optional(text())))
|
||||||
|
)(Smtp.apply),
|
||||||
|
"testAddress" -> trim(label("", text(required)))
|
||||||
|
)(SendMailForm.apply)
|
||||||
|
|
||||||
case class PluginForm(pluginIds: List[String])
|
case class SendMailForm(smtp: Smtp, testAddress: String)
|
||||||
|
|
||||||
case class DataExportForm(tableNames: List[String])
|
case class DataExportForm(tableNames: List[String])
|
||||||
|
|
||||||
@@ -152,8 +163,24 @@ trait SystemSettingsControllerBase extends AccountManagementControllerBase {
|
|||||||
redirect("/admin/system")
|
redirect("/admin/system")
|
||||||
})
|
})
|
||||||
|
|
||||||
|
post("/admin/system/sendmail", sendMailForm)(adminOnly { form =>
|
||||||
|
try {
|
||||||
|
new Mailer(form.smtp).send(form.testAddress,
|
||||||
|
"Test message from GitBucket", "This is a test message from GitBucket.")
|
||||||
|
|
||||||
|
"Test mail has been sent to: " + form.testAddress
|
||||||
|
|
||||||
|
} catch {
|
||||||
|
case e: Exception => "[Error] " + e.toString
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
get("/admin/plugins")(adminOnly {
|
get("/admin/plugins")(adminOnly {
|
||||||
html.plugins(PluginRegistry().getPlugins())
|
val manager = new JDBCVersionManager(request2Session(request).conn)
|
||||||
|
val plugins = PluginRegistry().getPlugins().map { plugin =>
|
||||||
|
(plugin, manager.getCurrentVersion(plugin.pluginId))
|
||||||
|
}
|
||||||
|
html.plugins(plugins)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,8 @@
|
|||||||
package gitbucket.core.controller
|
package gitbucket.core.controller
|
||||||
|
|
||||||
|
import gitbucket.core.service.RepositoryService.RepositoryInfo
|
||||||
import gitbucket.core.wiki.html
|
import gitbucket.core.wiki.html
|
||||||
import gitbucket.core.service.{RepositoryService, WikiService, ActivityService, AccountService}
|
import gitbucket.core.service.{AccountService, ActivityService, RepositoryService, WikiService}
|
||||||
import gitbucket.core.util._
|
import gitbucket.core.util._
|
||||||
import gitbucket.core.util.StringUtil._
|
import gitbucket.core.util.StringUtil._
|
||||||
import gitbucket.core.util.ControlUtil._
|
import gitbucket.core.util.ControlUtil._
|
||||||
@@ -39,7 +40,7 @@ trait WikiControllerBase extends ControllerBase {
|
|||||||
get("/:owner/:repository/wiki")(referrersOnly { repository =>
|
get("/:owner/:repository/wiki")(referrersOnly { repository =>
|
||||||
getWikiPage(repository.owner, repository.name, "Home").map { page =>
|
getWikiPage(repository.owner, repository.name, "Home").map { page =>
|
||||||
html.page("Home", page, getWikiPageList(repository.owner, repository.name),
|
html.page("Home", page, getWikiPageList(repository.owner, repository.name),
|
||||||
repository, hasWritePermission(repository.owner, repository.name, context.loginAccount),
|
repository, isEditable(repository),
|
||||||
getWikiPage(repository.owner, repository.name, "_Sidebar"),
|
getWikiPage(repository.owner, repository.name, "_Sidebar"),
|
||||||
getWikiPage(repository.owner, repository.name, "_Footer"))
|
getWikiPage(repository.owner, repository.name, "_Footer"))
|
||||||
} getOrElse redirect(s"/${repository.owner}/${repository.name}/wiki/Home/_edit")
|
} getOrElse redirect(s"/${repository.owner}/${repository.name}/wiki/Home/_edit")
|
||||||
@@ -50,7 +51,7 @@ trait WikiControllerBase extends ControllerBase {
|
|||||||
|
|
||||||
getWikiPage(repository.owner, repository.name, pageName).map { page =>
|
getWikiPage(repository.owner, repository.name, pageName).map { page =>
|
||||||
html.page(pageName, page, getWikiPageList(repository.owner, repository.name),
|
html.page(pageName, page, getWikiPageList(repository.owner, repository.name),
|
||||||
repository, hasWritePermission(repository.owner, repository.name, context.loginAccount),
|
repository, isEditable(repository),
|
||||||
getWikiPage(repository.owner, repository.name, "_Sidebar"),
|
getWikiPage(repository.owner, repository.name, "_Sidebar"),
|
||||||
getWikiPage(repository.owner, repository.name, "_Footer"))
|
getWikiPage(repository.owner, repository.name, "_Footer"))
|
||||||
} getOrElse redirect(s"/${repository.owner}/${repository.name}/wiki/${StringUtil.urlEncode(pageName)}/_edit")
|
} getOrElse redirect(s"/${repository.owner}/${repository.name}/wiki/${StringUtil.urlEncode(pageName)}/_edit")
|
||||||
@@ -62,7 +63,7 @@ trait WikiControllerBase extends ControllerBase {
|
|||||||
using(Git.open(getWikiRepositoryDir(repository.owner, repository.name))){ git =>
|
using(Git.open(getWikiRepositoryDir(repository.owner, repository.name))){ git =>
|
||||||
JGitUtil.getCommitLog(git, "master", path = pageName + ".md") match {
|
JGitUtil.getCommitLog(git, "master", path = pageName + ".md") match {
|
||||||
case Right((logs, hasNext)) => html.history(Some(pageName), logs, repository)
|
case Right((logs, hasNext)) => html.history(Some(pageName), logs, repository)
|
||||||
case Left(_) => NotFound
|
case Left(_) => NotFound()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
@@ -73,7 +74,7 @@ trait WikiControllerBase extends ControllerBase {
|
|||||||
|
|
||||||
using(Git.open(getWikiRepositoryDir(repository.owner, repository.name))){ git =>
|
using(Git.open(getWikiRepositoryDir(repository.owner, repository.name))){ git =>
|
||||||
html.compare(Some(pageName), from, to, JGitUtil.getDiffs(git, from, to, true).filter(_.newPath == pageName + ".md"), repository,
|
html.compare(Some(pageName), from, to, JGitUtil.getDiffs(git, from, to, true).filter(_.newPath == pageName + ".md"), repository,
|
||||||
hasWritePermission(repository.owner, repository.name, context.loginAccount), flash.get("info"))
|
isEditable(repository), flash.get("info"))
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
@@ -82,102 +83,115 @@ trait WikiControllerBase extends ControllerBase {
|
|||||||
|
|
||||||
using(Git.open(getWikiRepositoryDir(repository.owner, repository.name))){ git =>
|
using(Git.open(getWikiRepositoryDir(repository.owner, repository.name))){ git =>
|
||||||
html.compare(None, from, to, JGitUtil.getDiffs(git, from, to, true), repository,
|
html.compare(None, from, to, JGitUtil.getDiffs(git, from, to, true), repository,
|
||||||
hasWritePermission(repository.owner, repository.name, context.loginAccount), flash.get("info"))
|
isEditable(repository), flash.get("info"))
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
get("/:owner/:repository/wiki/:page/_revert/:commitId")(collaboratorsOnly { repository =>
|
get("/:owner/:repository/wiki/:page/_revert/:commitId")(referrersOnly { repository =>
|
||||||
val pageName = StringUtil.urlDecode(params("page"))
|
if(isEditable(repository)){
|
||||||
val Array(from, to) = params("commitId").split("\\.\\.\\.")
|
val pageName = StringUtil.urlDecode(params("page"))
|
||||||
|
val Array(from, to) = params("commitId").split("\\.\\.\\.")
|
||||||
|
|
||||||
if(revertWikiPage(repository.owner, repository.name, from, to, context.loginAccount.get, Some(pageName))){
|
if(revertWikiPage(repository.owner, repository.name, from, to, context.loginAccount.get, Some(pageName))){
|
||||||
redirect(s"/${repository.owner}/${repository.name}/wiki/${StringUtil.urlEncode(pageName)}")
|
redirect(s"/${repository.owner}/${repository.name}/wiki/${StringUtil.urlEncode(pageName)}")
|
||||||
} else {
|
|
||||||
flash += "info" -> "This patch was not able to be reversed."
|
|
||||||
redirect(s"/${repository.owner}/${repository.name}/wiki/${StringUtil.urlEncode(pageName)}/_compare/${from}...${to}")
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
get("/:owner/:repository/wiki/_revert/:commitId")(collaboratorsOnly { repository =>
|
|
||||||
val Array(from, to) = params("commitId").split("\\.\\.\\.")
|
|
||||||
|
|
||||||
if(revertWikiPage(repository.owner, repository.name, from, to, context.loginAccount.get, None)){
|
|
||||||
redirect(s"/${repository.owner}/${repository.name}/wiki/")
|
|
||||||
} else {
|
|
||||||
flash += "info" -> "This patch was not able to be reversed."
|
|
||||||
redirect(s"/${repository.owner}/${repository.name}/wiki/_compare/${from}...${to}")
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
get("/:owner/:repository/wiki/:page/_edit")(collaboratorsOnly { repository =>
|
|
||||||
val pageName = StringUtil.urlDecode(params("page"))
|
|
||||||
html.edit(pageName, getWikiPage(repository.owner, repository.name, pageName), repository)
|
|
||||||
})
|
|
||||||
|
|
||||||
post("/:owner/:repository/wiki/_edit", editForm)(collaboratorsOnly { (form, repository) =>
|
|
||||||
defining(context.loginAccount.get){ loginAccount =>
|
|
||||||
saveWikiPage(
|
|
||||||
repository.owner,
|
|
||||||
repository.name,
|
|
||||||
form.currentPageName,
|
|
||||||
form.pageName,
|
|
||||||
appendNewLine(convertLineSeparator(form.content, "LF"), "LF"),
|
|
||||||
loginAccount,
|
|
||||||
form.message.getOrElse(""),
|
|
||||||
Some(form.id)
|
|
||||||
).map { commitId =>
|
|
||||||
updateLastActivityDate(repository.owner, repository.name)
|
|
||||||
recordEditWikiPageActivity(repository.owner, repository.name, loginAccount.userName, form.pageName, commitId)
|
|
||||||
}
|
|
||||||
if(notReservedPageName(form.pageName)) {
|
|
||||||
redirect(s"/${repository.owner}/${repository.name}/wiki/${StringUtil.urlEncode(form.pageName)}")
|
|
||||||
} else {
|
} else {
|
||||||
redirect(s"/${repository.owner}/${repository.name}/wiki")
|
flash += "info" -> "This patch was not able to be reversed."
|
||||||
|
redirect(s"/${repository.owner}/${repository.name}/wiki/${StringUtil.urlEncode(pageName)}/_compare/${from}...${to}")
|
||||||
}
|
}
|
||||||
}
|
} else Unauthorized()
|
||||||
|
})
|
||||||
|
|
||||||
|
get("/:owner/:repository/wiki/_revert/:commitId")(referrersOnly { repository =>
|
||||||
|
if(isEditable(repository)){
|
||||||
|
val Array(from, to) = params("commitId").split("\\.\\.\\.")
|
||||||
|
|
||||||
|
if(revertWikiPage(repository.owner, repository.name, from, to, context.loginAccount.get, None)){
|
||||||
|
redirect(s"/${repository.owner}/${repository.name}/wiki/")
|
||||||
|
} else {
|
||||||
|
flash += "info" -> "This patch was not able to be reversed."
|
||||||
|
redirect(s"/${repository.owner}/${repository.name}/wiki/_compare/${from}...${to}")
|
||||||
|
}
|
||||||
|
} else Unauthorized()
|
||||||
|
})
|
||||||
|
|
||||||
|
get("/:owner/:repository/wiki/:page/_edit")(referrersOnly { repository =>
|
||||||
|
if(isEditable(repository)){
|
||||||
|
val pageName = StringUtil.urlDecode(params("page"))
|
||||||
|
html.edit(pageName, getWikiPage(repository.owner, repository.name, pageName), repository)
|
||||||
|
} else Unauthorized()
|
||||||
})
|
})
|
||||||
|
|
||||||
get("/:owner/:repository/wiki/_new")(collaboratorsOnly {
|
post("/:owner/:repository/wiki/_edit", editForm)(referrersOnly { (form, repository) =>
|
||||||
html.edit("", None, _)
|
if(isEditable(repository)){
|
||||||
|
defining(context.loginAccount.get){ loginAccount =>
|
||||||
|
saveWikiPage(
|
||||||
|
repository.owner,
|
||||||
|
repository.name,
|
||||||
|
form.currentPageName,
|
||||||
|
form.pageName,
|
||||||
|
appendNewLine(convertLineSeparator(form.content, "LF"), "LF"),
|
||||||
|
loginAccount,
|
||||||
|
form.message.getOrElse(""),
|
||||||
|
Some(form.id)
|
||||||
|
).map { commitId =>
|
||||||
|
updateLastActivityDate(repository.owner, repository.name)
|
||||||
|
recordEditWikiPageActivity(repository.owner, repository.name, loginAccount.userName, form.pageName, commitId)
|
||||||
|
}
|
||||||
|
if(notReservedPageName(form.pageName)) {
|
||||||
|
redirect(s"/${repository.owner}/${repository.name}/wiki/${StringUtil.urlEncode(form.pageName)}")
|
||||||
|
} else {
|
||||||
|
redirect(s"/${repository.owner}/${repository.name}/wiki")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else Unauthorized()
|
||||||
})
|
})
|
||||||
|
|
||||||
post("/:owner/:repository/wiki/_new", newForm)(collaboratorsOnly { (form, repository) =>
|
get("/:owner/:repository/wiki/_new")(referrersOnly { repository =>
|
||||||
defining(context.loginAccount.get){ loginAccount =>
|
if(isEditable(repository)){
|
||||||
saveWikiPage(repository.owner, repository.name, form.currentPageName, form.pageName,
|
html.edit("", None, repository)
|
||||||
|
} else Unauthorized()
|
||||||
|
})
|
||||||
|
|
||||||
|
post("/:owner/:repository/wiki/_new", newForm)(referrersOnly { (form, repository) =>
|
||||||
|
if(isEditable(repository)){
|
||||||
|
defining(context.loginAccount.get){ loginAccount =>
|
||||||
|
saveWikiPage(repository.owner, repository.name, form.currentPageName, form.pageName,
|
||||||
form.content, loginAccount, form.message.getOrElse(""), None)
|
form.content, loginAccount, form.message.getOrElse(""), None)
|
||||||
|
|
||||||
updateLastActivityDate(repository.owner, repository.name)
|
updateLastActivityDate(repository.owner, repository.name)
|
||||||
recordCreateWikiPageActivity(repository.owner, repository.name, loginAccount.userName, form.pageName)
|
recordCreateWikiPageActivity(repository.owner, repository.name, loginAccount.userName, form.pageName)
|
||||||
|
|
||||||
if(notReservedPageName(form.pageName)) {
|
if(notReservedPageName(form.pageName)) {
|
||||||
redirect(s"/${repository.owner}/${repository.name}/wiki/${StringUtil.urlEncode(form.pageName)}")
|
redirect(s"/${repository.owner}/${repository.name}/wiki/${StringUtil.urlEncode(form.pageName)}")
|
||||||
} else {
|
} else {
|
||||||
redirect(s"/${repository.owner}/${repository.name}/wiki")
|
redirect(s"/${repository.owner}/${repository.name}/wiki")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
} else Unauthorized()
|
||||||
})
|
})
|
||||||
|
|
||||||
get("/:owner/:repository/wiki/:page/_delete")(collaboratorsOnly { repository =>
|
get("/:owner/:repository/wiki/:page/_delete")(referrersOnly { repository =>
|
||||||
val pageName = StringUtil.urlDecode(params("page"))
|
if(isEditable(repository)){
|
||||||
|
val pageName = StringUtil.urlDecode(params("page"))
|
||||||
|
|
||||||
defining(context.loginAccount.get){ loginAccount =>
|
defining(context.loginAccount.get){ loginAccount =>
|
||||||
deleteWikiPage(repository.owner, repository.name, pageName, loginAccount.fullName, loginAccount.mailAddress, s"Destroyed ${pageName}")
|
deleteWikiPage(repository.owner, repository.name, pageName, loginAccount.fullName, loginAccount.mailAddress, s"Destroyed ${pageName}")
|
||||||
updateLastActivityDate(repository.owner, repository.name)
|
updateLastActivityDate(repository.owner, repository.name)
|
||||||
|
|
||||||
redirect(s"/${repository.owner}/${repository.name}/wiki")
|
redirect(s"/${repository.owner}/${repository.name}/wiki")
|
||||||
}
|
}
|
||||||
|
} else Unauthorized()
|
||||||
})
|
})
|
||||||
|
|
||||||
get("/:owner/:repository/wiki/_pages")(referrersOnly { repository =>
|
get("/:owner/:repository/wiki/_pages")(referrersOnly { repository =>
|
||||||
html.pages(getWikiPageList(repository.owner, repository.name), repository,
|
html.pages(getWikiPageList(repository.owner, repository.name), repository, isEditable(repository))
|
||||||
hasWritePermission(repository.owner, repository.name, context.loginAccount))
|
|
||||||
})
|
})
|
||||||
|
|
||||||
get("/:owner/:repository/wiki/_history")(referrersOnly { repository =>
|
get("/:owner/:repository/wiki/_history")(referrersOnly { repository =>
|
||||||
using(Git.open(getWikiRepositoryDir(repository.owner, repository.name))){ git =>
|
using(Git.open(getWikiRepositoryDir(repository.owner, repository.name))){ git =>
|
||||||
JGitUtil.getCommitLog(git, "master") match {
|
JGitUtil.getCommitLog(git, "master") match {
|
||||||
case Right((logs, hasNext)) => html.history(None, logs, repository)
|
case Right((logs, hasNext)) => html.history(None, logs, repository)
|
||||||
case Left(_) => NotFound
|
case Left(_) => NotFound()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
@@ -226,4 +240,9 @@ trait WikiControllerBase extends ControllerBase {
|
|||||||
|
|
||||||
private def targetWikiPage = getWikiPage(params("owner"), params("repository"), params("pageName"))
|
private def targetWikiPage = getWikiPage(params("owner"), params("repository"), params("pageName"))
|
||||||
|
|
||||||
|
private def isEditable(repository: RepositoryInfo)(implicit context: Context): Boolean =
|
||||||
|
repository.repository.allowWikiEditing || (
|
||||||
|
hasWritePermission(repository.owner, repository.name, context.loginAccount)
|
||||||
|
)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,7 +17,14 @@ trait RepositoryComponent extends TemplateComponent { self: Profile =>
|
|||||||
val originRepositoryName = column[String]("ORIGIN_REPOSITORY_NAME")
|
val originRepositoryName = column[String]("ORIGIN_REPOSITORY_NAME")
|
||||||
val parentUserName = column[String]("PARENT_USER_NAME")
|
val parentUserName = column[String]("PARENT_USER_NAME")
|
||||||
val parentRepositoryName = column[String]("PARENT_REPOSITORY_NAME")
|
val parentRepositoryName = column[String]("PARENT_REPOSITORY_NAME")
|
||||||
def * = (userName, repositoryName, isPrivate, description.?, defaultBranch, registeredDate, updatedDate, lastActivityDate, originUserName.?, originRepositoryName.?, parentUserName.?, parentRepositoryName.?) <> (Repository.tupled, Repository.unapply)
|
val enableIssues = column[Boolean]("ENABLE_ISSUES")
|
||||||
|
val externalIssuesUrl = column[String]("EXTERNAL_ISSUES_URL")
|
||||||
|
val enableWiki = column[Boolean]("ENABLE_WIKI")
|
||||||
|
val allowWikiEditing = column[Boolean]("ALLOW_WIKI_EDITING")
|
||||||
|
val externalWikiUrl = column[String]("EXTERNAL_WIKI_URL")
|
||||||
|
def * = (userName, repositoryName, isPrivate, description.?, defaultBranch,
|
||||||
|
registeredDate, updatedDate, lastActivityDate, originUserName.?, originRepositoryName.?, parentUserName.?, parentRepositoryName.?,
|
||||||
|
enableIssues, externalIssuesUrl.?, enableWiki, allowWikiEditing, externalWikiUrl.?) <> (Repository.tupled, Repository.unapply)
|
||||||
|
|
||||||
def byPrimaryKey(owner: String, repository: String) = byRepository(owner, repository)
|
def byPrimaryKey(owner: String, repository: String) = byRepository(owner, repository)
|
||||||
}
|
}
|
||||||
@@ -35,5 +42,10 @@ case class Repository(
|
|||||||
originUserName: Option[String],
|
originUserName: Option[String],
|
||||||
originRepositoryName: Option[String],
|
originRepositoryName: Option[String],
|
||||||
parentUserName: Option[String],
|
parentUserName: Option[String],
|
||||||
parentRepositoryName: Option[String]
|
parentRepositoryName: Option[String],
|
||||||
|
enableIssues: Boolean,
|
||||||
|
externalIssuesUrl: Option[String],
|
||||||
|
enableWiki: Boolean,
|
||||||
|
allowWikiEditing: Boolean,
|
||||||
|
externalWikiUrl: Option[String]
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -149,6 +149,36 @@ abstract class Plugin {
|
|||||||
*/
|
*/
|
||||||
def dashboardTabs(registry: PluginRegistry, context: ServletContext, settings: SystemSettings): Seq[(Context) => Option[Link]] = Nil
|
def dashboardTabs(registry: PluginRegistry, context: ServletContext, settings: SystemSettings): Seq[(Context) => Option[Link]] = Nil
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Override to add assets mappings.
|
||||||
|
*/
|
||||||
|
val assetsMappings: Seq[(String, String)] = Nil
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Override to add assets mappings.
|
||||||
|
*/
|
||||||
|
def assetsMappings(registry: PluginRegistry, context: ServletContext, settings: SystemSettings): Seq[(String, String)] = Nil
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Override to add text decorators.
|
||||||
|
*/
|
||||||
|
val textDecorators: Seq[TextDecorator] = Nil
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Override to add text decorators.
|
||||||
|
*/
|
||||||
|
def textDecorators(registry: PluginRegistry, context: ServletContext, settings: SystemSettings): Seq[TextDecorator] = Nil
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Override to add suggestion provider.
|
||||||
|
*/
|
||||||
|
val suggestionProviders: Seq[SuggestionProvider] = Nil
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Override to add suggestion provider.
|
||||||
|
*/
|
||||||
|
def suggestionProviders(registry: PluginRegistry, context: ServletContext, settings: SystemSettings): Seq[SuggestionProvider] = Nil
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method is invoked in initialization of plugin system.
|
* This method is invoked in initialization of plugin system.
|
||||||
* Register plugin functionality to PluginRegistry.
|
* Register plugin functionality to PluginRegistry.
|
||||||
@@ -193,6 +223,15 @@ abstract class Plugin {
|
|||||||
(dashboardTabs ++ dashboardTabs(registry, context, settings)).foreach { dashboardTab =>
|
(dashboardTabs ++ dashboardTabs(registry, context, settings)).foreach { dashboardTab =>
|
||||||
registry.addDashboardTab(dashboardTab)
|
registry.addDashboardTab(dashboardTab)
|
||||||
}
|
}
|
||||||
|
(assetsMappings ++ assetsMappings(registry, context, settings)).foreach { assetMapping =>
|
||||||
|
registry.addAssetsMapping((assetMapping._1, assetMapping._2, getClass.getClassLoader))
|
||||||
|
}
|
||||||
|
(textDecorators ++ textDecorators(registry, context, settings)).foreach { textDecorator =>
|
||||||
|
registry.addTextDecorator(textDecorator)
|
||||||
|
}
|
||||||
|
(suggestionProviders ++ suggestionProviders(registry, context, settings)).foreach { suggestionProvider =>
|
||||||
|
registry.addSuggestionProvider(suggestionProvider)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -14,7 +14,6 @@ import gitbucket.core.util.DatabaseConfig
|
|||||||
import gitbucket.core.util.Directory._
|
import gitbucket.core.util.Directory._
|
||||||
import io.github.gitbucket.solidbase.Solidbase
|
import io.github.gitbucket.solidbase.Solidbase
|
||||||
import io.github.gitbucket.solidbase.model.Module
|
import io.github.gitbucket.solidbase.model.Module
|
||||||
import liquibase.database.core.H2Database
|
|
||||||
import org.apache.commons.codec.binary.{Base64, StringUtils}
|
import org.apache.commons.codec.binary.{Base64, StringUtils}
|
||||||
import org.slf4j.LoggerFactory
|
import org.slf4j.LoggerFactory
|
||||||
|
|
||||||
@@ -42,10 +41,13 @@ class PluginRegistry {
|
|||||||
private val systemSettingMenus = new ListBuffer[(Context) => Option[Link]]
|
private val systemSettingMenus = new ListBuffer[(Context) => Option[Link]]
|
||||||
private val accountSettingMenus = new ListBuffer[(Context) => Option[Link]]
|
private val accountSettingMenus = new ListBuffer[(Context) => Option[Link]]
|
||||||
private val dashboardTabs = new ListBuffer[(Context) => Option[Link]]
|
private val dashboardTabs = new ListBuffer[(Context) => Option[Link]]
|
||||||
|
private val assetsMappings = new ListBuffer[(String, String, ClassLoader)]
|
||||||
|
private val textDecorators = new ListBuffer[TextDecorator]
|
||||||
|
|
||||||
def addPlugin(pluginInfo: PluginInfo): Unit = {
|
private val suggestionProviders = new ListBuffer[SuggestionProvider]
|
||||||
plugins += pluginInfo
|
suggestionProviders += new UserNameSuggestionProvider()
|
||||||
}
|
|
||||||
|
def addPlugin(pluginInfo: PluginInfo): Unit = plugins += pluginInfo
|
||||||
|
|
||||||
def getPlugins(): List[PluginInfo] = plugins.toList
|
def getPlugins(): List[PluginInfo] = plugins.toList
|
||||||
|
|
||||||
@@ -66,42 +68,26 @@ class PluginRegistry {
|
|||||||
|
|
||||||
def getImage(id: String): String = images(id)
|
def getImage(id: String): String = images(id)
|
||||||
|
|
||||||
def addController(path: String, controller: ControllerBase): Unit = {
|
def addController(path: String, controller: ControllerBase): Unit = controllers += ((controller, path))
|
||||||
controllers += ((controller, path))
|
|
||||||
}
|
|
||||||
|
|
||||||
@deprecated("Use addController(path: String, controller: ControllerBase) instead", "3.4.0")
|
@deprecated("Use addController(path: String, controller: ControllerBase) instead", "3.4.0")
|
||||||
def addController(controller: ControllerBase, path: String): Unit = {
|
def addController(controller: ControllerBase, path: String): Unit = addController(path, controller)
|
||||||
addController(path, controller)
|
|
||||||
}
|
|
||||||
|
|
||||||
def getControllers(): Seq[(ControllerBase, String)] = controllers.toSeq
|
def getControllers(): Seq[(ControllerBase, String)] = controllers.toSeq
|
||||||
|
|
||||||
def addJavaScript(path: String, script: String): Unit = {
|
def addJavaScript(path: String, script: String): Unit = javaScripts += ((path, script))
|
||||||
javaScripts += ((path, script))
|
|
||||||
}
|
|
||||||
|
|
||||||
def getJavaScript(currentPath: String): List[String] = {
|
def getJavaScript(currentPath: String): List[String] = javaScripts.filter(x => currentPath.matches(x._1)).toList.map(_._2)
|
||||||
javaScripts.filter(x => currentPath.matches(x._1)).toList.map(_._2)
|
|
||||||
}
|
|
||||||
|
|
||||||
def addRenderer(extension: String, renderer: Renderer): Unit = {
|
def addRenderer(extension: String, renderer: Renderer): Unit = renderers += ((extension, renderer))
|
||||||
renderers += ((extension, renderer))
|
|
||||||
}
|
|
||||||
|
|
||||||
def getRenderer(extension: String): Renderer = {
|
def getRenderer(extension: String): Renderer = renderers.get(extension).getOrElse(DefaultRenderer)
|
||||||
renderers.get(extension).getOrElse(DefaultRenderer)
|
|
||||||
}
|
|
||||||
|
|
||||||
def renderableExtensions: Seq[String] = renderers.keys.toSeq
|
def renderableExtensions: Seq[String] = renderers.keys.toSeq
|
||||||
|
|
||||||
def addRepositoryRouting(routing: GitRepositoryRouting): Unit = {
|
def addRepositoryRouting(routing: GitRepositoryRouting): Unit = repositoryRoutings += routing
|
||||||
repositoryRoutings += routing
|
|
||||||
}
|
|
||||||
|
|
||||||
def getRepositoryRoutings(): Seq[GitRepositoryRouting] = {
|
def getRepositoryRoutings(): Seq[GitRepositoryRouting] = repositoryRoutings.toSeq
|
||||||
repositoryRoutings.toSeq
|
|
||||||
}
|
|
||||||
|
|
||||||
def getRepositoryRouting(repositoryPath: String): Option[GitRepositoryRouting] = {
|
def getRepositoryRouting(repositoryPath: String): Option[GitRepositoryRouting] = {
|
||||||
PluginRegistry().getRepositoryRoutings().find {
|
PluginRegistry().getRepositoryRoutings().find {
|
||||||
@@ -111,54 +97,49 @@ class PluginRegistry {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
def addReceiveHook(commitHook: ReceiveHook): Unit = {
|
def addReceiveHook(commitHook: ReceiveHook): Unit = receiveHooks += commitHook
|
||||||
receiveHooks += commitHook
|
|
||||||
}
|
|
||||||
|
|
||||||
def getReceiveHooks: Seq[ReceiveHook] = receiveHooks.toSeq
|
def getReceiveHooks: Seq[ReceiveHook] = receiveHooks.toSeq
|
||||||
|
|
||||||
def addGlobalMenu(globalMenu: (Context) => Option[Link]): Unit = {
|
def addGlobalMenu(globalMenu: (Context) => Option[Link]): Unit = globalMenus += globalMenu
|
||||||
globalMenus += globalMenu
|
|
||||||
}
|
|
||||||
|
|
||||||
def getGlobalMenus: Seq[(Context) => Option[Link]] = globalMenus.toSeq
|
def getGlobalMenus: Seq[(Context) => Option[Link]] = globalMenus.toSeq
|
||||||
|
|
||||||
def addRepositoryMenu(repositoryMenu: (RepositoryInfo, Context) => Option[Link]): Unit = {
|
def addRepositoryMenu(repositoryMenu: (RepositoryInfo, Context) => Option[Link]): Unit = repositoryMenus += repositoryMenu
|
||||||
repositoryMenus += repositoryMenu
|
|
||||||
}
|
|
||||||
|
|
||||||
def getRepositoryMenus: Seq[(RepositoryInfo, Context) => Option[Link]] = repositoryMenus.toSeq
|
def getRepositoryMenus: Seq[(RepositoryInfo, Context) => Option[Link]] = repositoryMenus.toSeq
|
||||||
|
|
||||||
def addRepositorySettingTab(repositorySettingTab: (RepositoryInfo, Context) => Option[Link]): Unit = {
|
def addRepositorySettingTab(repositorySettingTab: (RepositoryInfo, Context) => Option[Link]): Unit = repositorySettingTabs += repositorySettingTab
|
||||||
repositorySettingTabs += repositorySettingTab
|
|
||||||
}
|
|
||||||
|
|
||||||
def getRepositorySettingTabs: Seq[(RepositoryInfo, Context) => Option[Link]] = repositorySettingTabs.toSeq
|
def getRepositorySettingTabs: Seq[(RepositoryInfo, Context) => Option[Link]] = repositorySettingTabs.toSeq
|
||||||
|
|
||||||
def addProfileTab(profileTab: (Account, Context) => Option[Link]): Unit = {
|
def addProfileTab(profileTab: (Account, Context) => Option[Link]): Unit = profileTabs += profileTab
|
||||||
profileTabs += profileTab
|
|
||||||
}
|
|
||||||
|
|
||||||
def getProfileTabs: Seq[(Account, Context) => Option[Link]] = profileTabs.toSeq
|
def getProfileTabs: Seq[(Account, Context) => Option[Link]] = profileTabs.toSeq
|
||||||
|
|
||||||
def addSystemSettingMenu(systemSettingMenu: (Context) => Option[Link]): Unit = {
|
def addSystemSettingMenu(systemSettingMenu: (Context) => Option[Link]): Unit = systemSettingMenus += systemSettingMenu
|
||||||
systemSettingMenus += systemSettingMenu
|
|
||||||
}
|
|
||||||
|
|
||||||
def getSystemSettingMenus: Seq[(Context) => Option[Link]] = systemSettingMenus.toSeq
|
def getSystemSettingMenus: Seq[(Context) => Option[Link]] = systemSettingMenus.toSeq
|
||||||
|
|
||||||
def addAccountSettingMenu(accountSettingMenu: (Context) => Option[Link]): Unit = {
|
def addAccountSettingMenu(accountSettingMenu: (Context) => Option[Link]): Unit = accountSettingMenus += accountSettingMenu
|
||||||
accountSettingMenus += accountSettingMenu
|
|
||||||
}
|
|
||||||
|
|
||||||
def getAccountSettingMenus: Seq[(Context) => Option[Link]] = accountSettingMenus.toSeq
|
def getAccountSettingMenus: Seq[(Context) => Option[Link]] = accountSettingMenus.toSeq
|
||||||
|
|
||||||
def addDashboardTab(dashboardTab: (Context) => Option[Link]): Unit = {
|
def addDashboardTab(dashboardTab: (Context) => Option[Link]): Unit = dashboardTabs += dashboardTab
|
||||||
dashboardTabs += dashboardTab
|
|
||||||
}
|
|
||||||
|
|
||||||
def getDashboardTabs: Seq[(Context) => Option[Link]] = dashboardTabs.toSeq
|
def getDashboardTabs: Seq[(Context) => Option[Link]] = dashboardTabs.toSeq
|
||||||
|
|
||||||
|
def addAssetsMapping(assetsMapping: (String, String, ClassLoader)): Unit = assetsMappings += assetsMapping
|
||||||
|
|
||||||
|
def getAssetsMappings: Seq[(String, String, ClassLoader)] = assetsMappings.toSeq
|
||||||
|
|
||||||
|
def addTextDecorator(textDecorator: TextDecorator): Unit = textDecorators += textDecorator
|
||||||
|
|
||||||
|
def getTextDecorators: Seq[TextDecorator] = textDecorators.toSeq
|
||||||
|
|
||||||
|
def addSuggestionProvider(suggestionProvider: SuggestionProvider): Unit = suggestionProviders += suggestionProvider
|
||||||
|
|
||||||
|
def getSuggestionProviders: Seq[SuggestionProvider] = suggestionProviders.toSeq
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -195,11 +176,11 @@ object PluginRegistry {
|
|||||||
// Initialize
|
// Initialize
|
||||||
plugin.initialize(instance, context, settings)
|
plugin.initialize(instance, context, settings)
|
||||||
instance.addPlugin(PluginInfo(
|
instance.addPlugin(PluginInfo(
|
||||||
pluginId = plugin.pluginId,
|
pluginId = plugin.pluginId,
|
||||||
pluginName = plugin.pluginName,
|
pluginName = plugin.pluginName,
|
||||||
version = plugin.versions.head.getVersion,
|
pluginVersion = plugin.versions.last.getVersion,
|
||||||
description = plugin.description,
|
description = plugin.description,
|
||||||
pluginClass = plugin
|
pluginClass = plugin
|
||||||
))
|
))
|
||||||
|
|
||||||
} catch {
|
} catch {
|
||||||
@@ -231,7 +212,7 @@ case class Link(id: String, label: String, path: String, icon: Option[String] =
|
|||||||
case class PluginInfo(
|
case class PluginInfo(
|
||||||
pluginId: String,
|
pluginId: String,
|
||||||
pluginName: String,
|
pluginName: String,
|
||||||
version: String,
|
pluginVersion: String,
|
||||||
description: String,
|
description: String,
|
||||||
pluginClass: Plugin
|
pluginClass: Plugin
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -0,0 +1,27 @@
|
|||||||
|
package gitbucket.core.plugin
|
||||||
|
|
||||||
|
import gitbucket.core.controller.Context
|
||||||
|
import gitbucket.core.service.RepositoryService.RepositoryInfo
|
||||||
|
|
||||||
|
trait SuggestionProvider {
|
||||||
|
|
||||||
|
val id: String
|
||||||
|
val prefix: String
|
||||||
|
val suffix: String = " "
|
||||||
|
val context: Seq[String]
|
||||||
|
|
||||||
|
def values(repository: RepositoryInfo): Seq[String]
|
||||||
|
def template(implicit context: Context): String = "value"
|
||||||
|
def additionalScript(implicit context: Context): String = ""
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class UserNameSuggestionProvider extends SuggestionProvider {
|
||||||
|
override val id: String = "user"
|
||||||
|
override val prefix: String = "@"
|
||||||
|
override val context: Seq[String] = Seq("issues")
|
||||||
|
override def values(repository: RepositoryInfo): Seq[String] = Nil
|
||||||
|
override def template(implicit context: Context): String = "'@' + value"
|
||||||
|
override def additionalScript(implicit context: Context): String =
|
||||||
|
s"""$$.get('${context.path}/_user/proposals', { query: '' }, function (data) { user = data.options; });"""
|
||||||
|
}
|
||||||
10
src/main/scala/gitbucket/core/plugin/TextDecorator.scala
Normal file
10
src/main/scala/gitbucket/core/plugin/TextDecorator.scala
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
package gitbucket.core.plugin
|
||||||
|
|
||||||
|
import gitbucket.core.controller.Context
|
||||||
|
import gitbucket.core.service.RepositoryService.RepositoryInfo
|
||||||
|
|
||||||
|
trait TextDecorator {
|
||||||
|
|
||||||
|
def decorate(text: String, repository: RepositoryInfo)(implicit context: Context): String
|
||||||
|
|
||||||
|
}
|
||||||
@@ -18,7 +18,7 @@ trait IssuesService {
|
|||||||
import IssuesService._
|
import IssuesService._
|
||||||
|
|
||||||
def getIssue(owner: String, repository: String, issueId: String)(implicit s: Session) =
|
def getIssue(owner: String, repository: String, issueId: String)(implicit s: Session) =
|
||||||
if (issueId forall (_.isDigit))
|
if (isInteger(issueId))
|
||||||
Issues filter (_.byPrimaryKey(owner, repository, issueId.toInt)) firstOption
|
Issues filter (_.byPrimaryKey(owner, repository, issueId.toInt)) firstOption
|
||||||
else None
|
else None
|
||||||
|
|
||||||
|
|||||||
@@ -36,7 +36,13 @@ trait RepositoryService { self: AccountService =>
|
|||||||
originUserName = originUserName,
|
originUserName = originUserName,
|
||||||
originRepositoryName = originRepositoryName,
|
originRepositoryName = originRepositoryName,
|
||||||
parentUserName = parentUserName,
|
parentUserName = parentUserName,
|
||||||
parentRepositoryName = parentRepositoryName)
|
parentRepositoryName = parentRepositoryName,
|
||||||
|
enableIssues = true,
|
||||||
|
externalIssuesUrl = None,
|
||||||
|
enableWiki = true,
|
||||||
|
allowWikiEditing = true,
|
||||||
|
externalWikiUrl = None
|
||||||
|
)
|
||||||
|
|
||||||
IssueId insert (userName, repositoryName, 0)
|
IssueId insert (userName, repositoryName, 0)
|
||||||
}
|
}
|
||||||
@@ -222,7 +228,7 @@ trait RepositoryService { self: AccountService =>
|
|||||||
* Include public repository, private own repository and private but collaborator repository.
|
* Include public repository, private own repository and private but collaborator repository.
|
||||||
*
|
*
|
||||||
* @param userName the user name of collaborator
|
* @param userName the user name of collaborator
|
||||||
* @return the repository infomation list
|
* @return the repository information list
|
||||||
*/
|
*/
|
||||||
def getAllRepositories(userName: String)(implicit s: Session): List[(String, String)] = {
|
def getAllRepositories(userName: String)(implicit s: Session): List[(String, String)] = {
|
||||||
Repositories.filter { t1 =>
|
Repositories.filter { t1 =>
|
||||||
@@ -313,10 +319,12 @@ trait RepositoryService { self: AccountService =>
|
|||||||
* Save repository options.
|
* Save repository options.
|
||||||
*/
|
*/
|
||||||
def saveRepositoryOptions(userName: String, repositoryName: String,
|
def saveRepositoryOptions(userName: String, repositoryName: String,
|
||||||
description: Option[String], isPrivate: Boolean)(implicit s: Session): Unit =
|
description: Option[String], isPrivate: Boolean,
|
||||||
|
enableIssues: Boolean, externalIssuesUrl: Option[String],
|
||||||
|
enableWiki: Boolean, allowWikiEditing: Boolean, externalWikiUrl: Option[String])(implicit s: Session): Unit =
|
||||||
Repositories.filter(_.byRepository(userName, repositoryName))
|
Repositories.filter(_.byRepository(userName, repositoryName))
|
||||||
.map { r => (r.description.?, r.isPrivate, r.updatedDate) }
|
.map { r => (r.description.?, r.isPrivate, r.enableIssues, r.externalIssuesUrl.?, r.enableWiki, r.allowWikiEditing, r.externalWikiUrl.?, r.updatedDate) }
|
||||||
.update (description, isPrivate, currentDate)
|
.update (description, isPrivate, enableIssues, externalIssuesUrl, enableWiki, allowWikiEditing, externalWikiUrl, currentDate)
|
||||||
|
|
||||||
def saveRepositoryDefaultBranch(userName: String, repositoryName: String,
|
def saveRepositoryDefaultBranch(userName: String, repositoryName: String,
|
||||||
defaultBranch: String)(implicit s: Session): Unit =
|
defaultBranch: String)(implicit s: Session): Unit =
|
||||||
@@ -412,6 +420,17 @@ object RepositoryService {
|
|||||||
|
|
||||||
def httpUrl(implicit context: Context): String = RepositoryService.httpUrl(owner, name)
|
def httpUrl(implicit context: Context): String = RepositoryService.httpUrl(owner, name)
|
||||||
def sshUrl(implicit context: Context): Option[String] = RepositoryService.sshUrl(owner, name)
|
def sshUrl(implicit context: Context): Option[String] = RepositoryService.sshUrl(owner, name)
|
||||||
|
|
||||||
|
def splitPath(path: String): (String, String) = {
|
||||||
|
val id = branchList.collectFirst {
|
||||||
|
case branch if(path == branch || path.startsWith(branch + "/")) => branch
|
||||||
|
} orElse tags.collectFirst {
|
||||||
|
case tag if(path == tag.name || path.startsWith(tag.name + "/")) => tag.name
|
||||||
|
} getOrElse path.split("/")(0)
|
||||||
|
|
||||||
|
(id, path.substring(id.length).stripPrefix("/"))
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
def httpUrl(owner: String, name: String)(implicit context: Context): String = s"${context.baseUrl}/git/${owner}/${name}.git"
|
def httpUrl(owner: String, name: String)(implicit context: Context): String = s"${context.baseUrl}/git/${owner}/${name}.git"
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
package gitbucket.core.service
|
package gitbucket.core.service
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream
|
|
||||||
import fr.brouillard.oss.security.xhub.XHub
|
import fr.brouillard.oss.security.xhub.XHub
|
||||||
import fr.brouillard.oss.security.xhub.XHub.{XHubDigest, XHubConverter}
|
import fr.brouillard.oss.security.xhub.XHub.{XHubDigest, XHubConverter}
|
||||||
import gitbucket.core.api._
|
import gitbucket.core.api._
|
||||||
@@ -22,6 +21,7 @@ import org.apache.http.HttpRequest
|
|||||||
import org.apache.http.HttpResponse
|
import org.apache.http.HttpResponse
|
||||||
import gitbucket.core.model.WebHookContentType
|
import gitbucket.core.model.WebHookContentType
|
||||||
import org.apache.http.client.entity.EntityBuilder
|
import org.apache.http.client.entity.EntityBuilder
|
||||||
|
import org.apache.http.entity.ContentType
|
||||||
|
|
||||||
|
|
||||||
trait WebHookService {
|
trait WebHookService {
|
||||||
@@ -118,8 +118,8 @@ trait WebHookService {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
case WebHookContentType.JSON => {
|
case WebHookContentType.JSON => {
|
||||||
httpPost.setEntity(EntityBuilder.create().setText(json).build())
|
httpPost.setEntity(EntityBuilder.create().setContentType(ContentType.APPLICATION_JSON).setText(json).build())
|
||||||
if (!webHook.token.isEmpty) {
|
if (webHook.token.exists(_.trim.nonEmpty)) {
|
||||||
httpPost.addHeader("X-Hub-Signature", XHub.generateHeaderXHubToken(XHubConverter.HEXA_LOWERCASE, XHubDigest.SHA1, webHook.token.orNull, json.getBytes("UTF-8")))
|
httpPost.addHeader("X-Hub-Signature", XHub.generateHeaderXHubToken(XHubConverter.HEXA_LOWERCASE, XHubDigest.SHA1, webHook.token.orNull, json.getBytes("UTF-8")))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,15 +4,14 @@ import javax.servlet._
|
|||||||
import javax.servlet.http.{HttpServletRequest, HttpServletResponse}
|
import javax.servlet.http.{HttpServletRequest, HttpServletResponse}
|
||||||
|
|
||||||
import gitbucket.core.model.Account
|
import gitbucket.core.model.Account
|
||||||
import gitbucket.core.service.AccessTokenService
|
import gitbucket.core.service.SystemSettingsService.SystemSettings
|
||||||
import gitbucket.core.util.Keys
|
import gitbucket.core.service.{AccessTokenService, AccountService, SystemSettingsService}
|
||||||
|
import gitbucket.core.util.{AuthUtil, Keys}
|
||||||
import org.scalatra.servlet.ServletApiImplicits._
|
import org.scalatra.servlet.ServletApiImplicits._
|
||||||
import org.scalatra._
|
import org.scalatra._
|
||||||
|
|
||||||
|
|
||||||
class AccessTokenAuthenticationFilter extends Filter with AccessTokenService {
|
class ApiAuthenticationFilter extends Filter with AccessTokenService with AccountService with SystemSettingsService {
|
||||||
private val tokenHeaderPrefix = "token "
|
|
||||||
|
|
||||||
override def init(filterConfig: FilterConfig): Unit = {}
|
override def init(filterConfig: FilterConfig): Unit = {}
|
||||||
|
|
||||||
@@ -23,9 +22,9 @@ class AccessTokenAuthenticationFilter extends Filter with AccessTokenService {
|
|||||||
implicit val session = req.getAttribute(Keys.Request.DBSession).asInstanceOf[slick.jdbc.JdbcBackend#Session]
|
implicit val session = req.getAttribute(Keys.Request.DBSession).asInstanceOf[slick.jdbc.JdbcBackend#Session]
|
||||||
val response = res.asInstanceOf[HttpServletResponse]
|
val response = res.asInstanceOf[HttpServletResponse]
|
||||||
Option(request.getHeader("Authorization")).map{
|
Option(request.getHeader("Authorization")).map{
|
||||||
case auth if auth.startsWith("token ") => AccessTokenService.getAccountByAccessToken(auth.substring(6).trim).toRight(Unit)
|
case auth if auth.startsWith("token ") => AccessTokenService.getAccountByAccessToken(auth.substring(6).trim).toRight(())
|
||||||
// TODO Basic Authentication Support
|
case auth if auth.startsWith("Basic ") => doBasicAuth(auth, loadSystemSettings(), request).toRight(())
|
||||||
case _ => Left(Unit)
|
case _ => Left(())
|
||||||
}.orElse{
|
}.orElse{
|
||||||
Option(request.getSession.getAttribute(Keys.Session.LoginAccount).asInstanceOf[Account]).map(Right(_))
|
Option(request.getSession.getAttribute(Keys.Session.LoginAccount).asInstanceOf[Account]).map(Right(_))
|
||||||
} match {
|
} match {
|
||||||
@@ -40,4 +39,10 @@ class AccessTokenAuthenticationFilter extends Filter with AccessTokenService {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def doBasicAuth(auth: String, settings: SystemSettings, request: HttpServletRequest): Option[Account] = {
|
||||||
|
implicit val session = request.getAttribute(Keys.Request.DBSession).asInstanceOf[slick.jdbc.JdbcBackend#Session]
|
||||||
|
val Array(username, password) = AuthUtil.decodeAuthHeader(auth).split(":", 2)
|
||||||
|
authenticate(settings, username, password)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@@ -5,16 +5,16 @@ import javax.servlet.http._
|
|||||||
import gitbucket.core.plugin.{GitRepositoryFilter, GitRepositoryRouting, PluginRegistry}
|
import gitbucket.core.plugin.{GitRepositoryFilter, GitRepositoryRouting, PluginRegistry}
|
||||||
import gitbucket.core.service.SystemSettingsService.SystemSettings
|
import gitbucket.core.service.SystemSettingsService.SystemSettings
|
||||||
import gitbucket.core.service.{RepositoryService, AccountService, SystemSettingsService}
|
import gitbucket.core.service.{RepositoryService, AccountService, SystemSettingsService}
|
||||||
import gitbucket.core.util.{Keys, Implicits}
|
import gitbucket.core.util.{Keys, Implicits, AuthUtil}
|
||||||
import org.slf4j.LoggerFactory
|
import org.slf4j.LoggerFactory
|
||||||
import Implicits._
|
import Implicits._
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides BASIC Authentication for [[GitRepositoryServlet]].
|
* Provides BASIC Authentication for [[GitRepositoryServlet]].
|
||||||
*/
|
*/
|
||||||
class BasicAuthenticationFilter extends Filter with RepositoryService with AccountService with SystemSettingsService {
|
class GitAuthenticationFilter extends Filter with RepositoryService with AccountService with SystemSettingsService {
|
||||||
|
|
||||||
private val logger = LoggerFactory.getLogger(classOf[BasicAuthenticationFilter])
|
private val logger = LoggerFactory.getLogger(classOf[GitAuthenticationFilter])
|
||||||
|
|
||||||
def init(config: FilterConfig) = {}
|
def init(config: FilterConfig) = {}
|
||||||
|
|
||||||
@@ -43,7 +43,7 @@ class BasicAuthenticationFilter extends Filter with RepositoryService with Accou
|
|||||||
} catch {
|
} catch {
|
||||||
case ex: Exception => {
|
case ex: Exception => {
|
||||||
logger.error("error", ex)
|
logger.error("error", ex)
|
||||||
requireAuth(response)
|
AuthUtil.requireAuth(response)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -54,7 +54,7 @@ class BasicAuthenticationFilter extends Filter with RepositoryService with Accou
|
|||||||
|
|
||||||
val account = for {
|
val account = for {
|
||||||
auth <- Option(request.getHeader("Authorization"))
|
auth <- Option(request.getHeader("Authorization"))
|
||||||
Array(username, password) = decodeAuthHeader(auth).split(":", 2)
|
Array(username, password) = AuthUtil.decodeAuthHeader(auth).split(":", 2)
|
||||||
account <- authenticate(settings, username, password)
|
account <- authenticate(settings, username, password)
|
||||||
} yield {
|
} yield {
|
||||||
request.setAttribute(Keys.Request.UserName, account.userName)
|
request.setAttribute(Keys.Request.UserName, account.userName)
|
||||||
@@ -64,7 +64,7 @@ class BasicAuthenticationFilter extends Filter with RepositoryService with Accou
|
|||||||
if(filter.filter(request.gitRepositoryPath, account.map(_.userName), settings, isUpdating)){
|
if(filter.filter(request.gitRepositoryPath, account.map(_.userName), settings, isUpdating)){
|
||||||
chain.doFilter(request, response)
|
chain.doFilter(request, response)
|
||||||
} else {
|
} else {
|
||||||
requireAuth(response)
|
AuthUtil.requireAuth(response)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -81,7 +81,7 @@ class BasicAuthenticationFilter extends Filter with RepositoryService with Accou
|
|||||||
} else {
|
} else {
|
||||||
val passed = for {
|
val passed = for {
|
||||||
auth <- Option(request.getHeader("Authorization"))
|
auth <- Option(request.getHeader("Authorization"))
|
||||||
Array(username, password) = decodeAuthHeader(auth).split(":", 2)
|
Array(username, password) = AuthUtil.decodeAuthHeader(auth).split(":", 2)
|
||||||
account <- authenticate(settings, username, password)
|
account <- authenticate(settings, username, password)
|
||||||
} yield if(isUpdating || repository.repository.isPrivate){
|
} yield if(isUpdating || repository.repository.isPrivate){
|
||||||
if(hasWritePermission(repository.owner, repository.name, Some(account))){
|
if(hasWritePermission(repository.owner, repository.name, Some(account))){
|
||||||
@@ -93,7 +93,7 @@ class BasicAuthenticationFilter extends Filter with RepositoryService with Accou
|
|||||||
if(passed.getOrElse(false)){
|
if(passed.getOrElse(false)){
|
||||||
chain.doFilter(request, response)
|
chain.doFilter(request, response)
|
||||||
} else {
|
} else {
|
||||||
requireAuth(response)
|
AuthUtil.requireAuth(response)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -108,17 +108,4 @@ class BasicAuthenticationFilter extends Filter with RepositoryService with Accou
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private def requireAuth(response: HttpServletResponse): Unit = {
|
|
||||||
response.setHeader("WWW-Authenticate", "BASIC realm=\"GitBucket\"")
|
|
||||||
response.sendError(HttpServletResponse.SC_UNAUTHORIZED)
|
|
||||||
}
|
|
||||||
|
|
||||||
private def decodeAuthHeader(header: String): String = {
|
|
||||||
try {
|
|
||||||
new String(new sun.misc.BASE64Decoder().decodeBuffer(header.substring(6)))
|
|
||||||
} catch {
|
|
||||||
case _: Throwable => ""
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
@@ -27,7 +27,7 @@ import javax.servlet.http.{HttpServletResponse, HttpServletRequest}
|
|||||||
* Provides Git repository via HTTP.
|
* Provides Git repository via HTTP.
|
||||||
*
|
*
|
||||||
* This servlet provides only Git repository functionality.
|
* This servlet provides only Git repository functionality.
|
||||||
* Authentication is provided by [[BasicAuthenticationFilter]].
|
* Authentication is provided by [[GitAuthenticationFilter]].
|
||||||
*/
|
*/
|
||||||
class GitRepositoryServlet extends GitServlet with SystemSettingsService {
|
class GitRepositoryServlet extends GitServlet with SystemSettingsService {
|
||||||
|
|
||||||
|
|||||||
@@ -35,6 +35,7 @@ class InitializeListener extends ServletContextListener with SystemSettingsServi
|
|||||||
|
|
||||||
Database() withTransaction { session =>
|
Database() withTransaction { session =>
|
||||||
val conn = session.conn
|
val conn = session.conn
|
||||||
|
val manager = new JDBCVersionManager(conn)
|
||||||
|
|
||||||
// Check version
|
// Check version
|
||||||
val versionFile = new File(GitBucketHome, "version")
|
val versionFile = new File(GitBucketHome, "version")
|
||||||
@@ -56,9 +57,8 @@ class InitializeListener extends ServletContextListener with SystemSettingsServi
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Change form
|
// Change form
|
||||||
val manager = new JDBCVersionManager(conn)
|
|
||||||
manager.initialize()
|
manager.initialize()
|
||||||
manager.updateVersion(GitBucketCoreModule.getModuleId, "4.0")
|
manager.updateVersion(GitBucketCoreModule.getModuleId, "4.0.0")
|
||||||
conn.select("SELECT PLUGIN_ID, VERSION FROM PLUGIN"){ rs =>
|
conn.select("SELECT PLUGIN_ID, VERSION FROM PLUGIN"){ rs =>
|
||||||
manager.updateVersion(rs.getString("PLUGIN_ID"), rs.getString("VERSION"))
|
manager.updateVersion(rs.getString("PLUGIN_ID"), rs.getString("VERSION"))
|
||||||
}
|
}
|
||||||
@@ -77,6 +77,13 @@ class InitializeListener extends ServletContextListener with SystemSettingsServi
|
|||||||
val solidbase = new Solidbase()
|
val solidbase = new Solidbase()
|
||||||
solidbase.migrate(conn, Thread.currentThread.getContextClassLoader, DatabaseConfig.liquiDriver, GitBucketCoreModule)
|
solidbase.migrate(conn, Thread.currentThread.getContextClassLoader, DatabaseConfig.liquiDriver, GitBucketCoreModule)
|
||||||
|
|
||||||
|
// Rescue code for users who updated from 3.14 to 4.0.0
|
||||||
|
// https://github.com/gitbucket/gitbucket/issues/1227
|
||||||
|
val currentVersion = manager.getCurrentVersion(GitBucketCoreModule.getModuleId)
|
||||||
|
if(currentVersion == "4.0"){
|
||||||
|
manager.updateVersion(GitBucketCoreModule.getModuleId, "4.0.0")
|
||||||
|
}
|
||||||
|
|
||||||
// Load plugins
|
// Load plugins
|
||||||
logger.info("Initialize plugins")
|
logger.info("Initialize plugins")
|
||||||
PluginRegistry.initialize(event.getServletContext, loadSystemSettings(), conn)
|
PluginRegistry.initialize(event.getServletContext, loadSystemSettings(), conn)
|
||||||
|
|||||||
@@ -0,0 +1,39 @@
|
|||||||
|
package gitbucket.core.servlet
|
||||||
|
|
||||||
|
import javax.servlet.http.{HttpServlet, HttpServletRequest, HttpServletResponse}
|
||||||
|
|
||||||
|
import gitbucket.core.plugin.PluginRegistry
|
||||||
|
import gitbucket.core.util.FileUtil
|
||||||
|
import org.apache.commons.io.IOUtils
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Supply assets which are provided by plugins.
|
||||||
|
*/
|
||||||
|
class PluginAssetsServlet extends HttpServlet {
|
||||||
|
|
||||||
|
override def doGet(req: HttpServletRequest, resp: HttpServletResponse): Unit = {
|
||||||
|
val assetsMappings = PluginRegistry().getAssetsMappings
|
||||||
|
val path = req.getRequestURI.substring(req.getContextPath.length)
|
||||||
|
|
||||||
|
assetsMappings
|
||||||
|
.find { case (prefix, _, _) => path.startsWith("/plugin-assets" + prefix) }
|
||||||
|
.flatMap { case (prefix, resourcePath, classLoader) =>
|
||||||
|
val resourceName = path.substring(("/plugin-assets" + prefix).length)
|
||||||
|
Option(classLoader.getResourceAsStream(resourcePath.replaceFirst("^/", "") + resourceName))
|
||||||
|
}
|
||||||
|
.map { in =>
|
||||||
|
try {
|
||||||
|
val bytes = IOUtils.toByteArray(in)
|
||||||
|
resp.setContentLength(bytes.length)
|
||||||
|
resp.setContentType(FileUtil.getContentType(path, bytes))
|
||||||
|
resp.getOutputStream.write(bytes)
|
||||||
|
} finally {
|
||||||
|
in.close()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.getOrElse {
|
||||||
|
resp.setStatus(404)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
21
src/main/scala/gitbucket/core/util/AuthUtil.scala
Normal file
21
src/main/scala/gitbucket/core/util/AuthUtil.scala
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
package gitbucket.core.util
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletResponse
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provides HTTP (Basic) Authentication related functions.
|
||||||
|
*/
|
||||||
|
object AuthUtil {
|
||||||
|
def requireAuth(response: HttpServletResponse): Unit = {
|
||||||
|
response.setHeader("WWW-Authenticate", "BASIC realm=\"GitBucket\"")
|
||||||
|
response.sendError(HttpServletResponse.SC_UNAUTHORIZED)
|
||||||
|
}
|
||||||
|
|
||||||
|
def decodeAuthHeader(header: String): String = {
|
||||||
|
try {
|
||||||
|
new String(new sun.misc.BASE64Decoder().decodeBuffer(header.substring(6)))
|
||||||
|
} catch {
|
||||||
|
case _: Throwable => ""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -4,6 +4,8 @@ import gitbucket.core.api.JsonFormat
|
|||||||
import gitbucket.core.controller.Context
|
import gitbucket.core.controller.Context
|
||||||
import gitbucket.core.servlet.Database
|
import gitbucket.core.servlet.Database
|
||||||
|
|
||||||
|
import java.util.regex.Pattern.quote
|
||||||
|
|
||||||
import javax.servlet.http.{HttpSession, HttpServletRequest}
|
import javax.servlet.http.{HttpSession, HttpServletRequest}
|
||||||
|
|
||||||
import scala.util.matching.Regex
|
import scala.util.matching.Regex
|
||||||
@@ -73,7 +75,7 @@ object Implicits {
|
|||||||
|
|
||||||
def hasAttribute(name: String): Boolean = request.getAttribute(name) != null
|
def hasAttribute(name: String): Boolean = request.getAttribute(name) != null
|
||||||
|
|
||||||
def gitRepositoryPath: String = request.getRequestURI.replaceFirst("^/git/", "/")
|
def gitRepositoryPath: String = request.getRequestURI.replaceFirst("^" + quote(request.getContextPath) + "/git/", "/")
|
||||||
|
|
||||||
def baseUrl:String = {
|
def baseUrl:String = {
|
||||||
val url = request.getRequestURL.toString
|
val url = request.getRequestURL.toString
|
||||||
|
|||||||
@@ -84,26 +84,7 @@ class Mailer(private val smtp: Smtp) extends Notifier {
|
|||||||
enableLineBreaks = false
|
enableLineBreaks = false
|
||||||
))) { case (subject, msg) =>
|
))) { case (subject, msg) =>
|
||||||
recipients(issue) { to =>
|
recipients(issue) { to =>
|
||||||
val email = new HtmlEmail
|
send(to, subject, msg)
|
||||||
email.setHostName(smtp.host)
|
|
||||||
email.setSmtpPort(smtp.port.get)
|
|
||||||
smtp.user.foreach { user =>
|
|
||||||
email.setAuthenticator(new DefaultAuthenticator(user, smtp.password.getOrElse("")))
|
|
||||||
}
|
|
||||||
smtp.ssl.foreach { ssl =>
|
|
||||||
email.setSSLOnConnect(ssl)
|
|
||||||
}
|
|
||||||
smtp.fromAddress
|
|
||||||
.map (_ -> smtp.fromName.getOrElse(context.loginAccount.get.userName))
|
|
||||||
.orElse (Some("notifications@gitbucket.com" -> context.loginAccount.get.userName))
|
|
||||||
.foreach { case (address, name) =>
|
|
||||||
email.setFrom(address, name)
|
|
||||||
}
|
|
||||||
email.setCharset("UTF-8")
|
|
||||||
email.setSubject(subject)
|
|
||||||
email.setHtmlMsg(msg)
|
|
||||||
|
|
||||||
email.addTo(to).send
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -116,6 +97,30 @@ class Mailer(private val smtp: Smtp) extends Notifier {
|
|||||||
case t => logger.error("Notifications Failed.", t)
|
case t => logger.error("Notifications Failed.", t)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def send(to: String, subject: String, msg: String)(implicit context: Context): Unit = {
|
||||||
|
val email = new HtmlEmail
|
||||||
|
email.setHostName(smtp.host)
|
||||||
|
email.setSmtpPort(smtp.port.get)
|
||||||
|
smtp.user.foreach { user =>
|
||||||
|
email.setAuthenticator(new DefaultAuthenticator(user, smtp.password.getOrElse("")))
|
||||||
|
}
|
||||||
|
smtp.ssl.foreach { ssl =>
|
||||||
|
email.setSSLOnConnect(ssl)
|
||||||
|
}
|
||||||
|
smtp.fromAddress
|
||||||
|
.map (_ -> smtp.fromName.getOrElse(context.loginAccount.get.userName))
|
||||||
|
.orElse (Some("notifications@gitbucket.com" -> context.loginAccount.get.userName))
|
||||||
|
.foreach { case (address, name) =>
|
||||||
|
email.setFrom(address, name)
|
||||||
|
}
|
||||||
|
email.setCharset("UTF-8")
|
||||||
|
email.setSubject(subject)
|
||||||
|
email.setHtmlMsg(msg)
|
||||||
|
|
||||||
|
email.addTo(to).send
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
class MockMailer extends Notifier {
|
class MockMailer extends Notifier {
|
||||||
def toNotify(r: RepositoryService.RepositoryInfo, issue: Issue, content: String)
|
def toNotify(r: RepositoryService.RepositoryInfo, issue: Issue, content: String)
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ import org.mozilla.universalchardet.UniversalDetector
|
|||||||
import ControlUtil._
|
import ControlUtil._
|
||||||
import org.apache.commons.io.input.BOMInputStream
|
import org.apache.commons.io.input.BOMInputStream
|
||||||
import org.apache.commons.io.IOUtils
|
import org.apache.commons.io.IOUtils
|
||||||
|
import scala.util.control.Exception._
|
||||||
|
|
||||||
object StringUtil {
|
object StringUtil {
|
||||||
|
|
||||||
@@ -26,6 +27,8 @@ object StringUtil {
|
|||||||
|
|
||||||
def splitWords(value: String): Array[String] = value.split("[ \\t ]+")
|
def splitWords(value: String): Array[String] = value.split("[ \\t ]+")
|
||||||
|
|
||||||
|
def isInteger(value: String): Boolean = allCatch opt { value.toInt } map(_ => true) getOrElse(false)
|
||||||
|
|
||||||
def escapeHtml(value: String): String =
|
def escapeHtml(value: String): String =
|
||||||
value.replace("&", "&").replace("<", "<").replace(">", ">").replace("\"", """)
|
value.replace("&", "&").replace("<", "<").replace(">", ">").replace("\"", """)
|
||||||
|
|
||||||
|
|||||||
@@ -44,7 +44,7 @@ object Markdown {
|
|||||||
val renderer = new GitBucketMarkedRenderer(options, repository,
|
val renderer = new GitBucketMarkedRenderer(options, repository,
|
||||||
enableWikiLink, enableRefsLink, enableAnchor, enableTaskList, hasWritePermission, pages)
|
enableWikiLink, enableRefsLink, enableAnchor, enableTaskList, hasWritePermission, pages)
|
||||||
|
|
||||||
Marked.marked(source, options, renderer)
|
helpers.decorateHtml(Marked.marked(source, options, renderer), repository)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -5,10 +5,10 @@ import java.util.{Date, Locale, TimeZone}
|
|||||||
|
|
||||||
import gitbucket.core.controller.Context
|
import gitbucket.core.controller.Context
|
||||||
import gitbucket.core.model.CommitState
|
import gitbucket.core.model.CommitState
|
||||||
import gitbucket.core.plugin.{RenderRequest, PluginRegistry}
|
import gitbucket.core.plugin.{PluginRegistry, RenderRequest}
|
||||||
|
import gitbucket.core.service.RepositoryService.RepositoryInfo
|
||||||
import gitbucket.core.service.{RepositoryService, RequestCache}
|
import gitbucket.core.service.{RepositoryService, RequestCache}
|
||||||
import gitbucket.core.util.{FileUtil, JGitUtil, StringUtil}
|
import gitbucket.core.util.{FileUtil, JGitUtil, StringUtil}
|
||||||
|
|
||||||
import play.twirl.api.{Html, HtmlFormat}
|
import play.twirl.api.{Html, HtmlFormat}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -151,7 +151,7 @@ object helpers extends AvatarImageProvider with LinkConverter with RequestCache
|
|||||||
* Converts commit id, issue id and username to the link.
|
* Converts commit id, issue id and username to the link.
|
||||||
*/
|
*/
|
||||||
def link(value: String, repository: RepositoryService.RepositoryInfo)(implicit context: Context): Html =
|
def link(value: String, repository: RepositoryService.RepositoryInfo)(implicit context: Context): Html =
|
||||||
Html(convertRefsLinks(value, repository))
|
Html(decorateHtml(convertRefsLinks(value, repository), repository))
|
||||||
|
|
||||||
def cut(value: String, length: Int): String =
|
def cut(value: String, length: Int): String =
|
||||||
if(value.length > length){
|
if(value.length > length){
|
||||||
@@ -222,8 +222,14 @@ object helpers extends AvatarImageProvider with LinkConverter with RequestCache
|
|||||||
* Generates the avatar link to the account page.
|
* Generates the avatar link to the account page.
|
||||||
* If user does not exist or disabled, this method returns avatar image without link.
|
* If user does not exist or disabled, this method returns avatar image without link.
|
||||||
*/
|
*/
|
||||||
def avatarLink(userName: String, size: Int, mailAddress: String = "", tooltip: Boolean = false)(implicit context: Context): Html =
|
def avatarLink(userName: String, size: Int, mailAddress: String = "", tooltip: Boolean = false, label: Boolean = false)
|
||||||
userWithContent(userName, mailAddress)(avatar(userName, size, tooltip, mailAddress))
|
(implicit context: Context): Html = {
|
||||||
|
|
||||||
|
val avatarHtml = avatar(userName, size, tooltip, mailAddress)
|
||||||
|
val contentHtml = if(label == true) Html(avatarHtml.body + " " + userName) else avatarHtml
|
||||||
|
|
||||||
|
userWithContent(userName, mailAddress)(contentHtml)
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Generates the avatar link to the account page.
|
* Generates the avatar link to the account page.
|
||||||
@@ -232,7 +238,8 @@ object helpers extends AvatarImageProvider with LinkConverter with RequestCache
|
|||||||
def avatarLink(commit: JGitUtil.CommitInfo, size: Int)(implicit context: Context): Html =
|
def avatarLink(commit: JGitUtil.CommitInfo, size: Int)(implicit context: Context): Html =
|
||||||
userWithContent(commit.authorName, commit.authorEmailAddress)(avatar(commit, size))
|
userWithContent(commit.authorName, commit.authorEmailAddress)(avatar(commit, size))
|
||||||
|
|
||||||
private def userWithContent(userName: String, mailAddress: String = "", styleClass: String = "")(content: Html)(implicit context: Context): Html =
|
private def userWithContent(userName: String, mailAddress: String = "", styleClass: String = "")(content: Html)
|
||||||
|
(implicit context: Context): Html =
|
||||||
(if(mailAddress.isEmpty){
|
(if(mailAddress.isEmpty){
|
||||||
getAccountByUserName(userName)
|
getAccountByUserName(userName)
|
||||||
} else {
|
} else {
|
||||||
@@ -309,10 +316,18 @@ object helpers extends AvatarImageProvider with LinkConverter with RequestCache
|
|||||||
case CommitState.FAILURE => "Failed"
|
case CommitState.FAILURE => "Failed"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Render a given object as the JSON string.
|
||||||
|
*/
|
||||||
|
def json(obj: AnyRef): String = {
|
||||||
|
implicit val formats = org.json4s.DefaultFormats
|
||||||
|
org.json4s.jackson.Serialization.write(obj)
|
||||||
|
}
|
||||||
|
|
||||||
// This pattern comes from: http://stackoverflow.com/a/4390768/1771641 (extract-url-from-string)
|
// This pattern comes from: http://stackoverflow.com/a/4390768/1771641 (extract-url-from-string)
|
||||||
private[this] val detectAndRenderLinksRegex = """(?i)\b((?:https?://|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,13}/)(?:[^\s()<>]+|\(([^\s()<>]+|(\([^\s()<>]+\)))*\))+(?:\(([^\s()<>]+|(\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:'".,<>?«»“”‘’]))""".r
|
private[this] val detectAndRenderLinksRegex = """(?i)\b((?:https?://|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,13}/)(?:[^\s()<>]+|\(([^\s()<>]+|(\([^\s()<>]+\)))*\))+(?:\(([^\s()<>]+|(\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:'".,<>?«»“”‘’]))""".r
|
||||||
|
|
||||||
def detectAndRenderLinks(text: String): Html = {
|
def detectAndRenderLinks(text: String, repository: RepositoryInfo)(implicit context: Context): String = {
|
||||||
val matches = detectAndRenderLinksRegex.findAllMatchIn(text).toSeq
|
val matches = detectAndRenderLinksRegex.findAllMatchIn(text).toSeq
|
||||||
|
|
||||||
val (x, pos) = matches.foldLeft((collection.immutable.Seq.empty[Html], 0)){ case ((x, pos), m) =>
|
val (x, pos) = matches.foldLeft((collection.immutable.Seq.empty[Html], 0)){ case ((x, pos), m) =>
|
||||||
@@ -326,6 +341,43 @@ object helpers extends AvatarImageProvider with LinkConverter with RequestCache
|
|||||||
// append rest fragment
|
// append rest fragment
|
||||||
val out = if (pos < text.length) x :+ HtmlFormat.escape(text.substring(pos)) else x
|
val out = if (pos < text.length) x :+ HtmlFormat.escape(text.substring(pos)) else x
|
||||||
|
|
||||||
HtmlFormat.fill(out)
|
decorateHtml(HtmlFormat.fill(out).toString, repository)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def decorateHtml(html: String, repository: RepositoryInfo)(implicit context: Context): String = {
|
||||||
|
PluginRegistry().getTextDecorators.foldLeft(html){ case (html, decorator) =>
|
||||||
|
val text = new StringBuilder()
|
||||||
|
val result = new StringBuilder()
|
||||||
|
var tag = false
|
||||||
|
|
||||||
|
html.foreach { c =>
|
||||||
|
c match {
|
||||||
|
case '<' if tag == false => {
|
||||||
|
tag = true
|
||||||
|
if(text.nonEmpty){
|
||||||
|
result.append(decorator.decorate(text.toString, repository))
|
||||||
|
text.setLength(0)
|
||||||
|
}
|
||||||
|
result.append(c)
|
||||||
|
}
|
||||||
|
case '>' if tag == true => {
|
||||||
|
tag = false
|
||||||
|
result.append(c)
|
||||||
|
}
|
||||||
|
case _ if tag == false => {
|
||||||
|
text.append(c)
|
||||||
|
}
|
||||||
|
case _ if tag == true => {
|
||||||
|
result.append(c)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(text.nonEmpty){
|
||||||
|
result.append(decorator.decorate(text.toString, repository))
|
||||||
|
}
|
||||||
|
|
||||||
|
result.toString
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,11 +1,10 @@
|
|||||||
@(account: gitbucket.core.model.Account,
|
@(account: gitbucket.core.model.Account,
|
||||||
groupNames: List[String],
|
groupNames: List[String],
|
||||||
activities: List[gitbucket.core.model.Activity])(implicit context: gitbucket.core.controller.Context)
|
activities: List[gitbucket.core.model.Activity])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.account.html.main(account, groupNames, "activity"){
|
||||||
@main(account, groupNames, "activity"){
|
|
||||||
<div class="pull-right">
|
<div class="pull-right">
|
||||||
<a href="@path/@{account.userName}.atom"><img src="@assets/common/images/feed.png" alt="activities"></a>
|
<a href="@context.path/@{account.userName}.atom"><img src="@{helpers.assets}/common/images/feed.png" alt="activities"></a>
|
||||||
</div>
|
</div>
|
||||||
@helper.html.activities(activities)
|
@gitbucket.core.helper.html.activities(activities)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,11 +1,9 @@
|
|||||||
@(account: gitbucket.core.model.Account,
|
@(account: gitbucket.core.model.Account,
|
||||||
personalTokens: List[gitbucket.core.model.AccessToken],
|
personalTokens: List[gitbucket.core.model.AccessToken],
|
||||||
gneratedToken: Option[(gitbucket.core.model.AccessToken, String)])(implicit context: gitbucket.core.controller.Context)
|
gneratedToken: Option[(gitbucket.core.model.AccessToken, String)])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@gitbucket.core.html.main("Applications"){
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
@html.main("Applications"){
|
|
||||||
<div class="container body">
|
<div class="container body">
|
||||||
@menu("application", settings.ssh){
|
@gitbucket.core.account.html.menu("application", context.settings.ssh){
|
||||||
<div class="panel panel-default">
|
<div class="panel panel-default">
|
||||||
<div class="panel-heading strong">Personal access tokens</div>
|
<div class="panel-heading strong">Personal access tokens</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
@@ -15,13 +13,13 @@
|
|||||||
Tokens you have generated that can be used to access the GitBucket API.
|
Tokens you have generated that can be used to access the GitBucket API.
|
||||||
<hr style="margin-top: 10px;">
|
<hr style="margin-top: 10px;">
|
||||||
}
|
}
|
||||||
@gneratedToken.map{ case (token, tokenString) =>
|
@gneratedToken.map { case (token, tokenString) =>
|
||||||
<div class="alert alert-info">
|
<div class="alert alert-info">
|
||||||
Make sure to copy your new personal access token now. You won't be able to see it again!
|
Make sure to copy your new personal access token now. You won't be able to see it again!
|
||||||
</div>
|
</div>
|
||||||
<a href="@path/@account.userName/_personalToken/delete/@token.accessTokenId" class="btn btn-sm btn-danger pull-right">Delete</a>
|
<a href="@context.path/@account.userName/_personalToken/delete/@token.accessTokenId" class="btn btn-sm btn-danger pull-right">Delete</a>
|
||||||
<div style="width: 50%;">
|
<div style="width: 50%;">
|
||||||
@helper.html.copy("generated-token-copy", tokenString){
|
@gitbucket.core.helper.html.copy("generated-token-copy", tokenString){
|
||||||
<input type="text" value="@tokenString" class="form-control input-sm" readonly>
|
<input type="text" value="@tokenString" class="form-control input-sm" readonly>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
@@ -32,11 +30,11 @@
|
|||||||
<hr>
|
<hr>
|
||||||
}
|
}
|
||||||
<strong style="line-height: 30px;">@token.note</strong>
|
<strong style="line-height: 30px;">@token.note</strong>
|
||||||
<a href="@path/@account.userName/_personalToken/delete/@token.accessTokenId" class="btn btn-sm btn-danger pull-right">Delete</a>
|
<a href="@context.path/@account.userName/_personalToken/delete/@token.accessTokenId" class="btn btn-sm btn-danger pull-right">Delete</a>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<form method="POST" action="@path/@account.userName/_personalToken" validate="true">
|
<form method="POST" action="@context.path/@account.userName/_personalToken" validate="true">
|
||||||
<div class="panel panel-default">
|
<div class="panel panel-default">
|
||||||
<div class="panel-heading strong">Generate new token</div>
|
<div class="panel-heading strong">Generate new token</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
|
|||||||
@@ -1,14 +1,13 @@
|
|||||||
@(account: gitbucket.core.model.Account, info: Option[Any], error: Option[Any])(implicit context: gitbucket.core.controller.Context)
|
@(account: gitbucket.core.model.Account, info: Option[Any], error: Option[Any])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import gitbucket.core.util.LDAPUtil
|
@import gitbucket.core.util.LDAPUtil
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.html.main("Edit your profile"){
|
||||||
@html.main("Edit your profile"){
|
|
||||||
<div class="container body">
|
<div class="container body">
|
||||||
@menu("profile", settings.ssh){
|
@gitbucket.core.account.html.menu("profile", context.settings.ssh){
|
||||||
@helper.html.information(info)
|
@gitbucket.core.helper.html.information(info)
|
||||||
@helper.html.error(error)
|
@gitbucket.core.helper.html.error(error)
|
||||||
@if(LDAPUtil.isDummyMailAddress(account)){<div class="alert alert-danger">Please register your mail address.</div>}
|
@if(LDAPUtil.isDummyMailAddress(account)){<div class="alert alert-danger">Please register your mail address.</div>}
|
||||||
<form action="@url(account.userName)/_edit" method="POST" validate="true">
|
<form action="@helpers.url(account.userName)/_edit" method="POST" validate="true">
|
||||||
<div class="panel panel-default">
|
<div class="panel panel-default">
|
||||||
<div class="panel-heading strong">Profile</div>
|
<div class="panel-heading strong">Profile</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
@@ -42,7 +41,7 @@
|
|||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
<fieldset class="form-group">
|
<fieldset class="form-group">
|
||||||
<label for="avatar" class="strong">Image (optional):</label>
|
<label for="avatar" class="strong">Image (optional):</label>
|
||||||
@helper.html.uploadavatar(Some(account))
|
@gitbucket.core.helper.html.uploadavatar(Some(account))
|
||||||
</fieldset>
|
</fieldset>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -50,10 +49,10 @@
|
|||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
<div class="pull-right">
|
<div class="pull-right">
|
||||||
<a href="@path/@account.userName/_delete" class="btn btn-danger" id="delete">Delete account</a>
|
<a href="@context.path/@account.userName/_delete" class="btn btn-danger" id="delete">Delete account</a>
|
||||||
</div>
|
</div>
|
||||||
<input type="submit" class="btn btn-success" value="Save"/>
|
<input type="submit" class="btn btn-success" value="Save"/>
|
||||||
@if(!LDAPUtil.isDummyMailAddress(account)){<a href="@url(account.userName)" class="btn btn-default">Cancel</a>}
|
@if(!LDAPUtil.isDummyMailAddress(account)){<a href="@helpers.url(account.userName)" class="btn btn-default">Cancel</a>}
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,9 +1,10 @@
|
|||||||
@(account: Option[gitbucket.core.model.Account], members: List[gitbucket.core.model.GroupMember])(implicit context: gitbucket.core.controller.Context)
|
@(account: Option[gitbucket.core.model.Account], members: List[gitbucket.core.model.GroupMember])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.html.main(if(account.isEmpty) "Create group" else "Edit group"){
|
||||||
@html.main(if(account.isEmpty) "Create group" else "Edit group"){
|
<div class="content-wrapper main-center">
|
||||||
<div class="body main-center">
|
<div class="content body">
|
||||||
<form id="form" method="post" action="@if(account.isEmpty){@path/groups/new} else {@path/@account.get.userName/_editgroup}" validate="true">
|
<h2>@{if(account.isEmpty) "Create group" else "Edit group"}</h2>
|
||||||
|
<form id="form" method="post" action="@if(account.isEmpty){@context.path/groups/new} else {@context.path/@account.get.userName/_editgroup}" validate="true">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-5">
|
<div class="col-md-5">
|
||||||
<fieldset class="form-group">
|
<fieldset class="form-group">
|
||||||
@@ -22,7 +23,7 @@
|
|||||||
</fieldset>
|
</fieldset>
|
||||||
<fieldset class="form-group">
|
<fieldset class="form-group">
|
||||||
<label for="avatar" class="strong">Image (Optional)</label>
|
<label for="avatar" class="strong">Image (Optional)</label>
|
||||||
@helper.html.uploadavatar(account)
|
@gitbucket.core.helper.html.uploadavatar(account)
|
||||||
</fieldset>
|
</fieldset>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-7">
|
<div class="col-md-7">
|
||||||
@@ -30,7 +31,7 @@
|
|||||||
<label class="strong">Members</label>
|
<label class="strong">Members</label>
|
||||||
<ul id="member-list" class="collaborator">
|
<ul id="member-list" class="collaborator">
|
||||||
</ul>
|
</ul>
|
||||||
@helper.html.account("memberName", 200)
|
@gitbucket.core.helper.html.account("memberName", 200)
|
||||||
<input type="button" class="btn btn-default" value="Add" id="addMember"/>
|
<input type="button" class="btn btn-default" value="Add" id="addMember"/>
|
||||||
<input type="hidden" id="members" name="members" value="@members.map(member => member.userName + ":" + member.isManager).mkString(",")"/>
|
<input type="hidden" id="members" name="members" value="@members.map(member => member.userName + ":" + member.isManager).mkString(",")"/>
|
||||||
<div>
|
<div>
|
||||||
@@ -39,18 +40,19 @@
|
|||||||
</fieldset>
|
</fieldset>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<fieldset class="margin">
|
<fieldset class="border-top">
|
||||||
@if(account.isDefined){
|
@if(account.isDefined){
|
||||||
<div class="pull-right">
|
<div class="pull-right">
|
||||||
<a href="@url(account.get.userName)/_deletegroup" id="delete" class="btn btn-danger">Delete Group</a>
|
<a href="@helpers.url(account.get.userName)/_deletegroup" id="delete" class="btn btn-danger">Delete Group</a>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
<input type="submit" class="btn btn-success" value="@if(account.isEmpty){Create Group} else {Update Group}"/>
|
<input type="submit" class="btn btn-success" value="@if(account.isEmpty){Create Group} else {Update Group}"/>
|
||||||
@if(account.isDefined){
|
@if(account.isDefined){
|
||||||
<a href="@url(account.get.userName)" class="btn btn-default">Cancel</a>
|
<a href="@helpers.url(account.get.userName)" class="btn btn-default">Cancel</a>
|
||||||
}
|
}
|
||||||
</fieldset>
|
</fieldset>
|
||||||
</form>
|
</form>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
<script>
|
<script>
|
||||||
@@ -78,7 +80,7 @@ $(function(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
// check existence
|
// check existence
|
||||||
$.post('@path/_user/existence', {
|
$.post('@context.path/_user/existence', {
|
||||||
'userName': userName
|
'userName': userName
|
||||||
}, function(data, status){
|
}, function(data, status){
|
||||||
if(data == 'true'){
|
if(data == 'true'){
|
||||||
@@ -122,7 +124,7 @@ $(function(){
|
|||||||
.append(memberButton)
|
.append(memberButton)
|
||||||
.append(managerButton))
|
.append(managerButton))
|
||||||
.append(' ')
|
.append(' ')
|
||||||
.append($('<a>').attr('href', '@path/' + userName).text(userName))
|
.append($('<a>').attr('href', '@context.path/' + userName).text(userName))
|
||||||
.append(' ')
|
.append(' ')
|
||||||
.append($('<a href="#" class="remove pull-right">(remove)</a>')));
|
.append($('<a href="#" class="remove pull-right">(remove)</a>')));
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,54 +1,61 @@
|
|||||||
@(account: gitbucket.core.model.Account, groupNames: List[String], active: String,
|
@(account: gitbucket.core.model.Account, groupNames: List[String], active: String,
|
||||||
isGroupManager: Boolean = false)(body: Html)(implicit context: gitbucket.core.controller.Context)
|
isGroupManager: Boolean = false)(body: Html)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.html.main(account.userName){
|
||||||
@html.main(account.userName){
|
<div class="main-sidebar">
|
||||||
<div class="container body">
|
<div class="sidebar">
|
||||||
<div class="main-sidebar">
|
<div class="user-panel">
|
||||||
<div class="block">
|
<div class="pull-left image">@helpers.avatar(account.userName, 40)</div>
|
||||||
<div class="account-image">@avatar(account.userName, 240)</div>
|
<div class="pull-left info">
|
||||||
<div class="account-fullname">@account.fullName</div>
|
<p>@account.userName</p>
|
||||||
<div class="account-username">@account.userName</div>
|
@account.fullName
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="block">
|
<div style="padding-left: 10px; padding-right: 10px;">
|
||||||
@if(account.url.isDefined){
|
@if(account.url.isDefined){
|
||||||
<div><i class="octicon octicon-home"></i> <a href="@account.url">@account.url</a></div>
|
<p style="white-space: nowrap; overflow: hidden; text-overflow: ellipsis;">
|
||||||
|
<i class="octicon octicon-home"></i> <a href="@account.url">@account.url</a>
|
||||||
|
</p>
|
||||||
}
|
}
|
||||||
<div><i class="octicon octicon-clock"></i> <span class="muted">Joined on</span> @date(account.registeredDate)</div>
|
<p style="color: white;">
|
||||||
|
<i class="octicon octicon-clock"></i> Joined on @helpers.date(account.registeredDate)
|
||||||
|
</p>
|
||||||
</div>
|
</div>
|
||||||
@if(groupNames.nonEmpty){
|
@if(groupNames.nonEmpty){
|
||||||
<div>
|
<ul class="sidebar-menu">
|
||||||
<div>Groups</div>
|
<li class="header">Groups</li>
|
||||||
@groupNames.map { groupName =>
|
@groupNames.map { groupName =>
|
||||||
@avatarLink(groupName, 36, tooltip = true)
|
<li>@helpers.avatarLink(groupName, 20, tooltip = true, label = true)</li>
|
||||||
}
|
}
|
||||||
</div>
|
</ul>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
<div class="main-content">
|
</div>
|
||||||
|
<div class="content-wrapper">
|
||||||
|
<div class="content body">
|
||||||
<ul class="nav nav-tabs" style="margin-bottom: 5px;">
|
<ul class="nav nav-tabs" style="margin-bottom: 5px;">
|
||||||
<li@if(active == "repositories"){ class="active"}><a href="@url(account.userName)?tab=repositories">Repositories</a></li>
|
<li@if(active == "repositories"){ class="active"}><a href="@helpers.url(account.userName)?tab=repositories">Repositories</a></li>
|
||||||
@if(account.isGroupAccount){
|
@if(account.isGroupAccount){
|
||||||
<li@if(active == "members"){ class="active"}><a href="@url(account.userName)?tab=members">Members</a></li>
|
<li@if(active == "members"){ class="active"}><a href="@helpers.url(account.userName)?tab=members">Members</a></li>
|
||||||
} else {
|
} else {
|
||||||
<li@if(active == "activity"){ class="active"}><a href="@url(account.userName)?tab=activity">Public Activity</a></li>
|
<li@if(active == "activity"){ class="active"}><a href="@helpers.url(account.userName)?tab=activity">Public Activity</a></li>
|
||||||
}
|
}
|
||||||
@gitbucket.core.plugin.PluginRegistry().getProfileTabs.map { tab =>
|
@gitbucket.core.plugin.PluginRegistry().getProfileTabs.map { tab =>
|
||||||
@tab(account, context).map { link =>
|
@tab(account, context).map { link =>
|
||||||
<li@if(active == link.id){ class="active"}><a href="@path/@link.path">@link.label</a></li>
|
<li@if(active == link.id){ class="active"}><a href="@context.path/@link.path">@link.label</a></li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@if(loginAccount.isDefined && loginAccount.get.userName == account.userName){
|
@if(context.loginAccount.isDefined && context.loginAccount.get.userName == account.userName){
|
||||||
<li class="pull-right">
|
<li class="pull-right">
|
||||||
<div class="button-group">
|
<div class="button-group">
|
||||||
<a href="@url(account.userName)/_edit" class="btn btn-default">Edit Your Profile</a>
|
<a href="@helpers.url(account.userName)/_edit" class="btn btn-default">Edit Your Profile</a>
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
}
|
}
|
||||||
@if(loginAccount.isDefined && account.isGroupAccount && isGroupManager){
|
@if(context.loginAccount.isDefined && account.isGroupAccount && isGroupManager){
|
||||||
<li class="pull-right">
|
<li class="pull-right">
|
||||||
<div class="button-group">
|
<div class="button-group">
|
||||||
<a href="@url(account.userName)/_editgroup" class="btn btn-default">Edit Group</a>
|
<a href="@helpers.url(account.userName)/_editgroup" class="btn btn-default">Edit Group</a>
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,14 +1,13 @@
|
|||||||
@(account: gitbucket.core.model.Account, members: List[String], isGroupManager: Boolean)(implicit context: gitbucket.core.controller.Context)
|
@(account: gitbucket.core.model.Account, members: List[String], isGroupManager: Boolean)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.account.html.main(account, Nil, "members", isGroupManager){
|
||||||
@main(account, Nil, "members", isGroupManager){
|
|
||||||
@if(members.isEmpty){
|
@if(members.isEmpty){
|
||||||
No members
|
No members
|
||||||
} else {
|
} else {
|
||||||
@members.map { userName =>
|
@members.map { userName =>
|
||||||
<div class="block">
|
<div class="block">
|
||||||
<div class="block-header">
|
<div class="block-header">
|
||||||
@avatar(userName, 20) <a href="@url(userName)">@userName</a>
|
@helpers.avatar(userName, 20) <a href="@helpers.url(userName)">@userName</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,27 +1,30 @@
|
|||||||
@(active: String, ssh: Boolean)(body: Html)(implicit context: gitbucket.core.controller.Context)
|
@(active: String, ssh: Boolean)(body: Html)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
|
||||||
<div class="main-sidebar">
|
<div class="main-sidebar">
|
||||||
<ul class="nav nav-pills nav-stacked">
|
<div class="sidebar">
|
||||||
<li@if(active=="profile"){ class="active"}>
|
<ul class="sidebar-menu">
|
||||||
<a href="@path/@loginAccount.get.userName/_edit">Profile</a>
|
<li@if(active=="profile"){ class="active"}>
|
||||||
</li>
|
<a href="@context.path/@context.loginAccount.get.userName/_edit">Profile</a>
|
||||||
@if(ssh){
|
</li>
|
||||||
<li@if(active=="ssh"){ class="active"}>
|
@if(ssh){
|
||||||
<a href="@path/@loginAccount.get.userName/_ssh">SSH Keys</a>
|
<li@if(active=="ssh"){ class="active"}>
|
||||||
</li>
|
<a href="@context.path/@context.loginAccount.get.userName/_ssh">SSH Keys</a>
|
||||||
}
|
</li>
|
||||||
<li@if(active=="application"){ class="active"}>
|
|
||||||
<a href="@path/@loginAccount.get.userName/_application">Applications</a>
|
|
||||||
</li>
|
|
||||||
@gitbucket.core.plugin.PluginRegistry().getAccountSettingMenus.map { menu =>
|
|
||||||
@menu(context).map { link =>
|
|
||||||
<li@if(active==link.id){ class="active"}>
|
|
||||||
<a href="@path/@link.path">@link.label</a>
|
|
||||||
</li>
|
|
||||||
}
|
}
|
||||||
}
|
<li@if(active=="application"){ class="active"}>
|
||||||
</ul>
|
<a href="@context.path/@context.loginAccount.get.userName/_application">Applications</a>
|
||||||
|
</li>
|
||||||
|
@gitbucket.core.plugin.PluginRegistry().getAccountSettingMenus.map { menu =>
|
||||||
|
@menu(context).map { link =>
|
||||||
|
<li@if(active==link.id){ class="active"}>
|
||||||
|
<a href="@context.path/@link.path">@link.label</a>
|
||||||
|
</li>
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="main-content">
|
<div class="content-wrapper">
|
||||||
@body
|
<div class="content body">
|
||||||
|
@body
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -1,75 +1,76 @@
|
|||||||
@(groupNames: List[String],
|
@(groupNames: List[String],
|
||||||
isCreateRepoOptionPublic: Boolean)(implicit context: gitbucket.core.controller.Context)
|
isCreateRepoOptionPublic: Boolean)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.html.main("Create a New Repository"){
|
||||||
@html.main("Create a New Repository"){
|
<div class="content-wrapper main-center">
|
||||||
<div class="body main-center">
|
<div class="content body">
|
||||||
<h2>Create a new repository</h2>
|
<h2>Create a new repository</h2>
|
||||||
<p class="muted">
|
<p class="muted">
|
||||||
A repository contains all the files for your project, including the revision history.
|
A repository contains all the files for your project, including the revision history.
|
||||||
</p>
|
</p>
|
||||||
<form id="form" method="post" action="@path/new" validate="true">
|
<form id="form" method="post" action="@context.path/new" validate="true">
|
||||||
<fieldset class="margin form-group">
|
<fieldset class="border-top form-group">
|
||||||
<dl style="float: left;">
|
<dl style="float: left;">
|
||||||
<dt>Owner</dt>
|
<dt>Owner</dt>
|
||||||
<dd style="margin-left: 0px;">
|
<dd style="margin-left: 0px;">
|
||||||
<div class="btn-group" id="owner-dropdown">
|
<div class="btn-group" id="owner-dropdown">
|
||||||
<button class="btn dropdown-toggle btn-default" data-toggle="dropdown">
|
<button class="btn dropdown-toggle btn-default" data-toggle="dropdown">
|
||||||
<span class="strong">@avatar(loginAccount.get.userName, 20) @loginAccount.get.userName</span>
|
<span class="strong">@helpers.avatar(context.loginAccount.get.userName, 20) @context.loginAccount.get.userName</span>
|
||||||
<span class="caret"></span>
|
<span class="caret"></span>
|
||||||
</button>
|
</button>
|
||||||
<ul class="dropdown-menu">
|
<ul class="dropdown-menu">
|
||||||
<li><a href="javascript:void(0);" data-name="@loginAccount.get.userName"><i class="octicon octicon-check"></i> <span>@avatar(loginAccount.get.userName, 20) @loginAccount.get.userName</span></a></li>
|
<li><a href="javascript:void(0);" data-name="@context.loginAccount.get.userName"><i class="octicon octicon-check"></i> <span>@helpers.avatar(context.loginAccount.get.userName, 20) @context.loginAccount.get.userName</span></a></li>
|
||||||
@groupNames.map { groupName =>
|
@groupNames.map { groupName =>
|
||||||
<li><a href="javascript:void(0);" data-name="@groupName"><i class="octicon"></i> <span>@avatar(groupName, 20) @groupName</span></a></li>
|
<li><a href="javascript:void(0);" data-name="@groupName"><i class="octicon"></i> <span>@helpers.avatar(groupName, 20) @groupName</span></a></li>
|
||||||
}
|
}
|
||||||
</ul>
|
</ul>
|
||||||
<input type="hidden" name="owner" id="owner" value="@loginAccount.get.userName"/>
|
<input type="hidden" name="owner" id="owner" value="@context.loginAccount.get.userName"/>
|
||||||
|
</div>
|
||||||
|
</dd>
|
||||||
|
</dl>
|
||||||
|
<span class="slash" style="float: left; margin-left: 10px; margin-right: 10px; margin-top: 15px;">/</span>
|
||||||
|
<dl>
|
||||||
|
<dt>Repository name</dt>
|
||||||
|
<dd style="margin-left: 0px;">
|
||||||
|
<input type="text" name="name" id="name" class="form-control" style="width: 200px;" autofocus />
|
||||||
|
<span id="error-name" class="error"></span>
|
||||||
|
</dd>
|
||||||
|
</dl>
|
||||||
|
</fieldset>
|
||||||
|
<fieldset class="form-group">
|
||||||
|
<label for="description" class="strong">Description (optional):</label>
|
||||||
|
<input type="text" name="description" id="description" class="form-control" style="width: 95%;"/>
|
||||||
|
</fieldset>
|
||||||
|
<fieldset class="border-top">
|
||||||
|
<label class="radio">
|
||||||
|
<input type="radio" name="isPrivate" value="false" @if(isCreateRepoOptionPublic){checked}>
|
||||||
|
<span class="strong"><i class="octicon octicon-repo"></i> </i> Public</span>
|
||||||
|
<div class="normal muted">
|
||||||
|
Anyone can see this repository. You choose who can commit.
|
||||||
</div>
|
</div>
|
||||||
</dd>
|
</label>
|
||||||
</dl>
|
<label class="radio">
|
||||||
<span class="slash" style="float: left; margin-left: 10px; margin-right: 10px; margin-top: 15px;">/</span>
|
<input type="radio" name="isPrivate" value="true" @if(!isCreateRepoOptionPublic){checked}>
|
||||||
<dl>
|
<span class="strong"><i class="octicon octicon-lock"></i> </i> Private</span>
|
||||||
<dt>Repository name</dt>
|
<div class="normal muted">
|
||||||
<dd style="margin-left: 0px;">
|
You choose who can see and commit to this repository.
|
||||||
<input type="text" name="name" id="name" class="form-control" style="width: 200px;" autofocus />
|
</div>
|
||||||
<span id="error-name" class="error"></span>
|
</label>
|
||||||
</dd>
|
</fieldset>
|
||||||
</dl>
|
<fieldset class="border-top">
|
||||||
</fieldset>
|
<label for="createReadme" class="checkbox">
|
||||||
<fieldset class="form-group">
|
<input type="checkbox" name="createReadme" id="createReadme"/>
|
||||||
<label for="description" class="strong">Description (optional):</label>
|
<span class="strong">Initialize this repository with a README</span>
|
||||||
<input type="text" name="description" id="description" class="form-control" style="width: 95%;"/>
|
<div class="normal muted">
|
||||||
</fieldset>
|
This will let you immediately clone the repository to your computer. Skip this step if you’re importing an existing repository.
|
||||||
<fieldset class="margin">
|
</div>
|
||||||
<label class="radio">
|
</label>
|
||||||
<input type="radio" name="isPrivate" value="false" @if(isCreateRepoOptionPublic){checked}>
|
</fieldset>
|
||||||
<span class="strong"><i class="octicon octicon-repo"></i> </i> Public</span>
|
<fieldset class="border-top form-actions">
|
||||||
<div class="normal muted">
|
<input type="submit" class="btn btn-success" value="Create repository"/>
|
||||||
Anyone can see this repository. You choose who can commit.
|
</fieldset>
|
||||||
</div>
|
</form>
|
||||||
</label>
|
</div>
|
||||||
<label class="radio">
|
|
||||||
<input type="radio" name="isPrivate" value="true" @if(!isCreateRepoOptionPublic){checked}>
|
|
||||||
<span class="strong"><i class="octicon octicon-lock"></i> </i> Private</span>
|
|
||||||
<div class="normal muted">
|
|
||||||
You choose who can see and commit to this repository.
|
|
||||||
</div>
|
|
||||||
</label>
|
|
||||||
</fieldset>
|
|
||||||
<fieldset class="margin">
|
|
||||||
<label for="createReadme" class="checkbox">
|
|
||||||
<input type="checkbox" name="createReadme" id="createReadme"/>
|
|
||||||
<span class="strong">Initialize this repository with a README</span>
|
|
||||||
<div class="normal muted">
|
|
||||||
This will let you immediately clone the repository to your computer. Skip this step if you’re importing an existing repository.
|
|
||||||
</div>
|
|
||||||
</label>
|
|
||||||
</fieldset>
|
|
||||||
<fieldset class="margin form-actions">
|
|
||||||
<input type="submit" class="btn btn-success" value="Create repository"/>
|
|
||||||
</fieldset>
|
|
||||||
</form>
|
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
<script>
|
<script>
|
||||||
|
|||||||
@@ -1,50 +1,50 @@
|
|||||||
@()(implicit context: gitbucket.core.controller.Context)
|
@()(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@gitbucket.core.html.main("Create your account"){
|
||||||
@import gitbucket.core.view.helpers._
|
<div class="content-wrapper main-center">
|
||||||
@html.main("Create your account"){
|
<div class="content body">
|
||||||
<div class="container body main-center">
|
<h2>Create your account</h2>
|
||||||
<h3>Create your account</h3>
|
<form action="@context.path/register" method="POST" validate="true">
|
||||||
<form action="@path/register" method="POST" validate="true">
|
<div class="row">
|
||||||
<div class="row">
|
<div class="col-md-6">
|
||||||
<div class="col-md-6">
|
<fieldset>
|
||||||
<fieldset>
|
<label for="userName" class="strong">Username:</label>
|
||||||
<label for="userName" class="strong">Username:</label>
|
<input type="text" name="userName" id="userName" value="" class="form-control" autofocus/>
|
||||||
<input type="text" name="userName" id="userName" value="" class="form-control" autofocus/>
|
<span id="error-userName" class="error"></span>
|
||||||
<span id="error-userName" class="error"></span>
|
</fieldset>
|
||||||
</fieldset>
|
<fieldset>
|
||||||
<fieldset>
|
<label for="password" class="strong">
|
||||||
<label for="password" class="strong">
|
Password:
|
||||||
Password:
|
</label>
|
||||||
</label>
|
<input type="password" name="password" id="password" class="form-control" value=""/>
|
||||||
<input type="password" name="password" id="password" class="form-control" value=""/>
|
<span id="error-password" class="error"></span>
|
||||||
<span id="error-password" class="error"></span>
|
</fieldset>
|
||||||
</fieldset>
|
<fieldset>
|
||||||
<fieldset>
|
<label for="fullName" class="strong">Full Name:</label>
|
||||||
<label for="fullName" class="strong">Full Name:</label>
|
<input type="text" name="fullName" id="fullName" class="form-control" value=""/>
|
||||||
<input type="text" name="fullName" id="fullName" class="form-control" value=""/>
|
<span id="error-fullName" class="error"></span>
|
||||||
<span id="error-fullName" class="error"></span>
|
</fieldset>
|
||||||
</fieldset>
|
<fieldset>
|
||||||
<fieldset>
|
<label for="mailAddress" class="strong">Mail Address:</label>
|
||||||
<label for="mailAddress" class="strong">Mail Address:</label>
|
<input type="text" name="mailAddress" id="mailAddress" class="form-control" value=""/>
|
||||||
<input type="text" name="mailAddress" id="mailAddress" class="form-control" value=""/>
|
<span id="error-mailAddress" class="error"></span>
|
||||||
<span id="error-mailAddress" class="error"></span>
|
</fieldset>
|
||||||
</fieldset>
|
<fieldset>
|
||||||
<fieldset>
|
<label for="url" class="strong">URL (optional):</label>
|
||||||
<label for="url" class="strong">URL (optional):</label>
|
<input type="text" name="url" id="url" class="form-control" value=""/>
|
||||||
<input type="text" name="url" id="url" class="form-control" value=""/>
|
<span id="error-url" class="error"></span>
|
||||||
<span id="error-url" class="error"></span>
|
</fieldset>
|
||||||
</fieldset>
|
</div>
|
||||||
|
<div class="col-md-6">
|
||||||
|
<fieldset>
|
||||||
|
<label for="avatar" class="strong">Image (optional):</label>
|
||||||
|
@gitbucket.core.helper.html.uploadavatar(None)
|
||||||
|
</fieldset>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-6">
|
<fieldset class="border-top">
|
||||||
<fieldset>
|
<input type="submit" class="btn btn-success" value="Create account"/>
|
||||||
<label for="avatar" class="strong">Image (optional):</label>
|
</fieldset>
|
||||||
@helper.html.uploadavatar(None)
|
</form>
|
||||||
</fieldset>
|
</div>
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<fieldset class="margin">
|
|
||||||
<input type="submit" class="btn btn-success" value="Create account"/>
|
|
||||||
</fieldset>
|
|
||||||
</form>
|
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,31 +1,30 @@
|
|||||||
@(account: gitbucket.core.model.Account, groupNames: List[String],
|
@(account: gitbucket.core.model.Account, groupNames: List[String],
|
||||||
repositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo],
|
repositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo],
|
||||||
isGroupManager: Boolean)(implicit context: gitbucket.core.controller.Context)
|
isGroupManager: Boolean)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.account.html.main(account, groupNames, "repositories", isGroupManager){
|
||||||
@main(account, groupNames, "repositories", isGroupManager){
|
|
||||||
@if(repositories.isEmpty){
|
@if(repositories.isEmpty){
|
||||||
No repositories
|
No repositories
|
||||||
} else {
|
} else {
|
||||||
@repositories.map { repository =>
|
@repositories.map { repository =>
|
||||||
<div class="block">
|
<div class="block">
|
||||||
<div class="repository-icon">
|
<div class="repository-icon">
|
||||||
@helper.html.repositoryicon(repository, true)
|
@gitbucket.core.helper.html.repositoryicon(repository, true)
|
||||||
</div>
|
</div>
|
||||||
<div class="repository-content">
|
<div class="repository-content">
|
||||||
<div class="block-header">
|
<div class="block-header">
|
||||||
<a href="@url(repository)">@repository.name</a>
|
<a href="@helpers.url(repository)">@repository.name</a>
|
||||||
@if(repository.repository.isPrivate){
|
@if(repository.repository.isPrivate){
|
||||||
<i class="octicon octicon-lock"></i>
|
<i class="octicon octicon-lock"></i>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
@if(repository.repository.originUserName.isDefined){
|
@if(repository.repository.originUserName.isDefined){
|
||||||
<div class="small muted">forked from <a href="@path/@repository.repository.parentUserName/@repository.repository.parentRepositoryName">@repository.repository.parentUserName/@repository.repository.parentRepositoryName</a></div>
|
<div class="small muted">forked from <a href="@context.path/@repository.repository.parentUserName/@repository.repository.parentRepositoryName">@repository.repository.parentUserName/@repository.repository.parentRepositoryName</a></div>
|
||||||
}
|
}
|
||||||
@if(repository.repository.description.isDefined){
|
@if(repository.repository.description.isDefined){
|
||||||
<div>@repository.repository.description</div>
|
<div>@repository.repository.description</div>
|
||||||
}
|
}
|
||||||
<div><span class="muted small">Updated @helper.html.datetimeago(repository.repository.lastActivityDate)</span></div>
|
<div><span class="muted small">Updated @gitbucket.core.helper.html.datetimeago(repository.repository.lastActivityDate)</span></div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,10 +1,8 @@
|
|||||||
@(account: gitbucket.core.model.Account, sshKeys: List[gitbucket.core.model.SshKey])(implicit context: gitbucket.core.controller.Context)
|
@(account: gitbucket.core.model.Account, sshKeys: List[gitbucket.core.model.SshKey])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import gitbucket.core.ssh.SshUtil
|
@import gitbucket.core.ssh.SshUtil
|
||||||
@import context._
|
@gitbucket.core.html.main("SSH Keys"){
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
@html.main("SSH Keys"){
|
|
||||||
<div class="container body">
|
<div class="container body">
|
||||||
@menu("ssh", settings.ssh){
|
@gitbucket.core.account.html.menu("ssh", context.settings.ssh){
|
||||||
<div class="panel panel-default">
|
<div class="panel panel-default">
|
||||||
<div class="panel-heading strong">SSH Keys</div>
|
<div class="panel-heading strong">SSH Keys</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
@@ -16,11 +14,11 @@
|
|||||||
<hr>
|
<hr>
|
||||||
}
|
}
|
||||||
<strong style="line-height: 30px;">@key.title</strong> (@SshUtil.fingerPrint(key.publicKey).getOrElse("Key is invalid."))
|
<strong style="line-height: 30px;">@key.title</strong> (@SshUtil.fingerPrint(key.publicKey).getOrElse("Key is invalid."))
|
||||||
<a href="@path/@account.userName/_ssh/delete/@key.sshKeyId" class="btn btn-sm btn-danger pull-right">Delete</a>
|
<a href="@context.path/@account.userName/_ssh/delete/@key.sshKeyId" class="btn btn-sm btn-danger pull-right">Delete</a>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<form method="POST" action="@path/@account.userName/_ssh" validate="true">
|
<form method="POST" action="@context.path/@account.userName/_ssh" validate="true">
|
||||||
<div class="panel panel-default">
|
<div class="panel panel-default">
|
||||||
<div class="panel-heading strong">Add an SSH Key</div>
|
<div class="panel-heading strong">Add an SSH Key</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
|
|||||||
@@ -1,12 +1,10 @@
|
|||||||
@(tableNames: Seq[String])(implicit context: gitbucket.core.controller.Context)
|
@(tableNames: Seq[String])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@gitbucket.core.html.main("Data export / import"){
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.admin.html.menu("data") {
|
||||||
@html.main("Data export / import"){
|
|
||||||
@admin.html.menu("data") {
|
|
||||||
<div class="panel panel-default">
|
<div class="panel panel-default">
|
||||||
<div class="panel-heading strong">Export</div>
|
<div class="panel-heading strong">Export</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
<form class="form form-horizontal" action="@path/admin/export" method="POST">
|
<form class="form form-horizontal" action="@context.path/admin/export" method="POST">
|
||||||
@tableNames.map { tableName =>
|
@tableNames.map { tableName =>
|
||||||
<div class="checkbox">
|
<div class="checkbox">
|
||||||
<label>
|
<label>
|
||||||
@@ -32,7 +30,7 @@
|
|||||||
<div class="panel panel-default">
|
<div class="panel panel-default">
|
||||||
<div class="panel-heading strong">Import (only XML)</div>
|
<div class="panel-heading strong">Import (only XML)</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
<form class="form form-horizontal" action="@path/upload/import" method="POST" enctype="multipart/form-data" id="import-form">
|
<form class="form form-horizontal" action="@context.path/upload/import" method="POST" enctype="multipart/form-data" id="import-form">
|
||||||
<input type="file" name="file" id="file">
|
<input type="file" name="file" id="file">
|
||||||
<input type="submit" class="btn btn-success pull-right" value="Import" id="import">
|
<input type="submit" class="btn btn-success pull-right" value="Import" id="import">
|
||||||
</form>
|
</form>
|
||||||
|
|||||||
@@ -1,33 +1,34 @@
|
|||||||
@(active: String)(body: Html)(implicit context: gitbucket.core.controller.Context)
|
@(active: String)(body: Html)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
<div class="main-sidebar">
|
||||||
<div class="container body">
|
<div class="sidebar">
|
||||||
<div class="main-sidebar">
|
<ul class="sidebar-menu" id="system-admin-menu-container">
|
||||||
<ul class="nav nav-pills nav-stacked" id="system-admin-menu-container">
|
|
||||||
<li@if(active=="users"){ class="active"}>
|
<li@if(active=="users"){ class="active"}>
|
||||||
<a href="@path/admin/users">User Management</a>
|
<a href="@context.path/admin/users">User Management</a>
|
||||||
</li>
|
</li>
|
||||||
<li@if(active=="system"){ class="active"}>
|
<li@if(active=="system"){ class="active"}>
|
||||||
<a href="@path/admin/system">System Settings</a>
|
<a href="@context.path/admin/system">System Settings</a>
|
||||||
</li>
|
</li>
|
||||||
<li@if(active=="plugins"){ class="active"}>
|
<li@if(active=="plugins"){ class="active"}>
|
||||||
<a href="@path/admin/plugins">Plugins</a>
|
<a href="@context.path/admin/plugins">Plugins</a>
|
||||||
</li>
|
</li>
|
||||||
<li@if(active=="data"){ class="active"}>
|
<li@if(active=="data"){ class="active"}>
|
||||||
<a href="@path/admin/data">Data export / import</a>
|
<a href="@context.path/admin/data">Data export / import</a>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<a href="@path/console/login.jsp">H2 Console</a>
|
<a href="@context.path/console/login.jsp" target="_blank">H2 Console</a>
|
||||||
</li>
|
</li>
|
||||||
@gitbucket.core.plugin.PluginRegistry().getSystemSettingMenus.map { menu =>
|
@gitbucket.core.plugin.PluginRegistry().getSystemSettingMenus.map { menu =>
|
||||||
@menu(context).map { link =>
|
@menu(context).map { link =>
|
||||||
<li@if(active==link.id){ class="active"}>
|
<li@if(active==link.id){ class="active"}>
|
||||||
<a href="@path/@link.path">@link.label</a>
|
<a href="@context.path/@link.path">@link.label</a>
|
||||||
</li>
|
</li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
<div class="main-content">
|
</div>
|
||||||
|
<div class="content-wrapper">
|
||||||
|
<div class="content body">
|
||||||
@body
|
@body
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -1,36 +1,34 @@
|
|||||||
@(plugins: List[gitbucket.core.plugin.PluginInfo])(implicit context: gitbucket.core.controller.Context)
|
@(plugins: List[(gitbucket.core.plugin.PluginInfo, String)])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@gitbucket.core.html.main("Plugins"){
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.admin.html.menu("plugins") {
|
||||||
@html.main("Plugins"){
|
|
||||||
@admin.html.menu("plugins") {
|
|
||||||
<h1>Installed plugins</h1>
|
<h1>Installed plugins</h1>
|
||||||
|
|
||||||
@if(plugins.size > 0) {
|
@if(plugins.size > 0) {
|
||||||
<ul>
|
<ul>
|
||||||
@plugins.map {plugin =>
|
@plugins.map { case (plugin, migrationVersion) =>
|
||||||
<li><a href="#@plugin.pluginId">@plugin.pluginId:@plugin.version</a></li>
|
<li><a href="#@plugin.pluginId">@plugin.pluginId:@migrationVersion</a></li>
|
||||||
}
|
}
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
@plugins.map {plugin =>
|
@plugins.map { case (plugin, migrationVersion) =>
|
||||||
<div class="panel panel-default">
|
<div class="panel panel-default">
|
||||||
<div class="panel-heading strong">@plugin.pluginName</div>
|
<div class="panel-heading strong">@plugin.pluginName</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<label class="col-md-2">Id</label>
|
<label class="col-md-2">Id</label>
|
||||||
<span class="col-md-8">@plugin.pluginId</span>
|
<span class="col-md-10">@plugin.pluginId</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<label class="col-md-2">Version</label>
|
<label class="col-md-2">Version</label>
|
||||||
<span class="col-md-8">@plugin.version</span>
|
<span class="col-md-10">@migrationVersion @if(plugin.pluginVersion != migrationVersion){ <span class="error">(Migration is failed, installed version is @plugin.pluginVersion)</span> }</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<label class="col-md-2">Name</label>
|
<label class="col-md-2">Name</label>
|
||||||
<span class="col-md-8">@plugin.pluginName</span>
|
<span class="col-md-10">@plugin.pluginName</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<label class="col-md-2">Description</label>
|
<label class="col-md-2">Description</label>
|
||||||
<span class="col-md-8 muted">@plugin.description</span>
|
<span class="col-md-10 muted">@plugin.description</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -1,11 +1,8 @@
|
|||||||
@(info: Option[Any])(implicit context: gitbucket.core.controller.Context)
|
@(info: Option[Any])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@gitbucket.core.html.main("System Settings"){
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.admin.html.menu("system"){
|
||||||
@import gitbucket.core.util.Directory._
|
@gitbucket.core.helper.html.information(info)
|
||||||
@html.main("System Settings"){
|
<form action="@context.path/admin/system" method="POST" validate="true" class="form-horizontal">
|
||||||
@menu("system"){
|
|
||||||
@helper.html.information(info)
|
|
||||||
<form action="@path/admin/system" method="POST" validate="true" class="form-horizontal">
|
|
||||||
<div class="panel panel-default">
|
<div class="panel panel-default">
|
||||||
<div class="panel-heading strong">System Settings</div>
|
<div class="panel-heading strong">System Settings</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
@@ -19,7 +16,7 @@
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>GITBUCKET_HOME</td>
|
<td>GITBUCKET_HOME</td>
|
||||||
<td>@GitBucketHome</td>
|
<td>@gitbucket.core.util.Directory.GitBucketHome</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>DATABASE_URL</td>
|
<td>DATABASE_URL</td>
|
||||||
@@ -33,7 +30,7 @@
|
|||||||
<label><span class="strong">Base URL</span> (e.g. <code>http://example.com/gitbucket</code>)</label>
|
<label><span class="strong">Base URL</span> (e.g. <code>http://example.com/gitbucket</code>)</label>
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<div class="controls">
|
<div class="controls">
|
||||||
<input type="text" name="baseUrl" id="baseUrl" class="form-control" value="@settings.baseUrl"/>
|
<input type="text" name="baseUrl" id="baseUrl" class="form-control" value="@context.settings.baseUrl"/>
|
||||||
<span id="error-baseUrl" class="error"></span>
|
<span id="error-baseUrl" class="error"></span>
|
||||||
</div>
|
</div>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
@@ -48,7 +45,7 @@
|
|||||||
<hr>
|
<hr>
|
||||||
<label><span class="strong">Information</span> (HTML is available)</label>
|
<label><span class="strong">Information</span> (HTML is available)</label>
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<textarea name="information" class="form-control" style="height: 100px;">@settings.information</textarea>
|
<textarea name="information" class="form-control" style="height: 100px;">@context.settings.information</textarea>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
<!--====================================================================-->
|
<!--====================================================================-->
|
||||||
<!-- Account registration -->
|
<!-- Account registration -->
|
||||||
@@ -57,11 +54,11 @@
|
|||||||
<label class="strong">Account registration</label>
|
<label class="strong">Account registration</label>
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<label class="radio">
|
<label class="radio">
|
||||||
<input type="radio" name="allowAccountRegistration" value="true"@if(settings.allowAccountRegistration){ checked}>
|
<input type="radio" name="allowAccountRegistration" value="true"@if(context.settings.allowAccountRegistration){ checked}>
|
||||||
<span class="strong">Allow</span> <span class="normal">- Users can create accounts by themselves.</span>
|
<span class="strong">Allow</span> <span class="normal">- Users can create accounts by themselves.</span>
|
||||||
</label>
|
</label>
|
||||||
<label class="radio">
|
<label class="radio">
|
||||||
<input type="radio" name="allowAccountRegistration" value="false"@if(!settings.allowAccountRegistration){ checked}>
|
<input type="radio" name="allowAccountRegistration" value="false"@if(!context.settings.allowAccountRegistration){ checked}>
|
||||||
<span class="strong">Deny</span> - <span class="normal">Only administrators can create accounts.</span>
|
<span class="strong">Deny</span> - <span class="normal">Only administrators can create accounts.</span>
|
||||||
</label>
|
</label>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
@@ -69,11 +66,11 @@
|
|||||||
<label class="strong">Default option to create a new repository</label>
|
<label class="strong">Default option to create a new repository</label>
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<label class="radio">
|
<label class="radio">
|
||||||
<input type="radio" name="isCreateRepoOptionPublic" value="true"@if(settings.isCreateRepoOptionPublic){ checked}>
|
<input type="radio" name="isCreateRepoOptionPublic" value="true"@if(context.settings.isCreateRepoOptionPublic){ checked}>
|
||||||
<span class="strong">Public</span> <span class="normal">- All users and guests can read that repository.</span>
|
<span class="strong">Public</span> <span class="normal">- All users and guests can read that repository.</span>
|
||||||
</label>
|
</label>
|
||||||
<label class="radio">
|
<label class="radio">
|
||||||
<input type="radio" name="isCreateRepoOptionPublic" value="false"@if(!settings.isCreateRepoOptionPublic){ checked}>
|
<input type="radio" name="isCreateRepoOptionPublic" value="false"@if(!context.settings.isCreateRepoOptionPublic){ checked}>
|
||||||
<span class="strong">Private</span> <span class="normal">- Only collaborators can read that repository.</span>
|
<span class="strong">Private</span> <span class="normal">- Only collaborators can read that repository.</span>
|
||||||
</label>
|
</label>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
@@ -84,11 +81,11 @@
|
|||||||
<label class="strong">Anonymous access</label>
|
<label class="strong">Anonymous access</label>
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<label class="radio">
|
<label class="radio">
|
||||||
<input type="radio" name="allowAnonymousAccess" value="true"@if(settings.allowAnonymousAccess){ checked}>
|
<input type="radio" name="allowAnonymousAccess" value="true"@if(context.settings.allowAnonymousAccess){ checked}>
|
||||||
<span class="strong">Allow</span> <span class="normal">- Anyone can view public repositories, user/group profiles.</span>
|
<span class="strong">Allow</span> <span class="normal">- Anyone can view public repositories, user/group profiles.</span>
|
||||||
</label>
|
</label>
|
||||||
<label class="radio">
|
<label class="radio">
|
||||||
<input type="radio" name="allowAnonymousAccess" value="false"@if(!settings.allowAnonymousAccess){ checked}>
|
<input type="radio" name="allowAnonymousAccess" value="false"@if(!context.settings.allowAnonymousAccess){ checked}>
|
||||||
<span class="strong">Deny</span> <span class="normal">- Users must authenticate before viewing any information.</span>
|
<span class="strong">Deny</span> <span class="normal">- Users must authenticate before viewing any information.</span>
|
||||||
</label>
|
</label>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
@@ -97,10 +94,15 @@
|
|||||||
<!--====================================================================-->
|
<!--====================================================================-->
|
||||||
<hr>
|
<hr>
|
||||||
<label><span class="strong">Limit of activity logs</span> (Unlimited if it's not specified or zero)</label>
|
<label><span class="strong">Limit of activity logs</span> (Unlimited if it's not specified or zero)</label>
|
||||||
<div class="controls">
|
<fieldset>
|
||||||
<input type="text" id="activityLogLimit" name="activityLogLimit" class="form-control input-mini" value="@settings.activityLogLimit"/>
|
<div class="form-group">
|
||||||
<span id="error-activityLogLimit" class="error"></span>
|
<label class="control-label col-md-3" for="activityLogLimit">Limit</label>
|
||||||
</div>
|
<div class="col-md-9">
|
||||||
|
<input type="text" id="activityLogLimit" name="activityLogLimit" class="form-control input-mini" value="@context.settings.activityLogLimit"/>
|
||||||
|
<span id="error-activityLogLimit" class="error"></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</fieldset>
|
||||||
<!--====================================================================-->
|
<!--====================================================================-->
|
||||||
<!-- Services -->
|
<!-- Services -->
|
||||||
<!--====================================================================-->
|
<!--====================================================================-->
|
||||||
@@ -108,7 +110,7 @@
|
|||||||
<label class="strong">Services</label>
|
<label class="strong">Services</label>
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<label class="checkbox">
|
<label class="checkbox">
|
||||||
<input type="checkbox" name="gravatar"@if(settings.gravatar){ checked}/>
|
<input type="checkbox" name="gravatar"@if(context.settings.gravatar){ checked}/>
|
||||||
Use Gravatar for Profile-Images
|
Use Gravatar for Profile-Images
|
||||||
</label>
|
</label>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
@@ -119,7 +121,7 @@
|
|||||||
<label class="strong">SSH access</label>
|
<label class="strong">SSH access</label>
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<label class="checkbox">
|
<label class="checkbox">
|
||||||
<input type="checkbox" id="ssh" name="ssh"@if(settings.ssh){ checked}/>
|
<input type="checkbox" id="ssh" name="ssh"@if(context.settings.ssh){ checked}/>
|
||||||
Enable SSH access to git repository
|
Enable SSH access to git repository
|
||||||
</label>
|
</label>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
@@ -127,14 +129,14 @@
|
|||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="sshHost">SSH Host</label>
|
<label class="control-label col-md-3" for="sshHost">SSH Host</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="sshHost" name="sshHost" class="form-control" value="@settings.sshHost"/>
|
<input type="text" id="sshHost" name="sshHost" class="form-control" value="@context.settings.sshHost"/>
|
||||||
<span id="error-sshHost" class="error"></span>
|
<span id="error-sshHost" class="error"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="sshPort">SSH Port</label>
|
<label class="control-label col-md-3" for="sshPort">SSH Port</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="sshPort" name="sshPort" class="form-control" value="@settings.sshPort"/>
|
<input type="text" id="sshPort" name="sshPort" class="form-control" value="@context.settings.sshPort"/>
|
||||||
<span id="error-sshPort" class="error"></span>
|
<span id="error-sshPort" class="error"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -149,7 +151,7 @@
|
|||||||
<label class="strong">Authentication</label>
|
<label class="strong">Authentication</label>
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<label class="checkbox">
|
<label class="checkbox">
|
||||||
<input type="checkbox" id="ldapAuthentication" name="ldapAuthentication"@if(settings.ldap){ checked} />
|
<input type="checkbox" id="ldapAuthentication" name="ldapAuthentication"@if(context.settings.ldap){ checked} />
|
||||||
LDAP
|
LDAP
|
||||||
</label>
|
</label>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
@@ -157,82 +159,82 @@
|
|||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="ldapHost">LDAP Host</label>
|
<label class="control-label col-md-3" for="ldapHost">LDAP Host</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="ldapHost" name="ldap.host" class="form-control" value="@settings.ldap.map(_.host)"/>
|
<input type="text" id="ldapHost" name="ldap.host" class="form-control" value="@context.settings.ldap.map(_.host)"/>
|
||||||
<span id="error-ldap_host" class="error"></span>
|
<span id="error-ldap_host" class="error"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="ldapPort">LDAP Port</label>
|
<label class="control-label col-md-3" for="ldapPort">LDAP Port</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="ldapPort" name="ldap.port" class="form-control input-mini" value="@settings.ldap.map(_.port)"/>
|
<input type="text" id="ldapPort" name="ldap.port" class="form-control input-mini" value="@context.settings.ldap.map(_.port)"/>
|
||||||
<span id="error-ldap_port" class="error"></span>
|
<span id="error-ldap_port" class="error"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="ldapBindDN">Bind DN</label>
|
<label class="control-label col-md-3" for="ldapBindDN">Bind DN</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="ldapBindDN" name="ldap.bindDN" class="form-control" value="@settings.ldap.map(_.bindDN)"/>
|
<input type="text" id="ldapBindDN" name="ldap.bindDN" class="form-control" value="@context.settings.ldap.map(_.bindDN)"/>
|
||||||
<span id="error-ldap_bindDN" class="error"></span>
|
<span id="error-ldap_bindDN" class="error"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="ldapBindPassword">Bind Password</label>
|
<label class="control-label col-md-3" for="ldapBindPassword">Bind Password</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="password" id="ldapBindPassword" name="ldap.bindPassword" class="form-control" value="@settings.ldap.map(_.bindPassword)"/>
|
<input type="password" id="ldapBindPassword" name="ldap.bindPassword" class="form-control" value="@context.settings.ldap.map(_.bindPassword)"/>
|
||||||
<span id="error-ldap_bindPassword" class="error"></span>
|
<span id="error-ldap_bindPassword" class="error"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="ldapBaseDN">Base DN</label>
|
<label class="control-label col-md-3" for="ldapBaseDN">Base DN</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="ldapBaseDN" name="ldap.baseDN" class="form-control" value="@settings.ldap.map(_.baseDN)"/>
|
<input type="text" id="ldapBaseDN" name="ldap.baseDN" class="form-control" value="@context.settings.ldap.map(_.baseDN)"/>
|
||||||
<span id="error-ldap_baseDN" class="error"></span>
|
<span id="error-ldap_baseDN" class="error"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="ldapUserNameAttribute">User name attribute</label>
|
<label class="control-label col-md-3" for="ldapUserNameAttribute">User name attribute</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="ldapUserNameAttribute" name="ldap.userNameAttribute" class="form-control" value="@settings.ldap.map(_.userNameAttribute)"/>
|
<input type="text" id="ldapUserNameAttribute" name="ldap.userNameAttribute" class="form-control" value="@context.settings.ldap.map(_.userNameAttribute)"/>
|
||||||
<span id="error-ldap_userNameAttribute" class="error"></span>
|
<span id="error-ldap_userNameAttribute" class="error"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="ldapAdditionalFilterCondition">Additional filter condition</label>
|
<label class="control-label col-md-3" for="ldapAdditionalFilterCondition">Additional filter condition</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="ldapAdditionalFilterCondition" name="ldap.additionalFilterCondition" class="form-control" value="@settings.ldap.map(_.additionalFilterCondition)"/>
|
<input type="text" id="ldapAdditionalFilterCondition" name="ldap.additionalFilterCondition" class="form-control" value="@context.settings.ldap.map(_.additionalFilterCondition)"/>
|
||||||
<span id="error-ldap_additionalFilterCondition" class="error"></span>
|
<span id="error-ldap_additionalFilterCondition" class="error"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="ldapFullNameAttribute">Full name attribute</label>
|
<label class="control-label col-md-3" for="ldapFullNameAttribute">Full name attribute</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="ldapFullNameAttribute" name="ldap.fullNameAttribute" class="form-control" value="@settings.ldap.map(_.fullNameAttribute)"/>
|
<input type="text" id="ldapFullNameAttribute" name="ldap.fullNameAttribute" class="form-control" value="@context.settings.ldap.map(_.fullNameAttribute)"/>
|
||||||
<span id="error-ldap_fullNameAttribute" class="error"></span>
|
<span id="error-ldap_fullNameAttribute" class="error"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="ldapMailAttribute">Mail address attribute</label>
|
<label class="control-label col-md-3" for="ldapMailAttribute">Mail address attribute</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="ldapMailAttribute" name="ldap.mailAttribute" class="form-control" value="@settings.ldap.map(_.mailAttribute)"/>
|
<input type="text" id="ldapMailAttribute" name="ldap.mailAttribute" class="form-control" value="@context.settings.ldap.map(_.mailAttribute)"/>
|
||||||
<span id="error-ldap_mailAttribute" class="error"></span>
|
<span id="error-ldap_mailAttribute" class="error"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3">Enable TLS</label>
|
<label class="control-label col-md-3">Enable TLS</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="checkbox" name="ldap.tls"@if(settings.ldap.flatMap(_.tls).getOrElse(false)){ checked}/>
|
<input type="checkbox" name="ldap.tls"@if(context.settings.ldap.flatMap(_.tls).getOrElse(false)){ checked}/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3">Enable SSL</label>
|
<label class="control-label col-md-3">Enable SSL</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="checkbox" name="ldap.ssl"@if(settings.ldap.flatMap(_.ssl).getOrElse(false)){ checked}/>
|
<input type="checkbox" name="ldap.ssl"@if(context.settings.ldap.flatMap(_.ssl).getOrElse(false)){ checked}/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="ldapBindDN">Keystore</label>
|
<label class="control-label col-md-3" for="ldapBindDN">Keystore</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="ldapKeystore" name="ldap.keystore" class="form-control" value="@settings.ldap.map(_.keystore)"/>
|
<input type="text" id="ldapKeystore" name="ldap.keystore" class="form-control" value="@context.settings.ldap.map(_.keystore)"/>
|
||||||
<span id="error-ldap_keystore" class="error"></span>
|
<span id="error-ldap_keystore" class="error"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -244,7 +246,7 @@
|
|||||||
<label class="strong">Notifications</label>
|
<label class="strong">Notifications</label>
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<label class="checkbox">
|
<label class="checkbox">
|
||||||
<input type="checkbox" id="notification" name="notification"@if(settings.notification){ checked}/>
|
<input type="checkbox" id="notification" name="notification"@if(context.settings.notification){ checked}/>
|
||||||
Send notifications
|
Send notifications
|
||||||
</label>
|
</label>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
@@ -255,7 +257,7 @@
|
|||||||
<label class="strong">Communication</label>
|
<label class="strong">Communication</label>
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<label class="checkbox">
|
<label class="checkbox">
|
||||||
<input type="checkbox" id="useSMTP" name="useSMTP" @if(settings.useSMTP){ checked}/>
|
<input type="checkbox" id="useSMTP" name="useSMTP" @if(context.settings.useSMTP){ checked}/>
|
||||||
SMTP
|
SMTP
|
||||||
</label>
|
</label>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
@@ -263,47 +265,53 @@
|
|||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="smtpHost">SMTP Host</label>
|
<label class="control-label col-md-3" for="smtpHost">SMTP Host</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="smtpHost" name="smtp.host" class="form-control" value="@settings.smtp.map(_.host)"/>
|
<input type="text" id="smtpHost" name="smtp.host" class="form-control" value="@context.settings.smtp.map(_.host)"/>
|
||||||
<span id="error-smtp_host" class="error"></span>
|
<span id="error-smtp_host" class="error"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="smtpPort">SMTP Port</label>
|
<label class="control-label col-md-3" for="smtpPort">SMTP Port</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="smtpPort" name="smtp.port" class="form-control input-mini" value="@settings.smtp.map(_.port)"/>
|
<input type="text" id="smtpPort" name="smtp.port" class="form-control input-mini" value="@context.settings.smtp.map(_.port)"/>
|
||||||
<span id="error-smtp_port" class="error"></span>
|
<span id="error-smtp_port" class="error"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="smtpUser">SMTP User</label>
|
<label class="control-label col-md-3" for="smtpUser">SMTP User</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="smtpUser" name="smtp.user" class="form-control" value="@settings.smtp.map(_.user)"/>
|
<input type="text" id="smtpUser" name="smtp.user" class="form-control" value="@context.settings.smtp.map(_.user)"/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="smtpPassword">SMTP Password</label>
|
<label class="control-label col-md-3" for="smtpPassword">SMTP Password</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="password" id="smtpPassword" name="smtp.password" class="form-control" value="@settings.smtp.map(_.password)"/>
|
<input type="password" id="smtpPassword" name="smtp.password" class="form-control" value="@context.settings.smtp.map(_.password)"/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="smtpPassword">Enable SSL</label>
|
<label class="control-label col-md-3" for="smtpPassword">Enable SSL</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="checkbox" name="smtp.ssl"@if(settings.smtp.flatMap(_.ssl).getOrElse(false)){ checked}/>
|
<input type="checkbox" id="smtpSsl" name="smtp.ssl"@if(context.settings.smtp.flatMap(_.ssl).getOrElse(false)){ checked}/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="fromAddress">FROM Address</label>
|
<label class="control-label col-md-3" for="fromAddress">FROM Address</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="fromAddress" name="smtp.fromAddress" class="form-control" value="@settings.smtp.map(_.fromAddress)"/>
|
<input type="text" id="fromAddress" name="smtp.fromAddress" class="form-control" value="@context.settings.smtp.map(_.fromAddress)"/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3" for="fromName">FROM Name</label>
|
<label class="control-label col-md-3" for="fromName">FROM Name</label>
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<input type="text" id="fromName" name="smtp.fromName" class="form-control" value="@settings.smtp.map(_.fromName)"/>
|
<input type="text" id="fromName" name="smtp.fromName" class="form-control" value="@context.settings.smtp.map(_.fromName)"/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="text-right">
|
||||||
|
Send test mail to:
|
||||||
|
<input type="text" id="testAddress" size="30"/>
|
||||||
|
<input type="button" id="sendTestMail" value="Send"/>
|
||||||
|
</div>
|
||||||
|
|
||||||
<p class="muted">
|
<p class="muted">
|
||||||
Enable notification not only SMTP configuration if you want to send notification email.
|
Enable notification not only SMTP configuration if you want to send notification email.
|
||||||
</p>
|
</p>
|
||||||
@@ -318,6 +326,40 @@
|
|||||||
}
|
}
|
||||||
<script>
|
<script>
|
||||||
$(function(){
|
$(function(){
|
||||||
|
$('#sendTestMail').click(function(){
|
||||||
|
var host = $('#smtpHost' ).val();
|
||||||
|
var port = $('#smtpPort' ).val();
|
||||||
|
var user = $('#smtpUser' ).val();
|
||||||
|
var password = $('#smtpPassword').val();
|
||||||
|
var ssl = $('#smtpSsl' ).prop('checked');
|
||||||
|
var fromAddress = $('#fromAddress' ).val();
|
||||||
|
var fromName = $('#fromName' ).val();
|
||||||
|
var testAddress = $('#testAddress' ).val();
|
||||||
|
|
||||||
|
if(host == ''){
|
||||||
|
alert('SMTP Host is required.');
|
||||||
|
$('#smtpHost').focus();
|
||||||
|
} else if(testAddress == ''){
|
||||||
|
alert('Destination is required.');
|
||||||
|
$('#testAddress').focus();
|
||||||
|
} else {
|
||||||
|
$.post('@context.path/admin/system/sendmail', {
|
||||||
|
'smtp.host': host,
|
||||||
|
'smtp.port': port,
|
||||||
|
'smtp.user': user,
|
||||||
|
'smtp.password': password,
|
||||||
|
'smtp.ssl': ssl,
|
||||||
|
'smtp.fromAddress': fromAddress,
|
||||||
|
'smtp.fromName': fromName,
|
||||||
|
'testAddress': testAddress
|
||||||
|
}, function(data, status){
|
||||||
|
if(data != ''){
|
||||||
|
alert(data);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
$('#ssh').change(function(){
|
$('#ssh').change(function(){
|
||||||
$('.ssh input').prop('disabled', !$(this).prop('checked'));
|
$('.ssh input').prop('disabled', !$(this).prop('checked'));
|
||||||
}).change();
|
}).change();
|
||||||
|
|||||||
@@ -1,9 +1,8 @@
|
|||||||
@(account: Option[gitbucket.core.model.Account], error: Option[Any] = None)(implicit context: gitbucket.core.controller.Context)
|
@(account: Option[gitbucket.core.model.Account], error: Option[Any] = None)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@gitbucket.core.html.main(if(account.isEmpty) "New User" else "Update User"){
|
||||||
@html.main(if(account.isEmpty) "New User" else "Update User"){
|
@gitbucket.core.admin.html.menu("users"){
|
||||||
@admin.html.menu("users"){
|
@gitbucket.core.helper.html.error(error)
|
||||||
@helper.html.error(error)
|
<form method="POST" action="@if(account.isEmpty){@context.path/admin/users/_newuser} else {@context.path/admin/users/@account.get.userName/_edituser}" validate="true">
|
||||||
<form method="POST" action="@if(account.isEmpty){@path/admin/users/_newuser} else {@path/admin/users/@account.get.userName/_edituser}" validate="true">
|
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
<fieldset class="form-group">
|
<fieldset class="form-group">
|
||||||
@@ -71,13 +70,13 @@
|
|||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
<fieldset class="form-group">
|
<fieldset class="form-group">
|
||||||
<label for="avatar" class="strong">Image (Optional)</label>
|
<label for="avatar" class="strong">Image (Optional)</label>
|
||||||
@helper.html.uploadavatar(account)
|
@gitbucket.core.helper.html.uploadavatar(account)
|
||||||
</fieldset>
|
</fieldset>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<fieldset class="margin">
|
<fieldset class="border-top">
|
||||||
<input type="submit" class="btn btn-success" value="@if(account.isEmpty){Create User} else {Update User}"/>
|
<input type="submit" class="btn btn-success" value="@if(account.isEmpty){Create User} else {Update User}"/>
|
||||||
<a href="@path/admin/users" class="btn btn-default">Cancel</a>
|
<a href="@context.path/admin/users" class="btn btn-default">Cancel</a>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
</form>
|
</form>
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,9 +1,7 @@
|
|||||||
@(account: Option[gitbucket.core.model.Account], members: List[gitbucket.core.model.GroupMember])(implicit context: gitbucket.core.controller.Context)
|
@(account: Option[gitbucket.core.model.Account], members: List[gitbucket.core.model.GroupMember])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@gitbucket.core.html.main(if(account.isEmpty) "New Group" else "Update Group"){
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.admin.html.menu("users"){
|
||||||
@html.main(if(account.isEmpty) "New Group" else "Update Group"){
|
<form method="POST" action="@if(account.isEmpty){@context.path/admin/users/_newgroup} else {@context.path/admin/users/@account.get.userName/_editgroup}" validate="true">
|
||||||
@admin.html.menu("users"){
|
|
||||||
<form method="POST" action="@if(account.isEmpty){@path/admin/users/_newgroup} else {@path/admin/users/@account.get.userName/_editgroup}" validate="true">
|
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
<fieldset class="form-group">
|
<fieldset class="form-group">
|
||||||
@@ -28,7 +26,7 @@
|
|||||||
</fieldset>
|
</fieldset>
|
||||||
<fieldset class="form-group">
|
<fieldset class="form-group">
|
||||||
<label for="avatar" class="strong">Image (Optional)</label>
|
<label for="avatar" class="strong">Image (Optional)</label>
|
||||||
@helper.html.uploadavatar(account)
|
@gitbucket.core.helper.html.uploadavatar(account)
|
||||||
</fieldset>
|
</fieldset>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
@@ -36,7 +34,7 @@
|
|||||||
<label class="strong">Members</label>
|
<label class="strong">Members</label>
|
||||||
<ul id="member-list" class="collaborator">
|
<ul id="member-list" class="collaborator">
|
||||||
</ul>
|
</ul>
|
||||||
@helper.html.account("memberName", 200)
|
@gitbucket.core.helper.html.account("memberName", 200)
|
||||||
<input type="button" class="btn btn-default" value="Add" id="addMember"/>
|
<input type="button" class="btn btn-default" value="Add" id="addMember"/>
|
||||||
<input type="hidden" id="members" name="members" value="@members.map(member => member.userName + ":" + member.isManager).mkString(",")"/>
|
<input type="hidden" id="members" name="members" value="@members.map(member => member.userName + ":" + member.isManager).mkString(",")"/>
|
||||||
<div>
|
<div>
|
||||||
@@ -45,9 +43,9 @@
|
|||||||
</fieldset>
|
</fieldset>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<fieldset class="margin">
|
<fieldset class="border-top">
|
||||||
<input type="submit" class="btn btn-success" value="@if(account.isEmpty){Create Group} else {Update Group}"/>
|
<input type="submit" class="btn btn-success" value="@if(account.isEmpty){Create Group} else {Update Group}"/>
|
||||||
<a href="@path/admin/users" class="btn btn-default">Cancel</a>
|
<a href="@context.path/admin/users" class="btn btn-default">Cancel</a>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
</form>
|
</form>
|
||||||
}
|
}
|
||||||
@@ -77,7 +75,7 @@ $(function(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
// check existence
|
// check existence
|
||||||
$.post('@path/_user/existence', {
|
$.post('@context.path/_user/existence', {
|
||||||
'userName': userName,
|
'userName': userName,
|
||||||
'userOnly': true
|
'userOnly': true
|
||||||
}, function(data, status){
|
}, function(data, status){
|
||||||
@@ -103,11 +101,11 @@ $(function(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
function addMemberHTML(userName, isManager){
|
function addMemberHTML(userName, isManager){
|
||||||
var memberButton = $('<input type="radio" value="false" checked>Member</input>').data('name', userName);
|
var memberButton = $('<label class="btn btn-default btn-mini"><input type="radio" value="false" name="' + userName + '">Member</label>');
|
||||||
if(!isManager){
|
if(!isManager){
|
||||||
memberButton.addClass('active');
|
memberButton.addClass('active');
|
||||||
}
|
}
|
||||||
var managerButton = $('<input type="radio" value="true">Manager</input>').data('name', userName);
|
var managerButton = $('<label class="btn btn-default btn-mini"><input type="radio" value="true" name="' + userName + '">Manager</label>');
|
||||||
if(isManager){
|
if(isManager){
|
||||||
managerButton.addClass('active');
|
managerButton.addClass('active');
|
||||||
}
|
}
|
||||||
@@ -115,10 +113,10 @@ $(function(){
|
|||||||
$('#member-list').append($('<li>')
|
$('#member-list').append($('<li>')
|
||||||
.data('name', userName)
|
.data('name', userName)
|
||||||
.append($('<div class="btn-group is_manager" data-toggle="buttons">')
|
.append($('<div class="btn-group is_manager" data-toggle="buttons">')
|
||||||
.append($('<label class="btn btn-default btn-mini active">').append(memberButton))
|
.append(memberButton)
|
||||||
.append($('<label class="btn btn-default btn-mini">').append(managerButton)))
|
.append(managerButton))
|
||||||
.append(' ')
|
.append(' ')
|
||||||
.append($('<a>').attr('href', '@path/' + userName).text(userName))
|
.append($('<a>').attr('href', '@context.path/' + userName).text(userName))
|
||||||
.append(' ')
|
.append(' ')
|
||||||
.append($('<a href="#" class="remove pull-right">(remove)</a>')));
|
.append($('<a href="#" class="remove pull-right">(remove)</a>')));
|
||||||
}
|
}
|
||||||
@@ -126,9 +124,7 @@ $(function(){
|
|||||||
function updateMembers(){
|
function updateMembers(){
|
||||||
var members = $('#member-list li').map(function(i, e){
|
var members = $('#member-list li').map(function(i, e){
|
||||||
var userName = $(e).data('name');
|
var userName = $(e).data('name');
|
||||||
return userName + ':' + $('label.active > input[type=radio]').filter(function(i, e){
|
return userName + ':' + $(e).find('label.active input[type=radio]').attr('value');
|
||||||
return $(e).data('name') == userName;
|
|
||||||
}).attr('value');
|
|
||||||
}).get().join(',');
|
}).get().join(',');
|
||||||
$('#members').val(members);
|
$('#members').val(members);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,11 +1,10 @@
|
|||||||
@(users: List[gitbucket.core.model.Account], members: Map[String, List[String]], includeRemoved: Boolean)(implicit context: gitbucket.core.controller.Context)
|
@(users: List[gitbucket.core.model.Account], members: Map[String, List[String]], includeRemoved: Boolean)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.html.main("Manage Users"){
|
||||||
@html.main("Manage Users"){
|
@gitbucket.core.admin.html.menu("users"){
|
||||||
@admin.html.menu("users"){
|
|
||||||
<div class="pull-right" style="margin-bottom: 4px;">
|
<div class="pull-right" style="margin-bottom: 4px;">
|
||||||
<a href="@path/admin/users/_newuser" class="btn btn-default">New User</a>
|
<a href="@context.path/admin/users/_newuser" class="btn btn-default">New User</a>
|
||||||
<a href="@path/admin/users/_newgroup" class="btn btn-default">New Group</a>
|
<a href="@context.path/admin/users/_newgroup" class="btn btn-default">New Group</a>
|
||||||
</div>
|
</div>
|
||||||
<label for="includeRemoved">
|
<label for="includeRemoved">
|
||||||
<input type="checkbox" id="includeRemoved" name="includeRemoved" @if(includeRemoved){checked}/>
|
<input type="checkbox" id="includeRemoved" name="includeRemoved" @if(includeRemoved){checked}/>
|
||||||
@@ -17,14 +16,14 @@
|
|||||||
<td @if(account.isRemoved){style="background-color: #dddddd;"}>
|
<td @if(account.isRemoved){style="background-color: #dddddd;"}>
|
||||||
<div class="pull-right">
|
<div class="pull-right">
|
||||||
@if(account.isGroupAccount){
|
@if(account.isGroupAccount){
|
||||||
<a href="@path/admin/users/@account.userName/_editgroup">Edit</a>
|
<a href="@context.path/admin/users/@account.userName/_editgroup">Edit</a>
|
||||||
} else {
|
} else {
|
||||||
<a href="@path/admin/users/@account.userName/_edituser">Edit</a>
|
<a href="@context.path/admin/users/@account.userName/_edituser">Edit</a>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
<div class="strong">
|
<div class="strong">
|
||||||
@avatar(account.userName, 20)
|
@helpers.avatar(account.userName, 20)
|
||||||
<a href="@url(account.userName)">@account.userName</a>
|
<a href="@helpers.url(account.userName)">@account.userName</a>
|
||||||
@if(account.isGroupAccount){
|
@if(account.isGroupAccount){
|
||||||
(Group)
|
(Group)
|
||||||
} else {
|
} else {
|
||||||
@@ -36,7 +35,7 @@
|
|||||||
}
|
}
|
||||||
@if(account.isGroupAccount){
|
@if(account.isGroupAccount){
|
||||||
@members(account.userName).map { userName =>
|
@members(account.userName).map { userName =>
|
||||||
@avatar(userName, 20, tooltip = true)
|
@helpers.avatar(userName, 20, tooltip = true)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
@@ -50,10 +49,10 @@
|
|||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
<span class="muted">Registered:</span> @datetime(account.registeredDate)
|
<span class="muted">Registered:</span> @helpers.datetime(account.registeredDate)
|
||||||
<span class="muted">Updated:</span> @datetime(account.updatedDate)
|
<span class="muted">Updated:</span> @helpers.datetime(account.updatedDate)
|
||||||
@if(!account.isGroupAccount){
|
@if(!account.isGroupAccount){
|
||||||
<span class="muted">Last Login:</span> @account.lastLoginDate.map(datetime)
|
<span class="muted">Last Login:</span> @account.lastLoginDate.map(helpers.datetime)
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
</td>
|
</td>
|
||||||
@@ -65,7 +64,7 @@
|
|||||||
<script>
|
<script>
|
||||||
$(function(){
|
$(function(){
|
||||||
$('#includeRemoved').click(function(){
|
$('#includeRemoved').click(function(){
|
||||||
location.href = '@path/admin/users?includeRemoved=' + this.checked;
|
location.href = '@context.path/admin/users?includeRemoved=' + this.checked;
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
@@ -2,62 +2,61 @@
|
|||||||
closedCount: Int,
|
closedCount: Int,
|
||||||
condition: gitbucket.core.service.IssuesService.IssueSearchCondition,
|
condition: gitbucket.core.service.IssuesService.IssueSearchCondition,
|
||||||
groups: List[String])(implicit context: gitbucket.core.controller.Context)
|
groups: List[String])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
<div id="table-issues-control">
|
<div id="table-issues-control">
|
||||||
@helper.html.dropdown("Visibility"){
|
@gitbucket.core.helper.html.dropdown("Visibility"){
|
||||||
<li>
|
<li>
|
||||||
<a href="@(condition.copy(visibility = (if(condition.visibility == Some("private")) None else Some("private"))).toURL)">
|
<a href="@(condition.copy(visibility = (if(condition.visibility == Some("private")) None else Some("private"))).toURL)">
|
||||||
@helper.html.checkicon(condition.visibility == Some("private"))
|
@gitbucket.core.helper.html.checkicon(condition.visibility == Some("private"))
|
||||||
Private repository only
|
Private repository only
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<a href="@(condition.copy(visibility = (if(condition.visibility == Some("public")) None else Some("public"))).toURL)">
|
<a href="@(condition.copy(visibility = (if(condition.visibility == Some("public")) None else Some("public"))).toURL)">
|
||||||
@helper.html.checkicon(condition.visibility == Some("public"))
|
@gitbucket.core.helper.html.checkicon(condition.visibility == Some("public"))
|
||||||
Public repository only
|
Public repository only
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
}
|
}
|
||||||
@helper.html.dropdown("Organization"){
|
@gitbucket.core.helper.html.dropdown("Organization"){
|
||||||
@groups.map { group =>
|
@groups.map { group =>
|
||||||
<li>
|
<li>
|
||||||
<a href="@((if(condition.groups.contains(group)) condition.copy(groups = condition.groups - group) else condition.copy(groups = condition.groups + group)).toURL)">
|
<a href="@((if(condition.groups.contains(group)) condition.copy(groups = condition.groups - group) else condition.copy(groups = condition.groups + group)).toURL)">
|
||||||
@helper.html.checkicon(condition.groups.contains(group))
|
@gitbucket.core.helper.html.checkicon(condition.groups.contains(group))
|
||||||
@avatar(group, 20) @group
|
@helpers.avatar(group, 20) @group
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@helper.html.dropdown("Sort"){
|
@gitbucket.core.helper.html.dropdown("Sort"){
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(sort="created", direction="desc").toURL">
|
<a href="@condition.copy(sort="created", direction="desc").toURL">
|
||||||
@helper.html.checkicon(condition.sort == "created" && condition.direction == "desc") Newest
|
@gitbucket.core.helper.html.checkicon(condition.sort == "created" && condition.direction == "desc") Newest
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(sort="created", direction="asc" ).toURL">
|
<a href="@condition.copy(sort="created", direction="asc" ).toURL">
|
||||||
@helper.html.checkicon(condition.sort == "created" && condition.direction == "asc") Oldest
|
@gitbucket.core.helper.html.checkicon(condition.sort == "created" && condition.direction == "asc") Oldest
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(sort="comments", direction="desc").toURL">
|
<a href="@condition.copy(sort="comments", direction="desc").toURL">
|
||||||
@helper.html.checkicon(condition.sort == "comments" && condition.direction == "desc") Most commented
|
@gitbucket.core.helper.html.checkicon(condition.sort == "comments" && condition.direction == "desc") Most commented
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(sort="comments", direction="asc" ).toURL">
|
<a href="@condition.copy(sort="comments", direction="asc" ).toURL">
|
||||||
@helper.html.checkicon(condition.sort == "comments" && condition.direction == "asc") Least commented
|
@gitbucket.core.helper.html.checkicon(condition.sort == "comments" && condition.direction == "asc") Least commented
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(sort="updated", direction="desc").toURL">
|
<a href="@condition.copy(sort="updated", direction="desc").toURL">
|
||||||
@helper.html.checkicon(condition.sort == "updated" && condition.direction == "desc") Recently updated
|
@gitbucket.core.helper.html.checkicon(condition.sort == "updated" && condition.direction == "desc") Recently updated
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(sort="updated", direction="asc" ).toURL">
|
<a href="@condition.copy(sort="updated", direction="asc" ).toURL">
|
||||||
@helper.html.checkicon(condition.sort == "updated" && condition.direction == "asc") Least recently updated
|
@gitbucket.core.helper.html.checkicon(condition.sort == "updated" && condition.direction == "asc") Least recently updated
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,14 +7,12 @@
|
|||||||
groups: List[String],
|
groups: List[String],
|
||||||
recentRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo],
|
recentRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo],
|
||||||
userRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo])(implicit context: gitbucket.core.controller.Context)
|
userRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@gitbucket.core.html.main("Issues"){
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.dashboard.html.sidebar(recentRepositories, userRepositories){
|
||||||
@html.main("Issues"){
|
@gitbucket.core.dashboard.html.tab("issues")
|
||||||
@sidebar(recentRepositories, userRepositories){
|
|
||||||
@dashboard.html.tab("issues")
|
|
||||||
<div class="container">
|
<div class="container">
|
||||||
@issuesnavi(filter, openCount, closedCount, condition)
|
@gitbucket.core.dashboard.html.issuesnavi(filter, openCount, closedCount, condition)
|
||||||
@issueslist(issues, page, openCount, closedCount, condition, filter, groups)
|
@gitbucket.core.dashboard.html.issueslist(issues, page, openCount, closedCount, condition, filter, groups)
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,15 +5,14 @@
|
|||||||
condition: gitbucket.core.service.IssuesService.IssueSearchCondition,
|
condition: gitbucket.core.service.IssuesService.IssueSearchCondition,
|
||||||
filter: String,
|
filter: String,
|
||||||
groups: List[String])(implicit context: gitbucket.core.controller.Context)
|
groups: List[String])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
@import gitbucket.core.service.IssuesService
|
@import gitbucket.core.service.IssuesService
|
||||||
@import gitbucket.core.service.IssuesService.IssueInfo
|
@import gitbucket.core.service.IssuesService.IssueInfo
|
||||||
<table class="table table-bordered table-hover table-issues">
|
<table class="table table-bordered table-hover table-issues">
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th style="background-color: #eee;">
|
<th style="background-color: #eee;">
|
||||||
@dashboard.html.header(openCount, closedCount, condition, groups)
|
@gitbucket.core.dashboard.html.header(openCount, closedCount, condition, groups)
|
||||||
</th>
|
</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
@@ -21,11 +20,11 @@
|
|||||||
@issues.map { case IssueInfo(issue, labels, milestone, commentCount, commitStatus) =>
|
@issues.map { case IssueInfo(issue, labels, milestone, commentCount, commitStatus) =>
|
||||||
<tr>
|
<tr>
|
||||||
<td style="padding-top: 12px; padding-bottom: 12px;">
|
<td style="padding-top: 12px; padding-bottom: 12px;">
|
||||||
<a href="@path/@issue.userName/@issue.repositoryName">@issue.userName/@issue.repositoryName</a> ・
|
<a href="@context.path/@issue.userName/@issue.repositoryName">@issue.userName/@issue.repositoryName</a> ・
|
||||||
@if(issue.isPullRequest){
|
@if(issue.isPullRequest){
|
||||||
<a href="@path/@issue.userName/@issue.repositoryName/pull/@issue.issueId" class="issue-title">@issue.title</a>
|
<a href="@context.path/@issue.userName/@issue.repositoryName/pull/@issue.issueId" class="issue-title">@issue.title</a>
|
||||||
} else {
|
} else {
|
||||||
<a href="@path/@issue.userName/@issue.repositoryName/issues/@issue.issueId" class="issue-title">@issue.title</a>
|
<a href="@context.path/@issue.userName/@issue.repositoryName/issues/@issue.issueId" class="issue-title">@issue.title</a>
|
||||||
}
|
}
|
||||||
@gitbucket.core.issues.html.commitstatus(issue, commitStatus)
|
@gitbucket.core.issues.html.commitstatus(issue, commitStatus)
|
||||||
@labels.map { label =>
|
@labels.map { label =>
|
||||||
@@ -33,20 +32,20 @@
|
|||||||
}
|
}
|
||||||
<span class="pull-right muted">
|
<span class="pull-right muted">
|
||||||
@issue.assignedUserName.map { userName =>
|
@issue.assignedUserName.map { userName =>
|
||||||
@avatar(userName, 20, tooltip = true)
|
@helpers.avatar(userName, 20, tooltip = true)
|
||||||
}
|
}
|
||||||
@if(commentCount > 0){
|
@if(commentCount > 0){
|
||||||
<a href="@path/@issue.userName/@issue.repositoryName/issues/@issue.issueId" class="issue-comment-count">
|
<a href="@context.path/@issue.userName/@issue.repositoryName/issues/@issue.issueId" class="issue-comment-count">
|
||||||
<i class="octicon octicon-comment active"></i> @commentCount
|
<i class="octicon octicon-comment active"></i> @commentCount
|
||||||
</a>
|
</a>
|
||||||
} else {
|
} else {
|
||||||
<a href="@path/@issue.userName/@issue.repositoryName/issues/@issue.issueId" class="issue-comment-count" style="color: silver;">
|
<a href="@context.path/@issue.userName/@issue.repositoryName/issues/@issue.issueId" class="issue-comment-count" style="color: silver;">
|
||||||
<i class="octicon octicon-comment"></i> @commentCount
|
<i class="octicon octicon-comment"></i> @commentCount
|
||||||
</a>
|
</a>
|
||||||
}
|
}
|
||||||
</span>
|
</span>
|
||||||
<div class="small muted" style="margin-top: 2px;">
|
<div class="small muted" style="margin-top: 2px;">
|
||||||
#@issue.issueId opened by @user(issue.openedUserName, styleClass="username") @datetime(issue.registeredDate)
|
#@issue.issueId opened by @helpers.user(issue.openedUserName, styleClass="username") @helpers.datetime(issue.registeredDate)
|
||||||
@milestone.map { milestone =>
|
@milestone.map { milestone =>
|
||||||
<span style="margin: 20px;"><a href="@condition.copy(milestone = Some(Some(milestone))).toURL" class="username"><i class="octicon octicon-milestone"></i> @milestone</a></span>
|
<span style="margin: 20px;"><a href="@condition.copy(milestone = Some(Some(milestone))).toURL" class="username"><i class="octicon octicon-milestone"></i> @milestone</a></span>
|
||||||
}
|
}
|
||||||
@@ -64,5 +63,5 @@
|
|||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
<div class="pull-right">
|
<div class="pull-right">
|
||||||
@helper.html.paginator(page, (if(condition.state == "open") openCount else closedCount), IssuesService.IssueLimit, 10, condition.toURL)
|
@gitbucket.core.helper.html.paginator(page, (if(condition.state == "open") openCount else closedCount), IssuesService.IssueLimit, 10, condition.toURL)
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -2,8 +2,6 @@
|
|||||||
openCount: Int,
|
openCount: Int,
|
||||||
closedCount: Int,
|
closedCount: Int,
|
||||||
condition: gitbucket.core.service.IssuesService.IssueSearchCondition)(implicit context: gitbucket.core.controller.Context)
|
condition: gitbucket.core.service.IssuesService.IssueSearchCondition)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
<ul class="nav nav-pills pull-left" style="line-height: 14px; margin-bottom: 10px;">
|
<ul class="nav nav-pills pull-left" style="line-height: 14px; margin-bottom: 10px;">
|
||||||
<li class="@(if(condition.state == "open"){"active"})">
|
<li class="@(if(condition.state == "open"){"active"})">
|
||||||
<a href="@condition.copy(state = "open").toURL">Open <span class="badge">@openCount</span></a>
|
<a href="@condition.copy(state = "open").toURL">Open <span class="badge">@openCount</span></a>
|
||||||
|
|||||||
@@ -7,14 +7,12 @@
|
|||||||
groups: List[String],
|
groups: List[String],
|
||||||
recentRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo],
|
recentRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo],
|
||||||
userRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo])(implicit context: gitbucket.core.controller.Context)
|
userRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@gitbucket.core.html.main("Pull Requests"){
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.dashboard.html.sidebar(recentRepositories, userRepositories){
|
||||||
@html.main("Pull Requests"){
|
@gitbucket.core.dashboard.html.tab("pulls")
|
||||||
@sidebar(recentRepositories, userRepositories){
|
|
||||||
@dashboard.html.tab("pulls")
|
|
||||||
<div class="container">
|
<div class="container">
|
||||||
@issuesnavi(filter, openCount, closedCount, condition)
|
@gitbucket.core.dashboard.html.issuesnavi(filter, openCount, closedCount, condition)
|
||||||
@issueslist(issues, page, openCount, closedCount, condition, filter, groups)
|
@gitbucket.core.dashboard.html.issueslist(issues, page, openCount, closedCount, condition, filter, groups)
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,72 +1,65 @@
|
|||||||
@(recentRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo],
|
@(recentRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo],
|
||||||
userRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo])(body: Html)(implicit context: gitbucket.core.controller.Context)
|
userRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo])(body: Html)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
<div class="main-sidebar">
|
||||||
<div class="container body">
|
<div class="sidebar">
|
||||||
<div class="dashboard-sidebar">
|
<ul class="nav sidebar-menu">
|
||||||
@if(loginAccount.isEmpty){
|
@if(context.loginAccount.isDefined){
|
||||||
<div id="dashboard-signin-form">@html.signinform(settings)</div>
|
<li class="header">
|
||||||
|
<span class="label label-primary pull-right">@userRepositories.size</span>
|
||||||
|
Your repositories
|
||||||
|
</li>
|
||||||
|
@if(userRepositories.isEmpty){
|
||||||
|
<li>No repositories</li>
|
||||||
} else {
|
} else {
|
||||||
<div class="panel panel-default">
|
@defining(10){ max =>
|
||||||
<div class="panel-heading strong">
|
@userRepositories.zipWithIndex.map { case (repository, i) =>
|
||||||
Your repositories <span class="badge">@userRepositories.size</span>
|
<li class="repo-link" style="@if(i > max - 1){display:none;}">
|
||||||
</div>
|
@if(repository.owner == context.loginAccount.get.userName){
|
||||||
<ul class="list-group list-group-flush">
|
<a href="@helpers.url(repository)">@gitbucket.core.helper.html.repositoryicon(repository, false) <span class="strong">@repository.name</span></a>
|
||||||
@if(userRepositories.isEmpty){
|
} else {
|
||||||
<li class="list-group-item">No repositories</li>
|
<a href="@helpers.url(repository)">@gitbucket.core.helper.html.repositoryicon(repository, false) @repository.owner/<span class="strong">@repository.name</span></a>
|
||||||
} else {
|
|
||||||
@defining(20){ max =>
|
|
||||||
@userRepositories.zipWithIndex.map { case (repository, i) =>
|
|
||||||
<li class="list-group-item repo-link" style="@if(i > max - 1){display:none;}">
|
|
||||||
@helper.html.repositoryicon(repository, false)
|
|
||||||
@if(repository.owner == loginAccount.get.userName){
|
|
||||||
<a href="@url(repository)"><span class="strong">@repository.name</span></a>
|
|
||||||
} else {
|
|
||||||
<a href="@url(repository)">@repository.owner/<span class="strong">@repository.name</span></a>
|
|
||||||
}
|
|
||||||
</li>
|
|
||||||
}
|
|
||||||
@if(userRepositories.size > max){
|
|
||||||
<li class="list-group-item show-more">
|
|
||||||
<a href="javascript:void(0);" id="show-more-repos">Show @{userRepositories.size - max} more repositories...</a>
|
|
||||||
</li>
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
</li>
|
||||||
}
|
}
|
||||||
</ul>
|
@if(userRepositories.size > max){
|
||||||
</div>
|
<li class="show-more">
|
||||||
}
|
<a href="javascript:void(0);" id="show-more-repos">Show @{userRepositories.size - max} more repositories...</a>
|
||||||
<div class="panel panel-default">
|
</li>
|
||||||
<div class="panel-heading strong">Recent updated repositories</div>
|
|
||||||
<ul class="list-group list-group-flush">
|
|
||||||
@if(recentRepositories.isEmpty){
|
|
||||||
<li class="list-group-item">No repositories</li>
|
|
||||||
} else {
|
|
||||||
@defining(20){ max =>
|
|
||||||
@recentRepositories.zipWithIndex.map { case (repository, i) =>
|
|
||||||
<li class="list-group-item repo-link" style="@if(i > max - 1){display:none;}">
|
|
||||||
@helper.html.repositoryicon(repository, false)
|
|
||||||
<a href="@url(repository)">@repository.owner/<span class="strong">@repository.name</span></a>
|
|
||||||
</li>
|
|
||||||
}
|
|
||||||
@if(recentRepositories.size > max){
|
|
||||||
<li class="list-group-item show-more">
|
|
||||||
<a href="javascript:void(0);" id="show-more-recent-repos">Show @{recentRepositories.size - max} more repositories...</a>
|
|
||||||
</li>
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</ul>
|
}
|
||||||
</div>
|
} else {
|
||||||
|
<li class="header">Recent updated repositories</li>
|
||||||
|
@if(recentRepositories.isEmpty){
|
||||||
|
<li>No repositories</li>
|
||||||
|
} else {
|
||||||
|
@defining(10){ max =>
|
||||||
|
@recentRepositories.zipWithIndex.map { case (repository, i) =>
|
||||||
|
<li class="repo-link" style="@if(i > max - 1){display:none;}">
|
||||||
|
<a href="@helpers.url(repository)">@gitbucket.core.helper.html.repositoryicon(repository, false) @repository.owner/<span class="strong">@repository.name</span></a>
|
||||||
|
</li>
|
||||||
|
}
|
||||||
|
@if(recentRepositories.size > max){
|
||||||
|
<li class="show-more">
|
||||||
|
<a href="javascript:void(0);" id="show-more-recent-repos">Show @{recentRepositories.size - max} more repositories...</a>
|
||||||
|
</li>
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
<div class="dashboard-content">
|
</div>
|
||||||
|
<div class="content-wrapper">
|
||||||
|
<div class="content body">
|
||||||
@body
|
@body
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<script>
|
<script>
|
||||||
$(function(){
|
$(function(){
|
||||||
$('#show-more-repos, #show-more-recent-repos').click(function(e){
|
$('#show-more-repos, #show-more-recent-repos').click(function(e){
|
||||||
$(e.target).parents('ul.list-group').find('li.repo-link').show();
|
$(e.target).parents('ul').find('li.repo-link').show();
|
||||||
$(e.target).parents('li.show-more').remove();
|
$(e.target).parents('li.show-more').remove();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,14 +1,12 @@
|
|||||||
@(active: String = "")(implicit context: gitbucket.core.controller.Context)
|
@(active: String = "")(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
<ul class="nav nav-tabs" style="margin-bottom: 20px;">
|
<ul class="nav nav-tabs" style="margin-bottom: 20px;">
|
||||||
<li @if(active == ""){ class="active"}><a href="@path/">News Feed</a></li>
|
<li @if(active == ""){ class="active"}><a href="@context.path/">News Feed</a></li>
|
||||||
@if(loginAccount.isDefined){
|
@if(context.loginAccount.isDefined){
|
||||||
<li @if(active == "pulls" ){ class="active"}><a href="@path/dashboard/pulls">Pull Requests</a></li>
|
<li @if(active == "pulls" ){ class="active"}><a href="@context.path/dashboard/pulls">Pull Requests</a></li>
|
||||||
<li @if(active == "issues"){ class="active"}><a href="@path/dashboard/issues">Issues</a></li>
|
<li @if(active == "issues"){ class="active"}><a href="@context.path/dashboard/issues">Issues</a></li>
|
||||||
@gitbucket.core.plugin.PluginRegistry().getDashboardTabs.map { tab =>
|
@gitbucket.core.plugin.PluginRegistry().getDashboardTabs.map { tab =>
|
||||||
@tab(context).map { link =>
|
@tab(context).map { link =>
|
||||||
<li @if(active == link.id){ class="active"}><a href="@path/@link.path">@link.label</a></li>
|
<li @if(active == link.id){ class="active"}><a href="@context.path/@link.path">@link.label</a></li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
@(title: String)(implicit context: gitbucket.core.controller.Context)
|
@(title: String)(implicit context: gitbucket.core.controller.Context)
|
||||||
@main("Error"){
|
@gitbucket.core.html.main("Error"){
|
||||||
<h1>@title</h1>
|
<h1>@title</h1>
|
||||||
}
|
}
|
||||||
@@ -1,5 +1,4 @@
|
|||||||
@(id: String, width: Int)(implicit context: gitbucket.core.controller.Context)
|
@(id: String, width: Int)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
|
||||||
<span style="margin-right: 0px;">
|
<span style="margin-right: 0px;">
|
||||||
<input type="text" name="@id" id="@id" class="form-control" autocomplete="off" style="width: @{width}px; margin-bottom: 0px; display: inline; vertical-align: middle;"/>
|
<input type="text" name="@id" id="@id" class="form-control" autocomplete="off" style="width: @{width}px; margin-bottom: 0px; display: inline; vertical-align: middle;"/>
|
||||||
</span>
|
</span>
|
||||||
@@ -7,7 +6,7 @@
|
|||||||
$(function(){
|
$(function(){
|
||||||
$('#@id').typeahead({
|
$('#@id').typeahead({
|
||||||
source: function (query, process) {
|
source: function (query, process) {
|
||||||
return $.get('@path/_user/proposals', { query: query },
|
return $.get('@context.path/_user/proposals', { query: query },
|
||||||
function (data) {
|
function (data) {
|
||||||
return process(data.options);
|
return process(data.options);
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
@(activities: List[gitbucket.core.model.Activity])(implicit context: gitbucket.core.controller.Context)
|
@(activities: List[gitbucket.core.model.Activity])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
|
|
||||||
@if(activities.isEmpty){
|
@if(activities.isEmpty){
|
||||||
No activity
|
No activity
|
||||||
@@ -29,7 +28,7 @@
|
|||||||
} else {
|
} else {
|
||||||
if(commit.nonEmpty){
|
if(commit.nonEmpty){
|
||||||
<div>
|
<div>
|
||||||
<a href={s"${path}/${activity.userName}/${activity.repositoryName}/commit/${commit. substring(0, 40)}"} class="monospace">{commit.substring(0, 7)}</a>
|
<a href={s"${context.path}/${activity.userName}/${activity.repositoryName}/commit/${commit. substring(0, 40)}"} class="monospace">{commit.substring(0, 7)}</a>
|
||||||
<span>{commit.substring(41)}</span>
|
<span>{commit.substring(41)}</span>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
@@ -39,19 +38,19 @@
|
|||||||
}
|
}
|
||||||
case "create_wiki" => customActivity(activity, "book"){
|
case "create_wiki" => customActivity(activity, "book"){
|
||||||
<div class="small activity-message">
|
<div class="small activity-message">
|
||||||
Created <a href={s"${path}/${activity.userName}/${activity.repositoryName}/wiki/${activity.additionalInfo.get}"}>{activity.additionalInfo.get}</a>.
|
Created <a href={s"${context.path}/${activity.userName}/${activity.repositoryName}/wiki/${activity.additionalInfo.get}"}>{activity.additionalInfo.get}</a>.
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
case "edit_wiki" => customActivity(activity, "book"){
|
case "edit_wiki" => customActivity(activity, "book"){
|
||||||
activity.additionalInfo.get.split(":") match {
|
activity.additionalInfo.get.split(":") match {
|
||||||
case Array(pageName, commitId) =>
|
case Array(pageName, commitId) =>
|
||||||
<div class="small activity-message">
|
<div class="small activity-message">
|
||||||
Edited <a href={s"${path}/${activity.userName}/${activity.repositoryName}/wiki/${pageName}"}>{pageName}</a>.
|
Edited <a href={s"${context.path}/${activity.userName}/${activity.repositoryName}/wiki/${pageName}"}>{pageName}</a>.
|
||||||
<a href={s"${path}/${activity.userName}/${activity.repositoryName}/wiki/${pageName}/_compare/${commitId.substring(0, 7)}^...${commitId.substring(0, 7)}"}>View the diff »</a>
|
<a href={s"${context.path}/${activity.userName}/${activity.repositoryName}/wiki/${pageName}/_compare/${commitId.substring(0, 7)}^...${commitId.substring(0, 7)}"}>View the diff »</a>
|
||||||
</div>
|
</div>
|
||||||
case Array(pageName) =>
|
case Array(pageName) =>
|
||||||
<div class="small activity-message">
|
<div class="small activity-message">
|
||||||
Edited <a href={s"${path}/${activity.userName}/${activity.repositoryName}/wiki/${pageName}"}>{pageName}</a>.
|
Edited <a href={s"${context.path}/${activity.userName}/${activity.repositoryName}/wiki/${pageName}"}>{pageName}</a>.
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -65,10 +64,10 @@
|
|||||||
<div class="activity-icon-large"><i class="mega-octicon octicon-@image"></i></div>
|
<div class="activity-icon-large"><i class="mega-octicon octicon-@image"></i></div>
|
||||||
*@
|
*@
|
||||||
<div>
|
<div>
|
||||||
<div class="muted small">@helper.html.datetimeago(activity.activityDate)</div>
|
<div class="muted small">@gitbucket.core.helper.html.datetimeago(activity.activityDate)</div>
|
||||||
<div class="strong">
|
<div class="strong">
|
||||||
@avatar(activity.activityUserName, 16)
|
@helpers.avatar(activity.activityUserName, 16)
|
||||||
@activityMessage(activity.message)
|
@helpers.activityMessage(activity.message)
|
||||||
</div>
|
</div>
|
||||||
@activity.additionalInfo.map { additionalInfo =>
|
@activity.additionalInfo.map { additionalInfo =>
|
||||||
<div class=" activity-message">@additionalInfo</div>
|
<div class=" activity-message">@additionalInfo</div>
|
||||||
@@ -81,10 +80,10 @@
|
|||||||
<div class="activity-icon-large"><i class="mega-octicon octicon-@image"></i></div>
|
<div class="activity-icon-large"><i class="mega-octicon octicon-@image"></i></div>
|
||||||
*@
|
*@
|
||||||
<div>
|
<div>
|
||||||
<div class="muted small">@helper.html.datetimeago(activity.activityDate)</div>
|
<div class="muted small">@gitbucket.core.helper.html.datetimeago(activity.activityDate)</div>
|
||||||
<div class="strong">
|
<div class="strong">
|
||||||
@avatar(activity.activityUserName, 16)
|
@helpers.avatar(activity.activityUserName, 16)
|
||||||
@activityMessage(activity.message)
|
@helpers.activityMessage(activity.message)
|
||||||
</div>
|
</div>
|
||||||
@additionalInfo
|
@additionalInfo
|
||||||
</div>
|
</div>
|
||||||
@@ -95,10 +94,10 @@
|
|||||||
<div class="activity-icon-small"><i class="octicon octicon-@image"></i></div>
|
<div class="activity-icon-small"><i class="octicon octicon-@image"></i></div>
|
||||||
*@
|
*@
|
||||||
<div>
|
<div>
|
||||||
<span class="muted small">@helper.html.datetimeago(activity.activityDate)</span>
|
<span class="muted small">@gitbucket.core.helper.html.datetimeago(activity.activityDate)</span>
|
||||||
<div>
|
<div>
|
||||||
@avatar(activity.activityUserName, 16)
|
@helpers.avatar(activity.activityUserName, 16)
|
||||||
@activityMessage(activity.message)
|
@helpers.activityMessage(activity.message)
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
@(owner: String, repository: String)(textarea: Html)(implicit context: gitbucket.core.controller.Context)
|
@(repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
||||||
@import context._
|
completionContext: String, generateScript: Boolean = true)(textarea: Html)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import gitbucket.core.util.FileUtil
|
@import gitbucket.core.util.FileUtil
|
||||||
|
@import gitbucket.core.view.helpers
|
||||||
<div class="muted attachable">
|
<div class="muted attachable">
|
||||||
@textarea
|
@textarea
|
||||||
<div class="clickable">Attach images or documents by dragging & dropping, or selecting them.</div>
|
<div class="clickable">Attach images or documents by dragging & dropping, or selecting them.</div>
|
||||||
@@ -8,23 +9,60 @@
|
|||||||
@defining("(id=\")([\\w\\-]*)(\")".r.findFirstMatchIn(textarea.body).map(_.group(2))){ textareaId =>
|
@defining("(id=\")([\\w\\-]*)(\")".r.findFirstMatchIn(textarea.body).map(_.group(2))){ textareaId =>
|
||||||
<script>
|
<script>
|
||||||
$(function(){
|
$(function(){
|
||||||
try {
|
@gitbucket.core.plugin.PluginRegistry().getSuggestionProviders.map { provider =>
|
||||||
$([$('#@textareaId').closest('div')[0], $('#@textareaId').next('div')[0]]).dropzone({
|
@if(provider.context.contains(completionContext)){
|
||||||
url: '@path/upload/file/@owner/@repository',
|
var @provider.id = @Html(helpers.json(provider.values(repository)));
|
||||||
maxFilesize: 10,
|
@Html(provider.additionalScript)
|
||||||
acceptedFiles: @Html(FileUtil.mimeTypeWhiteList.mkString("'", ",", "'")),
|
}
|
||||||
dictInvalidFileType: 'Unfortunately, we don\'t support that file type. Try again with a PNG, GIF, JPG, DOCX, PPTX, XLSX, TXT, or PDF.',
|
}
|
||||||
previewTemplate: "<div class=\"dz-preview\">\n <div class=\"dz-progress\"><span class=\"dz-upload\" data-dz-uploadprogress>Uploading your files...</span></div>\n <div class=\"dz-error-message\"><span data-dz-errormessage></span></div>\n</div>",
|
$('#@textareaId').textcomplete([
|
||||||
success: function(file, id) {
|
@gitbucket.core.plugin.PluginRegistry().getSuggestionProviders.map { provider =>
|
||||||
var attachFile = (file.type.match(/image\/.*/) ? '\n![' + file.name.split('.')[0] : '\n[' + file.name) +
|
@if(provider.context.contains(completionContext)){
|
||||||
'](@baseUrl/@owner/@repository/_attached/' + id + ')';
|
{
|
||||||
$('#@textareaId').val($('#@textareaId').val() + attachFile);
|
id: '@{provider.id}',
|
||||||
$(file.previewElement).prevAll('div.dz-preview').addBack().remove();
|
match: /\B@{provider.prefix}([\-+\w]*)$/,
|
||||||
|
search: function (term, callback) {
|
||||||
|
callback($.map(@{provider.id}, function (proposal) {
|
||||||
|
return proposal.indexOf(term) === 0 ? proposal : null;
|
||||||
|
}));
|
||||||
|
},
|
||||||
|
template: function (value) {
|
||||||
|
return @{Html(provider.template)};
|
||||||
|
},
|
||||||
|
replace: function (value) {
|
||||||
|
return '@{provider.prefix}' + value + '@{provider.suffix}';
|
||||||
|
},
|
||||||
|
index: 1
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
], {
|
||||||
|
onKeydown: function (e, commands) {
|
||||||
|
if (e.ctrlKey && e.keyCode === 74) { // CTRL-J
|
||||||
|
return commands.KEY_ENTER;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
@if(generateScript){
|
||||||
|
try {
|
||||||
|
$([$('#@textareaId').closest('div')[0], $('#@textareaId').next('div')[0]]).dropzone({
|
||||||
|
url: '@context.path/upload/file/@repository.owner/@repository.name',
|
||||||
|
maxFilesize: 10,
|
||||||
|
acceptedFiles: @Html(FileUtil.mimeTypeWhiteList.mkString("'", ",", "'")),
|
||||||
|
dictInvalidFileType: 'Unfortunately, we don\'t support that file type. Try again with a PNG, GIF, JPG, DOCX, PPTX, XLSX, TXT, or PDF.',
|
||||||
|
previewTemplate: "<div class=\"dz-preview\">\n <div class=\"dz-progress\"><span class=\"dz-upload\" data-dz-uploadprogress>Uploading your files...</span></div>\n <div class=\"dz-error-message\"><span data-dz-errormessage></span></div>\n</div>",
|
||||||
|
success: function(file, id) {
|
||||||
|
var attachFile = (file.type.match(/image\/.*/) ? '\n![' + file.name.split('.')[0] : '\n[' + file.name) +
|
||||||
|
'](@context.baseUrl/@repository.owner/@repository.name/_attached/' + id + ')';
|
||||||
|
$('#@textareaId').val($('#@textareaId').val() + attachFile);
|
||||||
|
$(file.previewElement).prevAll('div.dz-preview').addBack().remove();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} catch(e) {
|
||||||
|
if (e.message !== "Dropzone already attached.") {
|
||||||
|
throw e;
|
||||||
}
|
}
|
||||||
});
|
|
||||||
} catch(e) {
|
|
||||||
if (e.message !== "Dropzone already attached.") {
|
|
||||||
throw e;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,11 +1,8 @@
|
|||||||
@(branch: String = "",
|
@(branch: String = "",
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
||||||
hasWritePermission: Boolean)(body: Html)(implicit context: gitbucket.core.controller.Context)
|
hasWritePermission: Boolean)(body: Html)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import gitbucket.core.service.RepositoryService
|
@import gitbucket.core.view.helpers
|
||||||
@import context._
|
@gitbucket.core.helper.html.dropdown(
|
||||||
@import gitbucket.core._
|
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
@helper.html.dropdown(
|
|
||||||
value = if(branch.length == 40) branch.substring(0, 10) else branch,
|
value = if(branch.length == 40) branch.substring(0, 10) else branch,
|
||||||
prefix = if(branch.length == 40) "tree" else if(repository.branchList.contains(branch)) "branch" else "tree"
|
prefix = if(branch.length == 40) "tree" else if(repository.branchList.contains(branch)) "branch" else "tree"
|
||||||
) {
|
) {
|
||||||
@@ -14,7 +11,7 @@
|
|||||||
@body
|
@body
|
||||||
@if(hasWritePermission) {
|
@if(hasWritePermission) {
|
||||||
<li id="create-branch" style="display: none;">
|
<li id="create-branch" style="display: none;">
|
||||||
<a><form action="@url(repository)/branches" method="post" style="margin: 0;">
|
<a><form action="@helpers.url(repository)/branches" method="post" style="margin: 0;">
|
||||||
<span class="new-branch-name">Create branch: <span class="new-branch"></span></span>
|
<span class="new-branch-name">Create branch: <span class="new-branch"></span></span>
|
||||||
<br><span style="padding-left: 17px;">from '@branch'</span>
|
<br><span style="padding-left: 17px;">from '@branch'</span>
|
||||||
<input type="hidden" name="new">
|
<input type="hidden" name="new">
|
||||||
|
|||||||
@@ -2,18 +2,16 @@
|
|||||||
hasWritePermission: Boolean,
|
hasWritePermission: Boolean,
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
||||||
latestCommitId: Option[String] = None)(implicit context: gitbucket.core.controller.Context)
|
latestCommitId: Option[String] = None)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core._
|
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
<div class="@if(comment.fileName.isDefined && (!latestCommitId.isDefined || latestCommitId.get == comment.commitId)){inline-comment}"
|
<div class="@if(comment.fileName.isDefined && (!latestCommitId.isDefined || latestCommitId.get == comment.commitId)){inline-comment}"
|
||||||
id="discussion_r@comment.commentId"
|
id="discussion_r@comment.commentId"
|
||||||
@if(comment.fileName.isDefined){filename="@comment.fileName.get"}
|
@if(comment.fileName.isDefined){filename="@comment.fileName.get"}
|
||||||
@if(comment.newLine.isDefined){newline="@comment.newLine.get"}
|
@if(comment.newLine.isDefined){newline="@comment.newLine.get"}
|
||||||
@if(comment.oldLine.isDefined){oldline="@comment.oldLine.get"}>
|
@if(comment.oldLine.isDefined){oldline="@comment.oldLine.get"}>
|
||||||
<div class="issue-avatar-image">@avatarLink(comment.commentedUserName, 48)</div>
|
<div class="issue-avatar-image">@helpers.avatarLink(comment.commentedUserName, 48)</div>
|
||||||
<div class="panel panel-default commit-comment-box commit-comment-@comment.commentId">
|
<div class="panel panel-default commit-comment-box commit-comment-@comment.commentId">
|
||||||
<div class="panel-heading">
|
<div class="panel-heading">
|
||||||
@user(comment.commentedUserName, styleClass="username strong")
|
@helpers.user(comment.commentedUserName, styleClass="username strong")
|
||||||
<span class="muted">
|
<span class="muted">
|
||||||
commented
|
commented
|
||||||
@if(comment.issueId.isDefined){
|
@if(comment.issueId.isDefined){
|
||||||
@@ -22,19 +20,19 @@
|
|||||||
@if(comment.fileName.isDefined){
|
@if(comment.fileName.isDefined){
|
||||||
on @comment.fileName.get
|
on @comment.fileName.get
|
||||||
}
|
}
|
||||||
in <a href="@path/@repository.owner/@repository.name/commit/@comment.commitId">@comment.commitId.substring(0, 7)</a>
|
in <a href="@context.path/@repository.owner/@repository.name/commit/@comment.commitId">@comment.commitId.substring(0, 7)</a>
|
||||||
}
|
}
|
||||||
@helper.html.datetimeago(comment.registeredDate)
|
@gitbucket.core.helper.html.datetimeago(comment.registeredDate)
|
||||||
</span>
|
</span>
|
||||||
<span class="pull-right">
|
<span class="pull-right">
|
||||||
@if(hasWritePermission || loginAccount.map(_.userName == comment.commentedUserName).getOrElse(false)){
|
@if(hasWritePermission || context.loginAccount.map(_.userName == comment.commentedUserName).getOrElse(false)){
|
||||||
<a href="#" data-comment-id="@comment.commentId"><i class="octicon octicon-pencil"></i></a>
|
<a href="#" data-comment-id="@comment.commentId"><i class="octicon octicon-pencil"></i></a>
|
||||||
<a href="#" data-comment-id="@comment.commentId"><i class="octicon octicon-x"></i></a>
|
<a href="#" data-comment-id="@comment.commentId"><i class="octicon octicon-x"></i></a>
|
||||||
}
|
}
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="panel-body issue-content commit-commentContent-@comment.commentId markdown-body">
|
<div class="panel-body issue-content commit-commentContent-@comment.commentId markdown-body">
|
||||||
@markdown(
|
@helpers.markdown(
|
||||||
markdown = comment.content,
|
markdown = comment.content,
|
||||||
repository = repository,
|
repository = repository,
|
||||||
enableWikiLink = false,
|
enableWikiLink = false,
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
@(latestUpdatedDate: java.util.Date,
|
@(latestUpdatedDate: java.util.Date,
|
||||||
recentOnly: Boolean = true)
|
recentOnly: Boolean = true)
|
||||||
@import gitbucket.core.view.helpers._
|
@import gitbucket.core.view.helpers
|
||||||
<span data-toggle="tooltip" title="@datetime(latestUpdatedDate)">
|
<span data-toggle="tooltip" title="@helpers.datetime(latestUpdatedDate)">
|
||||||
@if(recentOnly){
|
@if(recentOnly){
|
||||||
@datetimeAgoRecentOnly(latestUpdatedDate)
|
@helpers.datetimeAgoRecentOnly(latestUpdatedDate)
|
||||||
}else{
|
} else {
|
||||||
@datetimeAgo(latestUpdatedDate)
|
@helpers.datetimeAgo(latestUpdatedDate)
|
||||||
}
|
}
|
||||||
</span>
|
</span>
|
||||||
|
|||||||
@@ -6,19 +6,16 @@
|
|||||||
issueId: Option[Int],
|
issueId: Option[Int],
|
||||||
hasWritePermission: Boolean,
|
hasWritePermission: Boolean,
|
||||||
showLineNotes: Boolean)(implicit context: gitbucket.core.controller.Context)
|
showLineNotes: Boolean)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
@import org.eclipse.jgit.diff.DiffEntry.ChangeType
|
@import org.eclipse.jgit.diff.DiffEntry.ChangeType
|
||||||
@if(showIndex){
|
@if(showIndex){
|
||||||
<div style="overflow: hidden;">
|
<div class="pull-right" style="margin-bottom: 10px;">
|
||||||
<div class="pull-right" style="margin-bottom: 10px;">
|
<div class="btn-group" data-toggle="buttons-radio">
|
||||||
<div class="btn-group" data-toggle="buttons-radio">
|
<input type="button" id="btn-unified" class="btn btn-default btn-small active" value="Unified">
|
||||||
<input type="button" id="btn-unified" class="btn btn-default btn-small active" value="Unified">
|
<input type="button" id="btn-split" class="btn btn-default btn-small" value="Split">
|
||||||
<input type="button" id="btn-split" class="btn btn-default btn-small" value="Split">
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
Showing <a href="javascript:void(0);" id="toggle-file-list">@diffs.size changed @plural(diffs.size, "file")</a>
|
|
||||||
</div>
|
</div>
|
||||||
|
Showing <a href="javascript:void(0);" id="toggle-file-list">@diffs.size changed @helpers.plural(diffs.size, "file")</a>
|
||||||
<ul id="commit-file-list" style="display: none;">
|
<ul id="commit-file-list" style="display: none;">
|
||||||
@diffs.zipWithIndex.map { case (diff, i) =>
|
@diffs.zipWithIndex.map { case (diff, i) =>
|
||||||
<li@if(i > 0){ class="border"}>
|
<li@if(i > 0){ class="border"}>
|
||||||
@@ -51,7 +48,7 @@
|
|||||||
<div class="pull-right align-right">
|
<div class="pull-right align-right">
|
||||||
<label class="no-margin"><input type="checkbox" class="ignore-whitespace" value="1"/> Ignore Space</label>
|
<label class="no-margin"><input type="checkbox" class="ignore-whitespace" value="1"/> Ignore Space</label>
|
||||||
<label class="no-margin"><input type="checkbox" class="toggle-notes" checked> Show notes</label>
|
<label class="no-margin"><input type="checkbox" class="toggle-notes" checked> Show notes</label>
|
||||||
<a href="@url(repository)/blob/@newCommitId.get/@diff.newPath" class="btn btn-default btn-sm" title="View the whole file at version @newCommitId.get.substring(0, 10)" data-toggle="tooltip">View</a>
|
<a href="@helpers.url(repository)/blob/@newCommitId.get/@diff.newPath" class="btn btn-default btn-sm" title="View the whole file at version @newCommitId.get.substring(0, 10)" data-toggle="tooltip">View</a>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
<span class="diffstat"><i class="octicon octicon-diff-renamed"></i></span>
|
<span class="diffstat"><i class="octicon octicon-diff-renamed"></i></span>
|
||||||
@@ -62,13 +59,13 @@
|
|||||||
<div class="pull-right align-right">
|
<div class="pull-right align-right">
|
||||||
<label class="no-margin"><input type="checkbox" class="ignore-whitespace" value="1"/> Ignore Space</label>
|
<label class="no-margin"><input type="checkbox" class="ignore-whitespace" value="1"/> Ignore Space</label>
|
||||||
<label class="no-margin"><input type="checkbox" class="toggle-notes" checked> Show notes</label>
|
<label class="no-margin"><input type="checkbox" class="toggle-notes" checked> Show notes</label>
|
||||||
<a href="@url(repository)/blob/@newCommitId.get/@diff.newPath" class="btn btn-default btn-sm" title="View the whole file at version @newCommitId.get.substring(0, 10)" data-toggle="tooltip">View</a>
|
<a href="@helpers.url(repository)/blob/@newCommitId.get/@diff.newPath" class="btn btn-default btn-sm" title="View the whole file at version @newCommitId.get.substring(0, 10)" data-toggle="tooltip">View</a>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
<span class="diffstat">
|
<span class="diffstat">
|
||||||
@if(diff.changeType == ChangeType.ADD){
|
@if(diff.changeType == ChangeType.ADD){
|
||||||
<i class="octicon octicon-diff-added"></i>
|
<i class="octicon octicon-diff-added"></i>
|
||||||
}else{
|
} else {
|
||||||
<i class="octicon octicon-diff-modified"></i>
|
<i class="octicon octicon-diff-modified"></i>
|
||||||
}
|
}
|
||||||
</span>
|
</span>
|
||||||
@@ -78,7 +75,7 @@
|
|||||||
@if(oldCommitId.isDefined){
|
@if(oldCommitId.isDefined){
|
||||||
<div class="pull-right align-right">
|
<div class="pull-right align-right">
|
||||||
<label class="no-margin"><input type="checkbox" class="toggle-notes" checked> Show notes</label>
|
<label class="no-margin"><input type="checkbox" class="toggle-notes" checked> Show notes</label>
|
||||||
<a href="@url(repository)/blob/@oldCommitId.get/@diff.oldPath" class="btn btn-default btn-sm" title="View the whole file at version @oldCommitId.get.substring(0, 10)" data-toggle="tooltip">View</a>
|
<a href="@helpers.url(repository)/blob/@oldCommitId.get/@diff.oldPath" class="btn btn-default btn-sm" title="View the whole file at version @oldCommitId.get.substring(0, 10)" data-toggle="tooltip">View</a>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
<span class="diffstat"><i class="octicon octicon-diff-removed"></i></span>
|
<span class="diffstat"><i class="octicon octicon-diff-removed"></i></span>
|
||||||
@@ -106,14 +103,14 @@
|
|||||||
@if(diff.newIsImage || diff.oldIsImage){
|
@if(diff.newIsImage || diff.oldIsImage){
|
||||||
<div class="diff-image-render diff2up">
|
<div class="diff-image-render diff2up">
|
||||||
@if(oldCommitId.isDefined && diff.oldIsImage){
|
@if(oldCommitId.isDefined && diff.oldIsImage){
|
||||||
<div class="diff-image-frame diff-old"><img src="@url(repository)/raw/@oldCommitId.get/@diff.oldPath" class="diff-image" onload="onLoadedDiffImages(this)" style="display:none" /></div>
|
<div class="diff-image-frame diff-old"><img src="@helpers.url(repository)/raw/@oldCommitId.get/@diff.oldPath" class="diff-image" onload="onLoadedDiffImages(this)" style="display:none" /></div>
|
||||||
} else {
|
} else {
|
||||||
@if(diff.changeType != ChangeType.ADD){
|
@if(diff.changeType != ChangeType.ADD){
|
||||||
<div style="padding: 12px;">Not supported</div>
|
<div style="padding: 12px;">Not supported</div>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@if(newCommitId.isDefined && diff.newIsImage){
|
@if(newCommitId.isDefined && diff.newIsImage){
|
||||||
<div class="diff-image-frame diff-new"><img src="@url(repository)/raw/@newCommitId.get/@diff.newPath" class="diff-image" onload="onLoadedDiffImages(this)" style="display:none" /></div>
|
<div class="diff-image-frame diff-new"><img src="@helpers.url(repository)/raw/@newCommitId.get/@diff.newPath" class="diff-image" onload="onLoadedDiffImages(this)" style="display:none" /></div>
|
||||||
} else {
|
} else {
|
||||||
@if(diff.changeType != ChangeType.DELETE){
|
@if(diff.changeType != ChangeType.DELETE){
|
||||||
<div style="padding: 12px;">Not supported</div>
|
<div style="padding: 12px;">Not supported</div>
|
||||||
@@ -133,8 +130,8 @@
|
|||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
}
|
}
|
||||||
<script type="text/javascript" src="@assets/vendors/jsdifflib/difflib.js"></script>
|
<script type="text/javascript" src="@helpers.assets/vendors/jsdifflib/difflib.js"></script>
|
||||||
<link href="@assets/vendors/jsdifflib/diffview.css" type="text/css" rel="stylesheet" />
|
<link href="@helpers.assets/vendors/jsdifflib/diffview.css" type="text/css" rel="stylesheet" />
|
||||||
<script>
|
<script>
|
||||||
$(function(){
|
$(function(){
|
||||||
@if(showIndex){
|
@if(showIndex){
|
||||||
@@ -205,7 +202,7 @@ $(function(){
|
|||||||
var commitId = $this.closest('.table-bordered').attr('commitId'),
|
var commitId = $this.closest('.table-bordered').attr('commitId'),
|
||||||
fileName = $this.closest('.table-bordered').attr('fileName'),
|
fileName = $this.closest('.table-bordered').attr('fileName'),
|
||||||
oldLineNumber, newLineNumber,
|
oldLineNumber, newLineNumber,
|
||||||
url = '@url(repository)/commit/' + commitId + '/comment/_form?fileName=' + fileName@issueId.map { id => + '&issueId=@id' };
|
url = '@helpers.url(repository)/commit/' + commitId + '/comment/_form?fileName=' + fileName@issueId.map { id => + '&issueId=@id' };
|
||||||
if (viewType == 0) {
|
if (viewType == 0) {
|
||||||
oldLineNumber = $this.parent().prev('.oldline').attr('line-number');
|
oldLineNumber = $this.parent().prev('.oldline').attr('line-number');
|
||||||
newLineNumber = $this.parent().prev('.newline').attr('line-number');
|
newLineNumber = $this.parent().prev('.newline').attr('line-number');
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
@(activities: List[gitbucket.core.model.Activity])(implicit context: gitbucket.core.controller.Context)<?xml version="1.0" encoding="UTF-8"?>
|
@(activities: List[gitbucket.core.model.Activity])(implicit context: gitbucket.core.controller.Context)<?xml version="1.0" encoding="UTF-8"?>
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
<feed xmlns="http://www.w3.org/2005/Atom" xmlns:media="http://search.yahoo.com/mrss/" xml:lang="en-US">
|
<feed xmlns="http://www.w3.org/2005/Atom" xmlns:media="http://search.yahoo.com/mrss/" xml:lang="en-US">
|
||||||
<id>tag:@context.host,2013:gitbucket</id>
|
<id>tag:@context.host,2013:gitbucket</id>
|
||||||
<title>Gitbucket's activities</title>
|
<title>Gitbucket's activities</title>
|
||||||
@@ -9,19 +8,19 @@
|
|||||||
<name>Gitbucket</name>
|
<name>Gitbucket</name>
|
||||||
<uri>@context.baseUrl</uri>
|
<uri>@context.baseUrl</uri>
|
||||||
</author>
|
</author>
|
||||||
<updated>@datetimeRFC3339(if(activities.isEmpty) new java.util.Date else activities.map(_.activityDate).max)</updated>
|
<updated>@helpers.datetimeRFC3339(if(activities.isEmpty) new java.util.Date else activities.map(_.activityDate).max)</updated>
|
||||||
@activities.map { activity =>
|
@activities.map { activity =>
|
||||||
<entry>
|
<entry>
|
||||||
<id>tag:@context.host,@date(activity.activityDate):activity:@activity.activityId</id>
|
<id>tag:@context.host,@helpers.date(activity.activityDate):activity:@activity.activityId</id>
|
||||||
<published>@datetimeRFC3339(activity.activityDate)</published>
|
<published>@helpers.datetimeRFC3339(activity.activityDate)</published>
|
||||||
<updated>@datetimeRFC3339(activity.activityDate)</updated>
|
<updated>@helpers.datetimeRFC3339(activity.activityDate)</updated>
|
||||||
<link type="text/html" rel="alternate" href="@context.baseUrl/@activity.userName/@activity.repositoryName" />
|
<link type="text/html" rel="alternate" href="@context.baseUrl/@activity.userName/@activity.repositoryName" />
|
||||||
<title type="html">@removeHtml(activityMessage(activity.message))</title>
|
<title type="html">@helpers.removeHtml(helpers.activityMessage(activity.message))</title>
|
||||||
<author>
|
<author>
|
||||||
<name>@activity.activityUserName</name>
|
<name>@activity.activityUserName</name>
|
||||||
<uri>@url(activity.activityUserName)</uri>
|
<uri>@helpers.url(activity.activityUserName)</uri>
|
||||||
</author>
|
</author>
|
||||||
<content type="html">@activityMessage(activity.message)</content>
|
<content type="html">@helpers.activityMessage(activity.message)</content>
|
||||||
</entry>
|
</entry>
|
||||||
}
|
}
|
||||||
</feed>
|
</feed>
|
||||||
|
|||||||
@@ -1,16 +1,15 @@
|
|||||||
@(repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
@(repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
||||||
groupAndPerm: Map[String, Boolean])(implicit context: gitbucket.core.controller.Context)
|
groupAndPerm: Map[String, Boolean])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
<h2 class="facebox-header">Where should we fork this repository?</h2>
|
<h2 class="facebox-header">Where should we fork this repository?</h2>
|
||||||
<form action="@url(repository)/fork" id="fork" method="post">
|
<form action="@helpers.url(repository)/fork" id="fork" method="post">
|
||||||
<div class="owner-select-grid">
|
<div class="owner-select-grid">
|
||||||
<div class="owner-select-target js-fork-owner-select-target enabled">@avatar(loginAccount.get.userName, 100)<span class="owner css-truncate" title="@@@loginAccount.get.userName">@@@loginAccount.get.userName</span></div>
|
<div class="owner-select-target js-fork-owner-select-target enabled">@helpers.avatar(context.loginAccount.get.userName, 100)<span class="owner css-truncate" title="@@@context.loginAccount.get.userName">@@@context.loginAccount.get.userName</span></div>
|
||||||
@for((groupName, isManager) <- groupAndPerm) {
|
@for((groupName, isManager) <- groupAndPerm) {
|
||||||
@if(isManager) {
|
@if(isManager) {
|
||||||
<div class="owner-select-target js-fork-owner-select-target enabled">@avatar(groupName, 100)<span class="owner css-truncate" title="@@@groupName">@@@groupName</span></div>
|
<div class="owner-select-target js-fork-owner-select-target enabled">@helpers.avatar(groupName, 100)<span class="owner css-truncate" title="@@@groupName">@@@groupName</span></div>
|
||||||
} else {
|
} else {
|
||||||
<div title="You don't have permission to fork here." class="owner-select-target js-fork-owner-select-target disabled">@avatar(groupName, 100)<span class="owner css-truncate" title="@@@groupName">@@@groupName</span></div>
|
<div title="You don't have permission to fork here." class="owner-select-target js-fork-owner-select-target disabled">@helpers.avatar(groupName, 100)<span class="owner css-truncate" title="@@@groupName">@@@groupName</span></div>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -5,15 +5,14 @@
|
|||||||
enableLineBreaks: Boolean,
|
enableLineBreaks: Boolean,
|
||||||
enableTaskList: Boolean,
|
enableTaskList: Boolean,
|
||||||
hasWritePermission: Boolean,
|
hasWritePermission: Boolean,
|
||||||
|
completionContext: String,
|
||||||
style: String = "",
|
style: String = "",
|
||||||
styleClass: String = "",
|
styleClass: String = "",
|
||||||
placeholder: String = "Leave a comment",
|
placeholder: String = "Leave a comment",
|
||||||
elastic: Boolean = false,
|
elastic: Boolean = false,
|
||||||
tabIndex: Int = -2,
|
tabIndex: Int = -2,
|
||||||
uid: Long = new java.util.Date().getTime())(implicit context: gitbucket.core.controller.Context)
|
uid: Long = new java.util.Date().getTime())(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core._
|
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
<div class="tabbable">
|
<div class="tabbable">
|
||||||
<ul class="nav nav-tabs fill-width" style="margin-bottom: 10px;">
|
<ul class="nav nav-tabs fill-width" style="margin-bottom: 10px;">
|
||||||
<li class="active"><a href="#tab@uid" data-toggle="tab">Write</a></li>
|
<li class="active"><a href="#tab@uid" data-toggle="tab">Write</a></li>
|
||||||
@@ -28,11 +27,11 @@
|
|||||||
@if(style.nonEmpty){ style="@style"}
|
@if(style.nonEmpty){ style="@style"}
|
||||||
@if(styleClass.nonEmpty){ class="@styleClass" }>@content</textarea>
|
@if(styleClass.nonEmpty){ class="@styleClass" }>@content</textarea>
|
||||||
}
|
}
|
||||||
@if(enableWikiLink){
|
@gitbucket.core.helper.html.attached(
|
||||||
@textarea
|
repository = repository,
|
||||||
} else {
|
completionContext = completionContext,
|
||||||
@helper.html.attached(repository.owner, repository.name)(textarea)
|
generateScript = enableWikiLink
|
||||||
}
|
)(textarea)
|
||||||
</div>
|
</div>
|
||||||
<div class="tab-pane" id="tab@(uid+1)">
|
<div class="tab-pane" id="tab@(uid+1)">
|
||||||
<div class="markdown-body" id="preview-area@uid">
|
<div class="markdown-body" id="preview-area@uid">
|
||||||
@@ -40,8 +39,8 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<link href="@assets/vendors/google-code-prettify/prettify.css" type="text/css" rel="stylesheet"/>
|
<link href="@helpers.assets/vendors/google-code-prettify/prettify.css" type="text/css" rel="stylesheet"/>
|
||||||
<script src="@assets/vendors/google-code-prettify/prettify.js"></script>
|
<script src="@helpers.assets/vendors/google-code-prettify/prettify.js"></script>
|
||||||
<script>
|
<script>
|
||||||
$(function(){
|
$(function(){
|
||||||
@if(elastic){
|
@if(elastic){
|
||||||
@@ -49,8 +48,8 @@ $(function(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
$('#preview@uid').click(function(){
|
$('#preview@uid').click(function(){
|
||||||
$('#preview-area@uid').html('<img src="@assets/common/images/indicator.gif"> Previewing...');
|
$('#preview-area@uid').html('<img src="@helpers.assets/common/images/indicator.gif"> Previewing...');
|
||||||
$.post('@url(repository)/_preview', {
|
$.post('@helpers.url(repository)/_preview', {
|
||||||
content : $('#content@uid').val(),
|
content : $('#content@uid').val(),
|
||||||
enableWikiLink : @enableWikiLink,
|
enableWikiLink : @enableWikiLink,
|
||||||
enableRefsLink : @enableRefsLink,
|
enableRefsLink : @enableRefsLink,
|
||||||
|
|||||||
@@ -1,7 +1,4 @@
|
|||||||
@(repository: gitbucket.core.service.RepositoryService.RepositoryInfo, large: Boolean)(implicit context: gitbucket.core.controller.Context)
|
@(repository: gitbucket.core.service.RepositoryService.RepositoryInfo, large: Boolean)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import gitbucket.core.service.RepositoryService
|
|
||||||
@import context._
|
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
@if(repository.repository.isPrivate){
|
@if(repository.repository.isPrivate){
|
||||||
<i class="@{if(large){"mega-"}}octicon octicon-lock"></i>
|
<i class="@{if(large){"mega-"}}octicon octicon-lock"></i>
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -1,8 +1,7 @@
|
|||||||
@(account: Option[gitbucket.core.model.Account])(implicit context: gitbucket.core.controller.Context)
|
@(account: Option[gitbucket.core.model.Account])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
|
||||||
<div id="avatar" class="muted">
|
<div id="avatar" class="muted">
|
||||||
@if(account.nonEmpty && account.get.image.nonEmpty){
|
@if(account.nonEmpty && account.get.image.nonEmpty){
|
||||||
<img src="@path/@account.get.userName/_avatar" style="with: 120px; height: 120px;"/>
|
<img src="@context.path/@account.get.userName/_avatar" style="with: 120px; height: 120px;"/>
|
||||||
} else {
|
} else {
|
||||||
<div id="clickable">Upload Image</div>
|
<div id="clickable">Upload Image</div>
|
||||||
}
|
}
|
||||||
@@ -17,7 +16,7 @@
|
|||||||
<script>
|
<script>
|
||||||
$(function(){
|
$(function(){
|
||||||
var dropzone = new Dropzone('div#clickable', {
|
var dropzone = new Dropzone('div#clickable', {
|
||||||
url: '@path/upload/image',
|
url: '@context.path/upload/image',
|
||||||
previewsContainer: 'div#avatar',
|
previewsContainer: 'div#avatar',
|
||||||
parallelUploads: 1,
|
parallelUploads: 1,
|
||||||
thumbnailWidth: 120,
|
thumbnailWidth: 120,
|
||||||
|
|||||||
@@ -1,22 +1,21 @@
|
|||||||
@(activities: List[gitbucket.core.model.Activity],
|
@(activities: List[gitbucket.core.model.Activity],
|
||||||
recentRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo],
|
recentRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo],
|
||||||
userRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo])(implicit context: gitbucket.core.controller.Context)
|
userRepositories: List[gitbucket.core.service.RepositoryService.RepositoryInfo])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.html.main("GitBucket"){
|
||||||
@main("GitBucket"){
|
@gitbucket.core.dashboard.html.sidebar(recentRepositories, userRepositories){
|
||||||
@dashboard.html.sidebar(recentRepositories, userRepositories){
|
@context.settings.information.map { information =>
|
||||||
@settings.information.map { information =>
|
|
||||||
<div class="alert alert-info" style="background-color: white; color: #555; border-color: #4183c4; font-size: small; line-height: 120%;">
|
<div class="alert alert-info" style="background-color: white; color: #555; border-color: #4183c4; font-size: small; line-height: 120%;">
|
||||||
<button type="button" class="close" data-dismiss="alert">×</button>
|
<button type="button" class="close" data-dismiss="alert">×</button>
|
||||||
@Html(information)
|
@Html(information)
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
@dashboard.html.tab()
|
@gitbucket.core.dashboard.html.tab()
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<div class="pull-right">
|
<div class="pull-right">
|
||||||
<a href="@path/activities.atom"><img src="@assets/common/images/feed.png" alt="activities"></a>
|
<a href="@context.path/activities.atom"><img src="@helpers.assets/common/images/feed.png" alt="activities"></a>
|
||||||
</div>
|
</div>
|
||||||
@helper.html.activities(activities)
|
@gitbucket.core.helper.html.activities(activities)
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,15 +2,14 @@
|
|||||||
reopenable: Boolean,
|
reopenable: Boolean,
|
||||||
hasWritePermission: Boolean,
|
hasWritePermission: Boolean,
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@if(context.loginAccount.isDefined){
|
||||||
@if(loginAccount.isDefined){
|
|
||||||
<hr/><br/>
|
<hr/><br/>
|
||||||
<form method="POST" validate="true">
|
<form method="POST" validate="true">
|
||||||
<div class="issue-avatar-image">@avatarLink(loginAccount.get.userName, 48)</div>
|
<div class="issue-avatar-image">@helpers.avatarLink(context.loginAccount.get.userName, 48)</div>
|
||||||
<div class="panel panel-default issue-comment-box">
|
<div class="panel panel-default issue-comment-box">
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
@helper.html.preview(
|
@gitbucket.core.helper.html.preview(
|
||||||
repository = repository,
|
repository = repository,
|
||||||
content = "",
|
content = "",
|
||||||
enableWikiLink = false,
|
enableWikiLink = false,
|
||||||
@@ -18,16 +17,17 @@
|
|||||||
enableLineBreaks = true,
|
enableLineBreaks = true,
|
||||||
enableTaskList = true,
|
enableTaskList = true,
|
||||||
hasWritePermission = hasWritePermission,
|
hasWritePermission = hasWritePermission,
|
||||||
|
completionContext = "issues",
|
||||||
style = "",
|
style = "",
|
||||||
elastic = true,
|
elastic = true,
|
||||||
tabIndex = 1
|
tabIndex = 1
|
||||||
)
|
)
|
||||||
<div class="text-right">
|
<div class="text-right">
|
||||||
<input type="hidden" name="issueId" value="@issue.issueId"/>
|
<input type="hidden" name="issueId" value="@issue.issueId"/>
|
||||||
@if((reopenable || !issue.closed) && (hasWritePermission || issue.openedUserName == loginAccount.get.userName)){
|
@if((reopenable || !issue.closed) && (hasWritePermission || issue.openedUserName == context.loginAccount.get.userName)){
|
||||||
<input type="submit" class="btn btn-default" tabindex="3" formaction="@url(repository)/issue_comments/state" value="@{if(issue.closed) "Reopen" else "Close"}" id="action"/>
|
<input type="submit" class="btn btn-default" tabindex="3" formaction="@helpers.url(repository)/issue_comments/state" value="@{if(issue.closed) "Reopen" else "Close"}" id="action"/>
|
||||||
}
|
}
|
||||||
<input type="submit" class="btn btn-success" tabindex="2" formaction="@url(repository)/issue_comments/new" value="Comment"/>
|
<input type="submit" class="btn btn-success" tabindex="2" formaction="@helpers.url(repository)/issue_comments/new" value="Comment"/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -3,22 +3,21 @@
|
|||||||
hasWritePermission: Boolean,
|
hasWritePermission: Boolean,
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
||||||
pullreq: Option[gitbucket.core.model.PullRequest] = None)(implicit context: gitbucket.core.controller.Context)
|
pullreq: Option[gitbucket.core.model.PullRequest] = None)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
@import gitbucket.core.model.CommitComment
|
@import gitbucket.core.model.CommitComment
|
||||||
@if(issue.isDefined){
|
@if(issue.isDefined){
|
||||||
<div class="issue-avatar-image">@avatarLink(issue.get.openedUserName, 48)</div>
|
<div class="issue-avatar-image">@helpers.avatarLink(issue.get.openedUserName, 48)</div>
|
||||||
<div class="panel panel-default issue-comment-box">
|
<div class="panel panel-default issue-comment-box">
|
||||||
<div class="panel-heading">
|
<div class="panel-heading">
|
||||||
@user(issue.get.openedUserName, styleClass="username strong") <span class="muted">commented @helper.html.datetimeago(issue.get.registeredDate)</span>
|
@helpers.user(issue.get.openedUserName, styleClass="username strong") <span class="muted">commented @gitbucket.core.helper.html.datetimeago(issue.get.registeredDate)</span>
|
||||||
<span class="pull-right">
|
<span class="pull-right">
|
||||||
@if(hasWritePermission || loginAccount.map(_.userName == issue.get.openedUserName).getOrElse(false)){
|
@if(hasWritePermission || context.loginAccount.map(_.userName == issue.get.openedUserName).getOrElse(false)){
|
||||||
<a href="#" data-issue-id="@issue.get.issueId"><i class="octicon octicon-pencil" aria-label="Edit"></i></a>
|
<a href="#" data-issue-id="@issue.get.issueId"><i class="octicon octicon-pencil" aria-label="Edit"></i></a>
|
||||||
}
|
}
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="panel-body issue-content markdown-body" id="issueContent">
|
<div class="panel-body issue-content markdown-body" id="issueContent">
|
||||||
@markdown(
|
@helpers.markdown(
|
||||||
markdown = issue.get.content getOrElse "No description provided.",
|
markdown = issue.get.content getOrElse "No description provided.",
|
||||||
repository = repository,
|
repository = repository,
|
||||||
enableWikiLink = false,
|
enableWikiLink = false,
|
||||||
@@ -36,20 +35,20 @@
|
|||||||
case comment: gitbucket.core.model.IssueComment => {
|
case comment: gitbucket.core.model.IssueComment => {
|
||||||
@if(comment.action != "close" && comment.action != "reopen" && comment.action != "delete_branch"
|
@if(comment.action != "close" && comment.action != "reopen" && comment.action != "delete_branch"
|
||||||
&& comment.action != "commit" && comment.action != "refer"){
|
&& comment.action != "commit" && comment.action != "refer"){
|
||||||
<div class="issue-avatar-image">@avatarLink(comment.commentedUserName, 48)</div>
|
<div class="issue-avatar-image">@helpers.avatarLink(comment.commentedUserName, 48)</div>
|
||||||
<div class="panel panel-default issue-comment-box" id="comment-@comment.commentId">
|
<div class="panel panel-default issue-comment-box" id="comment-@comment.commentId">
|
||||||
<div class="panel-heading">
|
<div class="panel-heading">
|
||||||
@user(comment.commentedUserName, styleClass="username strong")
|
@helpers.user(comment.commentedUserName, styleClass="username strong")
|
||||||
<span class="muted">
|
<span class="muted">
|
||||||
@if(comment.action == "comment"){
|
@if(comment.action == "comment"){
|
||||||
commented
|
commented
|
||||||
} else {
|
} else {
|
||||||
referenced the @issueOrPullRequest()
|
referenced the @issueOrPullRequest()
|
||||||
}
|
}
|
||||||
@helper.html.datetimeago(comment.registeredDate)
|
@gitbucket.core.helper.html.datetimeago(comment.registeredDate)
|
||||||
</span>
|
</span>
|
||||||
@if(comment.action != "commit" && comment.action != "merge" && comment.action != "refer"
|
@if(comment.action != "commit" && comment.action != "merge" && comment.action != "refer"
|
||||||
&& (hasWritePermission || loginAccount.map(_.userName == comment.commentedUserName).getOrElse(false))){
|
&& (hasWritePermission || context.loginAccount.map(_.userName == comment.commentedUserName).getOrElse(false))){
|
||||||
<span class="pull-right">
|
<span class="pull-right">
|
||||||
<a href="#" data-comment-id="@comment.commentId"><i class="octicon octicon-pencil" aria-label="Edit"></i></a>
|
<a href="#" data-comment-id="@comment.commentId"><i class="octicon octicon-pencil" aria-label="Edit"></i></a>
|
||||||
<a href="#" data-comment-id="@comment.commentId"><i class="octicon octicon-x" aria-label="Remove"></i></a>
|
<a href="#" data-comment-id="@comment.commentId"><i class="octicon octicon-x" aria-label="Remove"></i></a>
|
||||||
@@ -57,7 +56,7 @@
|
|||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
<div class="panel-body issue-content markdown-body" id="commentContent-@comment.commentId">
|
<div class="panel-body issue-content markdown-body" id="commentContent-@comment.commentId">
|
||||||
@markdown(
|
@helpers.markdown(
|
||||||
markdown = comment.content,
|
markdown = comment.content,
|
||||||
repository = repository,
|
repository = repository,
|
||||||
enableWikiLink = false,
|
enableWikiLink = false,
|
||||||
@@ -80,20 +79,20 @@
|
|||||||
<div class="discussion-item discussion-item-commit">
|
<div class="discussion-item discussion-item-commit">
|
||||||
<div class="discussion-item-header">
|
<div class="discussion-item-header">
|
||||||
<span class="discussion-item-icon"><i class="octicon octicon-bookmark"></i></span>
|
<span class="discussion-item-icon"><i class="octicon octicon-bookmark"></i></span>
|
||||||
@avatar(comment.commentedUserName, 16)
|
@helpers.avatar(comment.commentedUserName, 16)
|
||||||
@user(comment.commentedUserName, styleClass="username strong")
|
@helpers.user(comment.commentedUserName, styleClass="username strong")
|
||||||
added a commit that referenced this @issueOrPullRequest()
|
added a commit that referenced this @issueOrPullRequest()
|
||||||
@helper.html.datetimeago(comment.registeredDate)
|
@gitbucket.core.helper.html.datetimeago(comment.registeredDate)
|
||||||
</div>
|
</div>
|
||||||
<div style="discussion-item-content">
|
<div style="discussion-item-content">
|
||||||
@commitId.map{ id =>
|
@commitId.map{ id =>
|
||||||
<span class="pull-right"><a href="@path/@repository.owner/@repository.name/commit/@id" class="monospace">@id.substring(0, 7)</a></span>
|
<span class="pull-right"><a href="@context.path/@repository.owner/@repository.name/commit/@id" class="monospace">@id.substring(0, 7)</a></span>
|
||||||
}
|
}
|
||||||
<span class="discussion-item-content-head"><i class="octicon octicon-git-commit"></i></span>
|
<span class="discussion-item-content-head"><i class="octicon octicon-git-commit"></i></span>
|
||||||
@link(head, repository)
|
@helpers.link(head, repository)
|
||||||
@rest.map{ content =>
|
@rest.map{ content =>
|
||||||
<a href="javascript:void(0)" class="omit" onclick="$(this.parentNode).find('.discussion-item-content-text').toggle()">...</a>
|
<a href="javascript:void(0)" class="omit" onclick="$(this.parentNode).find('.discussion-item-content-text').toggle()">...</a>
|
||||||
<pre class="reset discussion-item-content-text" style="display:none">@link(content, repository)</pre>
|
<pre class="reset discussion-item-content-text" style="display:none">@helpers.link(content, repository)</pre>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -103,14 +102,14 @@
|
|||||||
<div class="discussion-item discussion-item-refer">
|
<div class="discussion-item discussion-item-refer">
|
||||||
<div class="discussion-item-header">
|
<div class="discussion-item-header">
|
||||||
<span class="discussion-item-icon"><i class="octicon octicon-bookmark"></i></span>
|
<span class="discussion-item-icon"><i class="octicon octicon-bookmark"></i></span>
|
||||||
@avatar(comment.commentedUserName, 16)
|
@helpers.avatar(comment.commentedUserName, 16)
|
||||||
@user(comment.commentedUserName, styleClass="username strong")
|
@helpers.user(comment.commentedUserName, styleClass="username strong")
|
||||||
referenced the @issueOrPullRequest()
|
referenced the @issueOrPullRequest()
|
||||||
@helper.html.datetimeago(comment.registeredDate)
|
@gitbucket.core.helper.html.datetimeago(comment.registeredDate)
|
||||||
</div>
|
</div>
|
||||||
<div style="discussion-item-content">
|
<div style="discussion-item-content">
|
||||||
@defining(comment.content.split(":")){ case Array(issueId, rest @ _*) =>
|
@defining(comment.content.split(":")){ case Array(issueId, rest @ _*) =>
|
||||||
<strong>@issueLink(repository, issueId.toInt): @rest.mkString(":")</strong>
|
<strong>@helpers.issueLink(repository, issueId.toInt): @rest.mkString(":")</strong>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -119,8 +118,8 @@
|
|||||||
<div class="discussion-item discussion-item-merge">
|
<div class="discussion-item discussion-item-merge">
|
||||||
<div class="discussion-item-header">
|
<div class="discussion-item-header">
|
||||||
<span class="discussion-item-icon"><i class="octicon octicon-git-merge"></i></span>
|
<span class="discussion-item-icon"><i class="octicon octicon-git-merge"></i></span>
|
||||||
@avatar(comment.commentedUserName, 16)
|
@helpers.avatar(comment.commentedUserName, 16)
|
||||||
@user(comment.commentedUserName, styleClass="username strong")
|
@helpers.user(comment.commentedUserName, styleClass="username strong")
|
||||||
merged commit
|
merged commit
|
||||||
<code>@pullreq.map(_.commitIdTo.substring(0, 7))</code> into
|
<code>@pullreq.map(_.commitIdTo.substring(0, 7))</code> into
|
||||||
@if(pullreq.get.requestUserName == repository.owner){
|
@if(pullreq.get.requestUserName == repository.owner){
|
||||||
@@ -128,7 +127,7 @@
|
|||||||
} else {
|
} else {
|
||||||
<code>@pullreq.map(_.userName):@pullreq.map(_.branch)</code> from <code>@pullreq.map(_.requestUserName):@pullreq.map(_.requestBranch)</code>
|
<code>@pullreq.map(_.userName):@pullreq.map(_.branch)</code> from <code>@pullreq.map(_.requestUserName):@pullreq.map(_.requestBranch)</code>
|
||||||
}
|
}
|
||||||
@helper.html.datetimeago(comment.registeredDate)
|
@gitbucket.core.helper.html.datetimeago(comment.registeredDate)
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
@@ -136,10 +135,10 @@
|
|||||||
<div class="discussion-item discussion-item-close">
|
<div class="discussion-item discussion-item-close">
|
||||||
<div class="discussion-item-header">
|
<div class="discussion-item-header">
|
||||||
<span class="discussion-item-icon"><i class="octicon octicon-circle-slash"></i></span>
|
<span class="discussion-item-icon"><i class="octicon octicon-circle-slash"></i></span>
|
||||||
@avatar(comment.commentedUserName, 16)
|
@helpers.avatar(comment.commentedUserName, 16)
|
||||||
@user(comment.commentedUserName, styleClass="username strong")
|
@helpers.user(comment.commentedUserName, styleClass="username strong")
|
||||||
closed this @issueOrPullRequest()
|
closed this @issueOrPullRequest()
|
||||||
@helper.html.datetimeago(comment.registeredDate)
|
@gitbucket.core.helper.html.datetimeago(comment.registeredDate)
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
@@ -147,10 +146,10 @@
|
|||||||
<div class="discussion-item discussion-item-reopen">
|
<div class="discussion-item discussion-item-reopen">
|
||||||
<div class="discussion-item-header">
|
<div class="discussion-item-header">
|
||||||
<span class="discussion-item-icon"><i class="octicon octicon-primitive-dot"></i></span>
|
<span class="discussion-item-icon"><i class="octicon octicon-primitive-dot"></i></span>
|
||||||
@avatar(comment.commentedUserName, 16)
|
@helpers.avatar(comment.commentedUserName, 16)
|
||||||
@user(comment.commentedUserName, styleClass="username strong")
|
@helpers.user(comment.commentedUserName, styleClass="username strong")
|
||||||
reopened the @issueOrPullRequest()
|
reopened the @issueOrPullRequest()
|
||||||
@helper.html.datetimeago(comment.registeredDate)
|
@gitbucket.core.helper.html.datetimeago(comment.registeredDate)
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
@@ -158,16 +157,16 @@
|
|||||||
<div class="discussion-item discussion-item-delete_branch">
|
<div class="discussion-item discussion-item-delete_branch">
|
||||||
<div class="discussion-item-header">
|
<div class="discussion-item-header">
|
||||||
<span class="discussion-item-icon"><i class="octicon octicon-git-branch"></i></span>
|
<span class="discussion-item-icon"><i class="octicon octicon-git-branch"></i></span>
|
||||||
@avatar(comment.commentedUserName, 16)
|
@helpers.avatar(comment.commentedUserName, 16)
|
||||||
@user(comment.commentedUserName, styleClass="username strong")
|
@helpers.user(comment.commentedUserName, styleClass="username strong")
|
||||||
deleted the <code>@pullreq.map(_.requestBranch)</code> branch
|
deleted the <code>@pullreq.map(_.requestBranch)</code> branch
|
||||||
@helper.html.datetimeago(comment.registeredDate)
|
@gitbucket.core.helper.html.datetimeago(comment.registeredDate)
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
case comment: CommitComment => {
|
case comment: CommitComment => {
|
||||||
@helper.html.commitcomment(comment, hasWritePermission, repository, pullreq.map(_.commitIdTo))
|
@gitbucket.core.helper.html.commitcomment(comment, hasWritePermission, repository, pullreq.map(_.commitIdTo))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
<script>
|
<script>
|
||||||
@@ -175,12 +174,12 @@ $(function(){
|
|||||||
@if(issue.isDefined){
|
@if(issue.isDefined){
|
||||||
$('.issue-comment-box i.octicon-pencil').click(function(){
|
$('.issue-comment-box i.octicon-pencil').click(function(){
|
||||||
var id = $(this).closest('a').data('comment-id');
|
var id = $(this).closest('a').data('comment-id');
|
||||||
var url = '@url(repository)/issue_comments/_data/' + id;
|
var url = '@helpers.url(repository)/issue_comments/_data/' + id;
|
||||||
var $content = $('#commentContent-' + id);
|
var $content = $('#commentContent-' + id);
|
||||||
|
|
||||||
if(!id){
|
if(!id){
|
||||||
id = $(this).closest('a').data('issue-id');
|
id = $(this).closest('a').data('issue-id');
|
||||||
url = '@url(repository)/issues/_data/' + id;
|
url = '@helpers.url(repository)/issues/_data/' + id;
|
||||||
$content = $('#issueContent');
|
$content = $('#issueContent');
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -196,7 +195,7 @@ $(function(){
|
|||||||
$('.issue-comment-box i.octicon-x').click(function(){
|
$('.issue-comment-box i.octicon-x').click(function(){
|
||||||
if(confirm('Are you sure you want to delete this?')) {
|
if(confirm('Are you sure you want to delete this?')) {
|
||||||
var id = $(this).closest('a').data('comment-id');
|
var id = $(this).closest('a').data('comment-id');
|
||||||
$.post('@url(repository)/issue_comments/delete/' + id,
|
$.post('@helpers.url(repository)/issue_comments/delete/' + id,
|
||||||
function(data){
|
function(data){
|
||||||
if(data > 0) {
|
if(data > 0) {
|
||||||
$('#comment-' + id).prev('div.issue-avatar-image').remove();
|
$('#comment-' + id).prev('div.issue-avatar-image').remove();
|
||||||
@@ -209,7 +208,7 @@ $(function(){
|
|||||||
}
|
}
|
||||||
$(document).on('click', '.commit-comment-box i.octicon-pencil', function(){
|
$(document).on('click', '.commit-comment-box i.octicon-pencil', function(){
|
||||||
var id = $(this).closest('a').data('comment-id');
|
var id = $(this).closest('a').data('comment-id');
|
||||||
var url = '@url(repository)/commit_comments/_data/' + id;
|
var url = '@helpers.url(repository)/commit_comments/_data/' + id;
|
||||||
var $content = $('.commit-commentContent-' + id, $(this).closest('.commit-comment-box'));
|
var $content = $('.commit-commentContent-' + id, $(this).closest('.commit-comment-box'));
|
||||||
|
|
||||||
$.get(url,
|
$.get(url,
|
||||||
@@ -224,7 +223,7 @@ $(function(){
|
|||||||
$(document).on('click', '.commit-comment-box i.octicon-x', function(){
|
$(document).on('click', '.commit-comment-box i.octicon-x', function(){
|
||||||
if(confirm('Are you sure you want to delete this?')) {
|
if(confirm('Are you sure you want to delete this?')) {
|
||||||
var id = $(this).closest('a').data('comment-id');
|
var id = $(this).closest('a').data('comment-id');
|
||||||
$.post('@url(repository)/commit_comments/delete/' + id,
|
$.post('@helpers.url(repository)/commit_comments/delete/' + id,
|
||||||
function(data){
|
function(data){
|
||||||
if(data > 0) {
|
if(data > 0) {
|
||||||
$('.commit-comment-' + id).closest('.not-diff').remove();
|
$('.commit-comment-' + id).closest('.not-diff').remove();
|
||||||
@@ -260,13 +259,13 @@ $(function(){
|
|||||||
var $commentContent = $(ev.target).parents('div[class*=commit-commentContent-]'),
|
var $commentContent = $(ev.target).parents('div[class*=commit-commentContent-]'),
|
||||||
commentId = $commentContent.attr('class').match(/commit-commentContent-.+/)[0].replace(/commit-commentContent-/, ''),
|
commentId = $commentContent.attr('class').match(/commit-commentContent-.+/)[0].replace(/commit-commentContent-/, ''),
|
||||||
checkboxes = $commentContent.find(':checkbox');
|
checkboxes = $commentContent.find(':checkbox');
|
||||||
$.get('@url(repository)/commit_comments/_data/' + commentId,
|
$.get('@helpers.url(repository)/commit_comments/_data/' + commentId,
|
||||||
{
|
{
|
||||||
dataType : 'html'
|
dataType : 'html'
|
||||||
},
|
},
|
||||||
function(responseContent){
|
function(responseContent){
|
||||||
$.ajax({
|
$.ajax({
|
||||||
url: '@url(repository)/commit_comments/edit/' + commentId,
|
url: '@helpers.url(repository)/commit_comments/edit/' + commentId,
|
||||||
type: 'POST',
|
type: 'POST',
|
||||||
data: {
|
data: {
|
||||||
issueId : 0,
|
issueId : 0,
|
||||||
@@ -283,13 +282,13 @@ $(function(){
|
|||||||
@if(issue.isDefined){
|
@if(issue.isDefined){
|
||||||
$('#issueContent').on('click', ':checkbox', function(ev){
|
$('#issueContent').on('click', ':checkbox', function(ev){
|
||||||
var checkboxes = $('#issueContent :checkbox');
|
var checkboxes = $('#issueContent :checkbox');
|
||||||
$.get('@url(repository)/issues/_data/@issue.get.issueId',
|
$.get('@helpers.url(repository)/issues/_data/@issue.get.issueId',
|
||||||
{
|
{
|
||||||
dataType : 'html'
|
dataType : 'html'
|
||||||
},
|
},
|
||||||
function(responseContent){
|
function(responseContent){
|
||||||
$.ajax({
|
$.ajax({
|
||||||
url: '@url(repository)/issues/edit/@issue.get.issueId',
|
url: '@helpers.url(repository)/issues/edit/@issue.get.issueId',
|
||||||
type: 'POST',
|
type: 'POST',
|
||||||
data: {
|
data: {
|
||||||
title : $('#issueTitle').text(),
|
title : $('#issueTitle').text(),
|
||||||
@@ -304,13 +303,13 @@ $(function(){
|
|||||||
var $commentContent = $(ev.target).parents('div[id^=commentContent-]'),
|
var $commentContent = $(ev.target).parents('div[id^=commentContent-]'),
|
||||||
commentId = $commentContent.attr('id').replace(/commentContent-/, ''),
|
commentId = $commentContent.attr('id').replace(/commentContent-/, ''),
|
||||||
checkboxes = $commentContent.find(':checkbox');
|
checkboxes = $commentContent.find(':checkbox');
|
||||||
$.get('@url(repository)/issue_comments/_data/' + commentId,
|
$.get('@helpers.url(repository)/issue_comments/_data/' + commentId,
|
||||||
{
|
{
|
||||||
dataType : 'html'
|
dataType : 'html'
|
||||||
},
|
},
|
||||||
function(responseContent){
|
function(responseContent){
|
||||||
$.ajax({
|
$.ajax({
|
||||||
url: '@url(repository)/issue_comments/edit/' + commentId,
|
url: '@helpers.url(repository)/issue_comments/edit/' + commentId,
|
||||||
type: 'POST',
|
type: 'POST',
|
||||||
data: {
|
data: {
|
||||||
issueId : 0,
|
issueId : 0,
|
||||||
|
|||||||
@@ -1,11 +1,11 @@
|
|||||||
@(issue: gitbucket.core.model.Issue, statusInfo: Option[gitbucket.core.service.IssuesService.CommitStatusInfo])(implicit context: gitbucket.core.controller.Context)
|
@(issue: gitbucket.core.model.Issue, statusInfo: Option[gitbucket.core.service.IssuesService.CommitStatusInfo])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import gitbucket.core.view.helpers._
|
@import gitbucket.core.view.helpers
|
||||||
@statusInfo.map{ status =>
|
@statusInfo.map{ status =>
|
||||||
@if(status.count==1 && status.state.isDefined){
|
@if(status.count==1 && status.state.isDefined){
|
||||||
@if(status.targetUrl.isDefined){
|
@if(status.targetUrl.isDefined){
|
||||||
<a href="@status.targetUrl.get" class="text-@status.state.get.name" data-toggle="tooltip" title="@status.state.get.name : @status.description.getOrElse(status.context.get)">@commitStateIcon(status.state.get)</a>
|
<a href="@status.targetUrl.get" class="text-@status.state.get.name" data-toggle="tooltip" title="@status.state.get.name : @status.description.getOrElse(status.context.get)">@helpers.commitStateIcon(status.state.get)</a>
|
||||||
}else{
|
}else{
|
||||||
<span class="text-@status.state.get.name">@commitStateIcon(status.state.get)
|
<span class="text-@status.state.get.name">@helpers.commitStateIcon(status.state.get)
|
||||||
}
|
}
|
||||||
}else{
|
}else{
|
||||||
@defining(status.count==status.successCount){ isSuccess =>
|
@defining(status.count==status.successCount){ isSuccess =>
|
||||||
|
|||||||
@@ -3,16 +3,15 @@
|
|||||||
labels: List[gitbucket.core.model.Label],
|
labels: List[gitbucket.core.model.Label],
|
||||||
hasWritePermission: Boolean,
|
hasWritePermission: Boolean,
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.html.main(s"New Issue - ${repository.owner}/${repository.name}", Some(repository)){
|
||||||
@html.main(s"New Issue - ${repository.owner}/${repository.name}", Some(repository)){
|
@gitbucket.core.html.menu("issues", repository){
|
||||||
@html.menu("issues", repository){
|
<form action="@helpers.url(repository)/issues/new" method="POST" validate="true" class="form-group">
|
||||||
<form action="@url(repository)/issues/new" method="POST" validate="true" class="form-group">
|
|
||||||
<div class="row-fluid">
|
<div class="row-fluid">
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<span id="error-title" class="error"></span>
|
<span id="error-title" class="error"></span>
|
||||||
<input type="text" id="issue-title" name="title" class="form-control" value="" placeholder="Title" style="margin-bottom: 6px;" autofocus/>
|
<input type="text" id="issue-title" name="title" class="form-control" value="" placeholder="Title" style="margin-bottom: 6px;" autofocus/>
|
||||||
@helper.html.preview(
|
@gitbucket.core.helper.html.preview(
|
||||||
repository = repository,
|
repository = repository,
|
||||||
content = "",
|
content = "",
|
||||||
enableWikiLink = false,
|
enableWikiLink = false,
|
||||||
@@ -20,6 +19,7 @@
|
|||||||
enableLineBreaks = true,
|
enableLineBreaks = true,
|
||||||
enableTaskList = true,
|
enableTaskList = true,
|
||||||
hasWritePermission = hasWritePermission,
|
hasWritePermission = hasWritePermission,
|
||||||
|
completionContext = "issues",
|
||||||
style = "height: 200px; max-height: 250px;",
|
style = "height: 200px; max-height: 250px;",
|
||||||
elastic = true
|
elastic = true
|
||||||
)
|
)
|
||||||
@@ -28,7 +28,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-3">
|
<div class="col-md-3">
|
||||||
@issueinfo(None, Nil, Nil, collaborators, milestones.map(x => (x, 0, 0)), labels, hasWritePermission, repository)
|
@gitbucket.core.issues.html.issueinfo(None, Nil, Nil, collaborators, milestones.map(x => (x, 0, 0)), labels, hasWritePermission, repository)
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
@(content: String, commentId: Int, owner: String, repository: String)(implicit context: gitbucket.core.controller.Context)
|
@(content: String, commentId: Int,
|
||||||
@import context._
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
||||||
<span id="error-edit-content-@commentId" class="error"></span>
|
<span id="error-edit-content-@commentId" class="error"></span>
|
||||||
@helper.html.attached(owner, repository){
|
@gitbucket.core.helper.html.attached(repository, "issues"){
|
||||||
<textarea id="edit-content-@commentId" class="form-control">@content</textarea>
|
<textarea id="edit-content-@commentId" class="form-control">@content</textarea>
|
||||||
}
|
}
|
||||||
<div>
|
<div>
|
||||||
@@ -19,7 +19,7 @@ $(function(){
|
|||||||
$('#update-comment-@commentId').click(function(){
|
$('#update-comment-@commentId').click(function(){
|
||||||
$('#update-comment-@commentId, #cancel-comment-@commentId').attr('disabled', 'disabled');
|
$('#update-comment-@commentId, #cancel-comment-@commentId').attr('disabled', 'disabled');
|
||||||
$.ajax({
|
$.ajax({
|
||||||
url: '@path/@owner/@repository/issue_comments/edit/@commentId',
|
url: '@context.path/@repository.owner/@repository.name/issue_comments/edit/@commentId',
|
||||||
type: 'POST',
|
type: 'POST',
|
||||||
data: {
|
data: {
|
||||||
issueId : 0, // TODO
|
issueId : 0, // TODO
|
||||||
@@ -35,7 +35,7 @@ $(function(){
|
|||||||
|
|
||||||
$('#cancel-comment-@commentId').click(function(){
|
$('#cancel-comment-@commentId').click(function(){
|
||||||
$('#update-comment-@commentId, #cancel-comment-@commentId').attr('disabled', 'disabled');
|
$('#update-comment-@commentId, #cancel-comment-@commentId').attr('disabled', 'disabled');
|
||||||
$.get('@path/@owner/@repository/issue_comments/_data/@commentId', callback);
|
$.get('@context.path/@repository.owner/@repository.name/issue_comments/_data/@commentId', callback);
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
@(content: Option[String], issueId: Int, owner: String, repository: String)(implicit context: gitbucket.core.controller.Context)
|
@(content: Option[String], issueId: Int,
|
||||||
@import context._
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
||||||
@helper.html.attached(owner, repository){
|
@gitbucket.core.helper.html.attached(repository, "issues"){
|
||||||
<textarea id="edit-content" class="form-control">@content.getOrElse("")</textarea>
|
<textarea id="edit-content" class="form-control">@content.getOrElse("")</textarea>
|
||||||
}
|
}
|
||||||
<div>
|
<div>
|
||||||
@@ -17,7 +17,7 @@ $(function(){
|
|||||||
$('#update-issue').click(function(){
|
$('#update-issue').click(function(){
|
||||||
$('#update, #cancel').attr('disabled', 'disabled');
|
$('#update, #cancel').attr('disabled', 'disabled');
|
||||||
$.ajax({
|
$.ajax({
|
||||||
url: '@path/@owner/@repository/issues/edit/@issueId',
|
url: '@context.path/@repository.owner/@repository.name/issues/edit/@issueId',
|
||||||
type: 'POST',
|
type: 'POST',
|
||||||
data: {
|
data: {
|
||||||
content : $('#edit-content').val()
|
content : $('#edit-content').val()
|
||||||
@@ -31,7 +31,7 @@ $(function(){
|
|||||||
|
|
||||||
$('#cancel-issue').click(function(){
|
$('#cancel-issue').click(function(){
|
||||||
$('#update, #cancel').attr('disabled', 'disabled');
|
$('#update, #cancel').attr('disabled', 'disabled');
|
||||||
$.get('@path/@owner/@repository/issues/_data/@issueId', callback);
|
$.get('@context.path/@repository.owner/@repository.name/issues/_data/@issueId', callback);
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -6,16 +6,15 @@
|
|||||||
labels: List[gitbucket.core.model.Label],
|
labels: List[gitbucket.core.model.Label],
|
||||||
hasWritePermission: Boolean,
|
hasWritePermission: Boolean,
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.html.main(s"${issue.title} - Issue #${issue.issueId} - ${repository.owner}/${repository.name}", Some(repository)){
|
||||||
@html.main(s"${issue.title} - Issue #${issue.issueId} - ${repository.owner}/${repository.name}", Some(repository)){
|
@gitbucket.core.html.menu("issues", repository){
|
||||||
@html.menu("issues", repository){
|
|
||||||
<div>
|
<div>
|
||||||
<div class="show-title pull-right">
|
<div class="show-title pull-right">
|
||||||
@if(hasWritePermission || loginAccount.map(_.userName == issue.openedUserName).getOrElse(false)){
|
@if(hasWritePermission || context.loginAccount.map(_.userName == issue.openedUserName).getOrElse(false)){
|
||||||
<a class="btn btn-default" href="#" id="edit">Edit</a>
|
<a class="btn btn-default" href="#" id="edit">Edit</a>
|
||||||
}
|
}
|
||||||
<a class="btn btn-success" href="@url(repository)/issues/new">New issue</a>
|
<a class="btn btn-success" href="@helpers.url(repository)/issues/new">New issue</a>
|
||||||
</div>
|
</div>
|
||||||
<div class="edit-title pull-right" style="display: none;">
|
<div class="edit-title pull-right" style="display: none;">
|
||||||
<a class="btn btn-success" href="#" id="update">Save</a> <a class="btn btn-default" href="#" id="cancel">Cancel</a>
|
<a class="btn btn-success" href="#" id="update">Save</a> <a class="btn btn-default" href="#" id="cancel">Cancel</a>
|
||||||
@@ -38,21 +37,21 @@
|
|||||||
<span class="label label-success issue-status">Open</span>
|
<span class="label label-success issue-status">Open</span>
|
||||||
}
|
}
|
||||||
<span class="muted">
|
<span class="muted">
|
||||||
@user(issue.openedUserName, styleClass="username strong") opened this issue @helper.html.datetimeago(issue.registeredDate) - @defining(
|
@helpers.user(issue.openedUserName, styleClass="username strong") opened this issue @gitbucket.core.helper.html.datetimeago(issue.registeredDate) - @defining(
|
||||||
comments.count( _.action.contains("comment") )
|
comments.count( _.action.contains("comment") )
|
||||||
){ count =>
|
){ count =>
|
||||||
@count @plural(count, "comment")
|
@count @helpers.plural(count, "comment")
|
||||||
}
|
}
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<hr>
|
<hr>
|
||||||
<div style="margin-top: 15px;">
|
<div style="margin-top: 15px;">
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
@commentlist(Some(issue), comments, hasWritePermission, repository)
|
@gitbucket.core.issues.html.commentlist(Some(issue), comments, hasWritePermission, repository)
|
||||||
@commentform(issue, true, hasWritePermission, repository)
|
@gitbucket.core.issues.html.commentform(issue, true, hasWritePermission, repository)
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-3">
|
<div class="col-md-3">
|
||||||
@issueinfo(Some(issue), comments, issueLabels, collaborators, milestones, labels, hasWritePermission, repository)
|
@gitbucket.core.issues.html.issueinfo(Some(issue), comments, issueLabels, collaborators, milestones, labels, hasWritePermission, repository)
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
@@ -68,7 +67,7 @@ $(function(){
|
|||||||
$('#update').click(function(){
|
$('#update').click(function(){
|
||||||
$(this).attr('disabled', 'disabled');
|
$(this).attr('disabled', 'disabled');
|
||||||
$.ajax({
|
$.ajax({
|
||||||
url: '@url(repository)/issues/edit_title/@issue.issueId',
|
url: '@helpers.url(repository)/issues/edit_title/@issue.issueId',
|
||||||
type: 'POST',
|
type: 'POST',
|
||||||
data: {
|
data: {
|
||||||
title : $('#edit-title').val()
|
title : $('#edit-title').val()
|
||||||
|
|||||||
@@ -6,17 +6,16 @@
|
|||||||
labels: List[gitbucket.core.model.Label],
|
labels: List[gitbucket.core.model.Label],
|
||||||
hasWritePermission: Boolean,
|
hasWritePermission: Boolean,
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
<div style="margin-bottom: 14px;">
|
<div style="margin-bottom: 14px;">
|
||||||
<span class="muted small strong">Labels</span>
|
<span class="muted small strong">Labels</span>
|
||||||
@if(hasWritePermission){
|
@if(hasWritePermission){
|
||||||
<div class="pull-right">
|
<div class="pull-right">
|
||||||
@helper.html.dropdown("Edit", right = true) {
|
@gitbucket.core.helper.html.dropdown("Edit", right = true) {
|
||||||
@labels.map { label =>
|
@labels.map { label =>
|
||||||
<li>
|
<li>
|
||||||
<a href="#" class="toggle-label" data-label-id="@label.labelId">
|
<a href="#" class="toggle-label" data-label-id="@label.labelId">
|
||||||
@helper.html.checkicon(issueLabels.exists(_.labelId == label.labelId))
|
@gitbucket.core.helper.html.checkicon(issueLabels.exists(_.labelId == label.labelId))
|
||||||
<span class="label" style="background-color: #@label.color;"> </span>
|
<span class="label" style="background-color: #@label.color;"> </span>
|
||||||
@label.labelName
|
@label.labelName
|
||||||
</a>
|
</a>
|
||||||
@@ -30,29 +29,29 @@
|
|||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
<ul class="label-list nav nav-pills nav-stacked">
|
<ul class="label-list nav nav-pills nav-stacked">
|
||||||
@labellist(issueLabels)
|
@gitbucket.core.issues.html.labellist(issueLabels)
|
||||||
</ul>
|
</ul>
|
||||||
<hr/>
|
<hr/>
|
||||||
<div style="margin-bottom: 14px;">
|
<div style="margin-bottom: 14px;">
|
||||||
<span class="muted small strong">Milestone</span>
|
<span class="muted small strong">Milestone</span>
|
||||||
@if(hasWritePermission){
|
@if(hasWritePermission){
|
||||||
<div class="pull-right">
|
<div class="pull-right">
|
||||||
@helper.html.dropdown("Edit", right = true) {
|
@gitbucket.core.helper.html.dropdown("Edit", right = true) {
|
||||||
<li><a href="javascript:void(0);" class="milestone" data-id=""><i class="octicon octicon-x"></i> Clear this milestone</a></li>
|
<li><a href="javascript:void(0);" class="milestone" data-id=""><i class="octicon octicon-x"></i> Clear this milestone</a></li>
|
||||||
@milestones.filter(_._1.closedDate.isEmpty).map { case (milestone, _, _) =>
|
@milestones.filter(_._1.closedDate.isEmpty).map { case (milestone, _, _) =>
|
||||||
<li>
|
<li>
|
||||||
<a href="javascript:void(0);" class="milestone" data-id="@milestone.milestoneId" data-title="@milestone.title">
|
<a href="javascript:void(0);" class="milestone" data-id="@milestone.milestoneId" data-title="@milestone.title">
|
||||||
@issue.map { issue =>
|
@issue.map { issue =>
|
||||||
@helper.html.checkicon(Some(milestone.milestoneId) == issue.milestoneId)
|
@gitbucket.core.helper.html.checkicon(Some(milestone.milestoneId) == issue.milestoneId)
|
||||||
}
|
}
|
||||||
@milestone.title
|
@milestone.title
|
||||||
<div class="small" style="padding-left: 20px;">
|
<div class="small" style="padding-left: 20px;">
|
||||||
@milestone.dueDate.map { dueDate =>
|
@milestone.dueDate.map { dueDate =>
|
||||||
@if(isPast(dueDate)){
|
@if(helpers.isPast(dueDate)){
|
||||||
<i class="octicon octicon-alert" style="color:#BD2C00;"></i>
|
<i class="octicon octicon-alert" style="color:#BD2C00;"></i>
|
||||||
<span class="milestone-alert">Due by @date(dueDate)</span>
|
<span class="milestone-alert">Due by @helpers.date(dueDate)</span>
|
||||||
} else {
|
} else {
|
||||||
<span class="muted">Due by @date(dueDate)</span>
|
<span class="muted">Due by @helpers.date(dueDate)</span>
|
||||||
}
|
}
|
||||||
}.getOrElse {
|
}.getOrElse {
|
||||||
<span class="muted">No due date</span>
|
<span class="muted">No due date</span>
|
||||||
@@ -68,7 +67,7 @@
|
|||||||
<div id="milestone-progress-area">
|
<div id="milestone-progress-area">
|
||||||
@issue.flatMap(_.milestoneId).map { milestoneId =>
|
@issue.flatMap(_.milestoneId).map { milestoneId =>
|
||||||
@milestones.collect { case (milestone, openCount, closeCount) if(milestone.milestoneId == milestoneId) =>
|
@milestones.collect { case (milestone, openCount, closeCount) if(milestone.milestoneId == milestoneId) =>
|
||||||
@issues.milestones.html.progress(openCount + closeCount, closeCount)
|
@gitbucket.core.issues.milestones.html.progress(openCount + closeCount, closeCount)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
@@ -89,12 +88,12 @@
|
|||||||
<span class="muted small strong">Assignee</span>
|
<span class="muted small strong">Assignee</span>
|
||||||
@if(hasWritePermission){
|
@if(hasWritePermission){
|
||||||
<div class="pull-right">
|
<div class="pull-right">
|
||||||
@helper.html.dropdown("Edit", right = true) {
|
@gitbucket.core.helper.html.dropdown("Edit", right = true) {
|
||||||
<li><a href="javascript:void(0);" class="assign" data-name=""><i class="octicon octicon-x"></i> Clear assignee</a></li>
|
<li><a href="javascript:void(0);" class="assign" data-name=""><i class="octicon octicon-x"></i> Clear assignee</a></li>
|
||||||
@collaborators.map { collaborator =>
|
@collaborators.map { collaborator =>
|
||||||
<li>
|
<li>
|
||||||
<a href="javascript:void(0);" class="assign" data-name="@collaborator">
|
<a href="javascript:void(0);" class="assign" data-name="@collaborator">
|
||||||
@helper.html.checkicon(issue.exists(_.assignedUserName.exists(_ == collaborator)))@avatar(collaborator, 20) @collaborator
|
@gitbucket.core.helper.html.checkicon(issue.exists(_.assignedUserName.exists(_ == collaborator)))@helpers.avatar(collaborator, 20) @collaborator
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
}
|
}
|
||||||
@@ -104,7 +103,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<span id="label-assigned">
|
<span id="label-assigned">
|
||||||
@issue.flatMap(_.assignedUserName).map { userName =>
|
@issue.flatMap(_.assignedUserName).map { userName =>
|
||||||
@avatar(userName, 20) @user(userName, styleClass="username strong small")
|
@helpers.avatar(userName, 20) @helpers.user(userName, styleClass="username strong small")
|
||||||
}.getOrElse{
|
}.getOrElse{
|
||||||
<span class="muted small">No one</span>
|
<span class="muted small">No one</span>
|
||||||
}
|
}
|
||||||
@@ -116,12 +115,12 @@
|
|||||||
<hr/>
|
<hr/>
|
||||||
<div style="margin-bottom: 14px;">
|
<div style="margin-bottom: 14px;">
|
||||||
@defining((issue.openedUserName :: comments.map(_.commentedUserName)).distinct){ participants =>
|
@defining((issue.openedUserName :: comments.map(_.commentedUserName)).distinct){ participants =>
|
||||||
<div class="muted small strong">@participants.size @plural(participants.size, "participant")</div>
|
<div class="muted small strong">@participants.size @helpers.plural(participants.size, "participant")</div>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
@defining((issue.openedUserName :: comments.map(_.commentedUserName)).distinct){ participants =>
|
@defining((issue.openedUserName :: comments.map(_.commentedUserName)).distinct){ participants =>
|
||||||
@participants.map { participant =>
|
@participants.map { participant =>
|
||||||
@avatarLink(participant, 20, tooltip = true)
|
@helpers.avatarLink(participant, 20, tooltip = true)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -130,7 +129,7 @@ $(function(){
|
|||||||
@issue.map { issue =>
|
@issue.map { issue =>
|
||||||
$('a.toggle-label').click(function(){
|
$('a.toggle-label').click(function(){
|
||||||
var path = switchLabel($(this));
|
var path = switchLabel($(this));
|
||||||
$.post('@url(repository)/issues/@issue.issueId/label/' + path,
|
$.post('@helpers.url(repository)/issues/@issue.issueId/label/' + path,
|
||||||
{ labelId : $(this).data('label-id') },
|
{ labelId : $(this).data('label-id') },
|
||||||
function(data){
|
function(data){
|
||||||
$('ul.label-list').empty().html(data);
|
$('ul.label-list').empty().html(data);
|
||||||
@@ -142,7 +141,7 @@ $(function(){
|
|||||||
$('a.milestone').click(function(){
|
$('a.milestone').click(function(){
|
||||||
var title = $(this).data('title');
|
var title = $(this).data('title');
|
||||||
var milestoneId = $(this).data('id');
|
var milestoneId = $(this).data('id');
|
||||||
$.post('@url(repository)/issues/@issue.issueId/milestone',
|
$.post('@helpers.url(repository)/issues/@issue.issueId/milestone',
|
||||||
{ milestoneId: milestoneId },
|
{ milestoneId: milestoneId },
|
||||||
function(data){
|
function(data){
|
||||||
displayMilestone(title, milestoneId, data);
|
displayMilestone(title, milestoneId, data);
|
||||||
@@ -153,7 +152,7 @@ $(function(){
|
|||||||
$('a.assign').click(function(){
|
$('a.assign').click(function(){
|
||||||
var $this = $(this);
|
var $this = $(this);
|
||||||
var userName = $this.data('name');
|
var userName = $this.data('name');
|
||||||
$.post('@url(repository)/issues/@issue.issueId/assign',
|
$.post('@helpers.url(repository)/issues/@issue.issueId/assign',
|
||||||
{ assignedUserName: userName },
|
{ assignedUserName: userName },
|
||||||
function(){
|
function(){
|
||||||
displayAssignee($this, userName);
|
displayAssignee($this, userName);
|
||||||
@@ -171,7 +170,7 @@ $(function(){
|
|||||||
});
|
});
|
||||||
$('input[name=labelNames]').val(labelNames.join(','));
|
$('input[name=labelNames]').val(labelNames.join(','));
|
||||||
|
|
||||||
$.post('@url(repository)/issues/new/label',
|
$.post('@helpers.url(repository)/issues/new/label',
|
||||||
{ labelNames : labelNames.join(',') },
|
{ labelNames : labelNames.join(',') },
|
||||||
function(data){
|
function(data){
|
||||||
$('ul.label-list').empty().html(data);
|
$('ul.label-list').empty().html(data);
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
@(label: Option[gitbucket.core.model.Label],
|
@(label: Option[gitbucket.core.model.Label],
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
@defining(label.map(_.labelId).getOrElse("new")){ labelId =>
|
@defining(label.map(_.labelId).getOrElse("new")){ labelId =>
|
||||||
<div id="edit-label-area-@labelId">
|
<div id="edit-label-area-@labelId">
|
||||||
<form class="form-inline">
|
<form class="form-inline">
|
||||||
@@ -23,7 +22,7 @@
|
|||||||
<script>
|
<script>
|
||||||
$(function(){
|
$(function(){
|
||||||
$('#submit-@labelId').click(function(e){
|
$('#submit-@labelId').click(function(e){
|
||||||
$.post('@url(repository)/issues/labels/@{if(labelId == "new") "new" else labelId + "/edit"}', {
|
$.post('@helpers.url(repository)/issues/labels/@{if(labelId == "new") "new" else labelId + "/edit"}', {
|
||||||
'labelName' : $('#labelName-@labelId').val(),
|
'labelName' : $('#labelName-@labelId').val(),
|
||||||
'labelColor': $('#labelColor-@labelId').val()
|
'labelColor': $('#labelColor-@labelId').val()
|
||||||
}, function(data, status){
|
}, function(data, status){
|
||||||
|
|||||||
@@ -2,14 +2,13 @@
|
|||||||
counts: Map[String, Int],
|
counts: Map[String, Int],
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
||||||
hasWritePermission: Boolean)(implicit context: gitbucket.core.controller.Context)
|
hasWritePermission: Boolean)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
<tr id="label-row-@label.labelId">
|
<tr id="label-row-@label.labelId">
|
||||||
<td style="padding-top: 15px; padding-bottom: 15px;">
|
<td style="padding-top: 15px; padding-bottom: 15px;">
|
||||||
<div class="milestone row" id="label-@label.labelId">
|
<div class="milestone row" id="label-@label.labelId">
|
||||||
<div class="col-md-8">
|
<div class="col-md-8">
|
||||||
<div style="margin-top: 6px">
|
<div style="margin-top: 6px">
|
||||||
<a href="@url(repository)/issues?labels=@urlEncode(label.labelName)" id="label-row-content-@label.labelId">
|
<a href="@helpers.url(repository)/issues?labels=@helpers.urlEncode(label.labelName)" id="label-row-content-@label.labelId">
|
||||||
<span style="background-color: #@label.color; color: #@label.fontColor; padding: 8px; font-size: 120%; border-radius: 4px;">
|
<span style="background-color: #@label.color; color: #@label.fontColor; padding: 8px; font-size: 120%; border-radius: 4px;">
|
||||||
<i class="octicon octicon-tag" style="color: #@label.fontColor;"></i>
|
<i class="octicon octicon-tag" style="color: #@label.fontColor;"></i>
|
||||||
@label.labelName
|
@label.labelName
|
||||||
|
|||||||
@@ -2,11 +2,10 @@
|
|||||||
counts: Map[String, Int],
|
counts: Map[String, Int],
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
||||||
hasWritePermission: Boolean)(implicit context: gitbucket.core.controller.Context)
|
hasWritePermission: Boolean)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.html.main(s"Labels - ${repository.owner}/${repository.name}"){
|
||||||
@html.main(s"Labels - ${repository.owner}/${repository.name}"){
|
@gitbucket.core.html.menu("labels", repository){
|
||||||
@html.menu("labels", repository){
|
@if(context.loginAccount.isDefined){
|
||||||
@if(loginAccount.isDefined){
|
|
||||||
<div class="pull-right" style="margin-bottom: 10px;">
|
<div class="pull-right" style="margin-bottom: 10px;">
|
||||||
<a class="btn btn-success" href="javascript:void(0);" id="new-label-button">New label</a>
|
<a class="btn btn-success" href="javascript:void(0);" id="new-label-button">New label</a>
|
||||||
</div>
|
</div>
|
||||||
@@ -47,7 +46,7 @@ $(function(){
|
|||||||
$('div#edit-label-area-new').remove();
|
$('div#edit-label-area-new').remove();
|
||||||
$('#new-label-table').hide();
|
$('#new-label-table').hide();
|
||||||
} else {
|
} else {
|
||||||
$.get('@url(repository)/issues/labels/new',
|
$.get('@helpers.url(repository)/issues/labels/new',
|
||||||
function(data){
|
function(data){
|
||||||
$('#new-label-table').show().find('tr td').append(data);
|
$('#new-label-table').show().find('tr td').append(data);
|
||||||
}
|
}
|
||||||
@@ -58,14 +57,14 @@ $(function(){
|
|||||||
|
|
||||||
function deleteLabel(labelId){
|
function deleteLabel(labelId){
|
||||||
if(confirm('Once you delete this label, there is no going back.\nAre you sure?')){
|
if(confirm('Once you delete this label, there is no going back.\nAre you sure?')){
|
||||||
$.post('@url(repository)/issues/labels/' + labelId + '/delete', function(){
|
$.post('@helpers.url(repository)/issues/labels/' + labelId + '/delete', function(){
|
||||||
$('tr#label-row-' + labelId).remove();
|
$('tr#label-row-' + labelId).remove();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function editLabel(labelId){
|
function editLabel(labelId){
|
||||||
$.get('@url(repository)/issues/labels/' + labelId + '/edit',
|
$.get('@helpers.url(repository)/issues/labels/' + labelId + '/edit',
|
||||||
function(data){
|
function(data){
|
||||||
$('#label-' + labelId).hide().parent().append(data);
|
$('#label-' + labelId).hide().parent().append(data);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,10 +9,9 @@
|
|||||||
condition: gitbucket.core.service.IssuesService.IssueSearchCondition,
|
condition: gitbucket.core.service.IssuesService.IssueSearchCondition,
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
||||||
hasWritePermission: Boolean)(implicit context: gitbucket.core.controller.Context)
|
hasWritePermission: Boolean)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.html.main((if(target == "issues") "Issues" else "Pull requests") + s" - ${repository.owner}/${repository.name}", Some(repository)){
|
||||||
@html.main((if(target == "issues") "Issues" else "Pull requests") + s" - ${repository.owner}/${repository.name}", Some(repository)){
|
@gitbucket.core.html.menu(target, repository){
|
||||||
@html.menu(target, repository){
|
|
||||||
<ul class="nav nav-pills pull-left" style="line-height: 14px; margin-bottom: 10px;">
|
<ul class="nav nav-pills pull-left" style="line-height: 14px; margin-bottom: 10px;">
|
||||||
<li class="@if(condition.state == "open"){active}">
|
<li class="@if(condition.state == "open"){active}">
|
||||||
<a href="@condition.copy(state = "open").toURL">Open <span class="badge">@openCount</span></a>
|
<a href="@condition.copy(state = "open").toURL">Open <span class="badge">@openCount</span></a>
|
||||||
@@ -22,16 +21,16 @@
|
|||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
<form method="GET" id="search-filter-form" class="form-inline pull-right">
|
<form method="GET" id="search-filter-form" class="form-inline pull-right">
|
||||||
@if(loginAccount.isDefined){
|
@if(context.loginAccount.isDefined){
|
||||||
@if(target == "issues"){
|
@if(target == "issues"){
|
||||||
<a class="btn btn-success" href="@url(repository)/issues/new">New issue</a>
|
<a class="btn btn-success" href="@helpers.url(repository)/issues/new">New issue</a>
|
||||||
}
|
}
|
||||||
@if(target == "pulls"){
|
@if(target == "pulls"){
|
||||||
<a class="btn btn-success" href="@url(repository)/compare">New pull request</a>
|
<a class="btn btn-success" href="@helpers.url(repository)/compare">New pull request</a>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</form>
|
</form>
|
||||||
@listparts(target, issues, page, openCount, closedCount, condition, collaborators, milestones, labels, Some(repository), hasWritePermission)
|
@gitbucket.core.issues.html.listparts(target, issues, page, openCount, closedCount, condition, collaborators, milestones, labels, Some(repository), hasWritePermission)
|
||||||
@if(hasWritePermission){
|
@if(hasWritePermission){
|
||||||
<form id="batcheditForm" method="POST">
|
<form id="batcheditForm" method="POST">
|
||||||
<input type="hidden" name="value"/>
|
<input type="hidden" name="value"/>
|
||||||
@@ -99,16 +98,16 @@ $(function(){
|
|||||||
};
|
};
|
||||||
|
|
||||||
$('a.toggle-state').click(function(){
|
$('a.toggle-state').click(function(){
|
||||||
submitBatchEdit('@url(repository)/issues/batchedit/state', $(this).data('id'));
|
submitBatchEdit('@helpers.url(repository)/issues/batchedit/state', $(this).data('id'));
|
||||||
});
|
});
|
||||||
$('a.toggle-label').click(function(){
|
$('a.toggle-label').click(function(){
|
||||||
submitBatchEdit('@url(repository)/issues/batchedit/label', $(this).data('id'));
|
submitBatchEdit('@helpers.url(repository)/issues/batchedit/label', $(this).data('id'));
|
||||||
});
|
});
|
||||||
$('a.toggle-assign').click(function(){
|
$('a.toggle-assign').click(function(){
|
||||||
submitBatchEdit('@url(repository)/issues/batchedit/assign', $(this).data('name'));
|
submitBatchEdit('@helpers.url(repository)/issues/batchedit/assign', $(this).data('name'));
|
||||||
});
|
});
|
||||||
$('a.toggle-milestone').click(function(){
|
$('a.toggle-milestone').click(function(){
|
||||||
submitBatchEdit('@url(repository)/issues/batchedit/milestone', $(this).data('id'));
|
submitBatchEdit('@helpers.url(repository)/issues/batchedit/milestone', $(this).data('id'));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
@@ -9,8 +9,7 @@
|
|||||||
labels: List[gitbucket.core.model.Label] = Nil,
|
labels: List[gitbucket.core.model.Label] = Nil,
|
||||||
repository: Option[gitbucket.core.service.RepositoryService.RepositoryInfo] = None,
|
repository: Option[gitbucket.core.service.RepositoryService.RepositoryInfo] = None,
|
||||||
hasWritePermission: Boolean = false)(implicit context: gitbucket.core.controller.Context)
|
hasWritePermission: Boolean = false)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
@import gitbucket.core.service.IssuesService.IssueInfo
|
@import gitbucket.core.service.IssuesService.IssueInfo
|
||||||
@*
|
@*
|
||||||
@if(condition.nonEmpty){
|
@if(condition.nonEmpty){
|
||||||
@@ -28,96 +27,96 @@
|
|||||||
<th style="background-color: #eee;">
|
<th style="background-color: #eee;">
|
||||||
<input type="checkbox"/>
|
<input type="checkbox"/>
|
||||||
<span id="table-issues-control">
|
<span id="table-issues-control">
|
||||||
@helper.html.dropdown("Author") {
|
@gitbucket.core.helper.html.dropdown("Author") {
|
||||||
@collaborators.map { collaborator =>
|
@collaborators.map { collaborator =>
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(author = (if(condition.author == Some(collaborator)) None else Some(collaborator))).toURL">
|
<a href="@condition.copy(author = (if(condition.author == Some(collaborator)) None else Some(collaborator))).toURL">
|
||||||
@helper.html.checkicon(condition.author == Some(collaborator))
|
@gitbucket.core.helper.html.checkicon(condition.author == Some(collaborator))
|
||||||
@avatar(collaborator, 20) @collaborator
|
@helpers.avatar(collaborator, 20) @collaborator
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@helper.html.dropdown("Label") {
|
@gitbucket.core.helper.html.dropdown("Label") {
|
||||||
@labels.map { label =>
|
@labels.map { label =>
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(labels = (if(condition.labels.contains(label.labelName)) condition.labels - label.labelName else condition.labels + label.labelName)).toURL">
|
<a href="@condition.copy(labels = (if(condition.labels.contains(label.labelName)) condition.labels - label.labelName else condition.labels + label.labelName)).toURL">
|
||||||
@helper.html.checkicon(condition.labels.contains(label.labelName))
|
@gitbucket.core.helper.html.checkicon(condition.labels.contains(label.labelName))
|
||||||
<span style="background-color: #@label.color;" class="label-color"> </span>
|
<span style="background-color: #@label.color;" class="label-color"> </span>
|
||||||
@label.labelName
|
@label.labelName
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@helper.html.dropdown("Milestone") {
|
@gitbucket.core.helper.html.dropdown("Milestone") {
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(milestone = (if(condition.milestone == Some(None)) None else Some(None))).toURL">
|
<a href="@condition.copy(milestone = (if(condition.milestone == Some(None)) None else Some(None))).toURL">
|
||||||
@helper.html.checkicon(condition.milestone == Some(None)) Issues with no milestone
|
@gitbucket.core.helper.html.checkicon(condition.milestone == Some(None)) Issues with no milestone
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
@milestones.filter(_.closedDate.isEmpty).map { milestone =>
|
@milestones.filter(_.closedDate.isEmpty).map { milestone =>
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(milestone = (if(condition.milestone == Some(Some(milestone.title))) None else Some(Some(milestone.title)))).toURL">
|
<a href="@condition.copy(milestone = (if(condition.milestone == Some(Some(milestone.title))) None else Some(Some(milestone.title)))).toURL">
|
||||||
@helper.html.checkicon(condition.milestone == Some(Some(milestone.title))) @milestone.title
|
@gitbucket.core.helper.html.checkicon(condition.milestone == Some(Some(milestone.title))) @milestone.title
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@helper.html.dropdown("Assignee") {
|
@gitbucket.core.helper.html.dropdown("Assignee") {
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(assigned = (if(condition.assigned == Some(None)) None else Some(None))).toURL">
|
<a href="@condition.copy(assigned = (if(condition.assigned == Some(None)) None else Some(None))).toURL">
|
||||||
@helper.html.checkicon(condition.assigned == Some(None)) Assigned to nobody
|
@gitbucket.core.helper.html.checkicon(condition.assigned == Some(None)) Assigned to nobody
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
@collaborators.map { collaborator =>
|
@collaborators.map { collaborator =>
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(assigned = (if(condition.assigned == Some(Some(collaborator))) None else Some(Some(collaborator)))).toURL">
|
<a href="@condition.copy(assigned = (if(condition.assigned == Some(Some(collaborator))) None else Some(Some(collaborator)))).toURL">
|
||||||
@helper.html.checkicon(condition.assigned == Some(Some(collaborator)))
|
@gitbucket.core.helper.html.checkicon(condition.assigned == Some(Some(collaborator)))
|
||||||
@avatar(collaborator, 20) @collaborator
|
@helpers.avatar(collaborator, 20) @collaborator
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@helper.html.dropdown("Sort"){
|
@gitbucket.core.helper.html.dropdown("Sort"){
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(sort="created", direction="desc").toURL">
|
<a href="@condition.copy(sort="created", direction="desc").toURL">
|
||||||
@helper.html.checkicon(condition.sort == "created" && condition.direction == "desc") Newest
|
@gitbucket.core.helper.html.checkicon(condition.sort == "created" && condition.direction == "desc") Newest
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(sort="created", direction="asc" ).toURL">
|
<a href="@condition.copy(sort="created", direction="asc" ).toURL">
|
||||||
@helper.html.checkicon(condition.sort == "created" && condition.direction == "asc") Oldest
|
@gitbucket.core.helper.html.checkicon(condition.sort == "created" && condition.direction == "asc") Oldest
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(sort="comments", direction="desc").toURL">
|
<a href="@condition.copy(sort="comments", direction="desc").toURL">
|
||||||
@helper.html.checkicon(condition.sort == "comments" && condition.direction == "desc") Most commented
|
@gitbucket.core.helper.html.checkicon(condition.sort == "comments" && condition.direction == "desc") Most commented
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(sort="comments", direction="asc" ).toURL">
|
<a href="@condition.copy(sort="comments", direction="asc" ).toURL">
|
||||||
@helper.html.checkicon(condition.sort == "comments" && condition.direction == "asc") Least commented
|
@gitbucket.core.helper.html.checkicon(condition.sort == "comments" && condition.direction == "asc") Least commented
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(sort="updated", direction="desc").toURL">
|
<a href="@condition.copy(sort="updated", direction="desc").toURL">
|
||||||
@helper.html.checkicon(condition.sort == "updated" && condition.direction == "desc") Recently updated
|
@gitbucket.core.helper.html.checkicon(condition.sort == "updated" && condition.direction == "desc") Recently updated
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<a href="@condition.copy(sort="updated", direction="asc" ).toURL">
|
<a href="@condition.copy(sort="updated", direction="asc" ).toURL">
|
||||||
@helper.html.checkicon(condition.sort == "updated" && condition.direction == "asc") Least recently updated
|
@gitbucket.core.helper.html.checkicon(condition.sort == "updated" && condition.direction == "asc") Least recently updated
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
}
|
}
|
||||||
</span>
|
</span>
|
||||||
@if(hasWritePermission){
|
@if(hasWritePermission){
|
||||||
<span id="table-issues-batchedit">
|
<span id="table-issues-batchedit">
|
||||||
@helper.html.dropdown("Mark as") {
|
@gitbucket.core.helper.html.dropdown("Mark as") {
|
||||||
<li><a href="javascript:void(0);" class="toggle-state" data-id="open">Open</a></li>
|
<li><a href="javascript:void(0);" class="toggle-state" data-id="open">Open</a></li>
|
||||||
<li><a href="javascript:void(0);" class="toggle-state" data-id="close">Close</a></li>
|
<li><a href="javascript:void(0);" class="toggle-state" data-id="close">Close</a></li>
|
||||||
}
|
}
|
||||||
@helper.html.dropdown("Label") {
|
@gitbucket.core.helper.html.dropdown("Label") {
|
||||||
@labels.map { label =>
|
@labels.map { label =>
|
||||||
<li>
|
<li>
|
||||||
<a href="javascript:void(0);" class="toggle-label" data-id="@label.labelId">
|
<a href="javascript:void(0);" class="toggle-label" data-id="@label.labelId">
|
||||||
@@ -128,16 +127,16 @@
|
|||||||
</li>
|
</li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@helper.html.dropdown("Milestone") {
|
@gitbucket.core.helper.html.dropdown("Milestone") {
|
||||||
<li><a href="javascript:void(0);" class="toggle-milestone" data-id="">No milestone</a></li>
|
<li><a href="javascript:void(0);" class="toggle-milestone" data-id="">No milestone</a></li>
|
||||||
@milestones.filter(_.closedDate.isEmpty).map { milestone =>
|
@milestones.filter(_.closedDate.isEmpty).map { milestone =>
|
||||||
<li><a href="javascript:void(0);" class="toggle-milestone" data-id="@milestone.milestoneId">@milestone.title</a></li>
|
<li><a href="javascript:void(0);" class="toggle-milestone" data-id="@milestone.milestoneId">@milestone.title</a></li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@helper.html.dropdown("Assignee") {
|
@gitbucket.core.helper.html.dropdown("Assignee") {
|
||||||
<li><a href="javascript:void(0);" class="toggle-assign" data-name=""><i class="octicon octicon-x"></i> Clear assignee</a></li>
|
<li><a href="javascript:void(0);" class="toggle-assign" data-name=""><i class="octicon octicon-x"></i> Clear assignee</a></li>
|
||||||
@collaborators.map { collaborator =>
|
@collaborators.map { collaborator =>
|
||||||
<li><a href="javascript:void(0);" class="toggle-assign" data-name="@collaborator"><i class="octicon"></i>@avatar(collaborator, 20) @collaborator</a></li>
|
<li><a href="javascript:void(0);" class="toggle-assign" data-name="@collaborator"><i class="octicon"></i>@helpers.avatar(collaborator, 20) @collaborator</a></li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</span>
|
</span>
|
||||||
@@ -161,9 +160,9 @@
|
|||||||
*@
|
*@
|
||||||
@if(repository.isDefined){
|
@if(repository.isDefined){
|
||||||
@if(target == "issues"){
|
@if(target == "issues"){
|
||||||
<a href="@url(repository.get)/issues/new">Create a new issue.</a>
|
<a href="@helpers.url(repository.get)/issues/new">Create a new issue.</a>
|
||||||
} else {
|
} else {
|
||||||
<a href="@url(repository.get)/compare">Create a new pull request.</a>
|
<a href="@helpers.url(repository.get)/compare">Create a new pull request.</a>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@*
|
@*
|
||||||
@@ -182,33 +181,33 @@
|
|||||||
<i class="octicon octicon-issue-@(if(issue.closed) "closed" else "opened")" style="margin-right: 3px;"></i>
|
<i class="octicon octicon-issue-@(if(issue.closed) "closed" else "opened")" style="margin-right: 3px;"></i>
|
||||||
*@
|
*@
|
||||||
@if(repository.isEmpty){
|
@if(repository.isEmpty){
|
||||||
<a href="@path/@issue.userName/@issue.repositoryName">@issue.repositoryName</a> ・
|
<a href="@context.path/@issue.userName/@issue.repositoryName">@issue.repositoryName</a> ・
|
||||||
}
|
}
|
||||||
@if(target == "issues"){
|
@if(target == "issues"){
|
||||||
<a href="@path/@issue.userName/@issue.repositoryName/issues/@issue.issueId" class="issue-title">@issue.title</a>
|
<a href="@context.path/@issue.userName/@issue.repositoryName/issues/@issue.issueId" class="issue-title">@issue.title</a>
|
||||||
} else {
|
} else {
|
||||||
<a href="@path/@issue.userName/@issue.repositoryName/pull/@issue.issueId" class="issue-title">@issue.title</a>
|
<a href="@context.path/@issue.userName/@issue.repositoryName/pull/@issue.issueId" class="issue-title">@issue.title</a>
|
||||||
}
|
}
|
||||||
@commitstatus(issue, commitStatus)
|
@gitbucket.core.issues.html.commitstatus(issue, commitStatus)
|
||||||
@labels.map { label =>
|
@labels.map { label =>
|
||||||
<span class="label-color small" style="background-color: #@label.color; color: #@label.fontColor; padding-left: 4px; padding-right: 4px">@label.labelName</span>
|
<span class="label-color small" style="background-color: #@label.color; color: #@label.fontColor; padding-left: 4px; padding-right: 4px">@label.labelName</span>
|
||||||
}
|
}
|
||||||
<span class="pull-right small">
|
<span class="pull-right small">
|
||||||
@issue.assignedUserName.map { userName =>
|
@issue.assignedUserName.map { userName =>
|
||||||
@avatar(userName, 20, tooltip = true)
|
@helpers.avatar(userName, 20, tooltip = true)
|
||||||
}
|
}
|
||||||
@if(commentCount > 0){
|
@if(commentCount > 0){
|
||||||
<a href="@path/@issue.userName/@issue.repositoryName/issues/@issue.issueId" class="issue-comment-count">
|
<a href="@context.path/@issue.userName/@issue.repositoryName/issues/@issue.issueId" class="issue-comment-count">
|
||||||
<i class="octicon octicon-comment active"></i> @commentCount
|
<i class="octicon octicon-comment active"></i> @commentCount
|
||||||
</a>
|
</a>
|
||||||
} else {
|
} else {
|
||||||
<a href="@path/@issue.userName/@issue.repositoryName/issues/@issue.issueId" class="issue-comment-count" style="color: silver;">
|
<a href="@context.path/@issue.userName/@issue.repositoryName/issues/@issue.issueId" class="issue-comment-count" style="color: silver;">
|
||||||
<i class="octicon octicon-comment"></i> @commentCount
|
<i class="octicon octicon-comment"></i> @commentCount
|
||||||
</a>
|
</a>
|
||||||
}
|
}
|
||||||
</span>
|
</span>
|
||||||
<div class="small muted" style="margin-left: 12px; margin-top: 2px;">
|
<div class="small muted" style="margin-left: 12px; margin-top: 2px;">
|
||||||
#@issue.issueId opened @helper.html.datetimeago(issue.registeredDate) by @user(issue.openedUserName, styleClass="username")
|
#@issue.issueId opened @gitbucket.core.helper.html.datetimeago(issue.registeredDate) by @helpers.user(issue.openedUserName, styleClass="username")
|
||||||
@milestone.map { milestone =>
|
@milestone.map { milestone =>
|
||||||
<span style="margin: 20px;"><a href="@condition.copy(milestone = Some(Some(milestone))).toURL" class="username"><i class="octicon octicon-milestone"></i> @milestone</a></span>
|
<span style="margin: 20px;"><a href="@condition.copy(milestone = Some(Some(milestone))).toURL" class="username"><i class="octicon octicon-milestone"></i> @milestone</a></span>
|
||||||
}
|
}
|
||||||
@@ -219,5 +218,5 @@
|
|||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
<div class="pull-right">
|
<div class="pull-right">
|
||||||
@helper.html.paginator(page, (if(condition.state == "open") openCount else closedCount), gitbucket.core.service.IssuesService.IssueLimit, 10, condition.toURL)
|
@gitbucket.core.helper.html.paginator(page, (if(condition.state == "open") openCount else closedCount), gitbucket.core.service.IssuesService.IssueLimit, 10, condition.toURL)
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -1,15 +1,14 @@
|
|||||||
@(milestone: Option[gitbucket.core.model.Milestone],
|
@(milestone: Option[gitbucket.core.model.Milestone],
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.html.main(s"Milestones - ${repository.owner}/${repository.name}"){
|
||||||
@html.main(s"Milestones - ${repository.owner}/${repository.name}"){
|
@gitbucket.core.html.menu("milestones", repository){
|
||||||
@html.menu("milestones", repository){
|
|
||||||
@if(milestone.isEmpty){
|
@if(milestone.isEmpty){
|
||||||
<h4>New milestone</h4>
|
<h4>New milestone</h4>
|
||||||
<div class="muted">Create a new milestone to help organize your issues and pull requests.</div>
|
<div class="muted">Create a new milestone to help organize your issues and pull requests.</div>
|
||||||
}
|
}
|
||||||
<hr style="margin-top: 12px; margin-bottom: 18px;" class="fill-width"/>
|
<hr style="margin-top: 12px; margin-bottom: 18px;" class="fill-width"/>
|
||||||
<form method="POST" action="@url(repository)/issues/milestones/@if(milestone.isEmpty){new}else{@milestone.get.milestoneId/edit}" validate="true">
|
<form method="POST" action="@helpers.url(repository)/issues/milestones/@if(milestone.isEmpty){new}else{@milestone.get.milestoneId/edit}" validate="true">
|
||||||
<fieldset class="form-group">
|
<fieldset class="form-group">
|
||||||
<input type="text" id="title" name="title" class="form-control" style="width: 500px;" value="@milestone.map(_.title)" placeholder="Title"/>
|
<input type="text" id="title" name="title" class="form-control" style="width: 500px;" value="@milestone.map(_.title)" placeholder="Title"/>
|
||||||
<span id="error-title" class="error"></span>
|
<span id="error-title" class="error"></span>
|
||||||
@@ -21,7 +20,7 @@
|
|||||||
</fieldset>
|
</fieldset>
|
||||||
<fieldset class="form-group">
|
<fieldset class="form-group">
|
||||||
<label for="dueDate" class="strong">Due Date</label>
|
<label for="dueDate" class="strong">Due Date</label>
|
||||||
@helper.html.datepicker("dueDate", milestone.flatMap(_.dueDate))
|
@gitbucket.core.helper.html.datepicker("dueDate", milestone.flatMap(_.dueDate))
|
||||||
<span id="error-dueDate" class="error"></span>
|
<span id="error-dueDate" class="error"></span>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
<hr>
|
<hr>
|
||||||
@@ -31,10 +30,10 @@
|
|||||||
} else {
|
} else {
|
||||||
@if(milestone.get.closedDate.isDefined){
|
@if(milestone.get.closedDate.isDefined){
|
||||||
<input type="button" class="btn btn-default" value="Open" id="open"
|
<input type="button" class="btn btn-default" value="Open" id="open"
|
||||||
onclick="location.href='@url(repository)/issues/milestones/@milestone.get.milestoneId/close';"/>
|
onclick="location.href='@helpers.url(repository)/issues/milestones/@milestone.get.milestoneId/close';"/>
|
||||||
} else {
|
} else {
|
||||||
<input type="button" class="btn btn-default" value="Close" id="close"
|
<input type="button" class="btn btn-default" value="Close" id="close"
|
||||||
onclick="location.href='@url(repository)/issues/milestones/@milestone.get.milestoneId/open';"/>
|
onclick="location.href='@helpers.url(repository)/issues/milestones/@milestone.get.milestoneId/open';"/>
|
||||||
}
|
}
|
||||||
<input type="submit" class="btn btn-success" value="Update milestone"/>
|
<input type="submit" class="btn btn-success" value="Update milestone"/>
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,13 +2,12 @@
|
|||||||
milestones: List[(gitbucket.core.model.Milestone, Int, Int)],
|
milestones: List[(gitbucket.core.model.Milestone, Int, Int)],
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
||||||
hasWritePermission: Boolean)(implicit context: gitbucket.core.controller.Context)
|
hasWritePermission: Boolean)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.html.main(s"Milestones - ${repository.owner}/${repository.name}"){
|
||||||
@html.main(s"Milestones - ${repository.owner}/${repository.name}"){
|
@gitbucket.core.html.menu("milestones", repository){
|
||||||
@html.menu("milestones", repository){
|
@if(context.loginAccount.isDefined){
|
||||||
@if(loginAccount.isDefined){
|
|
||||||
<div class="pull-right" style="margin-bottom: 10px;">
|
<div class="pull-right" style="margin-bottom: 10px;">
|
||||||
<a class="btn btn-success" href="@url(repository)/issues/milestones/new">New milestone</a>
|
<a class="btn btn-success" href="@helpers.url(repository)/issues/milestones/new">New milestone</a>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
<table class="table table-bordered table-hover table-issues">
|
<table class="table table-bordered table-hover table-issues">
|
||||||
@@ -35,17 +34,17 @@
|
|||||||
<td style="padding-top: 15px; padding-bottom: 15px;">
|
<td style="padding-top: 15px; padding-bottom: 15px;">
|
||||||
<div class="milestone row">
|
<div class="milestone row">
|
||||||
<div class="col-md-4">
|
<div class="col-md-4">
|
||||||
<a href="@url(repository)/issues?milestone=@milestone.title&state=open" class="milestone-title">@milestone.title</a>
|
<a href="@helpers.url(repository)/issues?milestone=@milestone.title&state=open" class="milestone-title">@milestone.title</a>
|
||||||
<div>
|
<div>
|
||||||
@if(milestone.closedDate.isDefined){
|
@if(milestone.closedDate.isDefined){
|
||||||
<span class="muted">Closed @helper.html.datetimeago(milestone.closedDate.get)</span>
|
<span class="muted">Closed @gitbucket.core.helper.html.datetimeago(milestone.closedDate.get)</span>
|
||||||
} else {
|
} else {
|
||||||
@milestone.dueDate.map { dueDate =>
|
@milestone.dueDate.map { dueDate =>
|
||||||
@if(isPast(dueDate)){
|
@if(helpers.isPast(dueDate)){
|
||||||
<i class="octicon octicon-alert" style="color:#BD2C00;"></i>
|
<i class="octicon octicon-alert" style="color:#BD2C00;"></i>
|
||||||
<span class="muted milestone-alert">Due by @date(dueDate)</span>
|
<span class="muted milestone-alert">Due by @helpers.date(dueDate)</span>
|
||||||
} else {
|
} else {
|
||||||
<span class="muted">Due by @date(dueDate)</span>
|
<span class="muted">Due by @helpers.date(dueDate)</span>
|
||||||
}
|
}
|
||||||
}.getOrElse {
|
}.getOrElse {
|
||||||
<span class="muted">No due date</span>
|
<span class="muted">No due date</span>
|
||||||
@@ -54,7 +53,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-8">
|
<div class="col-md-8">
|
||||||
@progress(openCount + closedCount, closedCount)
|
@gitbucket.core.issues.milestones.html.progress(openCount + closedCount, closedCount)
|
||||||
<div>
|
<div>
|
||||||
<div>
|
<div>
|
||||||
@if(closedCount == 0){
|
@if(closedCount == 0){
|
||||||
@@ -67,13 +66,13 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="milestone-menu">
|
<div class="milestone-menu">
|
||||||
@if(hasWritePermission){
|
@if(hasWritePermission){
|
||||||
<a href="@url(repository)/issues/milestones/@milestone.milestoneId/edit">Edit</a>
|
<a href="@helpers.url(repository)/issues/milestones/@milestone.milestoneId/edit">Edit</a>
|
||||||
@if(milestone.closedDate.isDefined){
|
@if(milestone.closedDate.isDefined){
|
||||||
<a href="@url(repository)/issues/milestones/@milestone.milestoneId/open">Open</a>
|
<a href="@helpers.url(repository)/issues/milestones/@milestone.milestoneId/open">Open</a>
|
||||||
} else {
|
} else {
|
||||||
<a href="@url(repository)/issues/milestones/@milestone.milestoneId/close">Close</a>
|
<a href="@helpers.url(repository)/issues/milestones/@milestone.milestoneId/close">Close</a>
|
||||||
}
|
}
|
||||||
<a href="@url(repository)/issues/milestones/@milestone.milestoneId/delete" class="delete">Delete</a>
|
<a href="@helpers.url(repository)/issues/milestones/@milestone.milestoneId/delete" class="delete">Delete</a>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -81,7 +80,7 @@
|
|||||||
</div>
|
</div>
|
||||||
@if(milestone.description.isDefined){
|
@if(milestone.description.isDefined){
|
||||||
<div class="milestone-description markdown-body">
|
<div class="milestone-description markdown-body">
|
||||||
@markdown(
|
@helpers.markdown(
|
||||||
markdown = milestone.description.get,
|
markdown = milestone.description.get,
|
||||||
repository = repository,
|
repository = repository,
|
||||||
enableWikiLink = false,
|
enableWikiLink = false,
|
||||||
@@ -98,7 +97,7 @@
|
|||||||
<td style="padding: 20px; background-color: #eee; text-align: center;">
|
<td style="padding: 20px; background-color: #eee; text-align: center;">
|
||||||
No milestones to show.
|
No milestones to show.
|
||||||
@if(hasWritePermission){
|
@if(hasWritePermission){
|
||||||
<a href="@url(repository)/issues/milestones/new">Create a new milestone.</a>
|
<a href="@helpers.url(repository)/issues/milestones/new">Create a new milestone.</a>
|
||||||
}
|
}
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|||||||
@@ -1,110 +1,110 @@
|
|||||||
@(title: String, repository: Option[gitbucket.core.service.RepositoryService.RepositoryInfo] = None)(body: Html)(implicit context: gitbucket.core.controller.Context)
|
@(title: String, repository: Option[gitbucket.core.service.RepositoryService.RepositoryInfo] = None)(body: Html)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import gitbucket.core.plugin.PluginRegistry
|
@import gitbucket.core.plugin.PluginRegistry
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<meta charset="utf-8">
|
<meta charset="utf-8">
|
||||||
<title>@title</title>
|
<title>@title</title>
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
||||||
<link rel="icon" href="@assets/common/images/gitbucket.png" type="image/vnd.microsoft.icon" />
|
<link rel="icon" href="@helpers.assets/common/images/gitbucket.png" type="image/vnd.microsoft.icon" />
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<link href="@assets/vendors/bootstrap-3.3.6/css/bootstrap.min.css" rel="stylesheet">
|
<link href="@helpers.assets/vendors/bootstrap-3.3.6/css/bootstrap.min.css" rel="stylesheet">
|
||||||
<link href="@assets/vendors/octicons/octicons.css" rel="stylesheet">
|
<link href="@helpers.assets/vendors/octicons-4.2.0/octicons.css" rel="stylesheet">
|
||||||
<link href="@assets/vendors/datepicker/css/bootstrap-datetimepicker.min.css" rel="stylesheet">
|
<link href="@helpers.assets/vendors/datepicker/css/bootstrap-datetimepicker.min.css" rel="stylesheet">
|
||||||
<link href="@assets/vendors/colorpicker/css/bootstrap-colorpicker.css" rel="stylesheet">
|
<link href="@helpers.assets/vendors/colorpicker/css/bootstrap-colorpicker.css" rel="stylesheet">
|
||||||
<link href="@assets/vendors/google-code-prettify/prettify.css" type="text/css" rel="stylesheet"/>
|
<link href="@helpers.assets/vendors/google-code-prettify/prettify.css" type="text/css" rel="stylesheet"/>
|
||||||
<link href="@assets/vendors/facebox/facebox.css" rel="stylesheet"/>
|
<link href="@helpers.assets/vendors/facebox/facebox.css" rel="stylesheet"/>
|
||||||
<link href="@assets/common/css/gitbucket.css" rel="stylesheet">
|
<link href="@helpers.assets/vendors/AdminLTE-2.2.3/css/AdminLTE.min.css" rel="stylesheet">
|
||||||
<script src="@assets/vendors/jquery/jquery-1.11.1.js"></script>
|
<link href="@helpers.assets/vendors/AdminLTE-2.2.3/css/skins/skin-blue.min.css" rel="stylesheet">
|
||||||
<script src="@assets/vendors/dropzone/dropzone.js"></script>
|
<link href="@helpers.assets/common/css/gitbucket.css" rel="stylesheet">
|
||||||
<script src="@assets/common/js/validation.js"></script>
|
<script src="@helpers.assets/vendors/jquery/jquery-1.11.1.js"></script>
|
||||||
<script src="@assets/common/js/gitbucket.js"></script>
|
<script src="@helpers.assets/vendors/dropzone/dropzone.js"></script>
|
||||||
<script src="@assets/vendors/bootstrap-3.3.6/js/bootstrap.js"></script>
|
<script src="@helpers.assets/common/js/validation.js"></script>
|
||||||
<script src="@assets/vendors/bootstrap3-typeahead/bootstrap3-typeahead.js"></script>
|
<script src="@helpers.assets/common/js/gitbucket.js"></script>
|
||||||
<script src="@assets/vendors/datepicker/js/moment.js"></script>
|
<script src="@helpers.assets/vendors/bootstrap-3.3.6/js/bootstrap.js"></script>
|
||||||
<script src="@assets/vendors/datepicker/js/bootstrap-datetimepicker.min.js"></script>
|
<script src="@helpers.assets/vendors/bootstrap3-typeahead/bootstrap3-typeahead.js"></script>
|
||||||
<script src="@assets/vendors/colorpicker/js/bootstrap-colorpicker.js"></script>
|
<script src="@helpers.assets/vendors/datepicker/js/moment.js"></script>
|
||||||
<script src="@assets/vendors/google-code-prettify/prettify.js"></script>
|
<script src="@helpers.assets/vendors/datepicker/js/bootstrap-datetimepicker.min.js"></script>
|
||||||
<script src="@assets/vendors/zclip/ZeroClipboard.min.js"></script>
|
<script src="@helpers.assets/vendors/colorpicker/js/bootstrap-colorpicker.js"></script>
|
||||||
<script src="@assets/vendors/elastic/jquery.elastic.source.js"></script>
|
<script src="@helpers.assets/vendors/google-code-prettify/prettify.js"></script>
|
||||||
<script src="@assets/vendors/facebox/facebox.js"></script>
|
<script src="@helpers.assets/vendors/zclip/ZeroClipboard.min.js"></script>
|
||||||
<script src="@assets/vendors/jquery-hotkeys/jquery.hotkeys.js"></script>
|
<script src="@helpers.assets/vendors/elastic/jquery.elastic.source.js"></script>
|
||||||
|
<script src="@helpers.assets/vendors/facebox/facebox.js"></script>
|
||||||
|
<script src="@helpers.assets/vendors/jquery-hotkeys/jquery.hotkeys.js"></script>
|
||||||
|
<script src="@helpers.assets/vendors/jquery-textcomplete-1.6.2/jquery.textcomplete.js"></script>
|
||||||
@repository.map { repository =>
|
@repository.map { repository =>
|
||||||
@if(!repository.repository.isPrivate){
|
@if(!repository.repository.isPrivate){
|
||||||
<meta name="go-import" content="@context.baseUrl.replaceFirst("^https?://", "")/@repository.owner/@repository.name git @repository.httpUrl" />
|
<meta name="go-import" content="@context.baseUrl.replaceFirst("^https?://", "")/@repository.owner/@repository.name git @repository.httpUrl" />
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
<script src="@helpers.assets/vendors/AdminLTE-2.2.3/js/app.js" type="text/javascript"></script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body class="skin-blue">
|
||||||
<form id="search" action="@path/search" method="POST" class="form-inline">
|
<div class="wrapper">
|
||||||
<nav class="navbar navbar-default">
|
<header class="main-header">
|
||||||
<div class="container">
|
<a href="@context.path/" class="logo">
|
||||||
@* TODO: for plugi-ins?
|
<img src="@helpers.assets/common/images/gitbucket.png" style="width: 24px; height: 24px; display: inline;"/>
|
||||||
<button type="button" class="btn btn-navbar" data-toggle="collapse" data-target=".nav-collapse">
|
GitBucket
|
||||||
<span class="icon-bar"></span>
|
<span class="header-version">@gitbucket.core.GitBucketCoreModule.getVersions.last.getVersion</span>
|
||||||
<span class="icon-bar"></span>
|
</a>
|
||||||
<span class="icon-bar"></span>
|
<nav class="navbar navbar-static-top" role="navigation">
|
||||||
</button>
|
@repository.map { repository =>
|
||||||
*@
|
<form id="search" action="@context.path/search" method="POST" class="navbar-form navbar-left" role="search">
|
||||||
<a class="navbar-brand" href="@path/">
|
<div class="form-group">
|
||||||
<img src="@assets/common/images/gitbucket.png" style="width: 24px; height: 24px; display: inline;"/>GitBucket
|
<input type="text" name="query" id="navbar-search-input" class="form-control" placeholder="Search this repository"/>
|
||||||
<span class="header-version">@gitbucket.core.GitBucketCoreModule.getVersions.get(0).getVersion</span>
|
<input type="hidden" name="owner" value="@repository.owner"/>
|
||||||
</a>
|
<input type="hidden" name="repository" value="@repository.name"/>
|
||||||
@if(loginAccount.isDefined){
|
|
||||||
@repository.map { repository =>
|
|
||||||
<input type="text" name="query" class="form-control" style="width: 400px; margin-top: 3px; margin-bottom: 3px;" placeholder="Search this repository"/>
|
|
||||||
<input type="hidden" name="owner" value="@repository.owner"/>
|
|
||||||
<input type="hidden" name="repository" value="@repository.name"/>
|
|
||||||
}
|
|
||||||
<a href="@path/dashboard/pulls" class="global-header-menu">Pull requests</a>
|
|
||||||
<a href="@path/dashboard/issues" class="global-header-menu">Issues</a>
|
|
||||||
} else {
|
|
||||||
@* TODO: merge with below *@
|
|
||||||
@repository.map { repository =>
|
|
||||||
<input type="text" name="query" class="form-control" style="width: 400px; margin-top: 3px; margin-bottom: 3px;" placeholder="Search this repository"/>
|
|
||||||
<input type="hidden" name="owner" value="@repository.owner"/>
|
|
||||||
<input type="hidden" name="repository" value="@repository.name"/>
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@gitbucket.core.plugin.PluginRegistry().getGlobalMenus.map { menu =>
|
|
||||||
@menu(context).map { link =>
|
|
||||||
<a href="@path/@link.path" class="global-header-menu">@link.label</a>
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@if(loginAccount.isDefined){
|
|
||||||
<div class="pull-right" style="margin-top: 6px;">
|
|
||||||
<div class="btn-group" style="margin-right: 8px;">
|
|
||||||
<a class="dropdown-toggle menu" data-toggle="dropdown" href="#">
|
|
||||||
<i class="octicon octicon-plus" style="color: black; font-size: 20px; vertical-align: middle;height:20px !important;"></i><span class="caret" style="color: black; vertical-align: middle;"></span>
|
|
||||||
</a>
|
|
||||||
<ul class="dropdown-menu pull-right">
|
|
||||||
<li><a href="@path/new">New repository</a></li>
|
|
||||||
<li><a href="@path/groups/new">New group</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="btn-group">
|
</form>
|
||||||
<a class="dropdown-toggle menu" data-toggle="dropdown" href="#" data-toggle="tooltip" data-placement="bottom" title="Signed is as @loginAccount.get.userName">
|
|
||||||
@avatar(loginAccount.get.userName, 16)<span class="caret" style="color: black; vertical-align: middle;"></span>
|
|
||||||
</a>
|
|
||||||
<ul class="dropdown-menu pull-right">
|
|
||||||
<li><a href="@url(loginAccount.get.userName)">Your profile</a></li>
|
|
||||||
<li><a href="@url(loginAccount.get.userName)/_edit">Account settings</a></li>
|
|
||||||
@if(loginAccount.get.isAdmin){
|
|
||||||
<li><a href="@path/admin/users">System administration</a></li>
|
|
||||||
}
|
|
||||||
<li><a href="@path/signout">Sign out</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
} else {
|
|
||||||
<a href="@path/signin?redirect=@urlEncode(currentPath)" class="btn btn-default pull-right" style="margin-top: 3px; margin-bottom: 3px;" id="signin">Sign in</a>
|
|
||||||
}
|
}
|
||||||
</div>
|
<ul class="nav navbar-nav">
|
||||||
</nav>
|
@if(context.loginAccount.isDefined){
|
||||||
</form>
|
<li><a href="@context.path/dashboard/pulls">Pull requests</a></li>
|
||||||
@body
|
<li><a href="@context.path/dashboard/issues">Issues</a></li>
|
||||||
|
}
|
||||||
|
@gitbucket.core.plugin.PluginRegistry().getGlobalMenus.map { menu =>
|
||||||
|
@menu(context).map { link =>
|
||||||
|
<li><a href="@context.path/@link.path">@link.label</a></li>
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</ul>
|
||||||
|
<div class="navbar-custom-menu">
|
||||||
|
<ul class="nav navbar-nav">
|
||||||
|
@if(context.loginAccount.isDefined){
|
||||||
|
<li class="dropdown">
|
||||||
|
<a class="dropdown-toggle menu" data-toggle="dropdown" href="#">
|
||||||
|
<i class="octicon octicon-plus" style="color: black;"></i><span class="caret" style="color: black; vertical-align: middle;"></span>
|
||||||
|
</a>
|
||||||
|
<ul class="dropdown-menu pull-right">
|
||||||
|
<li><a href="@context.path/new">New repository</a></li>
|
||||||
|
<li><a href="@context.path/groups/new">New group</a></li>
|
||||||
|
</ul>
|
||||||
|
</li>
|
||||||
|
<li class="dropdown">
|
||||||
|
<a class="dropdown-toggle menu" data-toggle="dropdown" href="#" data-toggle="tooltip" data-placement="bottom" title="Signed is as @context.loginAccount.get.userName">
|
||||||
|
@helpers.avatar(context.loginAccount.get.userName, 16)<span class="caret" style="color: black; vertical-align: middle;"></span>
|
||||||
|
</a>
|
||||||
|
<ul class="dropdown-menu pull-right">
|
||||||
|
<li><a href="@helpers.url(context.loginAccount.get.userName)">Your profile</a></li>
|
||||||
|
<li><a href="@helpers.url(context.loginAccount.get.userName)/_edit">Account settings</a></li>
|
||||||
|
@if(context.loginAccount.get.isAdmin){
|
||||||
|
<li><a href="@context.path/admin/users">System administration</a></li>
|
||||||
|
}
|
||||||
|
<li><a href="@context.path/signout">Sign out</a></li>
|
||||||
|
</ul>
|
||||||
|
</li>
|
||||||
|
} else {
|
||||||
|
<li>
|
||||||
|
<a href="@context.path/signin?redirect=@helpers.urlEncode(context.currentPath)" class="pull-right" id="signin">Sign in</a>
|
||||||
|
</li>
|
||||||
|
}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</nav>
|
||||||
|
</header>
|
||||||
|
@body
|
||||||
|
</div>
|
||||||
<script>
|
<script>
|
||||||
$(function(){
|
$(function(){
|
||||||
$('#search').submit(function(){
|
$('#search').submit(function(){
|
||||||
@@ -112,7 +112,7 @@
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
@PluginRegistry().getJavaScript(request.getRequestURI).map { script =>
|
@PluginRegistry().getJavaScript(context.request.getRequestURI).map { script =>
|
||||||
<script>
|
<script>
|
||||||
@Html(script)
|
@Html(script)
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
@@ -3,70 +3,84 @@
|
|||||||
id: Option[String] = None,
|
id: Option[String] = None,
|
||||||
info: Option[Any] = None,
|
info: Option[Any] = None,
|
||||||
error: Option[Any] = None)(body: Html)(implicit context: gitbucket.core.controller.Context)
|
error: Option[Any] = None)(body: Html)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
|
|
||||||
@menuitem(path: String, name: String, label: String, icon: String, count: Int = 0) = {
|
@menuitem(path: String, name: String, label: String, icon: String, count: Int = 0) = {
|
||||||
<li @if(active == name){class="active"}>
|
<li @if(active == name){class="active"}>
|
||||||
<a href="@url(repository)@path">
|
@if(path.startsWith("http")){
|
||||||
<i class="menu-icon octicon octicon-@icon"></i>
|
<a href="@path" target="_blank">
|
||||||
<span class="pc">
|
<i class="menu-icon octicon octicon-@icon"></i> @label @if(count > 0) { <span class="label label-primary pull-right">@count</span> }
|
||||||
@label
|
</a>
|
||||||
@if(count > 0){
|
} else {
|
||||||
<span class="badge">@count</span>
|
<a href="@helpers.url(repository)@path">
|
||||||
}
|
<i class="menu-icon octicon octicon-@icon"></i> @label @if(count > 0) { <span class="label label-primary pull-right">@count</span> }
|
||||||
</span>
|
</a>
|
||||||
</a>
|
}
|
||||||
</li>
|
</li>
|
||||||
}
|
}
|
||||||
|
|
||||||
<div class="headbar">
|
<div class="main-sidebar">
|
||||||
<div class="container">
|
<div class="sidebar">
|
||||||
@helper.html.information(info)
|
<ul class="sidebar-menu">
|
||||||
@helper.html.error(error)
|
@menuitem("", "files", "Files", "code")
|
||||||
<div class="head">
|
@if(repository.commitCount != 0) {
|
||||||
@helper.html.repositoryicon(repository, true)
|
@menuitem("/branches", "branches", "Branches", "git-branch", repository.branchList.length)
|
||||||
<a href="@url(repository.owner)">@repository.owner</a> / <a href="@url(repository)" class="strong">@repository.name</a>
|
@menuitem("/tags", "tags", "Tags", "tag", repository.tags.length)
|
||||||
|
}
|
||||||
|
@if(repository.repository.enableIssues) {
|
||||||
|
@menuitem("/issues", "issues", "Issues", "issue-opened", repository.issueCount)
|
||||||
|
@menuitem("/pulls", "pulls", "Pull Requests", "git-pull-request", repository.pullCount)
|
||||||
|
@menuitem("/issues/labels", "labels", "Labels", "tag")
|
||||||
|
@menuitem("/issues/milestones", "milestones", "Milestones", "milestone")
|
||||||
|
} else {
|
||||||
|
@repository.repository.externalIssuesUrl.map { externalIssuesUrl =>
|
||||||
|
@menuitem(externalIssuesUrl, "issues", "Issues", "issue-opened")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@if(repository.repository.enableWiki) {
|
||||||
|
@menuitem("/wiki", "wiki", "Wiki", "book")
|
||||||
|
} else {
|
||||||
|
@repository.repository.externalWikiUrl.map { externalWikiUrl =>
|
||||||
|
@menuitem(externalWikiUrl, "wiki", "Wiki", "book")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@menuitem("/network/members", "fork", "Forks", "repo-forked", repository.forkedCount)
|
||||||
|
@if(context.loginAccount.isDefined && (context.loginAccount.get.isAdmin || repository.managers.contains(context.loginAccount.get.userName))){
|
||||||
|
@menuitem("/settings", "settings", "Settings", "tools")
|
||||||
|
}
|
||||||
|
@gitbucket.core.plugin.PluginRegistry().getRepositoryMenus.map { menu =>
|
||||||
|
@menu(repository, context).map { link =>
|
||||||
|
@menuitem(link.path, link.id, link.label, link.icon.getOrElse("ruby"))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="content-wrapper">
|
||||||
|
<div class="content body clearfix">
|
||||||
|
<div class="headbar">
|
||||||
|
<div class="container">
|
||||||
|
@gitbucket.core.helper.html.information(info)
|
||||||
|
@gitbucket.core.helper.html.error(error)
|
||||||
|
<div class="head">
|
||||||
|
@gitbucket.core.helper.html.repositoryicon(repository, true)
|
||||||
|
<a href="@helpers.url(repository.owner)">@repository.owner</a> / <a href="@helpers.url(repository)" class="strong">@repository.name</a>
|
||||||
|
|
||||||
@defining(repository.repository){ x =>
|
@defining(repository.repository){ x =>
|
||||||
@if(repository.repository.originRepositoryName.isDefined){
|
@if(repository.repository.originRepositoryName.isDefined){
|
||||||
<div class="forked">
|
<div class="forked">
|
||||||
forked from <a href="@path/@x.parentUserName/@x.parentRepositoryName">@x.parentUserName/@x.parentRepositoryName</a>
|
forked from <a href="@context.path/@x.parentUserName/@x.parentRepositoryName">@x.parentUserName/@x.parentRepositoryName</a>
|
||||||
|
</div>
|
||||||
|
}
|
||||||
|
@x.description.map { description =>
|
||||||
|
<div class="normal muted" style="margin-left: 36px; font-size: 80%;">@Html(helpers.detectAndRenderLinks(description, repository))</div>
|
||||||
|
}
|
||||||
|
}
|
||||||
</div>
|
</div>
|
||||||
}
|
</div>
|
||||||
@x.description.map { description =>
|
</div>
|
||||||
<div class="normal muted" style="margin-left: 36px; font-size: 80%;">@detectAndRenderLinks(description)</div>
|
@body
|
||||||
}
|
|
||||||
}
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="container body">
|
|
||||||
<div class="main-sidebar">
|
|
||||||
<ul class="nav nav-pills nav-stacked">
|
|
||||||
@menuitem("" ,"files" ,"Files", "code")
|
|
||||||
@if(repository.commitCount != 0) {
|
|
||||||
@menuitem("/branches" ,"branches" ,"Branches", "git-branch", repository.branchList.length)
|
|
||||||
@menuitem("/tags" ,"tags" ,"Tags", "tag", repository.tags.length)
|
|
||||||
}
|
|
||||||
@menuitem("/issues" ,"issues" ,"Issues", "issue-opened", repository.issueCount)
|
|
||||||
@menuitem("/pulls" ,"pulls" ,"Pull Requests", "git-pull-request", repository.pullCount)
|
|
||||||
@menuitem("/issues/labels" ,"labels" ,"Labels", "tag")
|
|
||||||
@menuitem("/issues/milestones" ,"milestones" ,"Milestones", "milestone")
|
|
||||||
@menuitem("/wiki" ,"wiki" ,"Wiki", "book")
|
|
||||||
@menuitem("/network/members", "fork", "Forks", "repo-forked", repository.forkedCount)
|
|
||||||
@if(loginAccount.isDefined && (loginAccount.get.isAdmin || repository.managers.contains(loginAccount.get.userName))){
|
|
||||||
@menuitem("/settings" , "settings" , "Settings", "tools")
|
|
||||||
}
|
|
||||||
@gitbucket.core.plugin.PluginRegistry().getRepositoryMenus.map { menu =>
|
|
||||||
@menu(repository, context).map { link =>
|
|
||||||
@menuitem(link.path, link.id, link.label, link.icon.getOrElse("ruby"))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
<div class="main-content">
|
|
||||||
@body
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,39 +1,37 @@
|
|||||||
@(commits: Seq[Seq[gitbucket.core.util.JGitUtil.CommitInfo]],
|
@(commits: Seq[Seq[gitbucket.core.util.JGitUtil.CommitInfo]],
|
||||||
comments: Option[List[gitbucket.core.model.Comment]] = None,
|
comments: Option[List[gitbucket.core.model.Comment]] = None,
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
@import gitbucket.core.model._
|
|
||||||
<table class="table table-bordered">
|
<table class="table table-bordered">
|
||||||
@commits.map { day =>
|
@commits.map { day =>
|
||||||
<tr>
|
<tr>
|
||||||
<th rowspan="@day.size" width="100">@date(day.head.commitTime)</th>
|
<th rowspan="@day.size" width="100">@helpers.date(day.head.commitTime)</th>
|
||||||
@day.zipWithIndex.map { case (commit, i) =>
|
@day.zipWithIndex.map { case (commit, i) =>
|
||||||
@if(i != 0){ <tr> }
|
@if(i != 0){ <tr> }
|
||||||
<td>
|
<td>
|
||||||
<div class="pull-right text-right">
|
<div class="pull-right text-right">
|
||||||
<a href="@url(repository)/commit/@commit.id" class="monospace commit-message strong"><i class="octicon octicon-diff" style="color: black;"></i>@commit.id.substring(0, 7)</a><br>
|
<a href="@helpers.url(repository)/commit/@commit.id" class="monospace commit-message strong"><i class="octicon octicon-diff" style="color: black;"></i>@commit.id.substring(0, 7)</a><br>
|
||||||
<a href="@url(repository)/tree/@commit.id" class="button-link">Browse files »</a>
|
<a href="@helpers.url(repository)/tree/@commit.id" class="button-link">Browse files »</a>
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
<div class="commit-avatar-image">@avatarLink(commit, 40)</div>
|
<div class="commit-avatar-image">@helpers.avatarLink(commit, 40)</div>
|
||||||
<div>
|
<div>
|
||||||
<a href="@url(repository)/commit/@commit.id" class="commit-message strong">@link(commit.summary, repository)</a>
|
<a href="@helpers.url(repository)/commit/@commit.id" class="commit-message strong">@helpers.link(commit.summary, repository)</a>
|
||||||
@if(commit.description.isDefined){
|
@if(commit.description.isDefined){
|
||||||
<a href="javascript:void(0)" onclick="$('#description-@commit.id').toggle();" class="omit">...</a>
|
<a href="javascript:void(0)" onclick="$('#description-@commit.id').toggle();" class="omit">...</a>
|
||||||
}
|
}
|
||||||
<br>
|
<br>
|
||||||
@if(commit.description.isDefined){
|
@if(commit.description.isDefined){
|
||||||
<pre id="description-@commit.id" style="display: none;" class="commit-description">@link(commit.description.get, repository)</pre>
|
<pre id="description-@commit.id" style="display: none;" class="commit-description">@helpers.link(commit.description.get, repository)</pre>
|
||||||
}
|
}
|
||||||
<div>
|
<div>
|
||||||
@if(commit.isDifferentFromAuthor) {
|
@if(commit.isDifferentFromAuthor) {
|
||||||
@user(commit.authorName, commit.authorEmailAddress, "username")
|
@helpers.user(commit.authorName, commit.authorEmailAddress, "username")
|
||||||
<span class="muted">authored @helper.html.datetimeago(commit.authorTime)</span>
|
<span class="muted">authored @gitbucket.core.helper.html.datetimeago(commit.authorTime)</span>
|
||||||
<span class="octicon octicon-arrow-right" style="margin-top : -2px;"></span>
|
<span class="octicon octicon-arrow-right" style="margin-top : -2px;"></span>
|
||||||
}
|
}
|
||||||
@user(commit.committerName, commit.committerEmailAddress, "username")
|
@helpers.user(commit.committerName, commit.committerEmailAddress, "username")
|
||||||
<span class="muted">committed @helper.html.datetimeago(commit.commitTime)</span>
|
<span class="muted">committed @gitbucket.core.helper.html.datetimeago(commit.commitTime)</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -14,51 +14,50 @@
|
|||||||
collaborators: List[String],
|
collaborators: List[String],
|
||||||
milestones: List[gitbucket.core.model.Milestone],
|
milestones: List[gitbucket.core.model.Milestone],
|
||||||
labels: List[gitbucket.core.model.Label])(implicit context: gitbucket.core.controller.Context)
|
labels: List[gitbucket.core.model.Label])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.html.main(s"Pull Requests - ${repository.owner}/${repository.name}", Some(repository)){
|
||||||
@html.main(s"Pull Requests - ${repository.owner}/${repository.name}", Some(repository)){
|
@gitbucket.core.html.menu("pulls", repository){
|
||||||
@html.menu("pulls", repository){
|
|
||||||
<div class="pullreq-info">
|
<div class="pullreq-info">
|
||||||
<div id="compare-edit">
|
<div id="compare-edit">
|
||||||
@helper.html.dropdown(originRepository.owner + "/" + originRepository.name, "base fork") {
|
@gitbucket.core.helper.html.dropdown(originRepository.owner + "/" + originRepository.name, "base fork") {
|
||||||
@members.map { case (owner, name) =>
|
@members.map { case (owner, name) =>
|
||||||
<li><a href="#" class="origin-owner" data-owner="@owner" data-name="@name">@helper.html.checkicon(owner == originRepository.owner) @owner/@name</a></li>
|
<li><a href="#" class="origin-owner" data-owner="@owner" data-name="@name">@gitbucket.core.helper.html.checkicon(owner == originRepository.owner) @owner/@name</a></li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@helper.html.dropdown(originId, "base") {
|
@gitbucket.core.helper.html.dropdown(originId, "base") {
|
||||||
@originRepository.branchList.map { branch =>
|
@originRepository.branchList.map { branch =>
|
||||||
<li><a href="#" class="origin-branch" data-branch="@encodeRefName(branch)">@helper.html.checkicon(branch == originId) @branch</a></li>
|
<li><a href="#" class="origin-branch" data-branch="@helpers.encodeRefName(branch)">@gitbucket.core.helper.html.checkicon(branch == originId) @branch</a></li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
...
|
...
|
||||||
@helper.html.dropdown(forkedRepository.owner + "/" + forkedRepository.name, "head fork") {
|
@gitbucket.core.helper.html.dropdown(forkedRepository.owner + "/" + forkedRepository.name, "head fork") {
|
||||||
@members.map { case (owner, name) =>
|
@members.map { case (owner, name) =>
|
||||||
<li><a href="#" class="forked-owner" data-owner="@owner" data-name="@name">@helper.html.checkicon(owner == forkedRepository.owner) @owner/@name</a></li>
|
<li><a href="#" class="forked-owner" data-owner="@owner" data-name="@name">@gitbucket.core.helper.html.checkicon(owner == forkedRepository.owner) @owner/@name</a></li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@helper.html.dropdown(forkedId, "compare") {
|
@gitbucket.core.helper.html.dropdown(forkedId, "compare") {
|
||||||
@forkedRepository.branchList.map { branch =>
|
@forkedRepository.branchList.map { branch =>
|
||||||
<li><a href="#" class="forked-branch" data-branch="@encodeRefName(branch)">@helper.html.checkicon(branch == forkedId) @branch</a></li>
|
<li><a href="#" class="forked-branch" data-branch="@helpers.encodeRefName(branch)">@gitbucket.core.helper.html.checkicon(branch == forkedId) @branch</a></li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
<div class="check-conflict" style="display: none;">
|
<div class="check-conflict" style="display: none;">
|
||||||
<img src="@assets/common/images/indicator.gif"/> Checking...
|
<img src="@helpers.assets/common/images/indicator.gif"/> Checking...
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@if(commits.nonEmpty && loginAccount.isDefined){
|
@if(commits.nonEmpty && context.loginAccount.isDefined){
|
||||||
<div style="margin-bottom: 10px; padding: 8px; background-color: #fff9ea" id="create-pull-request" class="box-content">
|
<div style="margin-bottom: 10px; padding: 8px; background-color: #fff9ea" id="create-pull-request" class="box-content">
|
||||||
<a href="#" class="btn btn-success" id="show-form">Create pull request</a>
|
<a href="#" class="btn btn-success" id="show-form">Create pull request</a>
|
||||||
|
|
||||||
<span class="muted">Discuss and review the changes in this comparison with others.</span>
|
<span class="muted">Discuss and review the changes in this comparison with others.</span>
|
||||||
</div>
|
</div>
|
||||||
<div id="pull-request-form" @*class="box"*@ style="display: none; margin-bottom: 20px;">
|
<div id="pull-request-form" @*class="box"*@ style="display: none; margin-bottom: 20px;">
|
||||||
<form method="POST" action="@path/@originRepository.owner/@originRepository.name/pulls/new" validate="true">
|
<form method="POST" action="@context.path/@originRepository.owner/@originRepository.name/pulls/new" validate="true">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<span class="error" id="error-title"></span>
|
<span class="error" id="error-title"></span>
|
||||||
<input type="text" name="title" value="@title" class="form-control" style="margin-bottom: 6px;" placeholder="Title"/>
|
<input type="text" name="title" value="@title" class="form-control" style="margin-bottom: 6px;" placeholder="Title"/>
|
||||||
@helper.html.preview(
|
@gitbucket.core.helper.html.preview(
|
||||||
repository = repository,
|
repository = repository,
|
||||||
content = "",
|
content = "",
|
||||||
enableWikiLink = false,
|
enableWikiLink = false,
|
||||||
@@ -66,6 +65,7 @@
|
|||||||
enableLineBreaks = true,
|
enableLineBreaks = true,
|
||||||
enableTaskList = true,
|
enableTaskList = true,
|
||||||
hasWritePermission = true,
|
hasWritePermission = true,
|
||||||
|
completionContext = "issues",
|
||||||
style = "height: 200px;"
|
style = "height: 200px;"
|
||||||
)
|
)
|
||||||
<input type="hidden" name="targetUserName" value="@originRepository.owner"/>
|
<input type="hidden" name="targetUserName" value="@originRepository.owner"/>
|
||||||
@@ -80,7 +80,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-3">
|
<div class="col-md-3">
|
||||||
@issues.html.issueinfo(None, Nil, Nil, collaborators, milestones.map((_, 0, 0)), labels, hasOriginWritePermission, repository)
|
@gitbucket.core.issues.html.issueinfo(None, Nil, Nil, collaborators, milestones.map((_, 0, 0)), labels, hasOriginWritePermission, repository)
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
@@ -108,23 +108,23 @@
|
|||||||
<td style="width: 25%; text-align: center;">
|
<td style="width: 25%; text-align: center;">
|
||||||
<i class="octicon octicon-commit"></i>
|
<i class="octicon octicon-commit"></i>
|
||||||
@defining(commits.flatten){ commits =>
|
@defining(commits.flatten){ commits =>
|
||||||
<strong>@commits.size</strong> @plural(commits.size, "commit")
|
<strong>@commits.size</strong> @helpers.plural(commits.size, "commit")
|
||||||
}
|
}
|
||||||
</td>
|
</td>
|
||||||
<td style="width: 25%; text-align: center;">
|
<td style="width: 25%; text-align: center;">
|
||||||
<i class="octicon octicon-diff"></i>
|
<i class="octicon octicon-diff"></i>
|
||||||
<strong>@diffs.size</strong> @plural(diffs.size, "file") changed
|
<strong>@diffs.size</strong> @helpers.plural(diffs.size, "file") changed
|
||||||
</td>
|
</td>
|
||||||
<td style="width: 25%; text-align: center;">
|
<td style="width: 25%; text-align: center;">
|
||||||
<i class="octicon octicon-comment"></i>
|
<i class="octicon octicon-comment"></i>
|
||||||
@defining(comments.collect { case c: gitbucket.core.model.CommitComment => c }){ comments =>
|
@defining(comments.collect { case c: gitbucket.core.model.CommitComment => c }){ comments =>
|
||||||
<strong>@comments.size</strong> commit @plural(comments.size, "comment")
|
<strong>@comments.size</strong> commit @helpers.plural(comments.size, "comment")
|
||||||
}
|
}
|
||||||
</td>
|
</td>
|
||||||
<td style="width: 25%; text-align: center;">
|
<td style="width: 25%; text-align: center;">
|
||||||
<i class="octicon octicon-organization"></i>
|
<i class="octicon octicon-organization"></i>
|
||||||
@defining(commits.flatMap(_.map(_.authorEmailAddress)).distinct){ contributors =>
|
@defining(commits.flatMap(_.map(_.authorEmailAddress)).distinct){ contributors =>
|
||||||
<strong>@contributors.size</strong> @plural(contributors.size, "contributor")
|
<strong>@contributors.size</strong> @helpers.plural(contributors.size, "contributor")
|
||||||
}
|
}
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
@@ -133,16 +133,16 @@
|
|||||||
<div class="box" style="margin-bottom: 20px;">
|
<div class="box" style="margin-bottom: 20px;">
|
||||||
@commits.map { day =>
|
@commits.map { day =>
|
||||||
<div style="margin-top: 8px; margin-bottom: 8px;" class="muted">
|
<div style="margin-top: 8px; margin-bottom: 8px;" class="muted">
|
||||||
Commits on @date(day.head.commitTime)
|
Commits on @helpers.date(day.head.commitTime)
|
||||||
</div>
|
</div>
|
||||||
<table style="width: 100%;">
|
<table style="width: 100%;">
|
||||||
@day.map { commit =>
|
@day.map { commit =>
|
||||||
<tr>
|
<tr>
|
||||||
<td style="width: 20%;">
|
<td style="width: 20%;">
|
||||||
<i class="octicon octicon-git-commit"></i>
|
<i class="octicon octicon-git-commit"></i>
|
||||||
@avatar(commit, 20)
|
@helpers.avatar(commit, 20)
|
||||||
@user(commit.authorName, commit.authorEmailAddress, "username strong")
|
@helpers.user(commit.authorName, commit.authorEmailAddress, "username strong")
|
||||||
</td>
|
</td>
|
||||||
<td><span class="monospace">@commit.shortMessage</span></td>
|
<td><span class="monospace">@commit.shortMessage</span></td>
|
||||||
@*
|
@*
|
||||||
<span class="badge" style="display: inline">@if(comments.isDefined){
|
<span class="badge" style="display: inline">@if(comments.isDefined){
|
||||||
@@ -153,16 +153,16 @@
|
|||||||
}</span>
|
}</span>
|
||||||
*@
|
*@
|
||||||
<td style="width: 10%; text-align: right;">
|
<td style="width: 10%; text-align: right;">
|
||||||
<a href="@url(repository)/commit/@commit.id" class="monospace">@commit.id.substring(0, 7)</a>
|
<a href="@helpers.url(repository)/commit/@commit.id" class="monospace">@commit.id.substring(0, 7)</a>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
}
|
}
|
||||||
</table>
|
</table>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
@helper.html.diff(diffs, repository, Some(commitId), Some(sourceId), true, None, false, false)
|
@gitbucket.core.helper.html.diff(diffs, repository, Some(commitId), Some(sourceId), true, None, false, false)
|
||||||
<p>Showing you all comments on commits in this comparison.</p>
|
<p>Showing you all comments on commits in this comparison.</p>
|
||||||
@issues.html.commentlist(None, comments, false, repository, None)
|
@gitbucket.core.issues.html.commentlist(None, comments, false, repository, None)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -175,11 +175,11 @@ $(function(){
|
|||||||
e.parents('div.btn-group').find('button span.strong').text(e.text());
|
e.parents('div.btn-group').find('button span.strong').text(e.text());
|
||||||
|
|
||||||
@if(members.isEmpty){
|
@if(members.isEmpty){
|
||||||
location.href = '@url(repository)/compare/' +
|
location.href = '@helpers.url(repository)/compare/' +
|
||||||
$.trim($('i.octicon-check').parents('a.origin-branch').data('branch')) + '...' +
|
$.trim($('i.octicon-check').parents('a.origin-branch').data('branch')) + '...' +
|
||||||
$.trim($('i.octicon-check').parents('a.forked-branch').data('branch'));
|
$.trim($('i.octicon-check').parents('a.forked-branch').data('branch'));
|
||||||
} else {
|
} else {
|
||||||
location.href = '@path/' +
|
location.href = '@context.path/' +
|
||||||
$.trim($('i.octicon-check').parents('a.forked-owner' ).data('owner')) + '/' +
|
$.trim($('i.octicon-check').parents('a.forked-owner' ).data('owner')) + '/' +
|
||||||
$.trim($('i.octicon-check').parents('a.forked-owner' ).data('name')) +'/compare/' +
|
$.trim($('i.octicon-check').parents('a.forked-owner' ).data('name')) +'/compare/' +
|
||||||
$.trim($('i.octicon-check').parents('a.origin-owner' ).data('owner')) + ':' +
|
$.trim($('i.octicon-check').parents('a.origin-owner' ).data('owner')) + ':' +
|
||||||
@@ -197,10 +197,10 @@ $(function(){
|
|||||||
$('#show-form').click();
|
$('#show-form').click();
|
||||||
}
|
}
|
||||||
|
|
||||||
@if(loginAccount.isDefined){
|
@if(context.loginAccount.isDefined){
|
||||||
function checkConflict(from, to){
|
function checkConflict(from, to){
|
||||||
$('.check-conflict').show();
|
$('.check-conflict').show();
|
||||||
$.get('@url(forkedRepository)/compare/' + from + '...' + to + '/mergecheck',
|
$.get('@helpers.url(forkedRepository)/compare/' + from + '...' + to + '/mergecheck',
|
||||||
function(data){ $('.check-conflict').html(data); });
|
function(data){ $('.check-conflict').html(data); });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -7,12 +7,10 @@
|
|||||||
labels: List[gitbucket.core.model.Label],
|
labels: List[gitbucket.core.model.Label],
|
||||||
hasWritePermission: Boolean,
|
hasWritePermission: Boolean,
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
@import gitbucket.core.model._
|
|
||||||
<div class="col-md-9">
|
<div class="col-md-9">
|
||||||
<div id="comment-list">
|
<div id="comment-list">
|
||||||
@issues.html.commentlist(Some(issue), comments, hasWritePermission, repository, Some(pullreq))
|
@gitbucket.core.issues.html.commentlist(Some(issue), comments, hasWritePermission, repository, Some(pullreq))
|
||||||
</div>
|
</div>
|
||||||
@defining(comments.flatMap {
|
@defining(comments.flatMap {
|
||||||
case comment: gitbucket.core.model.IssueComment => Some(comment)
|
case comment: gitbucket.core.model.IssueComment => Some(comment)
|
||||||
@@ -20,18 +18,18 @@
|
|||||||
}.exists(_.action == "merge")){ merged =>
|
}.exists(_.action == "merge")){ merged =>
|
||||||
@if(!issue.closed){
|
@if(!issue.closed){
|
||||||
<div class="check-conflict" style="display: none;">
|
<div class="check-conflict" style="display: none;">
|
||||||
<div class="box issue-comment-box" style="background-color: #fbeed5">
|
<div class="issue-comment-box" style="background-color: #fbeed5">
|
||||||
<div class="box-content"class="issue-content" style="border: 1px solid #c09853; padding: 10px;">
|
<div class="box-content"class="issue-content" style="border: 1px solid #c09853; padding: 10px;">
|
||||||
<img src="@assets/common/images/indicator.gif"/> Checking...
|
<img src="@helpers.assets/common/images/indicator.gif"/> Checking...
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
@if(hasWritePermission && issue.closed && pullreq.userName == pullreq.requestUserName && merged &&
|
@if(hasWritePermission && issue.closed && pullreq.userName == pullreq.requestUserName && merged &&
|
||||||
pullreq.repositoryName == pullreq.requestRepositoryName && repository.branchList.contains(pullreq.requestBranch)){
|
pullreq.repositoryName == pullreq.requestRepositoryName && repository.branchList.contains(pullreq.requestBranch)){
|
||||||
<div class="box issue-comment-box" style="background-color: #d0eeff;">
|
<div class="issue-comment-box" style="background-color: #d0eeff;">
|
||||||
<div class="box-content"class="issue-content" style="border: 1px solid #87a8c9; padding: 10px;">
|
<div class="box-content"class="issue-content" style="border: 1px solid #87a8c9; padding: 10px;">
|
||||||
<a href="@url(repository)/pull/@issue.issueId/delete/@encodeRefName(pullreq.requestBranch)" class="btn btn-info pull-right delete-branch" data-name="@pullreq.requestBranch">Delete branch</a>
|
<a href="@helpers.url(repository)/pull/@issue.issueId/delete/@helpers.encodeRefName(pullreq.requestBranch)" class="btn btn-info pull-right delete-branch" data-name="@pullreq.requestBranch">Delete branch</a>
|
||||||
<div>
|
<div>
|
||||||
<span class="strong">Pull request successfully merged and closed</span>
|
<span class="strong">Pull request successfully merged and closed</span>
|
||||||
</div>
|
</div>
|
||||||
@@ -39,11 +37,11 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
@issues.html.commentform(issue, !merged, hasWritePermission, repository)
|
@gitbucket.core.issues.html.commentform(issue, !merged, hasWritePermission, repository)
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-3">
|
<div class="col-md-3">
|
||||||
@issues.html.issueinfo(Some(issue), comments, issueLabels, collaborators, milestones, labels, hasWritePermission, repository)
|
@gitbucket.core.issues.html.issueinfo(Some(issue), comments, issueLabels, collaborators, milestones, labels, hasWritePermission, repository)
|
||||||
</div>
|
</div>
|
||||||
<script>
|
<script>
|
||||||
$(function(){
|
$(function(){
|
||||||
@@ -54,7 +52,7 @@ $(function(){
|
|||||||
|
|
||||||
var checkConflict = $('.check-conflict').show();
|
var checkConflict = $('.check-conflict').show();
|
||||||
if(checkConflict.length){
|
if(checkConflict.length){
|
||||||
$.get('@url(repository)/pull/@issue.issueId/mergeguide', function(data){ $('.check-conflict').html(data); });
|
$.get('@helpers.url(repository)/pull/@issue.issueId/mergeguide', function(data){ $('.check-conflict').html(data); });
|
||||||
}
|
}
|
||||||
|
|
||||||
@if(hasWritePermission){
|
@if(hasWritePermission){
|
||||||
|
|||||||
@@ -3,19 +3,16 @@
|
|||||||
pullreq: gitbucket.core.model.PullRequest,
|
pullreq: gitbucket.core.model.PullRequest,
|
||||||
originRepository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
originRepository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
||||||
forkedRepository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
forkedRepository: gitbucket.core.service.RepositoryService.RepositoryInfo)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import gitbucket.core.service.SystemSettingsService
|
@import gitbucket.core.view.helpers
|
||||||
@import context._
|
<div class="issue-comment-box" style="background-color: @if(status.hasProblem){ #fbeed5 }else{ #d8f5cd };">
|
||||||
@import gitbucket.core.view.helpers._
|
|
||||||
@import model.CommitState
|
|
||||||
<div class="box issue-comment-box" style="background-color: @if(status.hasProblem){ #fbeed5 }else{ #d8f5cd };">
|
|
||||||
<div class="box-content issue-content" style="border: 1px solid @if(status.hasProblem){ #c09853 }else{ #95c97e };padding:0">
|
<div class="box-content issue-content" style="border: 1px solid @if(status.hasProblem){ #c09853 }else{ #95c97e };padding:0">
|
||||||
<div id="merge-pull-request">
|
<div id="merge-pull-request">
|
||||||
@if(!status.statuses.isEmpty){
|
@if(!status.statuses.isEmpty){
|
||||||
<div class="build-statuses">
|
<div class="build-statuses">
|
||||||
@defining(status.commitStateSummary){ case (summaryState, summary) =>
|
@defining(status.commitStateSummary){ case (summaryState, summary) =>
|
||||||
<a class="pull-right" id="toggle-all-checks"></a>
|
<a class="pull-right" id="toggle-all-checks"></a>
|
||||||
<span class="build-status-icon text-@{summaryState.name}">@commitStateIcon(summaryState)</span>
|
<span class="build-status-icon text-@{summaryState.name}">@helpers.commitStateIcon(summaryState)</span>
|
||||||
<strong class="text-@{summaryState.name}">@commitStateText(summaryState, pullreq.commitIdTo)</strong>
|
<strong class="text-@{summaryState.name}">@helpers.commitStateText(summaryState, pullreq.commitIdTo)</strong>
|
||||||
<span class="text-@{summaryState.name}">— @summary checks</span>
|
<span class="text-@{summaryState.name}">— @summary checks</span>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
@@ -26,7 +23,7 @@
|
|||||||
@if(required){ <span class="label">Required</span> }
|
@if(required){ <span class="label">Required</span> }
|
||||||
@status.targetUrl.map { url => <a href="@url">Details</a> }
|
@status.targetUrl.map { url => <a href="@url">Details</a> }
|
||||||
</div>
|
</div>
|
||||||
<span class="build-status-icon text-@{status.state.name}">@commitStateIcon(status.state)</span>
|
<span class="build-status-icon text-@{status.state.name}">@helpers.commitStateIcon(status.state)</span>
|
||||||
<strong>@status.context</strong>
|
<strong>@status.context</strong>
|
||||||
@status.description.map { desc => <span class="muted">— @desc</span> }
|
@status.description.map { desc => <span class="muted">— @desc</span> }
|
||||||
</div>
|
</div>
|
||||||
@@ -48,7 +45,7 @@
|
|||||||
@if(status.branchIsOutOfDate){
|
@if(status.branchIsOutOfDate){
|
||||||
@if(status.hasUpdatePermission){
|
@if(status.hasUpdatePermission){
|
||||||
<div class="pull-right">
|
<div class="pull-right">
|
||||||
<form method="POST" action="@url(originRepository)/pull/@pullreq.issueId/update_branch">
|
<form method="POST" action="@helpers.url(originRepository)/pull/@pullreq.issueId/update_branch">
|
||||||
<input type="hidden" name="expected_head_oid" value="@pullreq.commitIdFrom">
|
<input type="hidden" name="expected_head_oid" value="@pullreq.commitIdFrom">
|
||||||
<button class="btn btn-default"@if(!status.canUpdate){ disabled="true"} id="update-branch-button">Update branch</button>
|
<button class="btn btn-default"@if(!status.canUpdate){ disabled="true"} id="update-branch-button">Update branch</button>
|
||||||
</form>
|
</form>
|
||||||
@@ -102,10 +99,10 @@
|
|||||||
you can perform a manual merge on the command line.
|
you can perform a manual merge on the command line.
|
||||||
</p>
|
</p>
|
||||||
}
|
}
|
||||||
@helper.html.copy("repository-url-copy", forkedRepository.httpUrl){
|
@gitbucket.core.helper.html.copy("repository-url-copy", forkedRepository.httpUrl){
|
||||||
<div class="input-group-btn" data-toggle="buttons">
|
<div class="input-group-btn" data-toggle="buttons">
|
||||||
<label class="btn btn-sm btn-default active" id="repository-url-http"><input type="radio" checked>HTTP</label>
|
<label class="btn btn-sm btn-default active" id="repository-url-http"><input type="radio" checked>HTTP</label>
|
||||||
@if(settings.ssh && loginAccount.isDefined){
|
@if(context.settings.ssh && context.loginAccount.isDefined){
|
||||||
<label class="btn btn-sm btn-default" id="repository-url-ssh"><input type="radio">SSH</label>
|
<label class="btn btn-sm btn-default" id="repository-url-ssh"><input type="radio">SSH</label>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
@@ -117,7 +114,7 @@
|
|||||||
</p>
|
</p>
|
||||||
@defining(s"git checkout -b ${pullreq.requestUserName}-${pullreq.requestBranch} ${pullreq.branch}\n" +
|
@defining(s"git checkout -b ${pullreq.requestUserName}-${pullreq.requestBranch} ${pullreq.branch}\n" +
|
||||||
s"git pull ${forkedRepository.httpUrl} ${pullreq.requestBranch}"){ command =>
|
s"git pull ${forkedRepository.httpUrl} ${pullreq.requestBranch}"){ command =>
|
||||||
@helper.html.copy("merge-command-copy-1", command, "position: absolute; right: 31px;")()
|
@gitbucket.core.helper.html.copy("merge-command-copy-1", command, "position: absolute; right: 31px;")()
|
||||||
<pre style="font-size: 12px; border-radius: 3px;" id="merge-command">@Html(command)</pre>
|
<pre style="font-size: 12px; border-radius: 3px;" id="merge-command">@Html(command)</pre>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
@@ -127,7 +124,7 @@
|
|||||||
</p>
|
</p>
|
||||||
@defining(s"git checkout ${pullreq.branch}\ngit merge --no-ff ${pullreq.requestUserName}-${pullreq.requestBranch}\n" +
|
@defining(s"git checkout ${pullreq.branch}\ngit merge --no-ff ${pullreq.requestUserName}-${pullreq.requestBranch}\n" +
|
||||||
s"git push origin ${pullreq.branch}"){ command =>
|
s"git push origin ${pullreq.branch}"){ command =>
|
||||||
@helper.html.copy("merge-command-copy-2", command, "position: absolute; right: 31px;")()
|
@gitbucket.core.helper.html.copy("merge-command-copy-2", command, "position: absolute; right: 31px;")()
|
||||||
<pre style="font-size: 12px; border-radius: 3px;">@command</pre>
|
<pre style="font-size: 12px; border-radius: 3px;">@command</pre>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
@@ -136,7 +133,7 @@
|
|||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
<div id="confirm-merge-form" style="display: none; padding: 12px;">
|
<div id="confirm-merge-form" style="display: none; padding: 12px;">
|
||||||
<form method="POST" action="@url(originRepository)/pull/@pullreq.issueId/merge">
|
<form method="POST" action="@helpers.url(originRepository)/pull/@pullreq.issueId/merge" validate="true">
|
||||||
<div class="strong">
|
<div class="strong">
|
||||||
Merge pull request #@issue.issueId from @{pullreq.requestUserName}/@{pullreq.requestBranch}
|
Merge pull request #@issue.issueId from @{pullreq.requestUserName}/@{pullreq.requestBranch}
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -10,19 +10,19 @@
|
|||||||
hasWritePermission: Boolean,
|
hasWritePermission: Boolean,
|
||||||
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
repository: gitbucket.core.service.RepositoryService.RepositoryInfo,
|
||||||
flash: Map[String, String])(implicit context: gitbucket.core.controller.Context)
|
flash: Map[String, String])(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@import gitbucket.core.model.IssueComment
|
||||||
@import gitbucket.core.model._
|
@import gitbucket.core.model.CommitComment
|
||||||
@html.main(s"${issue.title} - Pull Request #${issue.issueId} - ${repository.owner}/${repository.name}", Some(repository)){
|
@gitbucket.core.html.main(s"${issue.title} - Pull Request #${issue.issueId} - ${repository.owner}/${repository.name}", Some(repository)){
|
||||||
@html.menu("pulls", repository){
|
@gitbucket.core.html.menu("pulls", repository){
|
||||||
@defining(dayByDayCommits.flatten){ commits =>
|
@defining(dayByDayCommits.flatten){ commits =>
|
||||||
<div>
|
<div>
|
||||||
<div class="show-title pull-right">
|
<div class="show-title pull-right">
|
||||||
@if(hasWritePermission || loginAccount.map(_.userName == issue.openedUserName).getOrElse(false)){
|
@if(hasWritePermission || context.loginAccount.map(_.userName == issue.openedUserName).getOrElse(false)){
|
||||||
<a class="btn" href="#" id="edit">Edit</a>
|
<a class="btn" href="#" id="edit">Edit</a>
|
||||||
}
|
}
|
||||||
@if(loginAccount.isDefined){
|
@if(context.loginAccount.isDefined){
|
||||||
<a class="btn btn-success" href="@url(repository)/compare">New pull request</a>
|
<a class="btn btn-success" href="@helpers.url(repository)/compare">New pull request</a>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
<div class="edit-title pull-right" style="display: none;">
|
<div class="edit-title pull-right" style="display: none;">
|
||||||
@@ -47,21 +47,21 @@
|
|||||||
}.find(_.action == "merge").map{ comment =>
|
}.find(_.action == "merge").map{ comment =>
|
||||||
<span class="label label-info issue-status">Merged</span>
|
<span class="label label-info issue-status">Merged</span>
|
||||||
<span class="muted">
|
<span class="muted">
|
||||||
@user(comment.commentedUserName, styleClass="username strong") merged @commits.size @plural(commits.size, "commit")
|
@helpers.user(comment.commentedUserName, styleClass="username strong") merged @commits.size @helpers.plural(commits.size, "commit")
|
||||||
into <code>@pullreq.userName:@pullreq.branch</code> from <code>@pullreq.requestUserName:@pullreq.requestBranch</code>
|
into <code>@pullreq.userName:@pullreq.branch</code> from <code>@pullreq.requestUserName:@pullreq.requestBranch</code>
|
||||||
@helper.html.datetimeago(comment.registeredDate)
|
@gitbucket.core.helper.html.datetimeago(comment.registeredDate)
|
||||||
</span>
|
</span>
|
||||||
}.getOrElse {
|
}.getOrElse {
|
||||||
<span class="label label-important issue-status">Closed</span>
|
<span class="label label-important issue-status">Closed</span>
|
||||||
<span class="muted">
|
<span class="muted">
|
||||||
@user(issue.openedUserName, styleClass="username strong") wants to merge @commits.size @plural(commits.size, "commit")
|
@helpers.user(issue.openedUserName, styleClass="username strong") wants to merge @commits.size @helpers.plural(commits.size, "commit")
|
||||||
into <code>@pullreq.userName:@pullreq.branch</code> from <code>@pullreq.requestUserName:@pullreq.requestBranch</code>
|
into <code>@pullreq.userName:@pullreq.branch</code> from <code>@pullreq.requestUserName:@pullreq.requestBranch</code>
|
||||||
</span>
|
</span>
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
<span class="label label-success issue-status">Open</span>
|
<span class="label label-success issue-status">Open</span>
|
||||||
<span class="muted">
|
<span class="muted">
|
||||||
@user(issue.openedUserName, styleClass="username strong") wants to merge @commits.size @plural(commits.size, "commit")
|
@helpers.user(issue.openedUserName, styleClass="username strong") wants to merge @commits.size @helpers.plural(commits.size, "commit")
|
||||||
into <code>@pullreq.userName:@pullreq.branch</code> from <code>@pullreq.requestUserName:@pullreq.requestBranch</code>
|
into <code>@pullreq.userName:@pullreq.branch</code> from <code>@pullreq.requestUserName:@pullreq.requestBranch</code>
|
||||||
</span>
|
</span>
|
||||||
}
|
}
|
||||||
@@ -82,13 +82,13 @@
|
|||||||
@flash.get("info").map{ info =>
|
@flash.get("info").map{ info =>
|
||||||
<div class="alert alert-info">@info</div>
|
<div class="alert alert-info">@info</div>
|
||||||
}
|
}
|
||||||
@pulls.html.conversation(issue, pullreq, comments, issueLabels, collaborators, milestones, labels, hasWritePermission, repository)
|
@gitbucket.core.pulls.html.conversation(issue, pullreq, comments, issueLabels, collaborators, milestones, labels, hasWritePermission, repository)
|
||||||
</div>
|
</div>
|
||||||
<div class="tab-pane" id="commits">
|
<div class="tab-pane" id="commits">
|
||||||
@pulls.html.commits(dayByDayCommits, Some(comments), repository)
|
@gitbucket.core.pulls.html.commits(dayByDayCommits, Some(comments), repository)
|
||||||
</div>
|
</div>
|
||||||
<div class="tab-pane" id="files">
|
<div class="tab-pane" id="files">
|
||||||
@helper.html.diff(diffs, repository, Some(commits.head.id), Some(commits.last.id), true, Some(pullreq.issueId), hasWritePermission, true)
|
@gitbucket.core.helper.html.diff(diffs, repository, Some(commits.head.id), Some(commits.last.id), true, Some(pullreq.issueId), hasWritePermission, true)
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
@@ -126,7 +126,7 @@ $(function(){
|
|||||||
$('#update').click(function(){
|
$('#update').click(function(){
|
||||||
$(this).attr('disabled', 'disabled');
|
$(this).attr('disabled', 'disabled');
|
||||||
$.ajax({
|
$.ajax({
|
||||||
url: '@url(repository)/issues/edit_title/@issue.issueId',
|
url: '@helpers.url(repository)/issues/edit_title/@issue.issueId',
|
||||||
type: 'POST',
|
type: 'POST',
|
||||||
data: {
|
data: {
|
||||||
title : $('#edit-title').val()
|
title : $('#edit-title').val()
|
||||||
|
|||||||
@@ -5,13 +5,12 @@
|
|||||||
latestCommit: gitbucket.core.util.JGitUtil.CommitInfo,
|
latestCommit: gitbucket.core.util.JGitUtil.CommitInfo,
|
||||||
hasWritePermission: Boolean,
|
hasWritePermission: Boolean,
|
||||||
isBlame: Boolean)(implicit context: gitbucket.core.controller.Context)
|
isBlame: Boolean)(implicit context: gitbucket.core.controller.Context)
|
||||||
@import context._
|
@import gitbucket.core.view.helpers
|
||||||
@import gitbucket.core.view.helpers._
|
@gitbucket.core.html.main(s"${(repository.name :: pathList).mkString("/")} at ${helpers.encodeRefName(branch)} - ${repository.owner}/${repository.name}", Some(repository)) {
|
||||||
@html.main(s"${(repository.name :: pathList).mkString("/")} at ${encodeRefName(branch)} - ${repository.owner}/${repository.name}", Some(repository)) {
|
@gitbucket.core.html.menu("files", repository){
|
||||||
@html.menu("files", repository){
|
|
||||||
<div class="head">
|
<div class="head">
|
||||||
<div class="pull-right hide-if-blame"><div class="btn-group">
|
<div class="pull-right hide-if-blame"><div class="btn-group">
|
||||||
<a href="@url(repository)/find/@encodeRefName(branch)" class="btn btn-sm btn-default" data-hotkey="t">Find file</a>
|
<a href="@helpers.url(repository)/find/@helpers.encodeRefName(branch)" class="btn btn-sm btn-default" data-hotkey="t">Find file</a>
|
||||||
</div></div>
|
</div></div>
|
||||||
<div class="line-age-legend">
|
<div class="line-age-legend">
|
||||||
<span>Newer</span>
|
<span>Newer</span>
|
||||||
@@ -29,71 +28,71 @@
|
|||||||
</ol>
|
</ol>
|
||||||
<span>Older</span>
|
<span>Older</span>
|
||||||
</div>
|
</div>
|
||||||
@helper.html.branchcontrol(
|
@gitbucket.core.helper.html.branchcontrol(
|
||||||
branch,
|
branch,
|
||||||
repository,
|
repository,
|
||||||
hasWritePermission
|
hasWritePermission
|
||||||
){
|
){
|
||||||
@repository.branchList.map { x =>
|
@repository.branchList.map { x =>
|
||||||
<li><a href="@url(repository)/blob/@encodeRefName(x)/@pathList.mkString("/")">@helper.html.checkicon(x == branch) @x</a></li>
|
<li><a href="@helpers.url(repository)/blob/@helpers.encodeRefName(x)/@pathList.mkString("/")">@gitbucket.core.helper.html.checkicon(x == branch) @x</a></li>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
<a href="@url(repository)/tree/@encodeRefName(branch)">@repository.name</a> /
|
<a href="@helpers.url(repository)/tree/@helpers.encodeRefName(branch)">@repository.name</a> /
|
||||||
@pathList.zipWithIndex.map { case (section, i) =>
|
@pathList.zipWithIndex.map { case (section, i) =>
|
||||||
@if(i == pathList.length - 1){
|
@if(i == pathList.length - 1){
|
||||||
@section
|
@section
|
||||||
} else {
|
} else {
|
||||||
<a href="@url(repository)/tree/@encodeRefName(branch)/@pathList.take(i + 1).mkString("/")">@section</a> /
|
<a href="@helpers.url(repository)/tree/@helpers.encodeRefName(branch)/@pathList.take(i + 1).mkString("/")">@section</a> /
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
<div class="box-header">
|
<div class="box-header">
|
||||||
@avatar(latestCommit, 28)
|
@helpers.avatar(latestCommit, 28)
|
||||||
@user(latestCommit.authorName, latestCommit.authorEmailAddress, "username strong")
|
@helpers.user(latestCommit.authorName, latestCommit.authorEmailAddress, "username strong")
|
||||||
<span class="muted">@helper.html.datetimeago(latestCommit.commitTime)</span>
|
<span class="muted">@gitbucket.core.helper.html.datetimeago(latestCommit.commitTime)</span>
|
||||||
<a href="@url(repository)/commit/@latestCommit.id" class="commit-message">@link(latestCommit.summary, repository)</a>
|
<a href="@helpers.url(repository)/commit/@latestCommit.id" class="commit-message">@helpers.link(latestCommit.summary, repository)</a>
|
||||||
<div class="btn-group pull-right">
|
<div class="btn-group pull-right">
|
||||||
@if(hasWritePermission && content.viewType == "text" && repository.branchList.contains(branch)){
|
@if(hasWritePermission && content.viewType == "text" && repository.branchList.contains(branch)){
|
||||||
<a class="btn btn-sm btn-default" href="@url(repository)/edit/@encodeRefName(branch)/@pathList.mkString("/")">Edit</a>
|
<a class="btn btn-sm btn-default" href="@helpers.url(repository)/edit/@helpers.encodeRefName(branch)/@pathList.mkString("/")">Edit</a>
|
||||||
}
|
}
|
||||||
<a class="btn btn-sm btn-default" href="@url(repository)/raw/@latestCommit.id/@pathList.mkString("/")">Raw</a>
|
<a class="btn btn-sm btn-default" href="@helpers.url(repository)/raw/@latestCommit.id/@pathList.mkString("/")">Raw</a>
|
||||||
@if(content.viewType == "text"){
|
@if(content.viewType == "text"){
|
||||||
<a class="btn btn-sm btn-default blame-action" href="@url(repository)/blame/@latestCommit.id/@pathList.mkString("/")" data-url="@url(repository)/get-blame/@latestCommit.id/@pathList.mkString("/")" data-repository="@url(repository)">Blame</a>
|
<a class="btn btn-sm btn-default blame-action" href="@helpers.url(repository)/blame/@latestCommit.id/@pathList.mkString("/")" data-url="@helpers.url(repository)/get-blame/@latestCommit.id/@pathList.mkString("/")" data-repository="@helpers.url(repository)">Blame</a>
|
||||||
}
|
}
|
||||||
<a class="btn btn-sm btn-default" href="@url(repository)/commits/@encodeRefName(branch)/@pathList.mkString("/")">History</a>
|
<a class="btn btn-sm btn-default" href="@helpers.url(repository)/commits/@helpers.encodeRefName(branch)/@pathList.mkString("/")">History</a>
|
||||||
@if(hasWritePermission && repository.branchList.contains(branch)){
|
@if(hasWritePermission && repository.branchList.contains(branch)){
|
||||||
<a class="btn btn-sm btn-danger" href="@url(repository)/remove/@encodeRefName(branch)/@pathList.mkString("/")">Delete</a>
|
<a class="btn btn-sm btn-danger" href="@helpers.url(repository)/remove/@helpers.encodeRefName(branch)/@pathList.mkString("/")">Delete</a>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@if(content.viewType == "text"){
|
@if(content.viewType == "text"){
|
||||||
@defining(isRenderable(pathList.reverse.head)){ isRrenderable =>
|
@defining(helpers.isRenderable(pathList.reverse.head)){ isRenderable =>
|
||||||
@if(!isBlame && isRrenderable) {
|
@if(!isBlame && isRenderable) {
|
||||||
<div class="box-content-bottom markdown-body" style="padding-left: 20px; padding-right: 20px;">
|
<div class="box-content-bottom markdown-body" style="padding-left: 20px; padding-right: 20px;">
|
||||||
@renderMarkup(pathList, content.content.get, branch, repository, false, false, true)
|
@helpers.renderMarkup(pathList, content.content.get, branch, repository, false, false, true)
|
||||||
</div>
|
</div>
|
||||||
} else {
|
} else {
|
||||||
<div class="box-content-bottom">
|
<div class="box-content-bottom">
|
||||||
<pre class="prettyprint linenums blob @if(!isRrenderable){ no-renderable } ">@content.content.get</pre>
|
<pre class="prettyprint linenums blob @if(!isRenderable){ no-renderable } ">@content.content.get</pre>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@if(content.viewType == "image"){
|
@if(content.viewType == "image"){
|
||||||
<div class="box-content-bottom">
|
<div class="box-content-bottom">
|
||||||
<img src="@url(repository)/raw/@encodeRefName(branch)/@pathList.mkString("/")"/>
|
<img src="@helpers.url(repository)/raw/@helpers.encodeRefName(branch)/@pathList.mkString("/")"/>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
@if(content.viewType == "large" || content.viewType == "binary"){
|
@if(content.viewType == "large" || content.viewType == "binary"){
|
||||||
<div class="box-content-bottom" style="text-align: center; padding-top: 20px; padding-bottom: 20px;">
|
<div class="box-content-bottom" style="text-align: center; padding-top: 20px; padding-bottom: 20px;">
|
||||||
<a href="@url(repository)/raw/@encodeRefName(branch)/@pathList.mkString("/")">View Raw</a><br>
|
<a href="@helpers.url(repository)/raw/@helpers.encodeRefName(branch)/@pathList.mkString("/")">View Raw</a><br>
|
||||||
<br>
|
<br>
|
||||||
(Sorry about that, but we can't show files that are this big right now)
|
(Sorry about that, but we can't show files that are this big right now)
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
<script src="@assets/vendors/jquery/jquery.ba-hashchange.js"></script>
|
<script src="@helpers.assets/vendors/jquery/jquery.ba-hashchange.js"></script>
|
||||||
<script>
|
<script>
|
||||||
$(window).load(function(){
|
$(window).load(function(){
|
||||||
$(window).hashchange(function(){
|
$(window).hashchange(function(){
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user