Unify organizations header (#29248)
Unify organizations header before:  after:  --------- Co-authored-by: silverwind <me@silverwind.io>
This commit is contained in:
		
							parent
							
								
									e044504241
								
							
						
					
					
						commit
						532e422027
					
				| @ -11,6 +11,8 @@ import ( | |||||||
| 	"code.gitea.io/gitea/models/perm" | 	"code.gitea.io/gitea/models/perm" | ||||||
| 	"code.gitea.io/gitea/models/unit" | 	"code.gitea.io/gitea/models/unit" | ||||||
| 	user_model "code.gitea.io/gitea/models/user" | 	user_model "code.gitea.io/gitea/models/user" | ||||||
|  | 	"code.gitea.io/gitea/modules/markup" | ||||||
|  | 	"code.gitea.io/gitea/modules/markup/markdown" | ||||||
| 	"code.gitea.io/gitea/modules/setting" | 	"code.gitea.io/gitea/modules/setting" | ||||||
| 	"code.gitea.io/gitea/modules/structs" | 	"code.gitea.io/gitea/modules/structs" | ||||||
| ) | ) | ||||||
| @ -255,6 +257,19 @@ func HandleOrgAssignment(ctx *Context, args ...bool) { | |||||||
| 	ctx.Data["CanReadProjects"] = ctx.Org.CanReadUnit(ctx, unit.TypeProjects) | 	ctx.Data["CanReadProjects"] = ctx.Org.CanReadUnit(ctx, unit.TypeProjects) | ||||||
| 	ctx.Data["CanReadPackages"] = ctx.Org.CanReadUnit(ctx, unit.TypePackages) | 	ctx.Data["CanReadPackages"] = ctx.Org.CanReadUnit(ctx, unit.TypePackages) | ||||||
| 	ctx.Data["CanReadCode"] = ctx.Org.CanReadUnit(ctx, unit.TypeCode) | 	ctx.Data["CanReadCode"] = ctx.Org.CanReadUnit(ctx, unit.TypeCode) | ||||||
|  | 
 | ||||||
|  | 	ctx.Data["IsFollowing"] = ctx.Doer != nil && user_model.IsFollowing(ctx, ctx.Doer.ID, ctx.ContextUser.ID) | ||||||
|  | 	if len(ctx.ContextUser.Description) != 0 { | ||||||
|  | 		content, err := markdown.RenderString(&markup.RenderContext{ | ||||||
|  | 			Metas: map[string]string{"mode": "document"}, | ||||||
|  | 			Ctx:   ctx, | ||||||
|  | 		}, ctx.ContextUser.Description) | ||||||
|  | 		if err != nil { | ||||||
|  | 			ctx.ServerError("RenderString", err) | ||||||
|  | 			return | ||||||
|  | 		} | ||||||
|  | 		ctx.Data["RenderedDescription"] = content | ||||||
|  | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // OrgAssignment returns a middleware to handle organization assignment | // OrgAssignment returns a middleware to handle organization assignment | ||||||
|  | |||||||
| @ -11,7 +11,6 @@ import ( | |||||||
| 	"code.gitea.io/gitea/models/db" | 	"code.gitea.io/gitea/models/db" | ||||||
| 	"code.gitea.io/gitea/models/organization" | 	"code.gitea.io/gitea/models/organization" | ||||||
| 	repo_model "code.gitea.io/gitea/models/repo" | 	repo_model "code.gitea.io/gitea/models/repo" | ||||||
| 	user_model "code.gitea.io/gitea/models/user" |  | ||||||
| 	"code.gitea.io/gitea/modules/base" | 	"code.gitea.io/gitea/modules/base" | ||||||
| 	"code.gitea.io/gitea/modules/context" | 	"code.gitea.io/gitea/modules/context" | ||||||
| 	"code.gitea.io/gitea/modules/git" | 	"code.gitea.io/gitea/modules/git" | ||||||
| @ -46,17 +45,6 @@ func Home(ctx *context.Context) { | |||||||
| 
 | 
 | ||||||
| 	ctx.Data["PageIsUserProfile"] = true | 	ctx.Data["PageIsUserProfile"] = true | ||||||
| 	ctx.Data["Title"] = org.DisplayName() | 	ctx.Data["Title"] = org.DisplayName() | ||||||
| 	if len(org.Description) != 0 { |  | ||||||
| 		desc, err := markdown.RenderString(&markup.RenderContext{ |  | ||||||
| 			Ctx:   ctx, |  | ||||||
| 			Metas: map[string]string{"mode": "document"}, |  | ||||||
| 		}, org.Description) |  | ||||||
| 		if err != nil { |  | ||||||
| 			ctx.ServerError("RenderString", err) |  | ||||||
| 			return |  | ||||||
| 		} |  | ||||||
| 		ctx.Data["RenderedDescription"] = desc |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	var orderBy db.SearchOrderBy | 	var orderBy db.SearchOrderBy | ||||||
| 	ctx.Data["SortType"] = ctx.FormString("sort") | 	ctx.Data["SortType"] = ctx.FormString("sort") | ||||||
| @ -131,18 +119,12 @@ func Home(ctx *context.Context) { | |||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	var isFollowing bool |  | ||||||
| 	if ctx.Doer != nil { |  | ||||||
| 		isFollowing = user_model.IsFollowing(ctx, ctx.Doer.ID, ctx.ContextUser.ID) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	ctx.Data["Repos"] = repos | 	ctx.Data["Repos"] = repos | ||||||
| 	ctx.Data["Total"] = count | 	ctx.Data["Total"] = count | ||||||
| 	ctx.Data["Members"] = members | 	ctx.Data["Members"] = members | ||||||
| 	ctx.Data["Teams"] = ctx.Org.Teams | 	ctx.Data["Teams"] = ctx.Org.Teams | ||||||
| 	ctx.Data["DisableNewPullMirrors"] = setting.Mirror.DisableNewPull | 	ctx.Data["DisableNewPullMirrors"] = setting.Mirror.DisableNewPull | ||||||
| 	ctx.Data["PageIsViewRepositories"] = true | 	ctx.Data["PageIsViewRepositories"] = true | ||||||
| 	ctx.Data["IsFollowing"] = isFollowing |  | ||||||
| 
 | 
 | ||||||
| 	err = shared_user.LoadHeaderCount(ctx) | 	err = shared_user.LoadHeaderCount(ctx) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
|  | |||||||
| @ -17,8 +17,6 @@ import ( | |||||||
| 	"code.gitea.io/gitea/modules/git" | 	"code.gitea.io/gitea/modules/git" | ||||||
| 	"code.gitea.io/gitea/modules/gitrepo" | 	"code.gitea.io/gitea/modules/gitrepo" | ||||||
| 	"code.gitea.io/gitea/modules/log" | 	"code.gitea.io/gitea/modules/log" | ||||||
| 	"code.gitea.io/gitea/modules/markup" |  | ||||||
| 	"code.gitea.io/gitea/modules/markup/markdown" |  | ||||||
| 	"code.gitea.io/gitea/modules/setting" | 	"code.gitea.io/gitea/modules/setting" | ||||||
| 	"code.gitea.io/gitea/modules/util" | 	"code.gitea.io/gitea/modules/util" | ||||||
| ) | ) | ||||||
| @ -36,7 +34,6 @@ func prepareContextForCommonProfile(ctx *context.Context) { | |||||||
| func PrepareContextForProfileBigAvatar(ctx *context.Context) { | func PrepareContextForProfileBigAvatar(ctx *context.Context) { | ||||||
| 	prepareContextForCommonProfile(ctx) | 	prepareContextForCommonProfile(ctx) | ||||||
| 
 | 
 | ||||||
| 	ctx.Data["IsFollowing"] = ctx.Doer != nil && user_model.IsFollowing(ctx, ctx.Doer.ID, ctx.ContextUser.ID) |  | ||||||
| 	ctx.Data["ShowUserEmail"] = setting.UI.ShowUserEmail && ctx.ContextUser.Email != "" && ctx.IsSigned && !ctx.ContextUser.KeepEmailPrivate | 	ctx.Data["ShowUserEmail"] = setting.UI.ShowUserEmail && ctx.ContextUser.Email != "" && ctx.IsSigned && !ctx.ContextUser.KeepEmailPrivate | ||||||
| 	ctx.Data["ContextUserLocationMapURL"] = setting.Service.UserLocationMapURL + url.QueryEscape(ctx.ContextUser.Location) | 	ctx.Data["ContextUserLocationMapURL"] = setting.Service.UserLocationMapURL + url.QueryEscape(ctx.ContextUser.Location) | ||||||
| 
 | 
 | ||||||
| @ -48,18 +45,6 @@ func PrepareContextForProfileBigAvatar(ctx *context.Context) { | |||||||
| 	} | 	} | ||||||
| 	ctx.Data["OpenIDs"] = openIDs | 	ctx.Data["OpenIDs"] = openIDs | ||||||
| 
 | 
 | ||||||
| 	if len(ctx.ContextUser.Description) != 0 { |  | ||||||
| 		content, err := markdown.RenderString(&markup.RenderContext{ |  | ||||||
| 			Metas: map[string]string{"mode": "document"}, |  | ||||||
| 			Ctx:   ctx, |  | ||||||
| 		}, ctx.ContextUser.Description) |  | ||||||
| 		if err != nil { |  | ||||||
| 			ctx.ServerError("RenderString", err) |  | ||||||
| 			return |  | ||||||
| 		} |  | ||||||
| 		ctx.Data["RenderedDescription"] = content |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	showPrivate := ctx.IsSigned && (ctx.Doer.IsAdmin || ctx.Doer.ID == ctx.ContextUser.ID) | 	showPrivate := ctx.IsSigned && (ctx.Doer.IsAdmin || ctx.Doer.ID == ctx.ContextUser.ID) | ||||||
| 	orgs, err := db.Find[organization.Organization](ctx, organization.FindOrgOptions{ | 	orgs, err := db.Find[organization.Organization](ctx, organization.FindOrgOptions{ | ||||||
| 		UserID:         ctx.ContextUser.ID, | 		UserID:         ctx.ContextUser.ID, | ||||||
|  | |||||||
| @ -324,6 +324,7 @@ func Action(ctx *context.Context) { | |||||||
| 		ctx.HTML(http.StatusOK, tplProfileBigAvatar) | 		ctx.HTML(http.StatusOK, tplProfileBigAvatar) | ||||||
| 		return | 		return | ||||||
| 	} else if ctx.ContextUser.IsOrganization() { | 	} else if ctx.ContextUser.IsOrganization() { | ||||||
|  | 		ctx.Data["Org"] = ctx.ContextUser | ||||||
| 		ctx.Data["IsFollowing"] = ctx.Doer != nil && user_model.IsFollowing(ctx, ctx.Doer.ID, ctx.ContextUser.ID) | 		ctx.Data["IsFollowing"] = ctx.Doer != nil && user_model.IsFollowing(ctx, ctx.Doer.ID, ctx.ContextUser.ID) | ||||||
| 		ctx.HTML(http.StatusOK, tplFollowUnfollow) | 		ctx.HTML(http.StatusOK, tplFollowUnfollow) | ||||||
| 		return | 		return | ||||||
|  | |||||||
| @ -1,18 +1,32 @@ | |||||||
| {{with .Org}} | <div class="ui container gt-df"> | ||||||
| 	<div class="ui container"> | 	{{ctx.AvatarUtils.Avatar .Org 100 "org-avatar"}} | ||||||
| 		<div class="ui vertically grid head"> | 	<div id="org-info" class="gt-df gt-fc"> | ||||||
| 			<div class="column"> | 		<div class="ui header"> | ||||||
| 				<div class="ui header gt-df gt-ac gt-word-break"> | 			{{.Org.DisplayName}} | ||||||
| 					{{ctx.AvatarUtils.Avatar . 100}} |  | ||||||
| 					<span class="text thin grey"><a href="{{.HomeLink}}">{{.DisplayName}}</a></span> |  | ||||||
| 			<span class="org-visibility"> | 			<span class="org-visibility"> | ||||||
| 						{{if .Visibility.IsLimited}}<div class="ui medium basic horizontal label">{{ctx.Locale.Tr "org.settings.visibility.limited_shortname"}}</div>{{end}} | 				{{if .Org.Visibility.IsLimited}}<span class="ui large basic horizontal label">{{ctx.Locale.Tr "org.settings.visibility.limited_shortname"}}</span>{{end}} | ||||||
| 						{{if .Visibility.IsPrivate}}<div class="ui medium basic horizontal label">{{ctx.Locale.Tr "org.settings.visibility.private_shortname"}}</div>{{end}} | 				{{if .Org.Visibility.IsPrivate}}<span class="ui large basic horizontal label">{{ctx.Locale.Tr "org.settings.visibility.private_shortname"}}</span>{{end}} | ||||||
|  | 			</span> | ||||||
|  | 			<span class="gt-df gt-ac gt-gap-2 gt-ml-auto gt-font-16 gt-whitespace-nowrap"> | ||||||
|  | 				{{if .EnableFeed}} | ||||||
|  | 					<a class="ui basic label button gt-mr-0" href="{{.Org.HomeLink}}.rss" data-tooltip-content="{{ctx.Locale.Tr "rss_feed"}}"> | ||||||
|  | 						{{svg "octicon-rss" 24}} | ||||||
|  | 					</a> | ||||||
|  | 				{{end}} | ||||||
|  | 				{{if .IsSigned}} | ||||||
|  | 					{{template "org/follow_unfollow" .}} | ||||||
|  | 				{{end}} | ||||||
| 			</span> | 			</span> | ||||||
| 		</div> | 		</div> | ||||||
| 			</div> | 		{{if .RenderedDescription}}<div class="render-content markup">{{.RenderedDescription | Str2html}}</div>{{end}} | ||||||
| 		</div> | 		<div class="text light meta gt-mt-2"> | ||||||
| 	</div> | 			{{if .Org.Location}}<div class="flex-text-block">{{svg "octicon-location"}} <span>{{.Org.Location}}</span></div>{{end}} | ||||||
|  | 			{{if .Org.Website}}<div class="flex-text-block">{{svg "octicon-link"}} <a class="muted" target="_blank" rel="noopener noreferrer me" href="{{.Org.Website}}">{{.Org.Website}}</a></div>{{end}} | ||||||
|  | 			{{if .IsSigned}} | ||||||
|  | 				{{if .Org.Email}}<div class="flex-text-block">{{svg "octicon-mail"}} <a class="muted" href="mailto:{{.Org.Email}}">{{.Org.Email}}</a></div>{{end}} | ||||||
| 			{{end}} | 			{{end}} | ||||||
|  | 		</div> | ||||||
|  | 	</div> | ||||||
|  | </div> | ||||||
| 
 | 
 | ||||||
| {{template "org/menu" .}} | {{template "org/menu" .}} | ||||||
|  | |||||||
| @ -1,37 +1,6 @@ | |||||||
| {{template "base/head" .}} | {{template "base/head" .}} | ||||||
| <div role="main" aria-label="{{.Title}}" class="page-content organization profile"> | <div role="main" aria-label="{{.Title}}" class="page-content organization profile"> | ||||||
| 	<div class="ui container gt-df"> | 	{{template "org/header" .}} | ||||||
| 		{{ctx.AvatarUtils.Avatar .Org 140 "org-avatar"}} |  | ||||||
| 		<div id="org-info"> |  | ||||||
| 			<div class="ui header"> |  | ||||||
| 				{{.Org.DisplayName}} |  | ||||||
| 				<span class="org-visibility"> |  | ||||||
| 					{{if .Org.Visibility.IsLimited}}<span class="ui large basic horizontal label">{{ctx.Locale.Tr "org.settings.visibility.limited_shortname"}}</span>{{end}} |  | ||||||
| 					{{if .Org.Visibility.IsPrivate}}<span class="ui large basic horizontal label">{{ctx.Locale.Tr "org.settings.visibility.private_shortname"}}</span>{{end}} |  | ||||||
| 				</span> |  | ||||||
| 			</div> |  | ||||||
| 			{{if $.RenderedDescription}}<div class="render-content markup">{{$.RenderedDescription|Str2html}}</div>{{end}} |  | ||||||
| 			<div class="text grey meta"> |  | ||||||
| 				{{if .Org.Location}}<div class="flex-text-block">{{svg "octicon-location"}} <span>{{.Org.Location}}</span></div>{{end}} |  | ||||||
| 				{{if .Org.Website}}<div class="flex-text-block">{{svg "octicon-link"}} <a target="_blank" rel="noopener noreferrer me" href="{{.Org.Website}}">{{.Org.Website}}</a></div>{{end}} |  | ||||||
| 				{{if $.IsSigned}} |  | ||||||
| 					{{if .Org.Email}}<div class="flex-text-block">{{svg "octicon-mail"}} <a class="muted" href="mailto:{{.Org.Email}}">{{.Org.Email}}</a></div>{{end}} |  | ||||||
| 				{{end}} |  | ||||||
| 			</div> |  | ||||||
| 		</div> |  | ||||||
| 		<div class="right menu"> |  | ||||||
| 			{{if .EnableFeed}} |  | ||||||
| 			<a class="ui basic label button gt-mr-0" href="{{$.Org.HomeLink}}.rss" data-tooltip-content="{{ctx.Locale.Tr "rss_feed"}}"> |  | ||||||
| 				{{svg "octicon-rss" 24}} |  | ||||||
| 			</a> |  | ||||||
| 			{{end}} |  | ||||||
| 			{{if .IsSigned}} |  | ||||||
| 				{{template "org/follow_unfollow" .}} |  | ||||||
| 			{{end}} |  | ||||||
| 		</div> |  | ||||||
| 	</div> |  | ||||||
| 
 |  | ||||||
| 	{{template "org/menu" .}} |  | ||||||
| 
 | 
 | ||||||
| 	<div class="ui container"> | 	<div class="ui container"> | ||||||
| 		<div class="ui mobile reversed stackable grid"> | 		<div class="ui mobile reversed stackable grid"> | ||||||
|  | |||||||
| @ -1,5 +1,5 @@ | |||||||
| {{template "base/head" .}} | {{template "base/head" .}} | ||||||
| <div role="main" aria-label="{{.Title}}" class="page-content organization"> | <div role="main" aria-label="{{.Title}}" class="page-content organization members"> | ||||||
| 	{{template "org/header" .}} | 	{{template "org/header" .}} | ||||||
| 	<div class="ui container"> | 	<div class="ui container"> | ||||||
| 		{{template "base/alert" .}} | 		{{template "base/alert" .}} | ||||||
|  | |||||||
| @ -15,24 +15,24 @@ | |||||||
| 		</a> | 		</a> | ||||||
| 		{{end}} | 		{{end}} | ||||||
| 		{{if and .IsPackageEnabled .CanReadPackages}} | 		{{if and .IsPackageEnabled .CanReadPackages}} | ||||||
| 		<a class="item" href="{{$.Org.HomeLink}}/-/packages"> | 		<a class="{{if .IsPackagesPage}}active {{end}}item" href="{{$.Org.HomeLink}}/-/packages"> | ||||||
| 			{{svg "octicon-package"}} {{ctx.Locale.Tr "packages.title"}} | 			{{svg "octicon-package"}} {{ctx.Locale.Tr "packages.title"}} | ||||||
| 		</a> | 		</a> | ||||||
| 		{{end}} | 		{{end}} | ||||||
| 		{{if and .IsRepoIndexerEnabled .CanReadCode}} | 		{{if and .IsRepoIndexerEnabled .CanReadCode}} | ||||||
| 		<a class="item" href="{{$.Org.HomeLink}}/-/code"> | 		<a class="{{if .IsCodePage}}active {{end}}item" href="{{$.Org.HomeLink}}/-/code"> | ||||||
| 			{{svg "octicon-code"}} {{ctx.Locale.Tr "org.code"}} | 			{{svg "octicon-code"}} {{ctx.Locale.Tr "org.code"}} | ||||||
| 		</a> | 		</a> | ||||||
| 		{{end}} | 		{{end}} | ||||||
| 		{{if .NumMembers}} | 		{{if .NumMembers}} | ||||||
| 			<a class="{{if $.PageIsOrgMembers}}active {{end}}item" href="{{$.OrgLink}}/members"> | 			<a class="{{if $.PageIsOrgMembers}}active {{end}}item" href="{{$.OrgLink}}/members"> | ||||||
| 				{{svg "octicon-person"}} {{ctx.Locale.Tr "org.members"}} | 				{{svg "octicon-person"}} {{ctx.Locale.Tr "org.members"}} | ||||||
| 				<div class="ui small label">{{.NumMembers}}</div> | 				<div class="ui small label">{{.NumMembers}}</div> | ||||||
| 			</a> | 			</a> | ||||||
| 		{{end}} | 		{{end}} | ||||||
| 		{{if .IsOrganizationMember}} | 		{{if .IsOrganizationMember}} | ||||||
| 			<a class="{{if $.PageIsOrgTeams}}active {{end}}item" href="{{$.OrgLink}}/teams"> | 			<a class="{{if $.PageIsOrgTeams}}active {{end}}item" href="{{$.OrgLink}}/teams"> | ||||||
| 				{{svg "octicon-people"}} {{ctx.Locale.Tr "org.teams"}} | 				{{svg "octicon-people"}} {{ctx.Locale.Tr "org.teams"}} | ||||||
| 				{{if .NumTeams}} | 				{{if .NumTeams}} | ||||||
| 					<div class="ui small label">{{.NumTeams}}</div> | 					<div class="ui small label">{{.NumTeams}}</div> | ||||||
| 				{{end}} | 				{{end}} | ||||||
|  | |||||||
| @ -1,9 +1,8 @@ | |||||||
| {{template "base/head" .}} | {{template "base/head" .}} | ||||||
| {{if .ContextUser.IsOrganization}} | {{if .ContextUser.IsOrganization}} | ||||||
| 	<div role="main" aria-label="{{.Title}}" class="page-content repository packages"> | 	<div role="main" aria-label="{{.Title}}" class="page-content organization projects"> | ||||||
| 		{{template "shared/user/org_profile_avatar" .}} | 		{{template "org/header" .}} | ||||||
| 		<div class="ui container"> | 		<div class="ui container"> | ||||||
| 		{{template "user/overview/header" .}} |  | ||||||
| 			{{template "projects/list" .}} | 			{{template "projects/list" .}} | ||||||
| 		</div> | 		</div> | ||||||
| 	</div> | 	</div> | ||||||
|  | |||||||
| @ -1,8 +1,14 @@ | |||||||
| {{template "base/head" .}} | {{template "base/head" .}} | ||||||
| <div role="main" aria-label="{{.Title}}" class="page-content repository settings options"> | <div role="main" aria-label="{{.Title}}" class="page-content repository settings options{{if .ContextUser.IsOrganization}} organization{{end}}"> | ||||||
|  | 	{{if .ContextUser.IsOrganization}} | ||||||
|  | 		{{template "org/header" .}} | ||||||
|  | 	{{else}} | ||||||
| 		{{template "shared/user/org_profile_avatar" .}} | 		{{template "shared/user/org_profile_avatar" .}} | ||||||
|  | 	{{end}} | ||||||
| 	<div class="ui container"> | 	<div class="ui container"> | ||||||
|  | 		{{if not .ContextUser.IsOrganization}} | ||||||
| 			{{template "user/overview/header" .}} | 			{{template "user/overview/header" .}} | ||||||
|  | 		{{end}} | ||||||
| 		{{template "base/alert" .}} | 		{{template "base/alert" .}} | ||||||
| 		<p><a href="{{.PackageDescriptor.FullWebLink}}">{{.PackageDescriptor.Package.Name}} ({{.PackageDescriptor.Version.Version}})</a> / <strong>{{ctx.Locale.Tr "repo.settings"}}</strong></p> | 		<p><a href="{{.PackageDescriptor.FullWebLink}}">{{.PackageDescriptor.Package.Name}} ({{.PackageDescriptor.Version.Version}})</a> / <strong>{{ctx.Locale.Tr "repo.settings"}}</strong></p> | ||||||
| 		<h4 class="ui top attached header"> | 		<h4 class="ui top attached header"> | ||||||
|  | |||||||
| @ -1,9 +1,8 @@ | |||||||
| {{template "base/head" .}} | {{template "base/head" .}} | ||||||
| {{if .ContextUser.IsOrganization}} | {{if .ContextUser.IsOrganization}} | ||||||
| 	<div role="main" aria-label="{{.Title}}" class="page-content repository"> | 	<div role="main" aria-label="{{.Title}}" class="page-content organization code"> | ||||||
| 		{{template "shared/user/org_profile_avatar" .}} | 		{{template "org/header" .}} | ||||||
| 		<div class="ui container"> | 		<div class="ui container"> | ||||||
| 			{{template "user/overview/header" .}} |  | ||||||
| 			{{template "code/searchcombo" .}} | 			{{template "code/searchcombo" .}} | ||||||
| 		</div> | 		</div> | ||||||
| 	</div> | 	</div> | ||||||
|  | |||||||
| @ -10,7 +10,7 @@ | |||||||
| 			<div class="ui small label">{{.RepoCount}}</div> | 			<div class="ui small label">{{.RepoCount}}</div> | ||||||
| 		{{end}} | 		{{end}} | ||||||
| 	</a> | 	</a> | ||||||
| 	{{if or .ContextUser.IsIndividual (and .ContextUser.IsOrganization .CanReadProjects)}} | 	{{if or .ContextUser.IsIndividual .CanReadProjects}} | ||||||
| 	<a href="{{.ContextUser.HomeLink}}/-/projects" class="{{if .PageIsViewProjects}}active {{end}}item"> | 	<a href="{{.ContextUser.HomeLink}}/-/projects" class="{{if .PageIsViewProjects}}active {{end}}item"> | ||||||
| 		{{svg "octicon-project-symlink"}} {{ctx.Locale.Tr "user.projects"}} | 		{{svg "octicon-project-symlink"}} {{ctx.Locale.Tr "user.projects"}} | ||||||
| 		{{if .ProjectCount}} | 		{{if .ProjectCount}} | ||||||
| @ -18,41 +18,17 @@ | |||||||
| 		{{end}} | 		{{end}} | ||||||
| 	</a> | 	</a> | ||||||
| 	{{end}} | 	{{end}} | ||||||
| 	{{if and .IsPackageEnabled (or .ContextUser.IsIndividual (and .ContextUser.IsOrganization .CanReadPackages))}} | 	{{if and .IsPackageEnabled (or .ContextUser.IsIndividual .CanReadPackages)}} | ||||||
| 		<a href="{{.ContextUser.HomeLink}}/-/packages" class="{{if .IsPackagesPage}}active {{end}}item"> | 		<a href="{{.ContextUser.HomeLink}}/-/packages" class="{{if .IsPackagesPage}}active {{end}}item"> | ||||||
| 			{{svg "octicon-package"}} {{ctx.Locale.Tr "packages.title"}} | 			{{svg "octicon-package"}} {{ctx.Locale.Tr "packages.title"}} | ||||||
| 		</a> | 		</a> | ||||||
| 	{{end}} | 	{{end}} | ||||||
| 	{{if and .IsRepoIndexerEnabled (or .ContextUser.IsIndividual (and .ContextUser.IsOrganization .CanReadCode))}} | 	{{if and .IsRepoIndexerEnabled (or .ContextUser.IsIndividual .CanReadCode)}} | ||||||
| 		<a href="{{.ContextUser.HomeLink}}/-/code" class="{{if .IsCodePage}}active {{end}}item"> | 		<a href="{{.ContextUser.HomeLink}}/-/code" class="{{if .IsCodePage}}active {{end}}item"> | ||||||
| 			{{svg "octicon-code"}} {{ctx.Locale.Tr "user.code"}} | 			{{svg "octicon-code"}} {{ctx.Locale.Tr "user.code"}} | ||||||
| 		</a> | 		</a> | ||||||
| 	{{end}} | 	{{end}} | ||||||
| 
 | 
 | ||||||
| 	{{if .ContextUser.IsOrganization}} |  | ||||||
| 		{{if .NumMembers}} |  | ||||||
| 			<a class="{{if $.PageIsOrgMembers}}active {{end}}item" href="{{$.OrgLink}}/members"> |  | ||||||
| 				{{svg "octicon-person"}} {{ctx.Locale.Tr "org.members"}} |  | ||||||
| 				<div class="ui small label">{{.NumMembers}}</div> |  | ||||||
| 			</a> |  | ||||||
| 		{{end}} |  | ||||||
| 		{{if .IsOrganizationMember}} |  | ||||||
| 			<a class="{{if $.PageIsOrgTeams}}active {{end}}item" href="{{$.OrgLink}}/teams"> |  | ||||||
| 				{{svg "octicon-people"}} {{ctx.Locale.Tr "org.teams"}} |  | ||||||
| 				{{if .NumTeams}} |  | ||||||
| 					<div class="ui small label">{{.NumTeams}}</div> |  | ||||||
| 				{{end}} |  | ||||||
| 			</a> |  | ||||||
| 		{{end}} |  | ||||||
| 
 |  | ||||||
| 		{{if .IsOrganizationOwner}} |  | ||||||
| 			<div class="right menu"> |  | ||||||
| 				<a class="item" href="{{.OrgLink}}/settings"> |  | ||||||
| 				{{svg "octicon-tools"}} {{ctx.Locale.Tr "repo.settings"}} |  | ||||||
| 				</a> |  | ||||||
| 			</div> |  | ||||||
| 		{{end}} |  | ||||||
| 	{{else}} |  | ||||||
| 	<a class="{{if eq .TabName "activity"}}active {{end}}item" href="{{.ContextUser.HomeLink}}?tab=activity"> | 	<a class="{{if eq .TabName "activity"}}active {{end}}item" href="{{.ContextUser.HomeLink}}?tab=activity"> | ||||||
| 		{{svg "octicon-rss"}} {{ctx.Locale.Tr "user.activity"}} | 		{{svg "octicon-rss"}} {{ctx.Locale.Tr "user.activity"}} | ||||||
| 	</a> | 	</a> | ||||||
| @ -68,5 +44,4 @@ | |||||||
| 			{{svg "octicon-eye"}} {{ctx.Locale.Tr "user.watched"}} | 			{{svg "octicon-eye"}} {{ctx.Locale.Tr "user.watched"}} | ||||||
| 		</a> | 		</a> | ||||||
| 	{{end}} | 	{{end}} | ||||||
| 	{{end}} |  | ||||||
| </div> | </div> | ||||||
|  | |||||||
| @ -1,9 +1,8 @@ | |||||||
| {{template "base/head" .}} | {{template "base/head" .}} | ||||||
| {{if .ContextUser.IsOrganization}} | {{if .ContextUser.IsOrganization}} | ||||||
| 	<div role="main" aria-label="{{.Title}}" class="page-content repository packages"> | 	<div role="main" aria-label="{{.Title}}" class="page-content organization packages"> | ||||||
| 		{{template "shared/user/org_profile_avatar" .}} | 		{{template "org/header" .}} | ||||||
| 		<div class="ui container"> | 		<div class="ui container"> | ||||||
| 		{{template "user/overview/header" .}} |  | ||||||
| 			{{template "package/shared/versionlist" .}} | 			{{template "package/shared/versionlist" .}} | ||||||
| 		</div> | 		</div> | ||||||
| 	</div> | 	</div> | ||||||
|  | |||||||
| @ -1,9 +1,8 @@ | |||||||
| {{template "base/head" .}} | {{template "base/head" .}} | ||||||
| {{if .ContextUser.IsOrganization}} | {{if .ContextUser.IsOrganization}} | ||||||
| 	<div role="main" aria-label="{{.Title}}" class="page-content repository packages"> | 	<div role="main" aria-label="{{.Title}}" class="page-content organization packages"> | ||||||
| 		{{template "shared/user/org_profile_avatar" .}} | 		{{template "org/header" .}} | ||||||
| 		<div class="ui container"> | 		<div class="ui container"> | ||||||
| 		{{template "user/overview/header" .}} |  | ||||||
| 			{{template "package/shared/list" .}} | 			{{template "package/shared/list" .}} | ||||||
| 		</div> | 		</div> | ||||||
| 	</div> | 	</div> | ||||||
|  | |||||||
| @ -93,46 +93,44 @@ | |||||||
|   min-width: 300px; |   min-width: 300px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .organization.profile .org-avatar { | .page-content.organization .org-avatar { | ||||||
|   width: 100px; |  | ||||||
|   height: 100px; |  | ||||||
|   margin-right: 15px; |   margin-right: 15px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .organization.profile #org-info { | .page-content.organization #org-info { | ||||||
|   overflow-wrap: anywhere; |   overflow-wrap: anywhere; | ||||||
|   flex: 1; |   flex: 1; | ||||||
|   word-break: break-all; |   word-break: break-all; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .organization.profile #org-info .ui.header { | .page-content.organization #org-info .ui.header { | ||||||
|   display: flex; |   display: flex; | ||||||
|   align-items: center; |   align-items: center; | ||||||
|   font-size: 36px; |   font-size: 36px; | ||||||
|   margin-bottom: 0; |   margin-bottom: 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .organization.profile #org-info .desc { | .page-content.organization #org-info .desc { | ||||||
|   font-size: 16px; |   font-size: 16px; | ||||||
|   margin-bottom: 10px; |   margin-bottom: 10px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .organization.profile #org-info .meta { | .page-content.organization #org-info .meta { | ||||||
|   display: flex; |   display: flex; | ||||||
|   align-items: center; |   align-items: center; | ||||||
|   flex-wrap: wrap; |   flex-wrap: wrap; | ||||||
|   gap: 8px; |   gap: 8px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .organization.profile .ui.top.header .ui.right { | .page-content.organization .ui.top.header .ui.right { | ||||||
|   margin-top: 0; |   margin-top: 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .organization.profile .teams .item { | .page-content.organization .teams .item { | ||||||
|   padding: 10px 15px; |   padding: 10px 15px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .organization.profile .members .ui.avatar { | .page-content.organization .members .ui.avatar { | ||||||
|   width: 48px; |   width: 48px; | ||||||
|   height: 48px; |   height: 48px; | ||||||
|   margin-right: 5px; |   margin-right: 5px; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user