Bladeren bron

Merge branch 'master' of https://gitote.in/gitote/gitote

Yoginth 7 jaren geleden
bovenliggende
commit
eabc68dff0

+ 8 - 3
cmd/web.go

@@ -172,7 +172,7 @@ func runWeb(c *cli.Context) error {
 	m.Get("/", ignSignIn, routes.Home)
 	m.Get("/trending", routes.ExploreTrending)
 	m.Group("/explore", func() {
-		m.Get("/", routes.ExploreHome)
+		m.Get("/", routes.Explore)
 		m.Get("/repos", routes.ExploreRepos)
 		m.Get("/users", routes.ExploreUsers)
 		m.Get("/organizations", routes.ExploreOrganizations)
@@ -263,8 +263,13 @@ func runWeb(c *cli.Context) error {
 		m.Post("/config/test_mail", admin.SendTestMail)
 		m.Get("/monitor", admin.Monitor)
 		m.Get("/inbox", admin.Inbox)
-		m.Get("/status", admin.Status)
-
+		
+		m.Group("/news", func() {
+			m.Get("", admin.News)
+			m.Get("/new", admin.NewsNew)
+			m.Get("/edit", admin.NewsEdit)
+		})
+		
 		m.Group("/users", func() {
 			m.Get("", admin.Users)
 			m.Combo("/new").Get(admin.NewUser).Post(bindIgnErr(form.AdminCrateUser{}), admin.NewUserPost)

+ 0 - 5
public/sitemap.xml

@@ -25,11 +25,6 @@
         <changefreq>Daily</changefreq>
         <priority>0.9</priority>
     </url>
-    <url>
-        <loc>https://gitote.in/developers</loc>
-        <changefreq>Daily</changefreq>
-        <priority>0.9</priority>
-    </url>
     <url>
         <loc>https://gitote.in/brand</loc>
         <changefreq>Daily</changefreq>

+ 0 - 10
routes/admin/admin.go

@@ -39,9 +39,6 @@ const (
 
 	// MONITOR page template
 	MONITOR = "admin/monitor"
-
-	// STATUS page template
-	STATUS = "admin/status"
 )
 
 var (
@@ -288,13 +285,6 @@ func Monitor(c *context.Context) {
 	c.HTML(200, MONITOR)
 }
 
-// Status shows status page
-func Status(c *context.Context) {
-	c.Data["Title"] = "Status"
-	c.Data["PageIsAdminStatus"] = true
-	c.HTML(200, STATUS)
-}
-
 // Analytics shows analytics page
 func Analytics(c *context.Context) {
 	c.Data["Title"] = "Analytics"

+ 43 - 0
routes/admin/news.go

@@ -0,0 +1,43 @@
+// Copyright 2015 The Gogs Authors. All rights reserved.
+// Copyright 2018 Gitote. All rights reserved.
+//
+// This source code is licensed under the MIT license found in the
+// LICENSE file in the root directory of this source tree.
+
+package admin
+
+import (
+	"gitote/gitote/pkg/context"
+)
+
+const (
+	// NEWS list page template
+	NEWS = "admin/news/list"
+
+	// NEWS_NEW page template
+	NEWS_NEW = "admin/news/new"
+
+	// NEWS_EDIT page template
+	NEWS_EDIT = "admin/news/edit"
+)
+
+// News shows news page
+func News(c *context.Context) {
+	c.Data["Title"] = "News"
+	c.Data["PageIsAdminNews"] = true
+	c.HTML(200, NEWS)
+}
+
+// News shows news page
+func NewsNew(c *context.Context) {
+	c.Data["Title"] = "News"
+	c.Data["PageIsAdminNews"] = true
+	c.HTML(200, NEWS_NEW)
+}
+
+// News shows news page
+func NewsEdit(c *context.Context) {
+	c.Data["Title"] = "News"
+	c.Data["PageIsAdminNews"] = true
+	c.HTML(200, NEWS_EDIT)
+}

+ 204 - 0
routes/explore.go

@@ -0,0 +1,204 @@
+// Copyright 2015 The Gogs Authors. All rights reserved.
+// Copyright 2018 Gitote. All rights reserved.
+//
+// This source code is licensed under the MIT license found in the
+// LICENSE file in the root directory of this source tree.
+
+package routes
+
+import (
+	"gitote/gitote/models"
+	"gitote/gitote/pkg/context"
+	"gitote/gitote/pkg/setting"
+
+	"gitlab.com/yoginth/paginater"
+)
+
+const (
+	// EXPLORE_HOME page template
+	EXPLORE = "explore/home"
+
+	// EXPLORE_REPOS page template
+	EXPLORE_REPOS = "explore/repos"
+
+	// EXPLORE_USERS page template
+	EXPLORE_USERS = "explore/users"
+
+	// EXPLORE_TRENDING page template
+	EXPLORE_TRENDING = "explore/trending"
+
+	// EXPLORE_ORGANIZATIONS page template
+	EXPLORE_ORGANIZATIONS = "explore/organizations"
+)
+
+// ExploreHome shows explore page
+func Explore(c *context.Context) {
+	c.Data["Title"] = c.Tr("explore")
+	c.Data["PageIsExplore"] = true
+	c.Data["PageIsExploreRepositories"] = true
+
+	repos, count, err := models.SearchRepositoryByName(&models.SearchRepoOptions{
+		UserID:   c.UserID(),
+		OrderBy:  "num_stars DESC",
+		PageSize: 4,
+	})
+	if err != nil {
+		c.ServerError("SearchRepositoryByName", err)
+		return
+	}
+	c.Data["Total"] = count
+
+	if err = models.RepositoryList(repos).LoadAttributes(); err != nil {
+		c.ServerError("RepositoryList.LoadAttributes", err)
+		return
+	}
+	c.Data["Repos"] = repos
+
+	c.Success(EXPLORE)
+}
+
+// ExploreRepos shows explore repositories page
+func ExploreRepos(c *context.Context) {
+	c.Data["Title"] = c.Tr("explore")
+	c.Data["PageIsExplore"] = true
+	c.Data["PageIsExploreRepositories"] = true
+
+	page := c.QueryInt("page")
+	if page <= 0 {
+		page = 1
+	}
+
+	keyword := c.Query("q")
+	// Search a repository
+	repos, count, err := models.SearchRepositoryByName(&models.SearchRepoOptions{
+		Keyword:  keyword,
+		UserID:   c.UserID(),
+		OrderBy:  "updated_unix DESC",
+		Page:     page,
+		PageSize: setting.UI.ExplorePagingNum,
+	})
+	if err != nil {
+		c.ServerError("SearchRepositoryByName", err)
+		return
+	}
+	c.Data["Keyword"] = keyword
+	c.Data["Total"] = count
+	c.Data["Page"] = paginater.New(int(count), setting.UI.ExplorePagingNum, page, 5)
+
+	if err = models.RepositoryList(repos).LoadAttributes(); err != nil {
+		c.ServerError("RepositoryList.LoadAttributes", err)
+		return
+	}
+	c.Data["Repos"] = repos
+
+	c.Success(EXPLORE_REPOS)
+}
+
+// ExploreTrending shows trending repositories page
+func ExploreTrending(c *context.Context) {
+	c.Data["Title"] = c.Tr("explore.trending")
+	c.Data["PageIsTrending"] = true
+
+	repos, count, err := models.SearchRepositoryByName(&models.SearchRepoOptions{
+		UserID:   c.UserID(),
+		OrderBy:  "num_stars DESC",
+		PageSize: 15,
+	})
+	if err != nil {
+		c.ServerError("SearchRepositoryByName", err)
+		return
+	}
+	c.Data["Total"] = count
+
+	if err = models.RepositoryList(repos).LoadAttributes(); err != nil {
+		c.ServerError("RepositoryList.LoadAttributes", err)
+		return
+	}
+	c.Data["Repos"] = repos
+
+	c.Success(EXPLORE_TRENDING)
+}
+
+// UserSearchOptions is the structure of the options choosed by the user
+type UserSearchOptions struct {
+	Type     models.UserType
+	Counter  func() int64
+	Ranger   func(int, int) ([]*models.User, error)
+	PageSize int
+	OrderBy  string
+	TplName  string
+}
+
+// RenderUserSearch renders user search
+func RenderUserSearch(c *context.Context, opts *UserSearchOptions) {
+	page := c.QueryInt("page")
+	if page <= 1 {
+		page = 1
+	}
+
+	var (
+		users []*models.User
+		count int64
+		err   error
+	)
+
+	keyword := c.Query("q")
+	if len(keyword) == 0 {
+		users, err = opts.Ranger(page, opts.PageSize)
+		if err != nil {
+			c.ServerError("Ranger", err)
+			return
+		}
+		count = opts.Counter()
+	} else {
+		users, count, err = models.SearchUserByName(&models.SearchUserOptions{
+			Keyword:  keyword,
+			Type:     opts.Type,
+			OrderBy:  opts.OrderBy,
+			Page:     page,
+			PageSize: opts.PageSize,
+		})
+		if err != nil {
+			c.ServerError("SearchUserByName", err)
+			return
+		}
+	}
+	c.Data["Keyword"] = keyword
+	c.Data["Total"] = count
+	c.Data["Page"] = paginater.New(int(count), opts.PageSize, page, 5)
+	c.Data["Users"] = users
+
+	c.Success(opts.TplName)
+}
+
+// ExploreUsers shows explore users page
+func ExploreUsers(c *context.Context) {
+	c.Data["Title"] = c.Tr("explore")
+	c.Data["PageIsExplore"] = true
+	c.Data["PageIsExploreUsers"] = true
+
+	RenderUserSearch(c, &UserSearchOptions{
+		Type:     models.USER_TYPE_INDIVIDUAL,
+		Counter:  models.CountUsers,
+		Ranger:   models.Users,
+		PageSize: setting.UI.ExplorePagingNum,
+		OrderBy:  "updated_unix DESC",
+		TplName:  EXPLORE_USERS,
+	})
+}
+
+//ExploreOrganizations shows explore organizations page
+func ExploreOrganizations(c *context.Context) {
+	c.Data["Title"] = c.Tr("explore")
+	c.Data["PageIsExplore"] = true
+	c.Data["PageIsExploreOrganizations"] = true
+
+	RenderUserSearch(c, &UserSearchOptions{
+		Type:     models.USER_TYPE_ORGANIZATION,
+		Counter:  models.CountOrganizations,
+		Ranger:   models.Organizations,
+		PageSize: setting.UI.ExplorePagingNum,
+		OrderBy:  "updated_unix DESC",
+		TplName:  EXPLORE_ORGANIZATIONS,
+	})
+}

+ 0 - 190
routes/home.go

@@ -7,32 +7,14 @@
 package routes
 
 import (
-	"gitote/gitote/models"
 	"gitote/gitote/pkg/context"
 	"gitote/gitote/pkg/setting"
 	"gitote/gitote/routes/user"
-
-	"gitlab.com/yoginth/paginater"
 )
 
 const (
 	// HOME page template
 	HOME = "home"
-
-	// EXPLORE_HOME page template
-	EXPLORE_HOME = "explore/home"
-
-	// EXPLORE_REPOS page template
-	EXPLORE_REPOS = "explore/repos"
-
-	// EXPLORE_USERS page template
-	EXPLORE_USERS = "explore/users"
-
-	// EXPLORE_TRENDING page template
-	EXPLORE_TRENDING = "explore/trending"
-
-	// EXPLORE_ORGANIZATIONS page template
-	EXPLORE_ORGANIZATIONS = "explore/organizations"
 )
 
 // Home shows the home page
@@ -58,178 +40,6 @@ func Home(c *context.Context) {
 	c.Success(HOME)
 }
 
-// ExploreHome shows explore page
-func ExploreHome(c *context.Context) {
-	c.Data["Title"] = c.Tr("explore")
-	c.Data["PageIsExplore"] = true
-	c.Data["PageIsExploreRepositories"] = true
-
-	repos, count, err := models.SearchRepositoryByName(&models.SearchRepoOptions{
-		UserID:   c.UserID(),
-		OrderBy:  "num_stars DESC",
-		PageSize: 4,
-	})
-	if err != nil {
-		c.ServerError("SearchRepositoryByName", err)
-		return
-	}
-	c.Data["Total"] = count
-
-	if err = models.RepositoryList(repos).LoadAttributes(); err != nil {
-		c.ServerError("RepositoryList.LoadAttributes", err)
-		return
-	}
-	c.Data["Repos"] = repos
-
-	c.Success(EXPLORE_HOME)
-}
-
-// ExploreRepos shows explore repositories page
-func ExploreRepos(c *context.Context) {
-	c.Data["Title"] = c.Tr("explore")
-	c.Data["PageIsExplore"] = true
-	c.Data["PageIsExploreRepositories"] = true
-
-	page := c.QueryInt("page")
-	if page <= 0 {
-		page = 1
-	}
-
-	keyword := c.Query("q")
-	// Search a repository
-	repos, count, err := models.SearchRepositoryByName(&models.SearchRepoOptions{
-		Keyword:  keyword,
-		UserID:   c.UserID(),
-		OrderBy:  "updated_unix DESC",
-		Page:     page,
-		PageSize: setting.UI.ExplorePagingNum,
-	})
-	if err != nil {
-		c.ServerError("SearchRepositoryByName", err)
-		return
-	}
-	c.Data["Keyword"] = keyword
-	c.Data["Total"] = count
-	c.Data["Page"] = paginater.New(int(count), setting.UI.ExplorePagingNum, page, 5)
-
-	if err = models.RepositoryList(repos).LoadAttributes(); err != nil {
-		c.ServerError("RepositoryList.LoadAttributes", err)
-		return
-	}
-	c.Data["Repos"] = repos
-
-	c.Success(EXPLORE_REPOS)
-}
-
-// ExploreTrending shows trending repositories page
-func ExploreTrending(c *context.Context) {
-	c.Data["Title"] = c.Tr("explore.trending")
-	c.Data["PageIsTrending"] = true
-
-	repos, count, err := models.SearchRepositoryByName(&models.SearchRepoOptions{
-		UserID:   c.UserID(),
-		OrderBy:  "num_stars DESC",
-		PageSize: 15,
-	})
-	if err != nil {
-		c.ServerError("SearchRepositoryByName", err)
-		return
-	}
-	c.Data["Total"] = count
-
-	if err = models.RepositoryList(repos).LoadAttributes(); err != nil {
-		c.ServerError("RepositoryList.LoadAttributes", err)
-		return
-	}
-	c.Data["Repos"] = repos
-
-	c.Success(EXPLORE_TRENDING)
-}
-
-// UserSearchOptions is the structure of the options choosed by the user
-type UserSearchOptions struct {
-	Type     models.UserType
-	Counter  func() int64
-	Ranger   func(int, int) ([]*models.User, error)
-	PageSize int
-	OrderBy  string
-	TplName  string
-}
-
-// RenderUserSearch renders user search
-func RenderUserSearch(c *context.Context, opts *UserSearchOptions) {
-	page := c.QueryInt("page")
-	if page <= 1 {
-		page = 1
-	}
-
-	var (
-		users []*models.User
-		count int64
-		err   error
-	)
-
-	keyword := c.Query("q")
-	if len(keyword) == 0 {
-		users, err = opts.Ranger(page, opts.PageSize)
-		if err != nil {
-			c.ServerError("Ranger", err)
-			return
-		}
-		count = opts.Counter()
-	} else {
-		users, count, err = models.SearchUserByName(&models.SearchUserOptions{
-			Keyword:  keyword,
-			Type:     opts.Type,
-			OrderBy:  opts.OrderBy,
-			Page:     page,
-			PageSize: opts.PageSize,
-		})
-		if err != nil {
-			c.ServerError("SearchUserByName", err)
-			return
-		}
-	}
-	c.Data["Keyword"] = keyword
-	c.Data["Total"] = count
-	c.Data["Page"] = paginater.New(int(count), opts.PageSize, page, 5)
-	c.Data["Users"] = users
-
-	c.Success(opts.TplName)
-}
-
-// ExploreUsers shows explore users page
-func ExploreUsers(c *context.Context) {
-	c.Data["Title"] = c.Tr("explore")
-	c.Data["PageIsExplore"] = true
-	c.Data["PageIsExploreUsers"] = true
-
-	RenderUserSearch(c, &UserSearchOptions{
-		Type:     models.USER_TYPE_INDIVIDUAL,
-		Counter:  models.CountUsers,
-		Ranger:   models.Users,
-		PageSize: setting.UI.ExplorePagingNum,
-		OrderBy:  "updated_unix DESC",
-		TplName:  EXPLORE_USERS,
-	})
-}
-
-//ExploreOrganizations shows explore organizations page
-func ExploreOrganizations(c *context.Context) {
-	c.Data["Title"] = c.Tr("explore")
-	c.Data["PageIsExplore"] = true
-	c.Data["PageIsExploreOrganizations"] = true
-
-	RenderUserSearch(c, &UserSearchOptions{
-		Type:     models.USER_TYPE_ORGANIZATION,
-		Counter:  models.CountOrganizations,
-		Ranger:   models.Organizations,
-		PageSize: setting.UI.ExplorePagingNum,
-		OrderBy:  "updated_unix DESC",
-		TplName:  EXPLORE_ORGANIZATIONS,
-	})
-}
-
 // NotFound renders 404 page if page not found
 func NotFound(c *context.Context) {
 	c.Data["Title"] = "Page Not Found"

+ 0 - 5
templates/admin/dashboard.tmpl

@@ -17,12 +17,7 @@
 						Git - <a href="https://git-scm.com">{{.GitVersion}}</a>
 						<br/>
 						GoLang - <a href="https://golang.org">{{GoVer}}</a>
-						<br/>
-						Macaron - <a href="https://golang.org">ToDo</a>
-						<br/>
-						PostgreSQL - <a href="https://www.postgresql.org">ToDo</a>
 					</h3>
-					<img style="margin-top:-9em;margin-right:1em" class="ui image tiny right" src="https://cdn.gitote.in/logo.png">
 				</div>
 				<h4 class="ui top attached header">
 					Statistics 📈

+ 8 - 2
templates/admin/navbar.tmpl

@@ -12,6 +12,10 @@
 			😍 Staff Picks
 			<span class="ui violet basic label small">ToDo</span>
 		</a>
+		<a class="{{if .PageIsAdminNews}}active{{end}} item" href="{{AppSubURL}}/admin/news">
+			🌐 News
+			<span class="ui green basic label small">Beta</span>
+		</a>
 		<a class="{{if .PageIsAdminUsers}}active{{end}} item" href="{{AppSubURL}}/admin/users">
 			👦 Users
 		</a>
@@ -41,9 +45,11 @@
 		<a class="{{if .PageIsAdminMonitor}}active{{end}} item" href="{{AppSubURL}}/admin/monitor">
 			💻 Monitoring
 		</a>
-		<a class="item" href="{{AppSubURL}}/admin/status">
+		<a class="item" href="https://gitote.grafana.net/d/1a2QccEmk/gitote?refresh=5s&orgId=1" target="_blank">
+			👷 Grafana
+		</a>
+		<a class="item" href="https://status.gitote.in" target="_blank">
 			📈 Status
-			<span class="ui green basic label small">Beta</span>
 		</a>
 	</div>
 </div>

+ 74 - 0
templates/admin/news.tmpl

@@ -0,0 +1,74 @@
+{{template "base/head" .}}
+<div class="admin monitor">
+	<div class="ui container">
+		<div class="ui grid">
+			{{template "admin/navbar" .}}
+			<div class="twelve wide column content">
+				{{template "base/alert" .}}
+				<h4 class="ui top attached header">
+					API 📲 <span class="ui basic green label small">Beta</span>
+				</h4>
+                <div class="ui attached segment">
+                    <h3>
+                        Version - <a href="{{AppURL}}api/{{APIVer}}/users/gitote">{{APIVer}}</a>
+                    </h3>
+                </div>
+
+                <h4 class="ui top attached header">
+					User
+				</h4>
+                <div class="ui attached segment">
+                    <h3>
+                        Soon
+                    </h3>
+                </div>
+
+                <h4 class="ui top attached header">
+					Organization
+				</h4>
+                <div class="ui attached segment">
+                    <h3>
+                        Soon
+                    </h3>
+                </div>
+
+                <h4 class="ui top attached header">
+					Repository
+				</h4>
+                <div class="ui attached segment">
+                    <h3>
+                        Soon
+                    </h3>
+                </div>
+
+                <h4 class="ui top attached header">
+					Issues
+				</h4>
+                <div class="ui attached segment">
+                    <h3>
+                        Soon
+                    </h3>
+                </div>
+
+                <h4 class="ui top attached header">
+					Admin
+				</h4>
+                <div class="ui attached segment">
+                    <h3>
+                        Soon
+                    </h3>
+                </div>
+
+                <h4 class="ui top attached header">
+					Miscellaneous
+				</h4>
+                <div class="ui attached segment">
+                    <h3>
+                        Soon
+                    </h3>
+                </div>
+			</div>
+		</div>
+	</div>
+</div>
+{{template "base/footer" .}}

+ 232 - 0
templates/admin/news/edit.tmpl

@@ -0,0 +1,232 @@
+{{template "base/head" .}}
+<div class="admin edit user">
+	<div class="ui container">
+		<div class="ui grid">
+			{{template "admin/navbar" .}}
+			<div class="twelve wide column content">
+				{{template "base/alert" .}}
+				<h4 class="ui top attached header">
+					Edit Account 🖊
+				</h4>
+				<div class="ui attached segment">
+					<form class="ui form" action="{{.Link}}" method="post">
+						{{.CSRFTokenHTML}}
+						<div class="inline field {{if .Err_UserName}}error{{end}}">
+							<label for="user_name">Username</label>
+							<a class="ui image label {{if .User.Suspended}}red{{end}}" href="{{AppURL}}{{.User.Name}}" target="_blank">
+								<img src="{{AppendAvatarSize .User.RelAvatarLink 40}}"> {{.User.Name}}
+							</a>
+							<div class="ui label">
+								Followers <div class="detail">{{.User.NumFollowers}}</div>
+							</div>
+							<div class="ui label">
+								Following <div class="detail">{{.User.NumFollowing}}</div>
+							</div>
+						</div>
+						<!-- Types and name -->
+						<div class="inline required field {{if .Err_LoginType}}error{{end}}">
+							<label>Authentication Source</label>
+							<div class="ui selection type dropdown">
+								<input type="hidden" id="login_type" name="login_type" value="{{.LoginSource.Type}}-{{.LoginSource.ID}}" required>
+								<div class="text">Local</div>
+								<i class="dropdown icon"></i>
+								<div class="menu">
+									<div class="item" data-value="0-0">Local</div>
+									{{range .Sources}}
+										<div class="item" data-value="{{.Type}}-{{.ID}}">{{.Name}}</div>
+									{{end}}
+								</div>
+							</div>
+						</div>
+						<div class="required non-local field {{if .Err_LoginName}}error{{end}} {{if eq .User.LoginSource 0}}hide{{end}}">
+							<label for="login_name">Authentication Login Name</label>
+							<input id="login_name" name="login_name" value="{{.User.LoginName}}" autofocus>
+						</div>
+						<div class="field {{if .Err_FullName}}error{{end}}">
+							<label for="full_name">Full Name</label>
+							<input id="full_name" name="full_name" value="{{.User.FullName}}">
+						</div>
+						<div class="field {{if .Err_Description}}error{{end}}">
+							<label for="description">Description</label>
+							<textarea id="description" name="description" rows="2">{{.User.Description}}</textarea>
+						</div>
+						<div class="field {{if .Err_Company}}error{{end}}">
+							<label for="company">Company</label>
+							<input id="company" name="company" value="{{.User.Company}}">
+						</div>
+						<div class="required field {{if .Err_Email}}error{{end}}">
+							<label for="email">Email</label>
+							<input id="email" name="email" type="email" value="{{.User.Email}}" autofocus required>
+						</div>
+						<input class="fake" type="password">
+						<div class="local field {{if .Err_Password}}error{{end}} {{if not (eq .User.LoginSource 0)}}hide{{end}}">
+							<label for="password">Password</label>
+							<input id="password" name="password" type="password">
+							<p class="help">Leave it empty to remain unchanged.</p>
+						</div>
+						<div class="field {{if .Err_Website}}error{{end}}">
+							<label for="website">Website</label>
+							<input id="website" name="website" type="url" value="{{.User.Website}}" placeholder="e.g. https://mydomain.com">
+						</div>
+						<div class="field {{if .Err_Location}}error{{end}}">
+							<label for="location">Location</label>
+							<input id="location" name="location" value="{{.User.Location}}">
+						</div>
+						<div class="field {{if .Err_Twitter}}error{{end}}">
+							<label for="twitter">Twitter</label>
+							<input id="twitter" name="twitter" value="{{.User.Twitter}}">
+						</div>
+						<div class="field {{if .Err_Linkedin}}error{{end}}">
+							<label for="linkedin">Linkedin</label>
+							<input id="linkedin" name="linkedin" value="{{.User.Linkedin}}">
+						</div>
+						<div class="field {{if .Err_Github}}error{{end}}">
+							<label for="github">GitHub</label>
+							<input id="github" name="github" value="{{.User.Github}}">
+						</div>
+						<div class="field {{if .Err_Gitlab}}error{{end}}">
+							<label for="gitlab">GitLab</label>
+							<input id="gitlab" name="gitlab" value="{{.User.Gitlab}}">
+						</div>
+						<div class="field {{if .Err_Devto}}error{{end}}">
+							<label for="devto">Dev.to</label>
+							<input id="devto" name="devto" value="{{.User.Devto}}">
+						</div>
+						<div class="field {{if .Err_Stackoverflow}}error{{end}}">
+							<label for="stackoverflow">Stackoverflow</label>
+							<input id="stackoverflow" name="stackoverflow" value="{{.User.Stackoverflow}}">
+						</div>
+						<div class="field {{if .Err_Reddit}}error{{end}}">
+							<label for="reddit">Reddit</label>
+							<input id="reddit" name="reddit" value="{{.User.Reddit}}">
+						</div>
+						<div class="field {{if .Err_Telegram}}error{{end}}">
+							<label for="telegram">Telegram</label>
+							<input id="telegram" name="telegram" value="{{.User.Telegram}}">
+						</div>
+						<div class="field {{if .Err_Codepen}}error{{end}}">
+							<label for="codepen">Codepen</label>
+							<input id="codepen" name="codepen" value="{{.User.Codepen}}">
+						</div>
+						<div class="field {{if .Err_Notes}}error{{end}}">
+							<label for="staff_notes">Staff Notes</label>
+							<textarea id="staff_notes" name="staff_notes" rows="2">{{.User.StaffNotes}}</textarea>
+							<p class="help">Take notes about <b>{{.User.Name}}</b> for future purpose.</p>
+							<p class="help"><b>Note:</b> This will displayed as <b>reason</b> on prohibited page</p>
+						</div>
+
+						<div class="ui divider"></div>
+
+						<div class="inline field {{if .Err_MaxRepoCreation}}error{{end}}">
+							<label for="max_repo_creation">Maximum Repository Creation Limit</label>
+							<input id="max_repo_creation" name="max_repo_creation" type="number" value="{{.User.MaxRepoCreation}}">
+							<p class="help">(Set -1 to use global default limit)</p>
+						</div>
+
+						<div class="ui divider"></div>
+
+						<div class="inline field">
+							<div class="ui checkbox">
+								<label><strong>This account is activated</strong></label>
+								<input name="active" type="checkbox" {{if .User.IsActive}}checked{{end}}>
+							</div>
+						</div>
+						<div class="inline field">
+							<div class="ui checkbox">
+								<label><strong>This account is verified</strong> <i class="verified octicon octicon-verified"></i></label>
+								<input name="is_verified" type="checkbox" {{if .User.IsVerified}}checked{{end}}>
+							</div>
+						</div>
+						<div class="inline field">
+							<div class="ui checkbox">
+								<label><strong>This account is maker</strong> <i class="maker octicon octicon-paintcan"></i></label>
+								<input name="is_maker" type="checkbox" {{if .User.IsMaker}}checked{{end}}>
+							</div>
+						</div>
+						<div class="inline field">
+							<div class="ui checkbox">
+								<label><strong>This account is staff</strong> <i class="isstaff octicon octicon-tools"></i></label>
+								<input name="is_staff" type="checkbox" {{if .User.IsStaff}}checked{{end}}>
+							</div>
+						</div>
+						<div class="inline field">
+							<div class="ui checkbox">
+								<label><strong>This account is intern</strong></label>
+								<input name="is_intern" type="checkbox" {{if .User.IsIntern}}checked{{end}}>
+							</div>
+						</div>
+						<div class="field">
+							<input id="recognized" name="recognized" value="{{.User.Recognized}}" placeholder="Recognized As">
+						</div>
+						<div class="field">
+							<input id="certified" name="certified" value="{{.User.Certified}}" placeholder="Date" type="date">
+						</div>
+						<div class="inline field">
+							<div class="ui checkbox">
+								<label><strong>This user is Bug Hunter</strong> <i class="bughunter octicon octicon-gist-secret"></i></label>
+								<input name="is_bug_hunter" type="checkbox" {{if .User.IsBugHunter}}checked{{end}}>
+							</div>
+						</div>
+						<div class="inline field">
+							<div class="ui checkbox">
+								<label><strong>This user is Gitote Developer</strong></label>
+								<input name="gitote_developer" type="checkbox" {{if .User.GitoteDeveloper}}checked{{end}}>
+							</div>
+						</div>
+						<div class="inline field">
+							<div class="ui checkbox">
+								<label><strong>This account is Beta Member</strong> <i class="developer octicon octicon-circuit-board"></i></label>
+								<input name="is_beta" type="checkbox" {{if .User.IsBeta}}checked{{end}}>
+							</div>
+						</div>
+						<div class="inline field">
+							<div class="ui checkbox">
+								<label><strong style="color:red">This account is suspended</strong></label>
+								<input name="suspended" type="checkbox" {{if .User.Suspended}}checked{{end}}>
+							</div>
+						</div>
+						<div class="inline field">
+							<div class="ui checkbox">
+								<label><strong>This account has administrator permissions</strong></label>
+								<input name="admin" type="checkbox" {{if .User.IsAdmin}}checked{{end}}>
+							</div>
+						</div>
+						<div class="inline field">
+							<div class="ui checkbox">
+								<label><strong>This account has permissions to create Git hooks</strong></label>
+								<input name="allow_git_hook" type="checkbox" {{if .User.CanEditGitHook}}checked{{end}}>
+							</div>
+						</div>
+						{{if .EnableLocalPathMigration}}
+							<div class="inline field">
+								<div class="ui checkbox">
+									<label><strong>This account has permissions to import local repositories</strong></label>
+									<input name="allow_import_local" type="checkbox" {{if .User.CanImportLocal}}checked{{end}}>
+								</div>
+							</div>
+						{{end}}
+
+						<div class="ui divider"></div>
+
+						<div class="field">
+							<button class="ui green button">Update Account Profile</button>
+							<div class="ui red button delete-button" data-url="{{$.Link}}/delete" data-id="{{.User.ID}}">Delete This Account</div>
+						</div>
+					</form>
+				</div>
+			</div>
+		</div>
+	</div>
+</div>
+
+<div class="ui small basic delete modal">
+	<div class="ui icon header">
+		<i class="trash icon"></i>
+		Account Deletion
+	</div>
+	<div class="content">
+		<p>This account is going to be deleted permanently, do you want to continue?</p>
+	</div>
+	{{template "base/delete_modal_actions" .}}
+</div>
+{{template "base/footer" .}}

+ 42 - 0
templates/admin/news/list.tmpl

@@ -0,0 +1,42 @@
+{{template "base/head" .}}
+<div class="admin user">
+	<div class="ui container">
+		<div class="ui grid">
+			{{template "admin/navbar" .}}
+			<div class="twelve wide column content">
+				{{template "base/alert" .}}
+				<h4 class="ui top attached header">
+					News Manage Panel 🌐
+					<div class="ui right">
+						<a class="ui black tiny button" href="{{AppSubURL}}/admin/news/new">Create New News</a>
+					</div>
+				</h4>
+				<div class="ui unstackable attached table segment">
+					<table class="ui unstackable very basic striped table">
+						<thead>
+							<tr>
+								<th>ID</th>
+								<th>Heading</th>
+								<th>Body</th>
+								<th>Edit</th>
+							</tr>
+						</thead>
+						<tbody>
+							{{range .Users}}
+								<tr>
+									<td>{{.ID}}</td>
+									<td><span class="text truncate email">{{.Heading}}</span></td>
+									<td><span class="text truncate email">{{.Body}}</span></td>
+									<td><a href="{{$.Link}}/{{.ID}}">🖊</a></td>
+								</tr>
+							{{end}}
+						</tbody>
+					</table>
+				</div>
+
+				{{template "admin/base/page" .}}
+			</div>
+		</div>
+	</div>
+</div>
+{{template "base/footer" .}}

+ 33 - 0
templates/admin/news/new.tmpl

@@ -0,0 +1,33 @@
+{{template "base/head" .}}
+<div class="admin new user">
+	<div class="ui container">
+		<div class="ui grid">
+			{{template "admin/navbar" .}}
+			<div class="twelve wide column content">
+				{{template "base/alert" .}}
+				<h4 class="ui top attached header">
+					Create New Account ➕
+				</h4>
+				<div class="ui attached segment">
+					<form class="ui form" action="{{.Link}}" method="post">
+						{{.CSRFTokenHTML}}
+						<!-- Types and name -->
+						<div class="required field">
+							<label for="">Heading</label>
+							<input id="" name="" value="" autofocus required>
+						</div>
+						<div class="required field">
+							<label for="">Body</label>
+							<textarea id="" name="" rows="2"></textarea>
+						</div>
+
+						<div class="field">
+							<button class="ui green button">Create New News</button>
+						</div>
+					</form>
+				</div>
+			</div>
+		</div>
+	</div>
+</div>
+{{template "base/footer" .}}

+ 0 - 29
templates/admin/status.tmpl

@@ -1,29 +0,0 @@
-{{template "base/head" .}}
-<div class="admin monitor">
-	<div class="ui container">
-		<div class="ui grid">
-			{{template "admin/navbar" .}}
-			<div class="twelve wide column content">
-				{{template "base/alert" .}}
-				<h4 class="ui top attached header">
-					Status 📈 <span class="ui basic green label small">Beta</span>
-				</h4>
-				<div class="ui unstackable attached table segment center">
-                    <div class="sitestatus ui center small labels">
-                        <a class="ui label">Website <img src="https://img.shields.io/uptimerobot/ratio/m780912498-752f7edbb4dbba05feb9e8ec.svg?style=for-the-badge"></a>
-                        <a class="ui label">SSH <img src="https://img.shields.io/uptimerobot/ratio/m781510920-51d08026236cf6f3f3911bb0.svg?style=for-the-badge"></a>
-                        <a class="ui label">Source <img src="https://img.shields.io/uptimerobot/ratio/m781510924-fea2fec4b96ccc4bd8fbaba0.svg?style=for-the-badge"></a>
-                        <a class="ui label">Server <img src="https://img.shields.io/uptimerobot/ratio/m781403200-935894641e47a01e0072deb6.svg?style=for-the-badge"></a>
-                        <a class="ui label">jsDelivr <img src="https://img.shields.io/uptimerobot/ratio/m780912503-6cd19c23e4eabb29bc76010a.svg?style=for-the-badge"></a>
-                        <a class="ui label">CDNJS <img src="https://img.shields.io/uptimerobot/ratio/m780912502-b79e1ecb21f413430a60ddae.svg?style=for-the-badge"></a>
-                        <a class="ui label">HTTPS Repo <img src="https://img.shields.io/uptimerobot/ratio/m781403206-6b0e192986d30800ee796e2b.svg?style=for-the-badge"></a>
-                        <a class="ui label">Heartbeat <img src="https://img.shields.io/uptimerobot/ratio/m781403195-099720146b519a42c26bdf40.svg?style=for-the-badge"></a>
-                        <a class="ui label">Database <img src="https://img.shields.io/uptimerobot/ratio/m781403191-ac8349e71d8589ebcd930999.svg?style=for-the-badge"></a>
-                        <a class="ui label">API <img src="https://img.shields.io/uptimerobot/ratio/m781493948-f67df23f4337f9ebc3b9388f.svg?style=for-the-badge"></a>
-                    </div>
-				</div>
-			</div>
-		</div>
-	</div>
-</div>
-{{template "base/footer" .}}

+ 1 - 1
templates/base/footer_content.tmpl

@@ -19,7 +19,7 @@
 	<div class="two wide column">
 		<h4 class="ui header explore-card font">Platform</h4>
 		<div class="ui link list">
-			<a class="item" href="{{AppURL}}developers">API</a>
+			<a class="item" href="https://developers.gitote.in">API</a>
 			<a class="item" href="{{AppURL}}partners">Partners</a>
 			<a class="item" href="{{AppURL}}jobs">Careers</a>
 		</div>

+ 10 - 8
templates/explore/home.tmpl

@@ -60,7 +60,7 @@
 
         <div style="margin-top:3em" class="feature alternate ui stripe vertical">
             <div class="ui three column center aligned divided relaxed stackable grid container">
-                <div class="row">
+                <div class="row hide-mobile">
                     <div style="margin-top:10px" class="column">
                         <h2 class="ui icon header">
                             <a class="{{if .PageIsExploreRepositories}}active{{end}} item" href="{{AppSubURL}}/explore/repos">
@@ -86,21 +86,23 @@
             </div>
         </div>
 
-        <h1 class="ui container center ex-head">Trending</h1>
+        <h2 class="ui container center ex-head">Trending</h2>
         <section style="background-color:#fff;height:auto" class="pages head">
             <div class="ui link cards explore-card top">
                 {{range .Repos}}
                 <div class="card explore-card card">
                     <div class="content">
-                        <div class="explore-card title">{{if $.PageIsExplore}}{{.Owner.Name}} / {{end}}{{.Name}}</div>
-                        <div class="explore-card description">
-                            {{.Description | Str2HTML}}
-                        </div>
+                        <a href="{{AppSubURL}}/{{if .Owner}}{{.Owner.Name}}{{else if $.Org}}{{$.Org.Name}}{{else}}{{$.Owner.Name}}{{end}}/{{.Name}}">
+                            <div class="explore-card title">{{if $.PageIsExplore}}{{.Owner.Name}} / {{end}}{{.Name}}</div>
+                            <div class="explore-card description has-emoji">
+                                {{.Description | Str2HTML}}
+                            </div>
+                        </a>
                     </div>
                     <div class="extra content explore-card extra">
-                        <i class="star icon"></i>{{.NumStars}}
+                        <i class="menu-icon octicon">⭐</i>{{.NumStars}}
                         <span class="explore-card seperator"></span>
-                        <i class="fork icon"></i>{{.NumForks}}
+                        <i class="menu-icon octicon">🌵</i>{{.NumForks}}
                     </div>
                 </div>
                 {{end}}

+ 1 - 1
templates/pages/contribute.tmpl

@@ -103,7 +103,7 @@
             <li class="pages-small">Get your changes merged!</li>
         </ol> 
         <p class="pages-small">
-            For more information, please see the <a href="/developers">Developer Documentation.</a>
+            For more information, please see the <a href="https://developers.gitote.in">Developer Documentation.</a>
         </p>
     </div>
     {{template "base/footer" .}}