mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-04-02 13:45:10 -05:00

* Implement share links Basic implementation of share links Make certain share link fields not editable, automatically grant permissions on migrate Updated styling, error messages from expired / deleted links frontend code linting, reversable sharelink migration testing coverage Update translation strings No links message * Consolidate file response methods * improvements to share links on mobile devices * Refactor share links file_version * Add docs for share links * Apply suggestions from code review * When filtering share links, use the timezone aware now() * Removes extra call to setup directories for usage in testing * FIx copied badge display on some browsers * Move copy to ngx-clipboard library --------- Co-authored-by: Trenton H <797416+stumpylog@users.noreply.github.com>
62 lines
3.6 KiB
HTML
62 lines
3.6 KiB
HTML
<div ngbDropdown>
|
|
<button class="btn btn-sm btn-outline-primary me-2" id="shareLinksDropdown" [disabled]="disabled" ngbDropdownToggle>
|
|
<svg class="toolbaricon" fill="currentColor">
|
|
<use xlink:href="assets/bootstrap-icons.svg#link" />
|
|
</svg>
|
|
<div class="d-none d-sm-inline"> <ng-container i18n>Share Links</ng-container></div>
|
|
</button>
|
|
<div ngbDropdownMenu aria-labelledby="shareLinksDropdown" class="shadow share-links-dropdown">
|
|
<ul class="list-group list-group-flush">
|
|
<li *ngIf="!shareLinks || shareLinks.length === 0" class="list-group-item fst-italic small text-center text-secondary" i18n>
|
|
No existing links
|
|
</li>
|
|
<li class="list-group-item" *ngFor="let link of shareLinks">
|
|
<div class="input-group input-group-sm w-100">
|
|
<input type="text" class="form-control" aria-label="Share link" [value]="getShareUrl(link)" readonly>
|
|
<span *ngIf="link.expiration" class="input-group-text">
|
|
{{ getDaysRemaining(link) }}
|
|
</span>
|
|
<button type="button" class="btn btn-sm btn-outline-primary" (click)="copy(link)">
|
|
<svg class="buttonicon" fill="currentColor">
|
|
<use *ngIf="copied !== link.id" xlink:href="assets/bootstrap-icons.svg#clipboard-fill" />
|
|
<use *ngIf="copied === link.id" xlink:href="assets/bootstrap-icons.svg#clipboard-check-fill" />
|
|
</svg><span class="visually-hidden" i18n>Copy</span>
|
|
</button>
|
|
<button *ngIf="canShare(link)" type="button" class="btn btn-sm btn-outline-primary" (click)="share(link)">
|
|
<svg class="buttonicon" fill="currentColor">
|
|
<use xlink:href="assets/bootstrap-icons.svg#box-arrow-up" />
|
|
</svg><span class="visually-hidden" i18n>Share</span>
|
|
</button>
|
|
<button type="button" class="btn btn-sm btn-outline-danger" (click)="delete(link)">
|
|
<svg class="buttonicon" fill="currentColor">
|
|
<use xlink:href="assets/bootstrap-icons.svg#trash" />
|
|
</svg><span class="visually-hidden" i18n>Delete</span>
|
|
</button>
|
|
</div>
|
|
<span class="badge copied-badge bg-primary small fade ms-4 position-absolute top-50 translate-middle-y pe-none z-3" [class.show]="copied === link.id" i18n>Copied!</span>
|
|
</li>
|
|
<li class="list-group-item pt-3 pb-2">
|
|
<div class="input-group input-group-sm w-100">
|
|
<div class="form-check form-switch ms-auto">
|
|
<input class="form-check-input" type="checkbox" role="switch" id="versionSwitch" [(ngModel)]="archiveVersion">
|
|
<label class="form-check-label small" for="versionSwitch" i18n>Share archive version</label>
|
|
</div>
|
|
</div>
|
|
<div class="input-group input-group-sm w-100 mt-2">
|
|
<label class="input-group-text" for="addLink">Expires:</label>
|
|
<select class="form-select form-select-sm" [(ngModel)]="expirationDays">
|
|
<option *ngFor="let option of EXPIRATION_OPTIONS" [ngValue]="option.value">{{ option.label }}</option>
|
|
</select>
|
|
<button class="btn btn-sm btn-outline-primary ms-auto" type="button" (click)="createLink()" [disabled]="loading">
|
|
<div *ngIf="loading" class="spinner-border spinner-border-sm me-2" role="status"></div>
|
|
<svg *ngIf="!loading" class="buttonicon me-1" fill="currentColor">
|
|
<use xlink:href="assets/bootstrap-icons.svg#plus" />
|
|
</svg>
|
|
<ng-container i18n>Create</ng-container>
|
|
</button>
|
|
</div>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|