mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 08:58:24 +00:00 
			
		
		
		
	Close #13539. Co-authored by: @lunny @appleboy @fuxiaohei and others. Related projects: - https://gitea.com/gitea/actions-proto-def - https://gitea.com/gitea/actions-proto-go - https://gitea.com/gitea/act - https://gitea.com/gitea/act_runner ### Summary The target of this PR is to bring a basic implementation of "Actions", an internal CI/CD system of Gitea. That means even though it has been merged, the state of the feature is **EXPERIMENTAL**, and please note that: - It is disabled by default; - It shouldn't be used in a production environment currently; - It shouldn't be used in a public Gitea instance currently; - Breaking changes may be made before it's stable. **Please comment on #13539 if you have any different product design ideas**, all decisions reached there will be adopted here. But in this PR, we don't talk about **naming, feature-creep or alternatives**. ### ⚠️ Breaking `gitea-actions` will become a reserved user name. If a user with the name already exists in the database, it is recommended to rename it. ### Some important reviews - What is `DEFAULT_ACTIONS_URL` in `app.ini` for? - https://github.com/go-gitea/gitea/pull/21937#discussion_r1055954954 - Why the api for runners is not under the normal `/api/v1` prefix? - https://github.com/go-gitea/gitea/pull/21937#discussion_r1061173592 - Why DBFS? - https://github.com/go-gitea/gitea/pull/21937#discussion_r1061301178 - Why ignore events triggered by `gitea-actions` bot? - https://github.com/go-gitea/gitea/pull/21937#discussion_r1063254103 - Why there's no permission control for actions? - https://github.com/go-gitea/gitea/pull/21937#discussion_r1090229868 ### What it looks like <details> #### Manage runners <img width="1792" alt="image" src="https://user-images.githubusercontent.com/9418365/205870657-c72f590e-2e08-4cd4-be7f-2e0abb299bbf.png"> #### List runs <img width="1792" alt="image" src="https://user-images.githubusercontent.com/9418365/205872794-50fde990-2b45-48c1-a178-908e4ec5b627.png"> #### View logs <img width="1792" alt="image" src="https://user-images.githubusercontent.com/9418365/205872501-9b7b9000-9542-4991-8f55-18ccdada77c3.png"> </details> ### How to try it <details> #### 1. Start Gitea Clone this branch and [install from source](https://docs.gitea.io/en-us/install-from-source). Add additional configurations in `app.ini` to enable Actions: ```ini [actions] ENABLED = true ``` Start it. If all is well, you'll see the management page of runners: <img width="1792" alt="image" src="https://user-images.githubusercontent.com/9418365/205877365-8e30a780-9b10-4154-b3e8-ee6c3cb35a59.png"> #### 2. Start runner Clone the [act_runner](https://gitea.com/gitea/act_runner), and follow the [README](https://gitea.com/gitea/act_runner/src/branch/main/README.md) to start it. If all is well, you'll see a new runner has been added: <img width="1792" alt="image" src="https://user-images.githubusercontent.com/9418365/205878000-216f5937-e696-470d-b66c-8473987d91c3.png"> #### 3. Enable actions for a repo Create a new repo or open an existing one, check the `Actions` checkbox in settings and submit. <img width="1792" alt="image" src="https://user-images.githubusercontent.com/9418365/205879705-53e09208-73c0-4b3e-a123-2dcf9aba4b9c.png"> <img width="1792" alt="image" src="https://user-images.githubusercontent.com/9418365/205879383-23f3d08f-1a85-41dd-a8b3-54e2ee6453e8.png"> If all is well, you'll see a new tab "Actions": <img width="1792" alt="image" src="https://user-images.githubusercontent.com/9418365/205881648-a8072d8c-5803-4d76-b8a8-9b2fb49516c1.png"> #### 4. Upload workflow files Upload some workflow files to `.gitea/workflows/xxx.yaml`, you can follow the [quickstart](https://docs.github.com/en/actions/quickstart) of GitHub Actions. Yes, Gitea Actions is compatible with GitHub Actions in most cases, you can use the same demo: ```yaml name: GitHub Actions Demo run-name: ${{ github.actor }} is testing out GitHub Actions 🚀 on: [push] jobs: Explore-GitHub-Actions: runs-on: ubuntu-latest steps: - run: echo "🎉 The job was automatically triggered by a ${{ github.event_name }} event." - run: echo "🐧 This job is now running on a ${{ runner.os }} server hosted by GitHub!" - run: echo "🔎 The name of your branch is ${{ github.ref }} and your repository is ${{ github.repository }}." - name: Check out repository code uses: actions/checkout@v3 - run: echo "💡 The ${{ github.repository }} repository has been cloned to the runner." - run: echo "🖥️ The workflow is now ready to test your code on the runner." - name: List files in the repository run: | ls ${{ github.workspace }} - run: echo "🍏 This job's status is ${{ job.status }}." ``` If all is well, you'll see a new run in `Actions` tab: <img width="1792" alt="image" src="https://user-images.githubusercontent.com/9418365/205884473-79a874bc-171b-4aaf-acd5-0241a45c3b53.png"> #### 5. Check the logs of jobs Click a run and you'll see the logs: <img width="1792" alt="image" src="https://user-images.githubusercontent.com/9418365/205884800-994b0374-67f7-48ff-be9a-4c53f3141547.png"> #### 6. Go on You can try more examples in [the documents](https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions) of GitHub Actions, then you might find a lot of bugs. Come on, PRs are welcome. </details> See also: [Feature Preview: Gitea Actions](https://blog.gitea.io/2022/12/feature-preview-gitea-actions/) --------- Co-authored-by: a1012112796 <1012112796@qq.com> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: delvh <dev.lh@web.de> Co-authored-by: ChristopherHX <christopher.homberger@web.de> Co-authored-by: John Olheiser <john.olheiser@gmail.com>
		
			
				
	
	
		
			3600 lines
		
	
	
		
			65 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			3600 lines
		
	
	
		
			65 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| .repository {
 | |
|   .popup.commit-statuses {
 | |
|     // we had better limit the max size of the popup, and add scroll bars if the content size is too large.
 | |
|     // otherwise some part of the popup will be hidden by viewport boundary
 | |
|     max-height: 45vh;
 | |
|     max-width: 60vw;
 | |
| 
 | |
|     &.ui.right {
 | |
|       // Override `.ui.attached.header .right:not(.dropdown) height: 30px;` which would otherwise lead to
 | |
|       // the status popup box having its height fixed at 30px. See https://github.com/go-gitea/gitea/issues/18498
 | |
|       height: auto;
 | |
|     }
 | |
| 
 | |
|     overflow: auto;
 | |
|     padding: 0;
 | |
| 
 | |
|     .list {
 | |
|       padding: .8em; // to make the scrollbar align to the border, we move the padding from outer `.popup` to this inside `.list`
 | |
| 
 | |
|       > .item {
 | |
|         line-height: 2;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .repo-header {
 | |
|     .ui.compact.menu {
 | |
|       margin-left: 1rem;
 | |
|     }
 | |
| 
 | |
|     .ui.header {
 | |
|       margin-top: 0;
 | |
|     }
 | |
| 
 | |
|     .fork-flag {
 | |
|       font-size: 12px;
 | |
|       margin-top: 2px;
 | |
|     }
 | |
| 
 | |
|     .repo-buttons .svg {
 | |
|       margin: 0 .42857143em 0 -.21428571em;
 | |
|     }
 | |
| 
 | |
|     .button {
 | |
|       margin-top: 2px;
 | |
|       margin-bottom: 2px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .tabs {
 | |
|     .navbar {
 | |
|       justify-content: initial;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .navbar {
 | |
|     display: flex;
 | |
|     justify-content: space-between;
 | |
| 
 | |
|     .ui.label {
 | |
|       margin-left: 7px;
 | |
|       padding: 3px 5px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .owner.dropdown {
 | |
|     min-width: 40% !important;
 | |
|   }
 | |
| 
 | |
|   .unicode-escaped .escaped-code-point {
 | |
|     &[data-escaped]::before {
 | |
|       visibility: visible;
 | |
|       content: attr(data-escaped);
 | |
|       font-family: var(--fonts-monospace);
 | |
|       color: var(--color-red);
 | |
|     }
 | |
| 
 | |
|     .char {
 | |
|       display: none;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .broken-code-point {
 | |
|     font-family: var(--fonts-monospace);
 | |
|     color: var(--color-blue);
 | |
|   }
 | |
| 
 | |
|   .unicode-escaped .ambiguous-code-point {
 | |
|     border: 1px var(--color-yellow) solid;
 | |
|   }
 | |
| 
 | |
|   .metas {
 | |
|     .menu {
 | |
|       overflow-x: auto;
 | |
|       max-height: 300px;
 | |
|     }
 | |
| 
 | |
|     .ui.list {
 | |
|       &.assignees .icon {
 | |
|         line-height: 2em;
 | |
|       }
 | |
| 
 | |
|       &.assignees .teamavatar {
 | |
|         margin-top: .125rem;
 | |
|         margin-left: 6.75px;
 | |
|         margin-right: 8.75px;
 | |
|       }
 | |
| 
 | |
|       .hide {
 | |
|         display: none !important;
 | |
|       }
 | |
| 
 | |
|       .dependency {
 | |
|         padding: 0;
 | |
|         white-space: nowrap;
 | |
|       }
 | |
| 
 | |
|       .title {
 | |
|         max-width: 200px;
 | |
|         overflow: hidden;
 | |
|         text-overflow: ellipsis;
 | |
|       }
 | |
| 
 | |
|       @media @mediaLgAndDown {
 | |
|         .title {
 | |
|           max-width: 150px;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       @media (max-width: 1000px) {
 | |
|         .title {
 | |
|           max-width: 100px;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     #deadlineForm input {
 | |
|       width: 12.8rem;
 | |
|       border-radius: 4px 0 0 4px;
 | |
|       border-right: 0;
 | |
|       white-space: nowrap;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .header-wrapper {
 | |
|     background-color: var(--color-navbar);
 | |
| 
 | |
|     .ui.tabs.divider {
 | |
|       border-bottom: 0;
 | |
|     }
 | |
| 
 | |
|     .ui.tabular .svg {
 | |
|       margin-right: 5px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .filter.menu {
 | |
|     .label.color {
 | |
|       border-radius: 3px;
 | |
|       margin-left: 15px;
 | |
|       padding: 0 8px;
 | |
|     }
 | |
| 
 | |
|     &.labels {
 | |
|       .label-filter .menu .info {
 | |
|         display: inline-block;
 | |
|         padding: .5rem .25rem;
 | |
|         border-bottom: 1px solid var(--color-secondary);
 | |
|         font-size: 12px;
 | |
|         width: 100%;
 | |
|         white-space: nowrap;
 | |
|         text-align: center;
 | |
| 
 | |
|         code {
 | |
|           border: 1px solid var(--color-secondary);
 | |
|           border-radius: 3px;
 | |
|           padding: 1px 2px;
 | |
|           font-size: 11px;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .menu {
 | |
|       max-height: 300px;
 | |
|       overflow-x: auto;
 | |
|       right: 0 !important;
 | |
|       left: auto !important;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .select-label {
 | |
|     .desc {
 | |
|       padding-left: 16px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .ui.tabs {
 | |
|     &.container {
 | |
|       margin-top: 14px;
 | |
|       margin-bottom: 0;
 | |
| 
 | |
|       .ui.menu {
 | |
|         border-bottom: 0;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.divider {
 | |
|       margin-top: 0;
 | |
|       margin-bottom: 20px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   #clone-panel {
 | |
|     #repo-clone-url {
 | |
|       width: 320px;
 | |
| 
 | |
|       @media @mediaMd {
 | |
|         width: 200px;
 | |
|       }
 | |
|       @media @mediaSm {
 | |
|         width: 200px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     #repo-clone-https,
 | |
|     #repo-clone-ssh {
 | |
|       border-right: none;
 | |
|     }
 | |
| 
 | |
|     #more-btn {
 | |
|       border-left: none;
 | |
|     }
 | |
| 
 | |
|     button:first-of-type {
 | |
|       border-radius: var(--border-radius) 0 0 var(--border-radius) !important;
 | |
|     }
 | |
| 
 | |
|     button:last-of-type {
 | |
|       border-radius: 0 var(--border-radius) var(--border-radius) 0 !important;
 | |
|     }
 | |
| 
 | |
|     .dropdown .menu {
 | |
|       right: 0 !important;
 | |
|       left: auto !important;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.file.list {
 | |
|     .repo-description {
 | |
|       display: flex;
 | |
|       justify-content: space-between;
 | |
|       align-items: center;
 | |
|     }
 | |
| 
 | |
|     #repo-desc {
 | |
|       font-size: 1.2em;
 | |
|     }
 | |
| 
 | |
|     .choose.reference {
 | |
|       .header .icon {
 | |
|         font-size: 1.4em;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .repo-path {
 | |
| 
 | |
|       .section,
 | |
|       .divider {
 | |
|         display: inline;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     #repo-files-table {
 | |
|       thead {
 | |
|         th {
 | |
|           padding-top: 8px;
 | |
|           padding-bottom: 5px;
 | |
|           font-weight: normal;
 | |
|         }
 | |
| 
 | |
|         .ui.avatar {
 | |
|           margin-bottom: 5px;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       tbody {
 | |
|         .svg {
 | |
|           margin-left: 3px;
 | |
|           margin-right: 5px;
 | |
| 
 | |
|           &.octicon-reply {
 | |
|             margin-right: 10px;
 | |
|           }
 | |
| 
 | |
|           &.octicon-file-directory-fill,
 | |
|           &.octicon-file-submodule {
 | |
|             color: var(--color-primary);
 | |
|           }
 | |
| 
 | |
|           &.octicon-file,
 | |
|           &.octicon-file-symlink-file {
 | |
|             color: var(--color-secondary-dark-7);
 | |
|           }
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       td {
 | |
|         padding-top: 0;
 | |
|         padding-bottom: 0;
 | |
|         overflow: initial;
 | |
| 
 | |
|         &.name {
 | |
|           @media @mediaXl {
 | |
|             max-width: 150px;
 | |
|           }
 | |
|           @media @mediaLg {
 | |
|             max-width: 200px;
 | |
|           }
 | |
|           @media @mediaMd {
 | |
|             max-width: 300px;
 | |
|           }
 | |
|           width: 33%;
 | |
| 
 | |
|           max-width: calc(100vw - 140px);
 | |
|         }
 | |
| 
 | |
|         &.message {
 | |
|           color: var(--color-text-light-1);
 | |
| 
 | |
|           @media @mediaXl {
 | |
|             max-width: 400px;
 | |
|           }
 | |
|           @media @mediaLg {
 | |
|             max-width: 350px;
 | |
|           }
 | |
|           @media @mediaMd {
 | |
|             max-width: 250px;
 | |
|           }
 | |
|           width: 66%;
 | |
|         }
 | |
| 
 | |
|         &.age {
 | |
|           width: 120px;
 | |
|           color: var(--color-text-light-1);
 | |
|         }
 | |
| 
 | |
|         .truncate {
 | |
|           display: inline-block;
 | |
|           overflow: hidden;
 | |
|           text-overflow: ellipsis;
 | |
|           white-space: nowrap;
 | |
|           width: 100%;
 | |
|           padding-top: 8px;
 | |
|           padding-bottom: 8px;
 | |
|         }
 | |
| 
 | |
|         a {
 | |
|           padding-top: 8px;
 | |
|           padding-bottom: 8px;
 | |
|         }
 | |
| 
 | |
|         .at {
 | |
|           margin-left: 3px;
 | |
|           margin-right: 3px;
 | |
|         }
 | |
| 
 | |
|         > * {
 | |
|           vertical-align: middle;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       td.message .isSigned {
 | |
|         cursor: default;
 | |
|       }
 | |
| 
 | |
|       tr:last-of-type {
 | |
|         td:first-child {
 | |
|           border-bottom-left-radius: var(--border-radius);
 | |
|         }
 | |
| 
 | |
|         td:last-child {
 | |
|           border-bottom-right-radius: var(--border-radius);
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       tr:hover {
 | |
|         background-color: var(--color-hover);
 | |
|       }
 | |
| 
 | |
|       tr.has-parent a {
 | |
|         display: inline-block;
 | |
|         padding-top: 8px;
 | |
|         padding-bottom: 8px;
 | |
|         width: calc(100% - 1.25rem);
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .non-diff-file-content {
 | |
|       .header {
 | |
|         .icon {
 | |
|           font-size: 1em;
 | |
|         }
 | |
| 
 | |
|         .small.icon {
 | |
|           font-size: .75em;
 | |
|         }
 | |
| 
 | |
|         .tiny.icon {
 | |
|           font-size: .5em;
 | |
|         }
 | |
| 
 | |
|         .file-actions {
 | |
|           .btn-octicon {
 | |
|             line-height: 1;
 | |
|             padding: 10px 8px;
 | |
|             vertical-align: middle;
 | |
|             color: var(--color-text);
 | |
|           }
 | |
| 
 | |
|           .btn-octicon:hover {
 | |
|             color: var(--color-primary);
 | |
|           }
 | |
| 
 | |
|           .btn-octicon-danger:hover {
 | |
|             color: var(--color-red);
 | |
|           }
 | |
| 
 | |
|           .btn-octicon.disabled {
 | |
|             color: inherit;
 | |
|             opacity: var(--opacity-disabled);
 | |
|             cursor: default;
 | |
|           }
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .view-raw {
 | |
|         padding: 5px;
 | |
| 
 | |
|         > * {
 | |
|           max-width: 100%;
 | |
|           border: 1px solid var(--color-secondary);
 | |
|         }
 | |
| 
 | |
|         img {
 | |
|           margin: 1rem 0;
 | |
|           border-radius: 0;
 | |
|           object-fit: contain;
 | |
|         }
 | |
| 
 | |
|         img[src$='.svg' i] {
 | |
|           max-height: 600px !important;
 | |
|           max-width: 600px !important;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .plain-text {
 | |
|         padding: 1em 2em;
 | |
| 
 | |
|         pre {
 | |
|           word-break: break-word;
 | |
|           white-space: pre-wrap;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .csv {
 | |
|         overflow-x: auto;
 | |
|         padding: 0 !important;
 | |
|       }
 | |
| 
 | |
|       pre {
 | |
|         overflow: auto;
 | |
|       }
 | |
| 
 | |
|       .asciicast {
 | |
|         padding: 5px !important;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .sidebar {
 | |
|       padding-left: 0;
 | |
| 
 | |
|       .svg {
 | |
|         width: 16px;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.file.editor {
 | |
|     .treepath {
 | |
|       width: 100%;
 | |
| 
 | |
|       input {
 | |
|         vertical-align: middle;
 | |
|         box-shadow: rgba(0, 0, 0, .0745098) 0 1px 2px inset;
 | |
|         width: inherit;
 | |
|         padding: 7px 8px;
 | |
|         margin-right: 5px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .tabular.menu {
 | |
|       .svg {
 | |
|         margin-right: 5px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .commit-form-wrapper {
 | |
|       padding-left: 64px;
 | |
| 
 | |
|       .commit-avatar {
 | |
|         float: left;
 | |
|         margin-left: -64px;
 | |
|         width: 3em;
 | |
|         height: auto;
 | |
|       }
 | |
| 
 | |
|       .commit-form {
 | |
|         position: relative;
 | |
|         padding: 15px;
 | |
|         margin-bottom: 10px;
 | |
|         border: 1px solid var(--color-secondary);
 | |
|         background: var(--color-box-body);
 | |
|         border-radius: 3px;
 | |
|         #avatar-arrow();
 | |
| 
 | |
|         &::after {
 | |
|           border-right-color: var(--color-box-body);
 | |
|         }
 | |
| 
 | |
|         .quick-pull-choice {
 | |
|           .branch-name {
 | |
|             display: inline-block;
 | |
|             padding: 2px 4px;
 | |
|             font: 12px var(--fonts-monospace);
 | |
|             color: var(--color-text);
 | |
|             background: var(--color-secondary);
 | |
|             border-radius: 3px;
 | |
|             margin: 0 2px;
 | |
|           }
 | |
| 
 | |
|           .new-branch-name-input {
 | |
|             position: relative;
 | |
|             margin-left: 25px;
 | |
| 
 | |
|             input {
 | |
|               width: 240px !important;
 | |
|               padding-left: 26px !important;
 | |
|             }
 | |
|           }
 | |
| 
 | |
|           .octicon-git-branch {
 | |
|             position: absolute;
 | |
|             top: 9px;
 | |
|             left: 10px;
 | |
|             color: var(--color-grey);
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.options {
 | |
|     #interval {
 | |
|       width: 100px !important;
 | |
|       min-width: 100px;
 | |
|     }
 | |
| 
 | |
|     .danger {
 | |
|       .item {
 | |
|         padding: 20px 15px;
 | |
|       }
 | |
| 
 | |
|       .ui.divider {
 | |
|         margin: 0;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   @comment-avatar-width: 3em;
 | |
| 
 | |
|   .comment textarea {
 | |
|     max-height: none !important;
 | |
|   }
 | |
| 
 | |
|   &.new.issue {
 | |
|     .comment.form {
 | |
|       .comment {
 | |
|         .avatar {
 | |
|           width: @comment-avatar-width;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .content {
 | |
|         margin-left: 4em;
 | |
|         #avatar-arrow();
 | |
| 
 | |
|         &::after {
 | |
|           border-right-color: var(--color-box-body);
 | |
|         }
 | |
| 
 | |
|         .markup {
 | |
|           font-size: 14px;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .metas {
 | |
|         min-width: 220px;
 | |
| 
 | |
|         .filter.menu {
 | |
|           max-height: 300px;
 | |
|           overflow-x: auto;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.view.issue {
 | |
|     .instruct-toggle {
 | |
|       display: inline-block;
 | |
|     }
 | |
| 
 | |
|     .title {
 | |
|       padding-bottom: 0 !important;
 | |
| 
 | |
|       .issue-title {
 | |
|         margin-bottom: .5rem;
 | |
| 
 | |
|         &.edit-active {
 | |
|           display: flex;
 | |
|           align-items: center;
 | |
| 
 | |
|           h1 {
 | |
|             display: flex;
 | |
|             width: 100%;
 | |
|           }
 | |
| 
 | |
|           @media @mediaSm {
 | |
|             flex-direction: column;
 | |
| 
 | |
|             h1 {
 | |
|               margin-right: 0;
 | |
|               margin-bottom: 1rem;
 | |
|               padding-right: 0;
 | |
| 
 | |
|               .ui.input input {
 | |
|                 width: calc(100% - 2rem);
 | |
|               }
 | |
|             }
 | |
| 
 | |
|             .edit-buttons {
 | |
|               padding-bottom: 1rem;
 | |
|               width: 100%;
 | |
| 
 | |
|               .button {
 | |
|                 width: 100%;
 | |
|                 margin-right: .5rem;
 | |
| 
 | |
|                 &:last-child {
 | |
|                   margin-right: 0;
 | |
|                 }
 | |
|               }
 | |
|             }
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         h1 {
 | |
|           font-weight: 300;
 | |
|           font-size: 2.3rem;
 | |
|           margin: 0;
 | |
|           padding-right: .5rem;
 | |
| 
 | |
|           .ui.input {
 | |
|             font-size: .5em;
 | |
|             width: 100%;
 | |
| 
 | |
|             input {
 | |
|               font-size: 1.5em;
 | |
|               padding: 6px 1rem;
 | |
|             }
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         .edit-button {
 | |
|           float: right;
 | |
|           padding-left: 1rem;
 | |
|         }
 | |
| 
 | |
|         .edit-buttons {
 | |
|           display: flex;
 | |
|         }
 | |
| 
 | |
|         .index {
 | |
|           color: var(--color-text-light-2);
 | |
|         }
 | |
| 
 | |
|         .label {
 | |
|           margin-right: 10px;
 | |
|         }
 | |
| 
 | |
|         .edit-zone {
 | |
|           margin-top: 10px;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .pull-desc {
 | |
|       code {
 | |
|         color: var(--color-primary);
 | |
|       }
 | |
|       a[data-clipboard-text] {
 | |
|         cursor: pointer;
 | |
|         svg {
 | |
|           vertical-align: middle;
 | |
|           position: relative;
 | |
|           top: -2px;
 | |
|           right: 1px;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .pull {
 | |
|       &.tabular.menu {
 | |
|         margin-bottom: 1rem;
 | |
| 
 | |
|         .svg {
 | |
|           margin-right: 5px;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .merge.box {
 | |
|         .avatar {
 | |
|           margin-left: 10px;
 | |
|           margin-top: 10px;
 | |
|         }
 | |
| 
 | |
|         .branch-update.grid {
 | |
|           .row {
 | |
|             padding-bottom: 1rem;
 | |
| 
 | |
|             .icon {
 | |
|               margin-top: 1.1rem;
 | |
|             }
 | |
|           }
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .review-item {
 | |
|         display: flex;
 | |
|         justify-content: space-between;
 | |
|         align-items: center;
 | |
| 
 | |
|         .review-item-left,
 | |
|         .review-item-right {
 | |
|           display: flex;
 | |
|           align-items: center;
 | |
|         }
 | |
| 
 | |
|         .text {
 | |
|           margin: .3em 0 .5em .5em;
 | |
|         }
 | |
| 
 | |
|         .type-icon {
 | |
|           align-self: flex-start;
 | |
|           margin-right: 1em;
 | |
| 
 | |
|           i {
 | |
|             line-height: 1.8em;
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         .divider {
 | |
|           margin: .5rem 0;
 | |
|         }
 | |
| 
 | |
|         .review-content {
 | |
|           padding: 1em 0 1em 3.8em;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .comment-list {
 | |
|       &:not(.prevent-before-timeline)::before {
 | |
|         display: block;
 | |
|         content: "";
 | |
|         position: absolute;
 | |
|         margin-top: 12px;
 | |
|         margin-bottom: 14px;
 | |
|         top: 0;
 | |
|         bottom: 0;
 | |
|         left: 96px;
 | |
|         width: 2px;
 | |
|         background-color: var(--color-timeline);
 | |
|         z-index: -1;
 | |
|       }
 | |
| 
 | |
|       .timeline {
 | |
|         position: relative;
 | |
|         display: block;
 | |
|         margin-left: 40px;
 | |
|         padding-left: 16px;
 | |
| 
 | |
|         &::before { //ciara
 | |
|           display: block;
 | |
|           content: "";
 | |
|           position: absolute;
 | |
|           margin-top: 12px;
 | |
|           margin-bottom: 14px;
 | |
|           top: 0;
 | |
|           bottom: 0;
 | |
|           left: 30px;
 | |
|           width: 2px;
 | |
|           background-color: var(--color-timeline);
 | |
|           z-index: -1;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .timeline-item,
 | |
|       .timeline-item-group {
 | |
|         padding: 12px 0;
 | |
|       }
 | |
| 
 | |
|       .timeline-item-group {
 | |
|         .timeline-item {
 | |
|           padding-top: 8px;
 | |
|           padding-bottom: 8px;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .timeline-item {
 | |
|         margin-left: 16px;
 | |
|         position: relative;
 | |
| 
 | |
|         .timeline-avatar {
 | |
|           position: absolute;
 | |
|           left: -68px;
 | |
| 
 | |
|           img {
 | |
|             width: 40px !important;
 | |
|             height: 40px !important;
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         /* Don't show the mobile oriented avatar ".inline-timeline-avatar" on desktop. Desktop uses the avatar with class ".timeline-avatar" */
 | |
|         .inline-timeline-avatar {
 | |
|           display: none;
 | |
|         }
 | |
| 
 | |
|         img.avatar,
 | |
|         .avatar img {
 | |
|           width: 20px;
 | |
|           height: 20px;
 | |
|           vertical-align: middle;
 | |
|         }
 | |
| 
 | |
|         &:first-child:not(.commit) {
 | |
|           padding-top: 0 !important;
 | |
|         }
 | |
| 
 | |
|         &:last-child:not(.commit) {
 | |
|           padding-bottom: 0 !important;
 | |
|         }
 | |
| 
 | |
|         .badge.badge-commit {
 | |
|           border-color: transparent;
 | |
|           background: radial-gradient(var(--color-body) 40%, transparent 40%) no-repeat;
 | |
|         }
 | |
| 
 | |
|         .badge {
 | |
|           width: 34px;
 | |
|           height: 34px;
 | |
|           background-color: var(--color-timeline);
 | |
|           border-radius: 50%;
 | |
|           display: flex;
 | |
|           float: left;
 | |
|           margin-left: -33px;
 | |
|           margin-right: 8px;
 | |
|           color: var(--color-text);
 | |
|           align-items: center;
 | |
|           justify-content: center;
 | |
| 
 | |
|           .svg {
 | |
|             width: 22px;
 | |
|             height: 22px;
 | |
|             padding: 3px;
 | |
| 
 | |
|             &.octicon-comment {
 | |
|               margin-top: 2px;
 | |
|             }
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         &.comment > .content {
 | |
|           margin-left: -16px;
 | |
|         }
 | |
| 
 | |
|         &.event > .text {
 | |
|           line-height: 32px;
 | |
|           vertical-align: middle;
 | |
|         }
 | |
| 
 | |
|         &.commits-list {
 | |
|           padding-left: 15px;
 | |
|           padding-top: 0;
 | |
| 
 | |
|           .singular-commit {
 | |
|             line-height: 34px; /* this must be same as .badge height, to avoid overflow */
 | |
|             clear: both; // reset the "float right shabox", in the future, use flexbox instead
 | |
| 
 | |
|             > img.avatar,
 | |
|             > .avatar img {
 | |
|               position: relative;
 | |
|               top: -2px;
 | |
|             }
 | |
| 
 | |
|             .shabox {
 | |
|               .sha.label {
 | |
|                 margin: 0;
 | |
|                 border: 1px solid var(--color-light-border);
 | |
| 
 | |
|                 &.isSigned.isWarning {
 | |
|                   border: 1px solid var(--color-red-badge);
 | |
|                   background: var(--color-red-badge-bg);
 | |
| 
 | |
|                   .shortsha {
 | |
|                     display: inline-block;
 | |
|                     padding-top: 1px;
 | |
|                   }
 | |
| 
 | |
|                   &:hover {
 | |
|                     background: var(--color-red-badge-hover-bg) !important;
 | |
|                   }
 | |
|                 }
 | |
| 
 | |
|                 &.isSigned.isVerified {
 | |
|                   border: 1px solid var(--color-green-badge);
 | |
|                   background: var(--color-green-badge-bg);
 | |
| 
 | |
|                   .shortsha {
 | |
|                     display: inline-block;
 | |
|                     padding-top: 1px;
 | |
|                   }
 | |
| 
 | |
|                   &:hover {
 | |
|                     background: var(--color-green-badge-hover-bg) !important;
 | |
|                   }
 | |
|                 }
 | |
| 
 | |
|                 &.isSigned.isVerifiedUntrusted {
 | |
|                   border: 1px solid var(--color-yellow-badge);
 | |
|                   background: var(--color-yellow-badge-bg);
 | |
| 
 | |
|                   .shortsha {
 | |
|                     display: inline-block;
 | |
|                     padding-top: 1px;
 | |
|                   }
 | |
| 
 | |
|                   &:hover {
 | |
|                     background: var(--color-yellow-badge-hover-bg) !important;
 | |
|                   }
 | |
|                 }
 | |
| 
 | |
|                 &.isSigned.isVerifiedUnmatched {
 | |
|                   border: 1px solid var(--color-orange-badge);
 | |
|                   background: var(--color-orange-badge-bg);
 | |
| 
 | |
|                   .shortsha {
 | |
|                     display: inline-block;
 | |
|                     padding-top: 1px;
 | |
|                   }
 | |
| 
 | |
|                   &:hover {
 | |
|                     background: var(--color-orange-badge-hover-bg) !important;
 | |
|                   }
 | |
|                 }
 | |
|               }
 | |
|             }
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         &.event > .commit-status-link {
 | |
|           float: right;
 | |
|           margin-right: 8px;
 | |
|           margin-top: 4px;
 | |
|         }
 | |
| 
 | |
|         .comment-form-reply .footer {
 | |
|           padding-bottom: 1em;
 | |
|         }
 | |
| 
 | |
|         @media @mediaSm {
 | |
|           .ui.segments {
 | |
|             margin-left: -2rem;
 | |
|           }
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .ui.comments {
 | |
|         max-width: 100%;
 | |
| 
 | |
|         .avatar {
 | |
|           margin-right: .5rem;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .comment {
 | |
|         > .content {
 | |
|           > div:first-child {
 | |
|             border-top-left-radius: 4px;
 | |
|             border-top-right-radius: 4px;
 | |
|           }
 | |
| 
 | |
|           > div:last-child {
 | |
|             border-bottom-left-radius: 4px;
 | |
|             border-bottom-right-radius: 4px;
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         .comment-container {
 | |
|           border: 1px solid var(--color-secondary);
 | |
|           border-radius: var(--border-radius);
 | |
|         }
 | |
| 
 | |
|         .content {
 | |
|           @media @mediaSm {
 | |
|             .form .button {
 | |
|               width: 100%;
 | |
|               margin: 0;
 | |
| 
 | |
|               &:not(:last-child) {
 | |
|                 margin-bottom: 1rem;
 | |
|               }
 | |
|             }
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         .merge-section {
 | |
|           background-color: var(--color-box-body);
 | |
| 
 | |
|           .item-section {
 | |
|             display: flex;
 | |
|             align-items: center;
 | |
|             justify-content: space-between;
 | |
|             padding: 0;
 | |
|             margin-top: -.25rem;
 | |
|             margin-bottom: -.25rem;
 | |
|           }
 | |
| 
 | |
|           @media @mediaSm {
 | |
|             .item-section {
 | |
|               align-items: flex-start;
 | |
|               flex-direction: column;
 | |
|             }
 | |
|           }
 | |
| 
 | |
|           .divider {
 | |
|             margin-left: -1rem;
 | |
|             margin-right: -1rem;
 | |
|           }
 | |
| 
 | |
|           &.no-header {
 | |
|             #avatar-arrow();
 | |
| 
 | |
|             &::after {
 | |
|               border-right-color: var(--color-box-body);
 | |
|             }
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         .markup {
 | |
|           font-size: 14px;
 | |
|         }
 | |
| 
 | |
|         .no-content {
 | |
|           color: var(--color-text-light-2);
 | |
|           font-style: italic;
 | |
|         }
 | |
| 
 | |
|         .ui.form {
 | |
|           .field {
 | |
|             &:first-child {
 | |
|               clear: none;
 | |
|             }
 | |
| 
 | |
|             &.footer {
 | |
|               overflow: hidden;
 | |
|             }
 | |
| 
 | |
|             .tab.markup {
 | |
|               min-height: 5rem;
 | |
|             }
 | |
|           }
 | |
| 
 | |
|           textarea {
 | |
|             height: 200px;
 | |
|             font-family: var(--fonts-monospace);
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         .edit.buttons {
 | |
|           margin-top: 10px;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .code-comment {
 | |
|         border: 1px solid transparent;
 | |
|         padding: .25rem .5rem;
 | |
|         margin: 0;
 | |
| 
 | |
|         .content {
 | |
|           border: none !important;
 | |
|         }
 | |
| 
 | |
|         .comment-header {
 | |
|           background: transparent;
 | |
|           border-bottom: 0 !important;
 | |
|           padding: 0 !important;
 | |
| 
 | |
|           &::after,
 | |
|           &::before {
 | |
|             display: none;
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         .comment-content {
 | |
|           margin-left: 36px;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .code-comment,
 | |
|       .comment {
 | |
|         img.avatar {
 | |
|           width: 28px;
 | |
|           height: 28px;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .comment-code-cloud {
 | |
|         .segment.reactions {
 | |
|           margin-top: 16px !important;
 | |
|           margin-bottom: -8px !important;
 | |
|           border-top: none !important;
 | |
| 
 | |
|           .ui.label {
 | |
|             border: 1px solid;
 | |
|             padding: 6px 10px !important;
 | |
|             margin: 0 2px;
 | |
|             border-radius: var(--border-radius);
 | |
|             border-color: var(--color-secondary-dark-1) !important;
 | |
|           }
 | |
| 
 | |
|           .ui.label.basic.primary {
 | |
|             background-color: var(--color-reaction-active-bg) !important;
 | |
|             border-color: var(--color-primary-alpha-80) !important;
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         button.comment-form-reply {
 | |
|           margin: 0;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .event {
 | |
|         padding-left: 15px;
 | |
| 
 | |
|         .detail {
 | |
|           margin-top: 4px;
 | |
|           margin-left: 14px;
 | |
| 
 | |
|           .svg {
 | |
|             margin-right: 2px;
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         .segments {
 | |
|           box-shadow: none;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       @media @mediaSm {
 | |
|         padding: 1rem 0 !important; // Important is required here to override existing fomantic styles.
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .ui.depending {
 | |
|       .item.is-closed {
 | |
|         .title {
 | |
|           text-decoration: line-through;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .comment.form {
 | |
|     .ui.comments {
 | |
|       margin-top: -12px;
 | |
|       max-width: 100%;
 | |
|     }
 | |
| 
 | |
|     .content {
 | |
|       .field:first-child {
 | |
|         clear: none;
 | |
|       }
 | |
| 
 | |
|       .form {
 | |
|         #avatar-arrow();
 | |
| 
 | |
|         &::after {
 | |
|           border-right-color: var(--color-box-body);
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       textarea {
 | |
|         height: 200px;
 | |
|         font-family: var(--fonts-monospace);
 | |
|       }
 | |
| 
 | |
|       .CodeMirror-scroll {
 | |
|         max-height: 85vh;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .milestone.list {
 | |
|     list-style: none;
 | |
|     padding-top: 15px;
 | |
| 
 | |
|     > .item {
 | |
|       padding-top: 10px;
 | |
|       padding-bottom: 10px;
 | |
|       border-bottom: 1px dashed var(--color-secondary);
 | |
| 
 | |
|       progress {
 | |
|         width: 200px;
 | |
|         height: 16px;
 | |
|       }
 | |
| 
 | |
|       .meta {
 | |
|         color: var(--color-text-light-2);
 | |
|         padding-top: 5px;
 | |
| 
 | |
|         .issue-stats .svg {
 | |
|           padding-left: 5px;
 | |
|         }
 | |
| 
 | |
|         .overdue {
 | |
|           color: var(--color-red);
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .operate {
 | |
|         margin-top: -15px;
 | |
| 
 | |
|         > a {
 | |
|           font-size: 15px;
 | |
|           padding-top: 5px;
 | |
|           padding-right: 10px;
 | |
|           color: var(--color-text-light-2);
 | |
| 
 | |
|           &:hover {
 | |
|             color: var(--color-text);
 | |
|           }
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .content {
 | |
|         padding-top: 10px;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.new.milestone {
 | |
|     textarea {
 | |
|       height: 200px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.compare.pull {
 | |
|     .show-form-container {
 | |
|       text-align: left;
 | |
|     }
 | |
| 
 | |
|     .choose.branch {
 | |
|       .svg {
 | |
|         margin-right: 10px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .comment.form {
 | |
|       .content {
 | |
|         #avatar-arrow();
 | |
| 
 | |
|         &::after {
 | |
|           border-right-color: var(--color-box-body);
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .pullrequest-form {
 | |
|       margin-bottom: 1.5rem;
 | |
|     }
 | |
| 
 | |
|     .markup {
 | |
|       font-size: 14px;
 | |
|     }
 | |
| 
 | |
|     .title {
 | |
|       .issue-title {
 | |
|         margin-bottom: .5rem;
 | |
|         .index {
 | |
|           color: var(--color-text-light-2);
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .filter.dropdown .menu {
 | |
|     margin-top: 1px !important;
 | |
|   }
 | |
| 
 | |
|   &.branches {
 | |
|     .commit-divergence {
 | |
|       .bar-group {
 | |
|         position: relative;
 | |
|         float: left;
 | |
|         padding-bottom: 6px;
 | |
|         width: 50%;
 | |
|         max-width: 90px;
 | |
| 
 | |
|         &:last-child {
 | |
|           border-left: 1px solid var(--color-secondary-dark-2);
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .count {
 | |
|         margin: 0 3px;
 | |
| 
 | |
|         &.count-ahead {
 | |
|           text-align: left;
 | |
|         }
 | |
| 
 | |
|         &.count-behind {
 | |
|           text-align: right;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .bar {
 | |
|         height: 4px;
 | |
|         position: absolute;
 | |
|         background-color: var(--color-secondary-dark-2);
 | |
| 
 | |
|         &.bar-behind {
 | |
|           right: 0;
 | |
|         }
 | |
| 
 | |
|         &.bar-ahead {
 | |
|           left: 0;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.commits {
 | |
|     .header {
 | |
|       .search {
 | |
|         input {
 | |
|           font-weight: normal;
 | |
|           padding: 5px 10px;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   #commits-table {
 | |
|     thead {
 | |
|       th:first-of-type {
 | |
|         padding-left: 15px;
 | |
|       }
 | |
| 
 | |
|       .sha {
 | |
|         &td {
 | |
|           text-align: center;
 | |
|         }
 | |
| 
 | |
|         width: 200px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     td.sha .sha.label {
 | |
|       margin: 0;
 | |
|     }
 | |
| 
 | |
|     td.message {
 | |
|       text-overflow: unset;
 | |
|     }
 | |
| 
 | |
|     &.ui.basic.striped.table tbody tr:nth-child(2n) {
 | |
|       background-color: rgba(0, 0, 0, .02) !important;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   #commits-table td.sha .sha.label,
 | |
|   #repo-files-table .sha.label,
 | |
|   #rev-list .sha.label,
 | |
|   .timeline-item.commits-list .singular-commit .sha.label {
 | |
|     border: 1px solid var(--color-light-border);
 | |
| 
 | |
|     .ui.signature.avatar {
 | |
|       height: 16px;
 | |
|       margin-bottom: 0;
 | |
|       width: 16px;
 | |
|     }
 | |
| 
 | |
|     .detail.icon {
 | |
|       background: var(--color-light);
 | |
|       margin: -6px -10px -4px 0;
 | |
|       padding: 5px 4px 5px 6px;
 | |
|       border-left: 1px solid var(--color-light-border);
 | |
|       border-top: 0;
 | |
|       border-right: 0;
 | |
|       border-bottom: 0;
 | |
|       border-top-left-radius: 0;
 | |
|       border-bottom-left-radius: 0;
 | |
| 
 | |
|       img {
 | |
|         margin-right: 0;
 | |
|       }
 | |
| 
 | |
|       .svg {
 | |
|         margin: 0 .25em 0 0;
 | |
|       }
 | |
| 
 | |
|       > div {
 | |
|         display: flex;
 | |
|         align-items: center;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.isSigned.isWarning {
 | |
|       border: 1px solid var(--color-red-badge);
 | |
|       background: var(--color-red-badge-bg);
 | |
| 
 | |
|       .shortsha {
 | |
|         display: inline-block;
 | |
|         padding-top: 1px;
 | |
|       }
 | |
| 
 | |
|       .detail.icon {
 | |
|         border-left: 1px solid var(--color-red-badge);
 | |
|         color: var(--color-red-badge);
 | |
|       }
 | |
| 
 | |
|       &:hover {
 | |
|         background: var(--color-red-badge-hover-bg) !important;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.isSigned.isVerified {
 | |
|       border: 1px solid var(--color-green-badge);
 | |
|       background: var(--color-green-badge-bg);
 | |
| 
 | |
|       .shortsha {
 | |
|         display: inline-block;
 | |
|         padding-top: 1px;
 | |
|       }
 | |
| 
 | |
|       .detail.icon {
 | |
|         border-left: 1px solid var(--color-green-badge);
 | |
|         color: var(--color-green-badge);
 | |
|       }
 | |
| 
 | |
|       &:hover {
 | |
|         background: var(--color-green-badge-hover-bg) !important;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.isSigned.isVerifiedUntrusted {
 | |
|       border: 1px solid var(--color-yellow-badge);
 | |
|       background: var(--color-yellow-badge-bg);
 | |
| 
 | |
|       .shortsha {
 | |
|         display: inline-block;
 | |
|         padding-top: 1px;
 | |
|       }
 | |
| 
 | |
|       .detail.icon {
 | |
|         border-left: 1px solid var(--color-yellow-badge);
 | |
|         color: var(--color-yellow-badge);
 | |
|       }
 | |
| 
 | |
|       &:hover {
 | |
|         background: var(--color-yellow-badge-hover-bg) !important;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.isSigned.isVerifiedUnmatched {
 | |
|       border: 1px solid var(--color-orange-badge);
 | |
|       background: var(--color-orange-badge-bg);
 | |
| 
 | |
|       .shortsha {
 | |
|         display: inline-block;
 | |
|         padding-top: 1px;
 | |
|       }
 | |
| 
 | |
|       .detail.icon {
 | |
|         border-left: 1px solid var(--color-orange-badge);
 | |
|         color: var(--color-orange-badge);
 | |
|       }
 | |
| 
 | |
|       &:hover {
 | |
|         background: var(--color-orange-badge-hover-bg) !important;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .data-table {
 | |
|     width: 100%;
 | |
| 
 | |
|     tr {
 | |
|       border-top: 0;
 | |
|     }
 | |
| 
 | |
|     td,
 | |
|     th {
 | |
|       padding: 5px !important;
 | |
|       overflow: hidden;
 | |
|       font-size: 12px;
 | |
|       text-align: left;
 | |
|       white-space: nowrap;
 | |
|       border: 1px solid var(--color-secondary);
 | |
|     }
 | |
| 
 | |
|     td {
 | |
|       white-space: pre-line;
 | |
|     }
 | |
| 
 | |
|     th {
 | |
|       font-weight: 600;
 | |
|       background: var(--color-box-header);
 | |
|       border-top: 0;
 | |
|     }
 | |
| 
 | |
|     td.added,
 | |
|     th.added,
 | |
|     tr.added {
 | |
|       background-color: var(--color-diff-added-row-bg) !important;
 | |
|     }
 | |
| 
 | |
|     td.removed,
 | |
|     th.removed,
 | |
|     tr.removed {
 | |
|       background-color: var(--color-diff-removed-row-bg) !important;
 | |
|     }
 | |
| 
 | |
|     td.moved,
 | |
|     th.moved,
 | |
|     tr.moved {
 | |
|       background-color: var(--color-diff-moved-row-bg) !important;
 | |
|     }
 | |
| 
 | |
|     tbody.section {
 | |
|       border-top: 2px solid var(--color-secondary);
 | |
|     }
 | |
| 
 | |
|     .line-num {
 | |
|       &:extend(.unselectable);
 | |
|       width: 1%;
 | |
|       min-width: 50px;
 | |
|       font-family: monospace;
 | |
|       line-height: 20px;
 | |
|       color: var(--color-secondary-dark-2);
 | |
|       white-space: nowrap;
 | |
|       vertical-align: top;
 | |
|       cursor: pointer;
 | |
|       text-align: right;
 | |
|       background: var(--color-body);
 | |
|       border: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .diff-detail-box {
 | |
|     padding: 7px 0;
 | |
|     background: var(--color-body);
 | |
|     line-height: 30px;
 | |
| 
 | |
|     @media @mediaMdAndDown {
 | |
|       flex-direction: column;
 | |
|       align-items: flex-start;
 | |
|     }
 | |
| 
 | |
|     @media (max-width: 480px) {
 | |
|       flex-wrap: wrap;
 | |
|     }
 | |
| 
 | |
|     &.sticky {
 | |
|       position: sticky;
 | |
|       top: 0;
 | |
|       z-index: 8;
 | |
|       border-bottom: 1px solid var(--color-secondary);
 | |
|       padding-left: 2px;
 | |
|       padding-right: 2px;
 | |
|       margin-left: -1px;
 | |
|       margin-right: -1px;
 | |
|     }
 | |
| 
 | |
|     > div::after {
 | |
|       clear: both;
 | |
|       content: "";
 | |
|       display: block;
 | |
|     }
 | |
| 
 | |
|     .diff-detail-stats strong {
 | |
|       margin-left: .25rem;
 | |
|       margin-right: .25rem;
 | |
|     }
 | |
| 
 | |
|     .diff-detail-stats {
 | |
|       @media (max-width: 480px) {
 | |
|         font-size: 0;
 | |
|         line-height: 1.6rem;
 | |
| 
 | |
|         strong {
 | |
|           font-size: 1rem;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .diff-detail-actions > * {
 | |
|       margin-right: 0;
 | |
|     }
 | |
| 
 | |
|     .diff-detail-actions > * + * {
 | |
|       margin-left: .25rem;
 | |
|     }
 | |
| 
 | |
|     .diff-detail-actions {
 | |
|       @media (max-width: 480px) {
 | |
|         padding-top: .25rem;
 | |
| 
 | |
|         .ui.button:not(.btn-submit) {
 | |
|           padding-left: .5rem;
 | |
|           padding-right: .5rem;
 | |
|           display: flex;
 | |
|           flex-wrap: wrap;
 | |
|           justify-content: center;
 | |
|           text-align: center;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     span.status {
 | |
|       display: inline-block;
 | |
|       width: 12px;
 | |
|       height: 12px;
 | |
|       margin-right: 8px;
 | |
|       vertical-align: middle;
 | |
| 
 | |
|       &.modify {
 | |
|         background-color: var(--color-yellow);
 | |
|       }
 | |
| 
 | |
|       &.add {
 | |
|         background-color: var(--color-green);
 | |
|       }
 | |
| 
 | |
|       &.del {
 | |
|         background-color: var(--color-red);
 | |
|       }
 | |
| 
 | |
|       &.rename {
 | |
|         background-color: var(--color-teal);
 | |
|       }
 | |
|     }
 | |
|     .button {
 | |
|       padding: 8px 12px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .diff-box .header:not(.resolved-placeholder) {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
| 
 | |
|     .file {
 | |
|       flex: 1;
 | |
|       word-break: break-all;
 | |
|     }
 | |
| 
 | |
|     .button {
 | |
|       padding: 8px 12px;
 | |
|       flex: 0 0 auto;
 | |
|       margin-top: -8px;
 | |
|       margin-bottom: -8px;
 | |
|       margin-right: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .diff-box .resolved-placeholder {
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
| 
 | |
|     .button {
 | |
|       padding: 8px 12px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .diff-file-box {
 | |
|     .header {
 | |
|       background-color: var(--color-box-header);
 | |
|     }
 | |
| 
 | |
|     .file-body.file-code {
 | |
|       background: var(--color-code-bg);
 | |
| 
 | |
|       .lines-num {
 | |
|         &:extend(.unselectable);
 | |
|         text-align: right;
 | |
|         color: var(--color-text-light);
 | |
|         width: 1%;
 | |
|         min-width: 50px;
 | |
| 
 | |
|         span.fold {
 | |
|           display: block;
 | |
|           text-align: center;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .code-diff {
 | |
|       font-size: 12px;
 | |
| 
 | |
|       td {
 | |
|         padding: 0 0 0 10px !important;
 | |
|         border-top: 0;
 | |
|       }
 | |
| 
 | |
|       .lines-num {
 | |
|         padding: 0 5px !important;
 | |
|       }
 | |
| 
 | |
|       .tag-code .lines-num,
 | |
|       .tag-code td {
 | |
|         padding: 0 !important;
 | |
|       }
 | |
| 
 | |
|       tbody {
 | |
|         tr {
 | |
|           td.halfwidth {
 | |
|             // halfwidth is used in split view - and in that case, 1% of each
 | |
|             width: 49%;
 | |
|           }
 | |
| 
 | |
|           td.center {
 | |
|             text-align: center;
 | |
|           }
 | |
| 
 | |
|           [data-line-num]::before {
 | |
|             content: attr(data-line-num);
 | |
|             text-align: right;
 | |
|           }
 | |
| 
 | |
|           .lines-type-marker {
 | |
|             &:extend(.unselectable);
 | |
|             width: 10px;
 | |
|             min-width: 10px;
 | |
|           }
 | |
| 
 | |
|           [data-type-marker]::before {
 | |
|             content: attr(data-type-marker);
 | |
|             text-align: right;
 | |
|             display: inline-block;
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .code-diff-split {
 | |
|       .tag-code .lines-code code.code-inner {
 | |
|         padding-left: 10px !important;
 | |
|       }
 | |
| 
 | |
|       table,
 | |
|       tbody {
 | |
|         width: 100%;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.file-content {
 | |
|       img {
 | |
|         max-width: 100%;
 | |
|         padding: 0;
 | |
|         border-radius: 0;
 | |
|       }
 | |
| 
 | |
|       img.emoji {
 | |
|         padding: 0;
 | |
|       }
 | |
| 
 | |
|       clear: right;
 | |
|     }
 | |
| 
 | |
|     .ui.bottom.attached.table.segment {
 | |
|       padding-top: 5px;
 | |
|       padding-bottom: 5px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .diff-stats {
 | |
|     clear: both;
 | |
|     margin-bottom: 5px;
 | |
|     max-height: 400px;
 | |
|     overflow: auto;
 | |
|     padding-left: 0;
 | |
| 
 | |
|     li {
 | |
|       list-style: none;
 | |
|       padding-bottom: 4px;
 | |
|       margin-bottom: 4px;
 | |
|       padding-left: 6px;
 | |
|     }
 | |
| 
 | |
|     li + li {
 | |
|       border-top: 1px solid var(--color-secondary);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .repo-search-result {
 | |
|     padding-top: 10px;
 | |
|     padding-bottom: 10px;
 | |
| 
 | |
|     .lines-num a {
 | |
|       color: inherit;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.quickstart {
 | |
|     .guide {
 | |
|       .item {
 | |
|         padding: 1em;
 | |
| 
 | |
|         small {
 | |
|           font-weight: normal;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .clone.button:first-child {
 | |
|         border-radius: var(--border-radius) 0 0 var(--border-radius);
 | |
|       }
 | |
| 
 | |
|       .ui.action.small.input {
 | |
|         width: 100%;
 | |
|       }
 | |
| 
 | |
|       #repo-clone-url {
 | |
|         border-radius: 0;
 | |
|         padding: 5px 10px;
 | |
|         font-size: 1.2em;
 | |
|         line-height: 1.4;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.release {
 | |
|     #release-list {
 | |
|       border-top: 1px solid var(--color-secondary);
 | |
|       margin-top: 20px;
 | |
|       padding-top: 15px;
 | |
|       padding-left: 0;
 | |
| 
 | |
|       .release-list-title {
 | |
|         font-size: 2rem;
 | |
|         font-weight: normal;
 | |
|         margin-top: -4px;
 | |
|         margin-bottom: 0;
 | |
|       }
 | |
| 
 | |
|       > li {
 | |
|         list-style: none;
 | |
| 
 | |
|         .meta,
 | |
|         .detail {
 | |
|           padding-top: 30px;
 | |
|           padding-bottom: 40px;
 | |
|         }
 | |
| 
 | |
|         .meta {
 | |
|           text-align: right;
 | |
|           position: relative;
 | |
| 
 | |
|           .label {
 | |
|             margin-right: 0;
 | |
|           }
 | |
| 
 | |
|           .commit {
 | |
|             display: block;
 | |
|             margin-top: 10px;
 | |
|           }
 | |
| 
 | |
|           .choose {
 | |
|             margin-top: 15px;
 | |
| 
 | |
|             .button {
 | |
|               margin-right: 0;
 | |
|             }
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         .detail {
 | |
|           border-left: 2px solid var(--color-secondary);
 | |
| 
 | |
|           .author {
 | |
|             img {
 | |
|               margin-bottom: 3px;
 | |
|             }
 | |
|           }
 | |
| 
 | |
|           .download {
 | |
|             > a {
 | |
|               .svg {
 | |
|                 margin-left: 5px;
 | |
|                 margin-right: 5px;
 | |
|               }
 | |
|             }
 | |
| 
 | |
|             .list {
 | |
|               padding-left: 0;
 | |
| 
 | |
|               li {
 | |
|                 list-style: none;
 | |
|                 display: block;
 | |
|                 padding: 8px;
 | |
|                 border: 1px solid var(--color-secondary);
 | |
|                 background: var(--color-light);
 | |
| 
 | |
|                 a > .text.right {
 | |
|                   margin-right: 5px;
 | |
|                 }
 | |
|               }
 | |
| 
 | |
|               li + li {
 | |
|                 border-top: 0;
 | |
|               }
 | |
| 
 | |
|               li:first-of-type {
 | |
|                 border-radius: var(--border-radius) 0 0 var(--border-radius);
 | |
|               }
 | |
| 
 | |
|               li:last-of-type {
 | |
|                 border-radius: 0 var(--border-radius) var(--border-radius) 0;
 | |
|               }
 | |
|             }
 | |
|           }
 | |
| 
 | |
|           .dot {
 | |
|             width: 10px;
 | |
|             height: 10px;
 | |
|             background-color: var(--color-secondary-dark-3);
 | |
|             z-index: 9;
 | |
|             position: absolute;
 | |
|             display: block;
 | |
|             left: -6px;
 | |
|             top: 40px;
 | |
|             border-radius: 100%;
 | |
|             border: 2.5px solid var(--color-body);
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     #tags-table {
 | |
|       .tag {
 | |
|         padding: 8px 12px;
 | |
|       }
 | |
| 
 | |
|       .release-tag-name {
 | |
|         font-size: 18px;
 | |
|         font-weight: normal;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.new.release {
 | |
|     .target {
 | |
|       min-width: 500px;
 | |
| 
 | |
|       #tag-name {
 | |
|         margin-top: -4px;
 | |
|       }
 | |
| 
 | |
|       .at {
 | |
|         margin-left: -5px;
 | |
|         margin-right: 5px;
 | |
|       }
 | |
| 
 | |
|       .selection.dropdown {
 | |
|         padding-top: 10px;
 | |
|         padding-bottom: 10px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .prerelease.field {
 | |
|       margin-bottom: 0;
 | |
|     }
 | |
| 
 | |
|     .field {
 | |
| 
 | |
|       button,
 | |
|       input {
 | |
|         @media (max-width: 438px) {
 | |
|           width: 100%;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       button {
 | |
|         @media @mediaSm {
 | |
|           margin-bottom: 1em;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .wrap_remove {
 | |
|         height: 38px;
 | |
|       }
 | |
| 
 | |
|       .attachment_edit {
 | |
|         width: 450px !important;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.forks {
 | |
|     .list {
 | |
|       margin-top: 0;
 | |
| 
 | |
|       .item {
 | |
|         padding-top: 10px;
 | |
|         padding-bottom: 10px;
 | |
|         border-bottom: 1px solid var(--color-secondary);
 | |
| 
 | |
|         .ui.avatar {
 | |
|           float: left;
 | |
|           margin-right: 5px;
 | |
|         }
 | |
| 
 | |
|         .link {
 | |
|           padding-top: 5px;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.packages {
 | |
|     .empty {
 | |
|       padding-top: 70px;
 | |
|       padding-bottom: 100px;
 | |
| 
 | |
|       .svg {
 | |
|         height: 48px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .file-size {
 | |
|       white-space: nowrap;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.wiki {
 | |
|     &.start {
 | |
|       .ui.segment {
 | |
|         padding-top: 70px;
 | |
|         padding-bottom: 100px;
 | |
| 
 | |
|         .svg {
 | |
|           height: 48px;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.new {
 | |
|       .ui.attached.tabular.menu.previewtabs {
 | |
|         margin-bottom: 15px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.view {
 | |
|       > .markup {
 | |
|         padding: 15px 30px;
 | |
| 
 | |
|         h1,
 | |
|         h2,
 | |
|         h3,
 | |
|         h4,
 | |
|         h5,
 | |
|         h6 {
 | |
|           &:first-of-type {
 | |
|             margin-top: 0;
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .form .CodeMirror-scroll {
 | |
|       max-height: 85vh;
 | |
|     }
 | |
| 
 | |
|     @media @mediaSm {
 | |
|       .dividing.header .stackable.grid .button {
 | |
|         margin-top: 2px;
 | |
|         margin-bottom: 2px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     @media @mediaSm {
 | |
|       #clone-panel #repo-clone-url {
 | |
|         width: 160px;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.settings {
 | |
|     &.collaboration {
 | |
|       .collaborator.list {
 | |
|         padding: 0;
 | |
| 
 | |
|         > .item {
 | |
|           margin: 0;
 | |
|           line-height: 2em;
 | |
| 
 | |
|           &:not(:last-child) {
 | |
|             border-bottom: 1px solid var(--color-secondary);
 | |
|           }
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       #repo-collab-form {
 | |
|         #search-user-box {
 | |
|           .results {
 | |
|             left: 7px;
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         .ui.button {
 | |
|           margin-left: 5px;
 | |
|           margin-top: -3px;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       #repo-collab-team-form {
 | |
|         #search-team-box {
 | |
|           .results {
 | |
|             left: 7px;
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         .ui.button {
 | |
|           margin-left: 5px;
 | |
|           margin-top: -3px;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.branches {
 | |
|       .protected-branches {
 | |
|         .selection.dropdown {
 | |
|           width: 300px;
 | |
|         }
 | |
| 
 | |
|         .item {
 | |
|           border: 1px solid var(--color-secondary);
 | |
|           padding: 10px 15px;
 | |
| 
 | |
|           &:not(:last-child) {
 | |
|             border-bottom: 0;
 | |
|           }
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .branch-protection {
 | |
|         .help {
 | |
|           margin-left: 26px;
 | |
|           padding-top: 0;
 | |
|         }
 | |
| 
 | |
|         .fields {
 | |
|           margin-left: 20px;
 | |
|           display: block;
 | |
|         }
 | |
| 
 | |
|         .whitelist {
 | |
|           margin-left: 26px;
 | |
| 
 | |
|           .dropdown img {
 | |
|             display: inline-block;
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.webhook {
 | |
|       .events {
 | |
|         .column {
 | |
|           padding-bottom: 0;
 | |
|         }
 | |
| 
 | |
|         .help {
 | |
|           font-size: 13px;
 | |
|           margin-left: 26px;
 | |
|           padding-top: 0;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .ui.attached.isSigned.isWarning {
 | |
|     border-left: 1px solid var(--color-error-border);
 | |
|     border-right: 1px solid var(--color-error-border);
 | |
| 
 | |
|     &.top,
 | |
|     &.message {
 | |
|       border-top: 1px solid var(--color-error-border);
 | |
|     }
 | |
| 
 | |
|     &.message {
 | |
|       box-shadow: none;
 | |
|       background-color: var(--color-error-bg);
 | |
|       color: var(--color-error-text);
 | |
| 
 | |
|       .ui.text {
 | |
|         color: var(--color-error-text);
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &:last-child,
 | |
|     &.bottom {
 | |
|       border-bottom: 1px solid var(--color-error-border);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .ui.attached.isSigned.isVerified {
 | |
|     border-left: 1px solid var(--color-success-border);
 | |
|     border-right: 1px solid var(--color-success-border);
 | |
| 
 | |
|     &.top,
 | |
|     &.message {
 | |
|       border-top: 1px solid var(--color-success-border);
 | |
|     }
 | |
| 
 | |
|     &.message {
 | |
|       box-shadow: none;
 | |
|       background-color: var(--color-success-bg);
 | |
|       color: var(--color-success-text);
 | |
| 
 | |
|       .pull-right {
 | |
|         color: var(--color-text);
 | |
|       }
 | |
| 
 | |
|       .ui.text {
 | |
|         color: var(--color-success-text);
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &:last-child,
 | |
|     &.bottom {
 | |
|       border-bottom: 1px solid var(--color-success-border);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .ui.attached.isSigned.isVerifiedUntrusted,
 | |
|   .ui.attached.isSigned.isVerifiedUnmatched {
 | |
|     border-left: 1px solid var(--color-warning-border);
 | |
|     border-right: 1px solid var(--color-warning-border);
 | |
| 
 | |
|     &.top,
 | |
|     &.message {
 | |
|       border-top: 1px solid var(--color-warning-border);
 | |
|     }
 | |
| 
 | |
|     &.message {
 | |
|       box-shadow: none;
 | |
|       background-color: var(--color-warning-bg);
 | |
|       color: var(--color-warning-text);
 | |
| 
 | |
|       .ui.text {
 | |
|         color: var(--color-warning-text);
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &:last-child,
 | |
|     &.bottom {
 | |
|       border-bottom: 1px solid var(--color-warning-border);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .ui.segment.sub-menu {
 | |
|     padding: 7px;
 | |
|     line-height: 0;
 | |
| 
 | |
|     .list {
 | |
|       width: 100%;
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
| 
 | |
|       .item {
 | |
|         width: 100%;
 | |
|         color: var(--color-text);
 | |
| 
 | |
|         &:first-of-type {
 | |
|           border-radius: var(--border-radius) 0 0 var(--border-radius);
 | |
|           padding-left: .25rem;
 | |
|         }
 | |
| 
 | |
|         &:last-of-type {
 | |
|           border-radius: 0 var(--border-radius) var(--border-radius) 0;
 | |
|           padding-right: .25rem;
 | |
|         }
 | |
| 
 | |
|         a {
 | |
|           color: var(--color-text);
 | |
| 
 | |
|           &:hover {
 | |
|             color: var(--color-primary-light-2);
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         &.active {
 | |
|           background: var(--color-secondary);
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .segment.reactions,
 | |
|   .select-reaction {
 | |
|     &.dropdown .menu {
 | |
|       right: 0 !important;
 | |
|       left: auto !important;
 | |
|       min-width: 15em;
 | |
| 
 | |
|       > .header {
 | |
|         margin: .75rem 0 .5rem;
 | |
|       }
 | |
| 
 | |
|       > .item {
 | |
|         float: left;
 | |
|         padding: .25rem !important;
 | |
|         margin: .25rem;
 | |
|         font-size: 1.5em;
 | |
|         width: 39px;
 | |
|         left: 13px;
 | |
|         border-radius: 6px;
 | |
|         display: flex;
 | |
|         justify-content: center;
 | |
|         align-items: center;
 | |
| 
 | |
|         img.emoji {
 | |
|           margin-right: 0;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       > .item:hover {
 | |
|         background: var(--color-primary);
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .segment.reactions {
 | |
|     padding: 0;
 | |
|     display: flex;
 | |
|     border: none !important;
 | |
|     border-top: 1px solid var(--color-secondary) !important;
 | |
|     width: 100% !important;
 | |
|     max-width: 100% !important;
 | |
|     margin: 0 !important;
 | |
| 
 | |
|     .ui.label {
 | |
|       max-height: 40px;
 | |
|       padding: 10px 18px !important;
 | |
|       display: flex !important;
 | |
|       align-items: center;
 | |
|       border: 0;
 | |
|       border-right: 1px solid;
 | |
|       border-radius: 0;
 | |
|       margin: 0;
 | |
|       font-size: 14px;
 | |
|       font-weight: normal;
 | |
|       border-color: var(--color-secondary) !important;
 | |
|       background: var(--color-reaction-bg);
 | |
| 
 | |
|       &.disabled {
 | |
|         cursor: default;
 | |
|         opacity: 1;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .ui.label.basic {
 | |
|       color: var(--color-primary) !important;
 | |
|     }
 | |
| 
 | |
|     .ui.label.basic.primary {
 | |
|       background-color: var(--color-reaction-active-bg) !important;
 | |
|       border-color: var(--color-secondary) !important;
 | |
|     }
 | |
| 
 | |
|     .reaction-count {
 | |
|       margin-left: .5rem;
 | |
|     }
 | |
| 
 | |
|     .select-reaction {
 | |
|       display: flex;
 | |
|       align-items: center;
 | |
|       padding: 0 14px;
 | |
| 
 | |
|       &:not(.active) a {
 | |
|         display: none;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &:hover .select-reaction a {
 | |
|       display: block;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .ui.fluid.action.input {
 | |
|     .ui.search.action.input {
 | |
|       flex: auto;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .repository-summary {
 | |
|     box-shadow: none !important;
 | |
| 
 | |
|     .segment.language-stats-details,
 | |
|     .segment.repository-summary {
 | |
|       border-top: none;
 | |
|       background: none;
 | |
|     }
 | |
| 
 | |
|     .segment.language-stats-details .item {
 | |
|       white-space: nowrap;
 | |
|     }
 | |
| 
 | |
|     .segment.language-stats {
 | |
|       &:extend(.unselectable);
 | |
|       padding: 0;
 | |
|       height: 11px;
 | |
|       display: flex;
 | |
|       white-space: nowrap;
 | |
|       width: 100%;
 | |
|       border-radius: 0;
 | |
| 
 | |
|       @media @mediaSm {
 | |
|         display: none;
 | |
|       }
 | |
| 
 | |
|       .bar {
 | |
|         white-space: nowrap;
 | |
|         border: 0;
 | |
|         padding: 0;
 | |
|         margin: 0;
 | |
|         height: 100%;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .repository-menu {
 | |
|     padding: 0 !important;
 | |
|   }
 | |
| 
 | |
|   .repository-menu .item {
 | |
|     padding-top: 9px !important;
 | |
|     padding-bottom: 9px !important;
 | |
|   }
 | |
| }
 | |
| 
 | |
| // End of .repository
 | |
| 
 | |
| #cite-repo-modal {
 | |
|   #citation-panel {
 | |
|     width: 500px;
 | |
| 
 | |
|     @media @mediaSm {
 | |
|       width: 100%;
 | |
|     }
 | |
| 
 | |
|     input {
 | |
|       border-radius: 0;
 | |
|       padding: 5px 10px;
 | |
|       width: 50%;
 | |
|       line-height: 1.4;
 | |
|     }
 | |
| 
 | |
|     .citation.button {
 | |
|       font-size: 13px;
 | |
|       padding: 7.5px 5px;
 | |
|     }
 | |
| 
 | |
|     #citation-copy-content {
 | |
|       border-radius: 0;
 | |
|       padding: 5px 10px;
 | |
|       font-size: 1.2em;
 | |
|       line-height: 1.4;
 | |
|     }
 | |
| 
 | |
|     #citation-copy-apa,
 | |
|     #citation-copy-bibtex {
 | |
|       border-right: none;
 | |
|     }
 | |
| 
 | |
|     #goto-citation-btn {
 | |
|       border-left: none;
 | |
|     }
 | |
| 
 | |
|     >:first-child {
 | |
|       border-radius: var(--border-radius) 0 0 var(--border-radius) !important;
 | |
|     }
 | |
| 
 | |
|     >:last-child {
 | |
|       border-radius: 0 var(--border-radius) var(--border-radius) 0 !important;
 | |
|     }
 | |
| 
 | |
|     .icon.button {
 | |
|       padding: 0 10px;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| &.user-cards {
 | |
|   .list {
 | |
|     padding: 0;
 | |
|     display: flex;
 | |
|     flex-wrap: wrap;
 | |
| 
 | |
|     .item {
 | |
|       list-style: none;
 | |
|       width: 32%;
 | |
|       margin: 10px 10px 10px 0;
 | |
|       padding-bottom: 14px;
 | |
|       float: left;
 | |
| 
 | |
|       .avatar {
 | |
|         width: 48px;
 | |
|         height: 48px;
 | |
|         float: left;
 | |
|         display: block;
 | |
|         margin-right: 10px;
 | |
|       }
 | |
| 
 | |
|       .name {
 | |
|         margin-top: 0;
 | |
|         margin-bottom: 0;
 | |
|         font-weight: normal;
 | |
|       }
 | |
| 
 | |
|       .meta {
 | |
|         margin-top: 5px;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| #search-repo-box,
 | |
| #search-user-box {
 | |
|   .results {
 | |
|     .result {
 | |
|       img {
 | |
|         float: left;
 | |
|         margin-right: 8px;
 | |
|         width: 2em;
 | |
|         height: 2em;
 | |
|       }
 | |
| 
 | |
|       .content {
 | |
|         margin: 6px 0;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| #search-team-box {
 | |
|   .results {
 | |
|     .result {
 | |
|       .content {
 | |
|         margin: 6px 0;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| #issue-filters.hide {
 | |
|   display: none;
 | |
| }
 | |
| 
 | |
| #issue-actions {
 | |
|   margin-top: -1rem !important; // counteract padding from Semantic
 | |
| }
 | |
| 
 | |
| #issue-actions.hide {
 | |
|   display: none;
 | |
| }
 | |
| 
 | |
| .ui.menu .item > img:not(.ui) {
 | |
|   width: auto;
 | |
| }
 | |
| 
 | |
| .page.buttons {
 | |
|   padding-top: 15px;
 | |
| }
 | |
| 
 | |
| .commit-header-row {
 | |
|   min-height: 50px !important;
 | |
|   padding-top: 0 !important;
 | |
|   padding-bottom: 0 !important;
 | |
| }
 | |
| 
 | |
| .settings {
 | |
|   .content {
 | |
|     > .header,
 | |
|     .segment {
 | |
|       box-shadow: 0 1px 2px 0 var(--color-box-header);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.webhooks .list > .item:not(:first-child),
 | |
|   &.githooks .list > .item:not(:first-child),
 | |
|   &.runners .list > .item:not(:first-child) {
 | |
|     padding: .25rem 1rem;
 | |
|     margin: 12px -1rem -1rem;
 | |
|   }
 | |
| 
 | |
|   .list {
 | |
|     > .item {
 | |
|       &:not(:first-child) {
 | |
|         border-top: 1px solid var(--color-secondary);
 | |
|         padding: 1rem;
 | |
|         margin: 16px -1rem -1rem;
 | |
|       }
 | |
| 
 | |
|       > .svg {
 | |
|         display: table-cell;
 | |
|       }
 | |
| 
 | |
|       > .svg + .content {
 | |
|         display: table-cell;
 | |
|         padding: 0 0 0 .5em;
 | |
|         vertical-align: top;
 | |
|       }
 | |
| 
 | |
|       .info {
 | |
|         margin-top: 10px;
 | |
| 
 | |
|         .tab.segment {
 | |
|           border: 0;
 | |
|           padding: 10px 0 0;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.key {
 | |
|       .meta {
 | |
|         padding-top: 5px;
 | |
|         color: var(--color-text-light-2);
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.email {
 | |
|       > .item:not(:first-child) {
 | |
|         min-height: 60px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     &.collaborator {
 | |
|       > .item {
 | |
|         padding: 0;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .ui.vertical.menu {
 | |
|   .header.item {
 | |
|     font-size: 1.1em;
 | |
|     background: var(--color-box-header);
 | |
|   }
 | |
| }
 | |
| 
 | |
| .comment:target .comment-container {
 | |
|   border-color: var(--color-primary) !important;
 | |
|   box-shadow: 0 0 0 3px var(--color-primary-alpha-30) !important;
 | |
| }
 | |
| 
 | |
| .comment:target .header::before {
 | |
|   border-right-color: var(--color-primary) !important;
 | |
|   filter: drop-shadow(-3px 0 0 var(--color-primary-alpha-30)) !important;
 | |
| }
 | |
| 
 | |
| .code-comment:target {
 | |
|   border-color: var(--color-primary) !important;
 | |
|   border-radius: var(--border-radius) !important;
 | |
|   box-shadow: 0 0 0 3px var(--color-primary-alpha-30) !important;
 | |
| }
 | |
| 
 | |
| .code-comment:target .content {
 | |
|   box-shadow: none !important;
 | |
| }
 | |
| 
 | |
| .comment-header {
 | |
|   #avatar-arrow();
 | |
|   border: none !important;
 | |
|   background: var(--color-box-header);
 | |
|   border-bottom: 1px solid var(--color-secondary) !important;
 | |
|   font-weight: normal !important;
 | |
|   padding: .5rem 1rem;
 | |
|   margin: 0 !important;
 | |
|   position: relative;
 | |
|   color: var(--color-text-light-2);
 | |
|   min-height: 41px;
 | |
|   background-color: var(--color-box-header);
 | |
|   display: flex;
 | |
|   justify-content: space-between;
 | |
|   align-items: center;
 | |
| 
 | |
|   &.arrow-top::before,
 | |
|   &.arrow-top::after {
 | |
|     transform: rotate(90deg);
 | |
|   }
 | |
| 
 | |
|   &.arrow-top::before {
 | |
|     top: -9px;
 | |
|     left: 6px;
 | |
|   }
 | |
| 
 | |
|   &.arrow-top::after {
 | |
|     top: -8px;
 | |
|     left: 7px;
 | |
|   }
 | |
| 
 | |
|   a {
 | |
|     color: var(--color-text);
 | |
|   }
 | |
| 
 | |
|   a:hover {
 | |
|     color: var(--color-primary);
 | |
|   }
 | |
| }
 | |
| 
 | |
| .comment-header .actions a {
 | |
|   margin-right: 0 !important;
 | |
|   padding: .5rem !important;
 | |
| }
 | |
| 
 | |
| .comment-header-left > * + *,
 | |
| .comment-header-right > * + * {
 | |
|   margin-left: .25rem;
 | |
| }
 | |
| 
 | |
| .comment-body {
 | |
|   background: var(--color-box-body);
 | |
|   border: none !important;
 | |
|   width: 100% !important;
 | |
|   max-width: 100% !important;
 | |
|   margin: 0 !important;
 | |
| }
 | |
| 
 | |
| .edit-label.modal,
 | |
| .new-label.segment {
 | |
|   .form {
 | |
|     .column {
 | |
|       padding-right: 0;
 | |
|     }
 | |
| 
 | |
|     .buttons {
 | |
|       margin-left: auto;
 | |
|       padding-top: 15px;
 | |
|     }
 | |
| 
 | |
|     .color.picker.column {
 | |
|       width: auto;
 | |
| 
 | |
|       .color-picker {
 | |
|         height: 35px;
 | |
|         width: auto;
 | |
|         padding-left: 30px;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .minicolors-swatch.minicolors-sprite {
 | |
|       top: 10px;
 | |
|       left: 10px;
 | |
|       width: 15px;
 | |
|       height: 15px;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| #avatar-arrow {
 | |
|   &::before,
 | |
|   &::after {
 | |
|     right: 100%;
 | |
|     top: 20px;
 | |
|     border: solid transparent;
 | |
|     content: " ";
 | |
|     height: 0;
 | |
|     width: 0;
 | |
|     position: absolute;
 | |
|     pointer-events: none;
 | |
|   }
 | |
| 
 | |
|   &::before {
 | |
|     border-right-color: var(--color-secondary);
 | |
|     border-width: 9px;
 | |
|     margin-top: -9px;
 | |
|   }
 | |
| 
 | |
|   &::after {
 | |
|     border-right-color: var(--color-box-header);
 | |
|     border-width: 8px;
 | |
|     margin-top: -8px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| #transfer-repo-modal,
 | |
| #delete-repo-modal,
 | |
| #delete-wiki-modal,
 | |
| #convert-fork-repo-modal,
 | |
| #convert-mirror-repo-modal,
 | |
| #fork-repo-modal {
 | |
|   .ui.message {
 | |
|     width: 100% !important;
 | |
|   }
 | |
| }
 | |
| 
 | |
| // generate .tab-size-{i} from 1 to 16
 | |
| .generate-tab-size(16);
 | |
| 
 | |
| .generate-tab-size(@n, @i: 1) when (@i =< @n) {
 | |
|   .tab-size-@{i} {
 | |
|     tab-size: @i !important;
 | |
|     -moz-tab-size: @i !important;
 | |
|   }
 | |
| 
 | |
|   .generate-tab-size(@n, (@i + 1));
 | |
| }
 | |
| 
 | |
| .stats-table {
 | |
|   display: table;
 | |
|   width: 100%;
 | |
| 
 | |
|   .table-cell {
 | |
|     display: table-cell;
 | |
| 
 | |
|     &.tiny {
 | |
|       height: .5em;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .labels-list .label {
 | |
|   margin: 2px 0;
 | |
|   display: inline-block !important;
 | |
|   line-height: 1.3em; // there is a `font-size: 1.25em` for inside emoji, so here the line-height needs to be larger slightly
 | |
| }
 | |
| 
 | |
| .repo-button-row {
 | |
|   margin-bottom: 10px;
 | |
| }
 | |
| 
 | |
| .repo-button-row > * {
 | |
|   margin-top: 10px;
 | |
| }
 | |
| 
 | |
| .repo-button-row .dropdown > .dropdown.icon {
 | |
|   margin-left: .25rem !important;
 | |
|   margin-right: 0 !important;
 | |
| }
 | |
| 
 | |
| .wiki .repo-button-row {
 | |
|   margin-bottom: 0;
 | |
| }
 | |
| 
 | |
| .wiki .repo-button-row > * {
 | |
|   margin-top: 0;
 | |
| }
 | |
| 
 | |
| .repo-button-row .button {
 | |
|   padding: 6px 10px !important;
 | |
|   height: 30px;
 | |
| }
 | |
| 
 | |
| .repo-button-row input {
 | |
|   height: 30px;
 | |
| }
 | |
| 
 | |
| tbody.commit-list {
 | |
|   vertical-align: baseline;
 | |
| }
 | |
| 
 | |
| .message-wrapper {
 | |
|   overflow: hidden;
 | |
|   text-overflow: ellipsis;
 | |
|   max-width: calc(100% - 50px);
 | |
|   display: inline-block;
 | |
|   vertical-align: middle;
 | |
| }
 | |
| 
 | |
| // in the commit list, messages can wrap so we can use inline
 | |
| .commit-list .message-wrapper {
 | |
|   display: inline;
 | |
| }
 | |
| 
 | |
| // but in the repo-files-table we cannot
 | |
| #repo-files-table .commit-list .message-wrapper {
 | |
|   display: inline-block;
 | |
| }
 | |
| 
 | |
| @media @mediaSm {
 | |
|   tr.commit-list {
 | |
|     width: 100%;
 | |
|   }
 | |
| 
 | |
|   th .message-wrapper {
 | |
|     display: block;
 | |
|     max-width: calc(100vw - 70px);
 | |
|   }
 | |
| }
 | |
| 
 | |
| @media @mediaMd {
 | |
|   tr.commit-list {
 | |
|     width: 723px;
 | |
|   }
 | |
| 
 | |
|   th .message-wrapper {
 | |
|     max-width: 280px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| @media @mediaLg {
 | |
|   tr.commit-list {
 | |
|     width: 933px;
 | |
|   }
 | |
| 
 | |
|   th .message-wrapper {
 | |
|     max-width: 490px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| @media @mediaXl {
 | |
|   tr.commit-list {
 | |
|     width: 1127px;
 | |
|   }
 | |
| 
 | |
|   th .message-wrapper {
 | |
|     max-width: 680px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .commit-list .commit-status-link {
 | |
|   display: inline-block;
 | |
|   vertical-align: middle;
 | |
| }
 | |
| 
 | |
| .commit-body {
 | |
|   white-space: pre-wrap;
 | |
|   line-height: initial;
 | |
| }
 | |
| 
 | |
| .repository:not(.diff) {
 | |
|   .commit-body { // commit history list
 | |
|     margin: 0;
 | |
|   }
 | |
| 
 | |
|   .timeline-item .commit-body { // PR-comment
 | |
|     margin-left: 40px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .git-notes.top {
 | |
|   text-align: left;
 | |
| }
 | |
| 
 | |
| .comment-diff-data {
 | |
|   background: var(--color-code-bg);
 | |
|   max-height: calc(100vh - 10.5rem);
 | |
|   overflow-y: auto;
 | |
| }
 | |
| 
 | |
| .comment-diff-data pre {
 | |
|   line-height: 18px;
 | |
|   white-space: pre-wrap;
 | |
|   word-break: break-all;
 | |
|   overflow-wrap: break-word;
 | |
| }
 | |
| 
 | |
| .content-history-detail-dialog .header .avatar {
 | |
|   position: relative;
 | |
|   top: -2px;
 | |
| }
 | |
| 
 | |
| #topic_edit {
 | |
|   margin-top: 5px;
 | |
| }
 | |
| 
 | |
| #repo-topics {
 | |
|   margin-top: 5px;
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   flex-wrap: wrap;
 | |
| }
 | |
| 
 | |
| .repo-topic {
 | |
|   font-weight: normal !important;
 | |
|   cursor: pointer;
 | |
|   margin: 2px !important;
 | |
| }
 | |
| 
 | |
| #new-dependency-drop-list {
 | |
|   &.ui.selection.dropdown {
 | |
|     min-width: 0;
 | |
|     width: 100%;
 | |
|     border-radius: 4px 0 0 4px;
 | |
|     border-right: 0;
 | |
|     white-space: nowrap;
 | |
|   }
 | |
| 
 | |
|   .text {
 | |
|     width: 100%;
 | |
|     overflow: hidden;
 | |
|   }
 | |
| }
 | |
| 
 | |
| #manage_topic {
 | |
|   font-size: 12px;
 | |
| }
 | |
| 
 | |
| .label + #manage_topic {
 | |
|   margin-left: 5px;
 | |
| }
 | |
| 
 | |
| .ui.small.label.topic {
 | |
|   margin-bottom: 4px;
 | |
| }
 | |
| 
 | |
| .repo-header {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   justify-content: space-between;
 | |
|   flex-wrap: wrap;
 | |
|   word-break: break-word;
 | |
| 
 | |
|   @media @mediaSm {
 | |
|     + .container {
 | |
|       margin-top: 7px;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .repo-buttons {
 | |
|   align-items: center;
 | |
|   display: flex;
 | |
|   flex-direction: row;
 | |
|   flex-wrap: wrap;
 | |
|   word-break: keep-all;
 | |
| 
 | |
|   @media @mediaSm {
 | |
|     margin-top: 1em;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .repo-buttons .ui.labeled.button > .label:hover {
 | |
|   color: var(--color-primary-light-2);
 | |
|   background: var(--color-light);
 | |
| }
 | |
| 
 | |
| .label-mimic-enabled() {
 | |
|   color: var(--color-text-dark);
 | |
|   background: var(--color-light-mimic-enabled) !important;
 | |
| 
 | |
|   &:hover {
 | |
|     color: var(--color-primary-dark-1);
 | |
|   }
 | |
| }
 | |
| 
 | |
| .repo-buttons button[disabled] ~ .label {
 | |
|   opacity: var(--opacity-disabled);
 | |
|   .label-mimic-enabled();
 | |
| }
 | |
| 
 | |
| .repo-buttons .ui.labeled.button {
 | |
|   cursor: initial;
 | |
| 
 | |
|   > .label {
 | |
|     border-left: 0 !important;
 | |
|     margin: 0 !important;
 | |
|   }
 | |
| 
 | |
|   &.disabled {
 | |
|     pointer-events: inherit !important;
 | |
| 
 | |
|     > .label {
 | |
|       .label-mimic-enabled();
 | |
|     }
 | |
| 
 | |
|     > .button {
 | |
|       pointer-events: none !important;
 | |
|     }
 | |
|   }
 | |
|   @media @mediaSm {
 | |
|     .svg {
 | |
|       display: none;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .tag-code {
 | |
|   height: 28px;
 | |
| }
 | |
| 
 | |
| .tag-code,
 | |
| .tag-code td,
 | |
| .tag-code .blob-excerpt {
 | |
|   background-color: var(--color-box-body-highlight);
 | |
|   vertical-align: middle;
 | |
| }
 | |
| 
 | |
| .resolved-placeholder {
 | |
|   font-weight: normal !important;
 | |
|   border: 1px solid var(--color-secondary) !important;
 | |
|   border-radius: var(--border-radius) !important;
 | |
|   margin: 4px !important;
 | |
| }
 | |
| 
 | |
| .resolved-placeholder + .comment-code-cloud {
 | |
|   padding-top: 0 !important;
 | |
| }
 | |
| 
 | |
| td.blob-excerpt {
 | |
|   background-color: var(--color-secondary-alpha-30);
 | |
| }
 | |
| 
 | |
| .issue-keyword {
 | |
|   border-bottom: 1px dotted var(--color-text-light-3) !important;
 | |
| }
 | |
| 
 | |
| .issue-keyword:hover {
 | |
|   border-bottom: none !important;
 | |
| }
 | |
| 
 | |
| .file-header {
 | |
|   align-items: center;
 | |
|   display: flex;
 | |
|   justify-content: space-between;
 | |
|   overflow-x: auto;
 | |
|   padding: 6px 12px !important;
 | |
|   font-size: 13px !important;
 | |
| }
 | |
| 
 | |
| .file-info {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
| }
 | |
| 
 | |
| .file-info-entry {
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
|   width: max-content;
 | |
| }
 | |
| 
 | |
| .file-info-entry + .file-info-entry {
 | |
|   border-left: 1px solid currentcolor;
 | |
|   margin-left: 8px;
 | |
|   padding-left: 8px;
 | |
| }
 | |
| 
 | |
| #diff-container {
 | |
|   display: flex;
 | |
| }
 | |
| #diff-file-boxes {
 | |
|   flex: 1;
 | |
| }
 | |
| 
 | |
| #diff-file-tree {
 | |
|   width: 20%;
 | |
|   max-width: 380px;
 | |
|   line-height: inherit;
 | |
|   position: sticky;
 | |
|   padding-top: 0;
 | |
|   top: 47px;
 | |
|   max-height: calc(100vh - 50px);
 | |
|   height: 100%;
 | |
|   overflow-y: auto;
 | |
| }
 | |
| 
 | |
| @media @mediaMdAndDown {
 | |
|   #diff-file-tree {
 | |
|     display: none !important;
 | |
|   }
 | |
| 
 | |
|   .diff-toggle-file-tree-button {
 | |
|     display: none !important;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .ui.message.unicode-escape-prompt {
 | |
|   margin-bottom: 0;
 | |
|   border-radius: 0;
 | |
|   display: flex;
 | |
|   flex-direction: column;
 | |
| }
 | |
| 
 | |
| .wiki-content-sidebar .ui.message.unicode-escape-prompt,
 | |
| .wiki-content-footer .ui.message.unicode-escape-prompt {
 | |
|   p {
 | |
|     display: none;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .wiki-content-toc {
 | |
|   > ul > li {
 | |
|     margin-bottom: 4px;
 | |
|   }
 | |
| 
 | |
|   ul {
 | |
|     margin: 0;
 | |
|     list-style: none;
 | |
|     padding-left: 1em;
 | |
|   }
 | |
| }
 | |
| 
 | |
| /* fomantic's last-child selector does not work with hidden last child */
 | |
| .ui.buttons .unescape-button {
 | |
|   border-top-right-radius: .28571429rem;
 | |
|   border-bottom-right-radius: .28571429rem;
 | |
| }
 | |
| 
 | |
| .webhook-info {
 | |
|   padding: 7px 12px;
 | |
|   margin: 10px 0;
 | |
|   background-color: var(--color-markup-code-block);
 | |
|   border: 1px solid var(--color-secondary);
 | |
|   border-radius: 3px;
 | |
|   font-size: 13px;
 | |
|   line-height: 1.5;
 | |
|   overflow: auto;
 | |
| }
 | |
| 
 | |
| .title_wip_desc {
 | |
|   margin-top: 1em;
 | |
| }
 | |
| 
 | |
| .sidebar-item-link {
 | |
|   display: inline-flex;
 | |
|   align-items: center;
 | |
| }
 | |
| 
 | |
| .diff-file-box[data-folded="true"] .diff-file-body {
 | |
|   display: none;
 | |
| }
 | |
| 
 | |
| .diff-file-box[data-folded="true"] .diff-file-header {
 | |
|   border-radius: var(--border-radius) !important;
 | |
| }
 | |
| 
 | |
| .diff-file-header-actions > * + * {
 | |
|   margin-left: .5rem !important;
 | |
| }
 | |
| 
 | |
| .ui.attached.header.diff-file-header {
 | |
|   &.sticky-2nd-row {
 | |
|     position: sticky;
 | |
|     top: 46px;
 | |
|     z-index: 7;
 | |
| 
 | |
|     @media @mediaMd {
 | |
|       top: 77px;
 | |
|     }
 | |
| 
 | |
|     @media @mediaSm {
 | |
|       top: 77px;
 | |
|     }
 | |
| 
 | |
|     @media (max-width: 480px) {
 | |
|       position: static;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .diff-stats-bar {
 | |
|   display: inline-block;
 | |
|   background-color: var(--color-red);
 | |
|   height: 12px;
 | |
|   width: 40px;
 | |
| 
 | |
|   .diff-stats-add-bar {
 | |
|     background-color: var(--color-green);
 | |
|     height: 100%;
 | |
|   }
 | |
| }
 | |
| 
 | |
| /* prevent page shaking on language bar click */
 | |
| .repository-summary-language-stats {
 | |
|   height: 48px;
 | |
|   overflow: hidden;
 | |
| 
 | |
|   @media @mediaSm {
 | |
|     height: auto;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .ui.form .right .ui.button {
 | |
|   margin-left: .25em;
 | |
|   margin-right: 0;
 | |
| }
 | |
| 
 | |
| .removed-code {
 | |
|   background: var(--color-diff-removed-word-bg);
 | |
| }
 | |
| 
 | |
| .added-code {
 | |
|   background: var(--color-diff-added-word-bg);
 | |
| }
 | |
| 
 | |
| .code-diff-unified .del-code,
 | |
| .code-diff-unified .del-code td,
 | |
| .code-diff-split .del-code .lines-num-old,
 | |
| .code-diff-split .del-code .lines-escape-old,
 | |
| .code-diff-split .del-code .lines-type-marker-old,
 | |
| .code-diff-split .del-code .lines-code-old {
 | |
|   background: var(--color-diff-removed-row-bg);
 | |
|   border-color: var(--color-diff-removed-row-border);
 | |
| }
 | |
| 
 | |
| .code-diff-unified .add-code,
 | |
| .code-diff-unified .add-code td,
 | |
| .code-diff-split .add-code .lines-num-new,
 | |
| .code-diff-split .add-code .lines-type-marker-new,
 | |
| .code-diff-split .add-code .lines-escape-new,
 | |
| .code-diff-split .add-code .lines-code-new,
 | |
| .code-diff-split .del-code .add-code.lines-num-new,
 | |
| .code-diff-split .del-code .add-code.lines-type-marker-new,
 | |
| .code-diff-split .del-code .add-code.lines-escape-new,
 | |
| .code-diff-split .del-code .add-code.lines-code-new {
 | |
|   background: var(--color-diff-added-row-bg);
 | |
|   border-color: var(--color-diff-added-row-border);
 | |
| }
 | |
| 
 | |
| .code-diff-split .del-code .lines-num-new,
 | |
| .code-diff-split .del-code .lines-type-marker-new,
 | |
| .code-diff-split .del-code .lines-code-new,
 | |
| .code-diff-split .del-code .lines-escape-new,
 | |
| .code-diff-split .add-code .lines-num-old,
 | |
| .code-diff-split .add-code .lines-escape-old,
 | |
| .code-diff-split .add-code .lines-type-marker-old,
 | |
| .code-diff-split .add-code .lines-code-old {
 | |
|   background: var(--color-diff-inactive);
 | |
| }
 | |
| 
 | |
| .code-diff-split tbody tr td:nth-child(5),
 | |
| .code-diff-split tbody tr td.add-comment-right {
 | |
|   border-left: 1px solid var(--color-secondary);
 | |
| }
 | |
| 
 | |
| .repository .ui.menu.new-menu {
 | |
|   background: none !important;
 | |
| 
 | |
|   @media @mediaLgAndDown {
 | |
|     &::after {
 | |
|       background: none !important;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .repository.migrate .card {
 | |
|   transition: all .1s ease-in-out;
 | |
|   box-shadow: none !important;
 | |
|   border: 1px solid var(--color-secondary);
 | |
|   color: var(--color-text);
 | |
| }
 | |
| 
 | |
| .repository.migrate .card:hover {
 | |
|   transform: scale(105%);
 | |
|   box-shadow: 0 .5rem 1rem var(--color-shadow) !important;
 | |
| }
 | |
| 
 | |
| @media @mediaSm {
 | |
|   .repository.file.list {
 | |
|     #repo-files-table {
 | |
|       .entry,
 | |
|       .commit-list {
 | |
|         align-items: center;
 | |
|         display: flex !important;
 | |
|         padding-top: 4px;
 | |
|         padding-bottom: 4px;
 | |
| 
 | |
|         td.age,
 | |
|         th.age {
 | |
|           margin-left: auto;
 | |
|         }
 | |
| 
 | |
|         td.message,
 | |
|         span.commit-summary {
 | |
|           display: none !important;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
|   .issue-list-headers.ui[class].grid {
 | |
|     > div:nth-child(1) {
 | |
|       order: 1;
 | |
|       width: 50%;
 | |
|     }
 | |
| 
 | |
|     > div:nth-child(2) {
 | |
|       order: 3;
 | |
|       width: 100%;
 | |
|     }
 | |
| 
 | |
|     > div.column:not(.row):nth-child(3) {
 | |
|       order: 2;
 | |
|       width: 50%;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .repository.view.issue .comment-list {
 | |
|     .timeline,
 | |
|     .timeline-item {
 | |
|       margin-left: 0;
 | |
|     }
 | |
| 
 | |
|     .timeline {
 | |
|       &::before {
 | |
|         left: 14px;
 | |
|       }
 | |
| 
 | |
|       .inline-timeline-avatar {
 | |
|         display: flex;
 | |
|         margin-bottom: auto;
 | |
| 
 | |
|         img.avatar {
 | |
|           height: 24px;
 | |
|           width: 24px;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .comment-header {
 | |
|         &::before,
 | |
|         &::after {
 | |
|           content: unset;
 | |
|         }
 | |
| 
 | |
|         padding-left: 4px;
 | |
|       }
 | |
| 
 | |
|       /* Don't show the general avatar, we show the inline avatar on mobile.
 | |
|        * And don't show the role labels, there's no place for that. */
 | |
|       .timeline-avatar,
 | |
|       .comment-header-right .role-label {
 | |
|         display: none;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
|   .commit-header-row {
 | |
|     .ui.horizontal.list {
 | |
|       width: 100%;
 | |
|       overflow-x: auto;
 | |
|       margin-top: 2px;
 | |
| 
 | |
|       .item {
 | |
|         align-items: center;
 | |
|         display: flex;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     .author {
 | |
|       padding: 3px 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .commit-header h3 {
 | |
|     flex-basis: auto !important;
 | |
|     margin-bottom: .5rem !important;
 | |
|   }
 | |
| 
 | |
|   .commits-table {
 | |
|     flex-direction: column;
 | |
| 
 | |
|     .commits-table-left {
 | |
|       align-items: initial !important;
 | |
|       margin-bottom: 6px;
 | |
|     }
 | |
| 
 | |
|     .commits-table-right form {
 | |
|       display: flex;
 | |
|       flex-wrap: wrap;
 | |
| 
 | |
|       > div:nth-child(1) {
 | |
|         order: 1;
 | |
|       }
 | |
| 
 | |
|       > div:nth-child(2) {
 | |
|         order: 3;
 | |
|         margin-left: .5rem;
 | |
|         margin-top: .5rem;
 | |
|       }
 | |
| 
 | |
|       > button:nth-child(3) {
 | |
|         order: 2;
 | |
|         margin-left: .25rem;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .commit-table {
 | |
|     overflow-x: auto;
 | |
| 
 | |
|     td.sha,
 | |
|     th.sha {
 | |
|       display: none !important;
 | |
|     }
 | |
| 
 | |
|     .commit-list {
 | |
|       span.message-wrapper {
 | |
|         max-width: none;
 | |
|       }
 | |
| 
 | |
|       tr td:last-child {
 | |
|         display: block;
 | |
|         width: max-content;
 | |
|       }
 | |
| 
 | |
|       td.author {
 | |
|         display: block;
 | |
|         width: calc(100% + .5rem);
 | |
|       }
 | |
| 
 | |
|       .copy-commit-sha {
 | |
|         display: none !important;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .comment-header {
 | |
|     flex-wrap: wrap;
 | |
| 
 | |
|     .comment-header-left {
 | |
|       flex-wrap: wrap;
 | |
|     }
 | |
| 
 | |
|     .comment-header-right {
 | |
|       margin-left: auto;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .branch-dropdown-button {
 | |
|   max-width: 340px;
 | |
|   vertical-align: bottom !important;
 | |
| 
 | |
|   @media @mediaMd {
 | |
|     max-width: 185px;
 | |
|   }
 | |
|   @media @mediaSm {
 | |
|     max-width: 165px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .pr-status {
 | |
|   padding: 0 !important; // To clear fomantic's padding on .ui.segment elements
 | |
|   display: flex;
 | |
|   align-items: center;
 | |
| 
 | |
|   .commit-status {
 | |
|     margin: 1em;
 | |
|     flex-shrink: 0;
 | |
|   }
 | |
| 
 | |
|   .status-context {
 | |
|     display: flex;
 | |
|     justify-content: space-between;
 | |
|     width: 100%;
 | |
| 
 | |
|     > span {
 | |
|       padding: 1em 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   .status-details {
 | |
|     display: flex;
 | |
|     padding-right: .5em;
 | |
|     align-items: center;
 | |
|     justify-content: flex-end;
 | |
| 
 | |
|     @media @mediaSm {
 | |
|       flex-direction: column;
 | |
|       align-items: flex-end;
 | |
|       justify-content: center;
 | |
|     }
 | |
| 
 | |
|     > span {
 | |
|       padding-right: .5em; // To match the alignment with the "required" label
 | |
|     }
 | |
|   }
 | |
| }
 |