mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-25 11:33:11 +00:00 
			
		
		
		
	- This is actually https://github.com/go-gitea/gitea/pull/19978 & https://github.com/go-gitea/gitea/pull/19486 but was removed in one of the UI refactors of v1.20 - This is a very technical fix and is best explained in the CSS comments. But the short version: When there's an overflow being set, but you want an element to 'break out' of that overflow with `position: absolute`, it sometimes doesn't work! You need to set some CSS to let the browser know that the element needs to use an element outside of that overflow as 'clip parent'. - Resolves my internal frustration with the mobile UI constantly getting broken. (cherry picked from commit879f842bed) (cherry picked from commit6099c9b41b) (cherry picked from commit0749d00b16) (cherry picked from commitec6a5428a7) (cherry picked from commit9d0bee784d) (cherry picked from commit61d6ae4882) (cherry picked from commit8b3f3639b6) (cherry picked from commit2c600ddb2c) (cherry picked from commit960a9786ef) (cherry picked from commitb194354c3b) (cherry picked from commit8e7915ee8c) (cherry picked from commitba82b0c6fe) (cherry picked from commitb2dfb233a8) (cherry picked from commitff3ec7f612) (cherry picked from commitef01240cc7) (cherry picked from commit7778b5bb10) (cherry picked from commit5f949b1b07) (cherry picked from commitb387209690) (cherry picked from commit5d7e3a542e) (cherry picked from commitffef2231fb) (cherry picked from commitc74cf73ab4) (cherry picked from commit4aa9e9fca4) (cherry picked from commit6b0dab3ba0) (cherry picked from commit374612f61b)
		
			
				
	
	
		
			118 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			CSS
		
	
	
	
	
	
			
		
		
	
	
			118 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			CSS
		
	
	
	
	
	
| .issue-list-toolbar {
 | |
|   display: flex;
 | |
|   flex-wrap: wrap-reverse;
 | |
|   justify-content: space-between;
 | |
|   align-items: flex-start;
 | |
|   gap: 1rem;
 | |
|   margin-top: 1rem;
 | |
| }
 | |
| 
 | |
| .issue-list-toolbar-left {
 | |
|   display: flex;
 | |
| }
 | |
| 
 | |
| .issue-list-toolbar-right .filter.menu {
 | |
|   flex-direction: row;
 | |
|   flex-wrap: wrap;
 | |
| }
 | |
| 
 | |
| @media (max-width: 767.98px) {
 | |
|   .issue-list-navbar {
 | |
|     order: 0;
 | |
|   }
 | |
|   .issue-list-new {
 | |
|     order: 1;
 | |
|     margin-left: auto !important;
 | |
|   }
 | |
|   .issue-list-search {
 | |
|     order: 2 !important;
 | |
|   }
 | |
|   /* Don't use flex wrap on mobile as it takes too much vertical space.
 | |
|    * Only set overflow properties on mobile screens, because while the
 | |
|    * CSS trick to pop out from overflowing works on desktop screen, it
 | |
|    * has a massive flaw that it cannot inherited any max width from it's 'real'
 | |
|    * parent and therefor ends up taking more vertical space than is desired.
 | |
|    **/
 | |
|   .issue-list-toolbar-right .filter.menu {
 | |
|     flex-wrap: nowrap;
 | |
|     overflow-x: auto;
 | |
|     overflow-y: hidden;
 | |
|   }
 | |
| 
 | |
|   /* The following few CSS was created with care and built with the information
 | |
|    * from CSS-Tricks: https://css-tricks.com/popping-hidden-overflow/
 | |
|   */
 | |
| 
 | |
|   /* It's important that every element up to .issue-list-toolbar-right doesn't
 | |
|    * have a position set, such that element that wants to pop out will use
 | |
|    * .issue-list-toolbar-right as 'clip parent' and thereby avoids the
 | |
|    * overflow-y: hidden.
 | |
|   */
 | |
|   .issue-list-toolbar-right .filter.menu > .dropdown.item {
 | |
|     position: initial;
 | |
|   }
 | |
|   /* It's important that this element and not an child has `position` set.
 | |
|    * Set width so that overflow-x knows where to stop overflowing.
 | |
|   */
 | |
|   .issue-list-toolbar-right {
 | |
|     position: relative;
 | |
|     width: 100%;
 | |
|   }
 | |
| }
 | |
| 
 | |
| #issue-list .flex-item-title .labels-list {
 | |
|   display: flex;
 | |
|   flex-wrap: wrap;
 | |
|   gap: 0.25em;
 | |
| }
 | |
| 
 | |
| #issue-list .flex-item-title .labels-list a {
 | |
|   display: flex;
 | |
|   text-decoration: none;
 | |
| }
 | |
| 
 | |
| #issue-list .flex-item-title .labels-list .label {
 | |
|   padding: 0 6px;
 | |
|   margin: 0;
 | |
|   min-height: 20px;
 | |
| }
 | |
| 
 | |
| #issue-list .flex-item-body .branches {
 | |
|   display: inline-flex;
 | |
| }
 | |
| 
 | |
| #issue-list .flex-item-body .branches .branch {
 | |
|   background-color: var(--color-secondary-alpha-40);
 | |
|   border-radius: var(--border-radius);
 | |
|   padding: 0 4px;
 | |
| }
 | |
| 
 | |
| #issue-list .flex-item-body .branches .truncated-name {
 | |
|   white-space: nowrap;
 | |
|   overflow: hidden;
 | |
|   text-overflow: ellipsis;
 | |
|   max-width: 10em;
 | |
| }
 | |
| 
 | |
| #issue-list .flex-item-body .checklist progress {
 | |
|   margin-left: 2px;
 | |
|   width: 80px;
 | |
|   height: 6px;
 | |
|   display: inline-block;
 | |
| }
 | |
| 
 | |
| #issue-list .flex-item-body .checklist progress::-webkit-progress-value {
 | |
|   background-color: var(--color-secondary-dark-4);
 | |
| }
 | |
| 
 | |
| #issue-list .flex-item-body .checklist progress::-moz-progress-bar {
 | |
|   background-color: var(--color-secondary-dark-4);
 | |
| }
 | |
| 
 | |
| .archived-label-filter {
 | |
|   margin-left: 10px;
 | |
|   font-size: 12px;
 | |
|   display: flex !important;
 | |
|   margin-bottom: 8px;
 | |
|   min-width: fit-content;
 | |
| }
 |