 b9baed2c74
			
		
	
	
	
	
	b9baed2c74This PR introduces a new UI element type for Gitea called `flex-item`. It consists of a horizontal card with a leading, main and trailing part:  The idea behind it is that in Gitea UI, we have many cases where we use this kind of layout, but it is achieved in many different ways: - grid layout - `.ui.list` with additional hacky flexbox - `.ui.key.list` - looks to me like a style set originally created for ssh/gpg key list, was used in many other places - `.issue.list` - created for issue cards, used in many other places - ... This new style is based on `.issue.list`, specifically the refactoring of it done in #25750. In this PR, the new element is introduced and lots of templates are being refactored to use that style. This allows to remove a lot of page-specific css, makes many of the elements responsive or simply provides a cleaner/better-looking way to present information. A devtest section with the new style is also available. <details> <summary>Screenshots (left: before, right: after)</summary>                    </details> --------- Co-authored-by: Giteabot <teabot@gitea.io>
		
			
				
	
	
		
			53 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Handlebars
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Handlebars
		
	
	
	
	
	
| {{template "base/alert" .}}
 | |
| <form class="ui form ignore-dirty">
 | |
| 	<div class="ui fluid action input">
 | |
| 		{{template "shared/searchinput" dict "locale" .locale "Value" .Query "AutoFocus" true}}
 | |
| 		<select class="ui dropdown" name="type">
 | |
| 			<option value="">{{.locale.Tr "packages.filter.type"}}</option>
 | |
| 			<option value="all">{{.locale.Tr "packages.filter.type.all"}}</option>
 | |
| 			{{range $type := .AvailableTypes}}
 | |
| 			<option{{if eq $.PackageType $type}} selected="selected"{{end}} value="{{$type}}">{{$type.Name}}</option>
 | |
| 			{{end}}
 | |
| 		</select>
 | |
| 		<button class="ui primary button">{{.locale.Tr "explore.search"}}</button>
 | |
| 	</div>
 | |
| </form>
 | |
| <div class="{{if .PackageDescriptors}}flex-list{{end}} gt-pt-4">
 | |
| 	{{range .PackageDescriptors}}
 | |
| 		<div class="flex-item">
 | |
| 			<div class="flex-item-main">
 | |
| 				<div class="flex-item-title">
 | |
| 					<a href="{{.FullWebLink}}">{{.Package.Name}}</a>
 | |
| 					<span class="ui label">{{svg .Package.Type.SVGName 16}} {{.Package.Type.Name}}</span>
 | |
| 				</div>
 | |
| 				<div class="flex-item-body">
 | |
| 					{{$timeStr := TimeSinceUnix .Version.CreatedUnix $.locale}}
 | |
| 					{{$hasRepositoryAccess := false}}
 | |
| 					{{if .Repository}}
 | |
| 						{{$hasRepositoryAccess = index $.RepositoryAccessMap .Repository.ID}}
 | |
| 					{{end}}
 | |
| 					{{if $hasRepositoryAccess}}
 | |
| 						{{$.locale.Tr "packages.published_by_in" $timeStr .Creator.HomeLink (.Creator.GetDisplayName | Escape) .Repository.Link (.Repository.FullName | Escape) | Safe}}
 | |
| 					{{else}}
 | |
| 						{{$.locale.Tr "packages.published_by" $timeStr .Creator.HomeLink (.Creator.GetDisplayName | Escape) | Safe}}
 | |
| 					{{end}}
 | |
| 				</div>
 | |
| 			</div>
 | |
| 		</div>
 | |
| 	{{else}}
 | |
| 		{{if not .HasPackages}}
 | |
| 			<div class="empty center">
 | |
| 				{{svg "octicon-package" 48}}
 | |
| 				<h2>{{.locale.Tr "packages.empty"}}</h2>
 | |
| 				{{if and .Repository .CanWritePackages}}
 | |
| 					{{$packagesUrl := URLJoin .Owner.HomeLink "-" "packages"}}
 | |
| 					<p>{{.locale.Tr "packages.empty.repo" $packagesUrl | Safe}}</p>
 | |
| 				{{end}}
 | |
| 				<p>{{.locale.Tr "packages.empty.documentation" "https://docs.gitea.io/en-us/usage/packages/overview/" | Safe}}</p>
 | |
| 			</div>
 | |
| 		{{else}}
 | |
| 			<p>{{.locale.Tr "packages.filter.no_result"}}</p>
 | |
| 		{{end}}
 | |
| 	{{end}}
 | |
| 	{{template "base/paginate" .}}
 | |
| </div>
 |