mirror of
https://github.com/tdurieux/anonymous_github.git
synced 2026-02-13 19:02:45 +00:00
418 lines
16 KiB
HTML
418 lines
16 KiB
HTML
<div class="container page">
|
|
<div class="row">
|
|
<div class="border-bottom color-border-secondary py-3 w-100">
|
|
<div class="d-flex flex-items-start w-100">
|
|
<form class="w-100" aria-label="Repositories" accept-charset="UTF-8">
|
|
<div class="d-flex flex-column flex-lg-row flex-auto">
|
|
<div class="mb-1 mb-md-0 mr-md-3">
|
|
<input
|
|
type="search"
|
|
id="search"
|
|
class="form-control"
|
|
aria-label="Find a repository…"
|
|
placeholder="Find a repository…"
|
|
autocomplete="off"
|
|
ng-model="search"
|
|
/>
|
|
</div>
|
|
|
|
<div class="d-flex flex-wrap">
|
|
<div class="dropdown mt-1 mt-lg-0 mr-1">
|
|
<button
|
|
class="btn btn-secondary dropdown-toggle"
|
|
type="button"
|
|
id="dropdownSort"
|
|
data-toggle="dropdown"
|
|
aria-haspopup="true"
|
|
aria-expanded="false"
|
|
>
|
|
Sort
|
|
</button>
|
|
<div class="dropdown-menu" aria-labelledby="dropdownSort">
|
|
<h6 class="dropdown-header">Select order</h6>
|
|
<div class="form-check dropdown-item">
|
|
<input
|
|
class="form-check-input"
|
|
type="radio"
|
|
name="sort"
|
|
id="sortFullName"
|
|
value="fullName"
|
|
ng-model="orderBy"
|
|
/>
|
|
<label class="form-check-label" for="sortFullName">
|
|
Repository
|
|
</label>
|
|
</div>
|
|
<div class="form-check dropdown-item">
|
|
<input
|
|
class="form-check-input"
|
|
type="radio"
|
|
name="sort"
|
|
id="sortAnonymizeDate"
|
|
value="-anonymizeDate"
|
|
ng-model="orderBy"
|
|
/>
|
|
<label class="form-check-label" for="sortAnonymizeDate">
|
|
Anonymize Date
|
|
</label>
|
|
</div>
|
|
<div class="form-check dropdown-item">
|
|
<input
|
|
class="form-check-input"
|
|
type="radio"
|
|
name="sort"
|
|
id="sortStatus"
|
|
value="-status"
|
|
ng-model="orderBy"
|
|
/>
|
|
<label class="form-check-label" for="sortStatus">
|
|
Status
|
|
</label>
|
|
</div>
|
|
<div class="form-check dropdown-item">
|
|
<input
|
|
class="form-check-input"
|
|
type="radio"
|
|
name="sort"
|
|
id="sortLastView"
|
|
value="-lastView"
|
|
ng-model="orderBy"
|
|
/>
|
|
<label class="form-check-label" for="sortLastView">
|
|
Last View
|
|
</label>
|
|
</div>
|
|
<div class="form-check dropdown-item">
|
|
<input
|
|
class="form-check-input"
|
|
type="radio"
|
|
name="sort"
|
|
id="sortPageView"
|
|
value="-pageView"
|
|
ng-model="orderBy"
|
|
/>
|
|
<label class="form-check-label" for="sortPageView">
|
|
Page View
|
|
</label>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="dropdown mt-1 mt-lg-0 mr-1">
|
|
<button
|
|
class="btn btn-secondary dropdown-toggle"
|
|
type="button"
|
|
id="dropdownStatus"
|
|
data-toggle="dropdown"
|
|
aria-haspopup="true"
|
|
aria-expanded="false"
|
|
>
|
|
Status
|
|
</button>
|
|
<div class="dropdown-menu" aria-labelledby="dropdownStatus">
|
|
<h6 class="dropdown-header">Select status</h6>
|
|
<div class="form-check dropdown-item">
|
|
<input
|
|
class="form-check-input"
|
|
type="checkbox"
|
|
name="sort"
|
|
id="statusReady"
|
|
value="ready"
|
|
ng-model="filters.status.ready"
|
|
/>
|
|
<label class="form-check-label" for="statusReady">
|
|
Ready
|
|
</label>
|
|
</div>
|
|
<div class="form-check dropdown-item">
|
|
<input
|
|
class="form-check-input"
|
|
type="checkbox"
|
|
name="sort"
|
|
id="statusExpired"
|
|
value="expired"
|
|
ng-model="filters.status.expired"
|
|
/>
|
|
<label class="form-check-label" for="statusExpired">
|
|
Expired
|
|
</label>
|
|
</div>
|
|
<div class="form-check dropdown-item">
|
|
<input
|
|
class="form-check-input"
|
|
type="checkbox"
|
|
name="sort"
|
|
id="statusRemoved"
|
|
value="removed"
|
|
ng-model="filters.status.removed"
|
|
/>
|
|
<label class="form-check-label" for="statusRemoved">
|
|
Removed
|
|
</label>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="mt-1 mr-1" style="margin-top: -0.25rem !important">
|
|
<strong>Repository</strong>
|
|
<div class="progress position-relative" style="min-width: 150px">
|
|
<div
|
|
class="progress-bar"
|
|
ng-class="{'progress-bar-striped progress-bar-animated w-100 bg-dark': !quota, 'bg-success': quota.repository.percent < 25 || quota.repository.total == 0, 'bg-danger': quota.repository.percent > 95 && quota.repository.total > 0, 'bg-warning': quota.repository.percent > 75 && quota.repository.total > 0 }"
|
|
role="progressbar"
|
|
style="width: {{quota.repository.percent}}%;"
|
|
aria-valuenow="{{quota.repository.used}}"
|
|
aria-valuemin="0"
|
|
aria-valuemax="{{quota.repository.total}}"
|
|
></div>
|
|
<span
|
|
class="
|
|
justify-content-center
|
|
d-flex
|
|
position-absolute
|
|
w-100
|
|
"
|
|
ng-show="quota"
|
|
>{{quota.repository.used |
|
|
number}}/{{quota.repository.total}}</span
|
|
>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="mt-1 mr-1" style="margin-top: -0.25rem !important">
|
|
<strong>Storage</strong>
|
|
<div
|
|
class="progress position-relative"
|
|
style="min-width: 150px"
|
|
>
|
|
<div
|
|
class="progress-bar"
|
|
ng-class="{'progress-bar-striped progress-bar-animated w-100 bg-dark': !quota, 'bg-success': quota.storage.percent < 25 || quota.storage.total == 0, 'bg-danger': quota.storage.percent > 95 && quota.storage.total > 0, 'bg-warning': quota.storage.percent > 75 && quota.storage.total > 0 }"
|
|
role="progressbar"
|
|
style="width: {{quota.storage.percent}}%;"
|
|
aria-valuenow="{{quota.storage.used}}"
|
|
aria-valuemin="0"
|
|
aria-valuemax="{{quota.storage.total}}"
|
|
></div>
|
|
<span
|
|
ng-show="quota"
|
|
class="
|
|
justify-content-center
|
|
d-flex
|
|
position-absolute
|
|
w-100
|
|
"
|
|
>{{quota.storage.used |
|
|
humanFileSize}}/{{quota.storage.total| humanFileSize}}</span
|
|
>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="mt-1 mr-1" style="margin-top: -0.25rem !important">
|
|
<strong>File</strong>
|
|
<div class="progress position-relative" style="min-width: 150px">
|
|
<div
|
|
class="progress-bar"
|
|
ng-class="{'progress-bar-striped progress-bar-animated w-100 bg-dark': !quota, 'bg-success': quota.file.percent < 25 || quota.file.total == 0, 'bg-danger': quota.file.percent > 95 && quota.file.total > 0, 'bg-warning': quota.file.percent > 75 && quota.file.total > 0 }"
|
|
role="progressbar"
|
|
style="width: {{quota.file.percent}}%;"
|
|
aria-valuenow="{{quota.file.used}}"
|
|
aria-valuemin="0"
|
|
aria-valuemax="{{quota.file.total}}"
|
|
></div>
|
|
<span
|
|
class="
|
|
justify-content-center
|
|
d-flex
|
|
position-absolute
|
|
w-100
|
|
"
|
|
ng-show="quota"
|
|
>{{quota.file.used | number}}/{{quota.file.total ||
|
|
"∞"}}</span
|
|
>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</form>
|
|
<div class="d-none d-md-flex flex-md-items-center flex-md-justify-end">
|
|
<a href="/anonymize" class="text-center btn btn-primary ml-3">
|
|
<i class="fa fa-plus-circle" aria-hidden="true"></i> Anonymize
|
|
</a>
|
|
<a
|
|
title="Claim the ownership of an existing anonymized repository."
|
|
data-toggle="tooltip"
|
|
data-placement="bottom"
|
|
href="/claim"
|
|
class="text-center btn btn-secondary ml-3"
|
|
>
|
|
Claim
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<ul class="p-0 m-0 w-100">
|
|
<li
|
|
class="col-12 d-flex px-0 py-3 border-bottom color-border-secondary"
|
|
ng-class="{'expired': repo.status == 'expired','removed': repo.status == 'removed','error': repo.status == 'error' }"
|
|
ng-repeat="repo in repositories| filter:repoFiler| orderBy:orderBy as filteredRepositories"
|
|
>
|
|
<div class="w-100">
|
|
<div class="">
|
|
<h3>
|
|
<a ng-href="/r/{{repo.repoId}}" ng-bind="repo.repoId"></a>
|
|
<span
|
|
class="badge"
|
|
ng-class="{'badge-warning': repo.status == 'removed' || repo.status == 'expired' || repo.status == 'removing' || repo.status == 'expiring', 'badge-info': repo.status == 'preparing', 'badge-success': repo.status == 'ready', 'badge-danger': repo.status == 'error'}"
|
|
><span ng-bind="repo.status | title"></span>
|
|
<span
|
|
ng-if="repo.status == 'error'"
|
|
ng-bind="': ' + repo.statusMessage"
|
|
></span
|
|
></span>
|
|
</h3>
|
|
<span class="color-text-secondary mb-1">
|
|
<span class="repository">
|
|
<i class="fab fa-github" aria-hidden="true"></i>
|
|
<a
|
|
href="https://github.com/{{repo.source.fullName}}/"
|
|
class="fullName"
|
|
ng-bind="repo.source.fullName"
|
|
></a>
|
|
</span>
|
|
<span class="branch" ng-if="repo.options.update">
|
|
<i class="fas fa-code-branch" aria-hidden="true"></i>
|
|
<a
|
|
href="https://github.com/{{repo.source.fullName}}/tree/{{repo.source.branch}}"
|
|
class="branch"
|
|
ng-bind="repo.source.branch"
|
|
></a>
|
|
</span>
|
|
<span class="commit" ng-if="!repo.options.update">
|
|
@<a
|
|
href="https://github.com/{{repo.source.fullName}}/tree/{{repo.source.commit}}"
|
|
class="commit"
|
|
ng-bind="repo.source.commit.substring(0, 8)"
|
|
></a>
|
|
</span>
|
|
anonymized {{repo.anonymizeDate | humanTime}}
|
|
</span>
|
|
</div>
|
|
<div class="color-text-secondary mt-2">
|
|
<span class="ml-0 mr-3" ng-if="::repo.conference">
|
|
<i class="fas fa-chalkboard-teacher"></i>
|
|
{{repo.conference}}
|
|
</span>
|
|
<span
|
|
class="ml-0 mr-3"
|
|
class="terms"
|
|
title="Terms: {{::repo.options.terms.join(', ')}}"
|
|
data-toggle="tooltip"
|
|
data-placement="bottom"
|
|
>
|
|
<i class="fas fa-shield-alt"></i>
|
|
{{::repo.options.terms.length | number}}
|
|
</span>
|
|
<span
|
|
class="ml-0 mr-3"
|
|
title="Size: {{::repo.size.storage | humanFileSize}}"
|
|
data-toggle="tooltip"
|
|
data-placement="bottom"
|
|
>
|
|
<i class="fas fa-database"></i> {{::repo.size.storage |
|
|
humanFileSize}}</span
|
|
>
|
|
<span
|
|
class="ml-0 mr-3"
|
|
title="View: {{::repo.pageView | number}}"
|
|
data-toggle="tooltip"
|
|
data-placement="bottom"
|
|
>
|
|
<i class="far fa-eye" aria-hidden="true"></i>
|
|
{{::repo.pageView | number}}
|
|
</span>
|
|
<span
|
|
class="ml-0 mr-3"
|
|
title="Last view: {{::repo.lastView | date}}"
|
|
data-toggle="tooltip"
|
|
data-placement="bottom"
|
|
>
|
|
<i class="far fa-calendar-alt" aria-hidden="true"></i>
|
|
Last view: {{::repo.lastView | humanTime}}</span
|
|
>
|
|
<span
|
|
class="ml-0 mr-3"
|
|
ng-if="repo.options.expirationMode!='never' && repo.status == 'ready'"
|
|
>
|
|
<i class="far fa-clock" aria-hidden="true"></i>
|
|
Expire: {{repo.options.expirationDate | humanTime}}</span
|
|
>
|
|
</div>
|
|
</div>
|
|
<div class="d-flex">
|
|
<div class="dropdown">
|
|
<button
|
|
class="btn black_border dropdown-toggle btn-sm"
|
|
type="button"
|
|
id="dropdownMenuButton"
|
|
data-toggle="dropdown"
|
|
aria-haspopup="true"
|
|
aria-expanded="false"
|
|
>
|
|
Actions
|
|
</button>
|
|
<div class="dropdown-menu" aria-labelledby="dropdownMenuButton">
|
|
<a class="dropdown-item" href="/anonymize/{{repo.repoId}}">
|
|
<i class="far fa-edit" aria-hidden="true"></i> Edit
|
|
</a>
|
|
<a
|
|
class="dropdown-item"
|
|
href="#"
|
|
ng-show="repo.status == 'ready'"
|
|
ng-click="updateRepository(repo)"
|
|
>
|
|
<i class="fas fa-sync"></i> Force update
|
|
</a>
|
|
<a
|
|
class="dropdown-item"
|
|
href="#"
|
|
ng-show="repo.status == 'removed'"
|
|
ng-click="updateRepository(repo)"
|
|
>
|
|
<i class="fas fa-check-circle"></i>
|
|
Enable
|
|
</a>
|
|
<a
|
|
class="dropdown-item"
|
|
href="#"
|
|
ng-show="repo.status != 'removed'"
|
|
ng-click="removeRepository(repo)"
|
|
>
|
|
<i class="fas fa-trash-alt"></i> Remove
|
|
</a>
|
|
<a class="dropdown-item" href="/r/{{repo.repoId}}/">
|
|
<i class="fa fa-eye" aria-hidden="true"></i> View Repo
|
|
</a>
|
|
<a
|
|
class="dropdown-item"
|
|
href="/w/{{repo.repoId}}/"
|
|
target="_self"
|
|
ng-if="repo.options.page"
|
|
>
|
|
<i class="fas fa-globe"></i> View Page
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</li>
|
|
<li
|
|
class="col-12 d-flex px-0 py-3 border-bottom color-border-secondary"
|
|
ng-if="filteredRepositories.length == 0"
|
|
>
|
|
There is no repository to display.
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|