 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>
		
			
				
	
	
		
			94 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			CSS
		
	
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			CSS
		
	
	
	
	
	
| .flex-list {
 | |
|   list-style: none;
 | |
| }
 | |
| 
 | |
| .flex-item {
 | |
|   display: flex;
 | |
|   gap: 8px;
 | |
|   align-items: flex-start;
 | |
| }
 | |
| 
 | |
| .flex-item:not(:last-child) {
 | |
|   padding-bottom: 8px;
 | |
| }
 | |
| 
 | |
| .flex-item-baseline {
 | |
|   align-items: baseline;
 | |
| }
 | |
| 
 | |
| .flex-item-center {
 | |
|   align-items: center;
 | |
| }
 | |
| 
 | |
| .flex-item .flex-item-leading {
 | |
|   display: flex;
 | |
|   align-items: flex-start;
 | |
| }
 | |
| 
 | |
| .flex-item .flex-item-main {
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
|   flex-grow: 1;
 | |
|   min-width: 0;
 | |
| }
 | |
| 
 | |
| .flex-item-header {
 | |
|   display: flex;
 | |
|   gap: .25rem;
 | |
|   justify-content: space-between;
 | |
|   flex-wrap: wrap;
 | |
| }
 | |
| 
 | |
| .flex-item a:not(.label, .button):hover {
 | |
|   color: var(--color-primary) !important;
 | |
| }
 | |
| 
 | |
| .flex-item .flex-item-icon svg {
 | |
|   margin-top: 1px;
 | |
| }
 | |
| 
 | |
| .flex-item .flex-item-trailing {
 | |
|   display: flex;
 | |
|   gap: 0.5rem;
 | |
|   align-items: center;
 | |
|   flex-grow: 0;
 | |
|   flex-wrap: wrap;
 | |
|   justify-content: end;
 | |
|   flex-shrink: 2;
 | |
| }
 | |
| 
 | |
| .flex-item .flex-item-title {
 | |
|   display: inline-flex;
 | |
|   flex-wrap: wrap;
 | |
|   align-items: center;
 | |
|   gap: .25rem;
 | |
|   max-width: 100%;
 | |
|   color: var(--color-text);
 | |
|   font-size: 16px;
 | |
|   min-width: 0;
 | |
|   font-weight: var(--font-weight-semibold);
 | |
| }
 | |
| 
 | |
| .flex-item .flex-item-title a {
 | |
|   color: var(--color-text);
 | |
|   overflow-wrap: anywhere;
 | |
| }
 | |
| 
 | |
| .flex-item .flex-item-body {
 | |
|   font-size: 13px;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   flex-wrap: wrap;
 | |
|   gap: .25rem;
 | |
|   color: var(--color-text-light-2);
 | |
| }
 | |
| 
 | |
| .flex-item .flex-item-body a {
 | |
|   color: inherit;
 | |
|   overflow-wrap: anywhere;
 | |
| }
 | |
| 
 | |
| .flex-list > .flex-item + .flex-item {
 | |
|   border-top: 1px solid var(--color-secondary);
 | |
|   padding-top: 8px;
 | |
| }
 |