passman/templates/views/show_vault.html

262 lines
9.9 KiB
HTML
Raw Normal View History

<div off-click="closeSelected()" off-click-filter="'.download-js-link, .sidebar-shown'">
<div id="passman-controls" ng-class="{ 'sidebar-shown': selectedCredential }">
2016-09-21 02:51:41 +08:00
<div class="breadcrumb">
<div class="breadcrumb">
<div class="crumb svg ui-droppable" data-dir="/">
<a><i class="fa fa-home"></i></a>
</div>
<div class="crumb svg last">
<a>{{active_vault.name}}</a>
</div>
2016-09-21 02:51:41 +08:00
</div>
</div>
<span class="title" ng-if="delete_time">
2016-12-20 06:51:15 +08:00
{{ 'deleted.since' | translate }}:
2016-09-27 01:15:39 +08:00
<span ng-if="delete_time == 1">All time</span>
<span ng-if="delete_time > 1">{{delete_time | date:'dd-MM-yyyy @ HH:mm:ss'}}</span>
</span>
<div class="actions creatable">
<span ng-click="addCredential()" class="button new">
<span >+</span></span>
</div>
2016-12-20 06:51:15 +08:00
<div class="title" ng-show="filtered_credentials.length > 0" translate="number.filtered"
translate-values="{number_filtered: filtered_credentials.length, credential_number: active_vault.credentials.length - 1}"
>
</div>
2017-01-03 23:19:53 +08:00
<div class="searchboxContainer" ng-init="filterOptionShown = false;" off-click="filterOptionShown = false;">
<input type="text" ng-model="filterOptions.filterText" class="searchbox" id="searchBox"
placeholder="{{'search.credential' | translate}}" select-on-click clear-btn ng-click="filterOptionShown = true;">
<div class="searchOptions" ng-show="filterOptionShown">
<input type="checkbox" ng-model="filterOptions.useRegex"> Use regex
</div>
</div>
<div class="viewModes">
<div class="view-mode" ng-class="{'active': view_mode === 'list' }"
ng-click="switchViewMode('list')"><i class="fa fa-list"></i></div>
<div class="view-mode" ng-class="{'active': view_mode === 'grid' }"
ng-click="switchViewMode('grid')"><i class="fa fa-th-large"></i>
</div>
2016-09-28 06:14:32 +08:00
</div>
</div>
2016-09-30 23:44:21 +08:00
<div class="loaderContainer" ng-if="show_spinner">
2016-09-27 01:15:39 +08:00
<div class="loader" use-theme type="'border-bottom-color'"></div>
</div>
2016-09-28 06:14:32 +08:00
<div ng-init="menuOpen = false;">
<table class="credential-table"
ng-if="view_mode === 'list'">
2016-10-07 17:15:51 +08:00
<tr ng-repeat="credential in filtered_credentials | orderBy:'label'"
ng-if="showCredentialRow(credential)"
2016-12-31 21:18:44 +08:00
ng-click="selectCredential(credential)" ng-dblclick="editCredential(credential)"
2016-09-28 06:14:32 +08:00
ng-class="{'selected': selectedCredential.credential_id == credential.credential_id}">
<td>
<span class="tags">
<span class="tag" ng-repeat="tag in credential.tags_raw">{{ ::tag.text}}</span>
</span>
2016-10-03 03:34:05 +08:00
<span class="icon">
2016-10-06 01:46:03 +08:00
<i class="fa fa-lock" ng-if="!credential.acl && !credential.shared_key"></i>
2016-10-03 03:34:05 +08:00
<i class="fa fa-share-alt" ng-if="credential.acl"></i>
2016-10-06 05:26:31 +08:00
<i class="fa fa-share-alt-square" ng-if="credential.shared_key"> </i>
2016-10-03 03:34:05 +08:00
</span>
2016-10-01 00:21:17 +08:00
<span class="label">{{ ::credential.label}}</span>
2016-09-16 03:43:23 +08:00
2016-09-28 06:14:32 +08:00
</td>
</tr>
</table>
2016-10-07 17:15:51 +08:00
2016-09-30 23:44:21 +08:00
<ul class="grid-view" ng-if="view_mode === 'grid'">
<li class="credential"
2016-10-07 17:15:51 +08:00
ng-repeat="credential in filtered_credentials | orderBy:'label'"
ng-if="credential.hidden == 0 && showCredentialRow(credential)"
ng-click="selectCredential(credential)"
use-theme type="'border-color'">
<div class="credential_content">
<div class="label">{{ ::credential.label}}</div>
<div class="tags">
<div class="tag" ng-repeat="tag in credential.tags_raw">
{{ ::tag.text}}
2016-09-28 06:14:32 +08:00
</div>
</div>
</div>
</li>
2016-09-28 06:14:32 +08:00
</ul>
</div>
2016-09-15 06:11:59 +08:00
<div id="app-sidebar" class="detailsView scroll-container app_sidebar"
ng-show="selectedCredential">
2016-10-07 18:10:06 +08:00
<h2>{{selectedCredential.label}}</h2>
2016-09-15 06:11:59 +08:00
<span class="close icon-close" ng-click="closeSelected()"
alt="Close"></span>
2016-10-07 18:10:06 +08:00
<div class="credential-data">
<div class="row" ng-show="selectedCredential.username">
2016-12-20 06:51:15 +08:00
<div class="col-xs-4 col-md-3 col-lg-3">{{ 'account' | translate }}</div>
2016-10-07 18:10:06 +08:00
<div class="col-xs-8 col-md-9 col-lg-9"><span credential-field
value="selectedCredential.username"></span></div>
</div>
<div class="row" ng-show="selectedCredential.password">
2016-12-20 06:51:15 +08:00
<div class="col-xs-4 col-md-3 col-lg-3">{{ 'password' | translate }}</div>
2016-10-07 18:10:06 +08:00
<div class="col-xs-8 col-md-9 col-lg-9">
<span credential-field value="selectedCredential.password" secret="'true'">
</span>
</div>
</div>
<div class="row" ng-show="selectedCredential.otp.secret">
2016-12-20 06:51:15 +08:00
<div class="col-xs-4 col-md-3 col-lg-3">{{'otp' | translate}}</div>
2016-10-07 18:10:06 +08:00
<div class="col-xs-8 col-md-9 col-lg-9"><span otp-generator
secret="selectedCredential.otp.secret"></span></div>
</div>
<div class="row" ng-show="selectedCredential.email">
2016-12-20 06:51:15 +08:00
<div class="col-xs-4 col-md-3 col-lg-3">{{'email' | translate}}</div>
2016-10-07 18:10:06 +08:00
<div class="col-xs-8 col-md-9 col-lg-9"><span credential-field
value="selectedCredential.email"></span></div>
</div>
<div class="row" ng-show="selectedCredential.url">
2016-12-20 06:51:15 +08:00
<div class="col-xs-4 col-md-3 col-lg-3">{{ 'url' | translate}}</div>
2016-10-07 18:10:06 +08:00
<div class="col-xs-8 col-md-9 col-lg-9"><span credential-field
value="selectedCredential.url"></span></div>
</div>
<div class="row" ng-show="selectedCredential.description">
2016-12-20 06:51:15 +08:00
<div class="col-xs-4 col-md-3 col-lg-3">{{'notes' | translate}}</div>
<div class="col-xs-8 col-md-9 col-lg-9" ng-bind-html="selectedCredential.description_html"></div>
</div>
2016-10-07 18:10:06 +08:00
<div class="row" ng-show="selectedCredential.files.length > 0">
2016-12-20 06:51:15 +08:00
<div class="col-xs-4 col-md-3 col-lg-3">{{ 'files' | translate}}</div>
2016-10-07 18:10:06 +08:00
<div class="col-xs-8 col-md-9 col-lg-9"><div ng-repeat="file in selectedCredential.files"
class="link" ng-click="downloadFile(selectedCredential, file)">
{{file.filename}} ({{file.size | bytes}})
</div></div>
</div>
<div class="row" ng-repeat="field in selectedCredential.custom_fields">
2016-10-07 23:22:58 +08:00
<div class="col-xs-4 col-md-3 col-lg-3">{{field.label}}</div>
<div class="col-xs-8 col-md-9 col-lg-9">
<span credential-field value="field.value" secret="field.secret" ng-if="field.field_type !== 'file' || !field.field_type"></span>
<span ng-if="field.field_type === 'file'" class="link" ng-click="downloadFile(selectedCredential, field.value)">{{field.value.filename}} ({{field.value.size | bytes}})</span>
</div>
2016-10-07 18:10:06 +08:00
</div>
<div class="row" ng-show="selectedCredential.expire_time > 0">
2016-12-20 06:51:15 +08:00
<div class="col-xs-4 col-md-3 col-lg-3">{{ 'expire.time' | translate }}</div>
2016-10-07 18:10:06 +08:00
<div class="col-xs-8 col-md-9 col-lg-9">
{{selectedCredential.expire_time * 1000 | date:'dd-MM-yyyy @ HH:mm:ss'}}
</div>
</div>
<div class="row" ng-show="selectedCredential.changed">
2016-12-20 06:51:15 +08:00
<div class="col-xs-4 col-md-3 col-lg-3">{{ 'changed' | translate}}</div>
2016-10-07 18:10:06 +08:00
<div class="col-xs-8 col-md-9 col-lg-9">
{{selectedCredential.changed * 1000 | date:'dd-MM-yyyy @ HH:mm:ss'}}
</div>
</div>
<div class="row" ng-show="selectedCredential.created">
2016-12-20 06:51:15 +08:00
<div class="col-xs-4 col-md-3 col-lg-3">{{ 'created' | translate}}</div>
2016-10-07 18:10:06 +08:00
<div class="col-xs-8 col-md-9 col-lg-9">
{{selectedCredential.created * 1000 | date:'dd-MM-yyyy @ HH:mm:ss'}}
2016-10-07 18:31:17 +08:00
</div>
2016-10-07 18:10:06 +08:00
</div>
2016-10-07 18:31:17 +08:00
<div class="row">
<div class="col-xs-12">
<div class="tags">
<span class="tag" ng-repeat="tag in selectedCredential.tags">{{tag.text}}</span>
</div>
</div>
</div>
</div>
2016-10-07 18:31:17 +08:00
2016-09-15 06:19:56 +08:00
<div ng-show="selectedCredential">
2016-10-04 02:33:32 +08:00
<div>
2016-10-03 03:47:57 +08:00
<button class="button"
ng-click="editCredential(selectedCredential)"
2016-10-04 02:33:32 +08:00
ng-if="selectedCredential.delete_time == 0 && hasPermission(selectedCredential.acl.permissions, permissions.permissions.WRITE)">
2016-12-20 06:51:15 +08:00
<span class="fa fa-edit"></span> {{ 'edit' | translate}}
2016-10-03 03:47:57 +08:00
</button>
<button class="button"
ng-click="deleteCredential(selectedCredential)"
2016-10-04 02:33:32 +08:00
ng-if="selectedCredential.delete_time == 0 && hasPermission(selectedCredential.acl.permissions, permissions.permissions.WRITE)">
2016-12-20 06:51:15 +08:00
<span class="fa fa-trash"></span> {{ 'delete' | translate}}
2016-10-03 03:47:57 +08:00
</button>
<button class="button"
ng-click="shareCredential(selectedCredential)"
ng-if="selectedCredential.delete_time == 0 && selectedCredential.acl === undefined &&
(settings.user_sharing_enabled === 1 || settings.user_sharing_enabled === '1' || settings.link_sharing_enabled === 1 || settings.link_sharing_enabled === '1')">
2016-12-20 06:51:15 +08:00
<span class="fa fa-share"></span> {{ 'share' | translate}}
2016-10-03 03:47:57 +08:00
</button>
2016-09-24 16:59:37 +08:00
2016-10-03 03:47:57 +08:00
<button class="button"
ng-click="getRevisions(selectedCredential)"
2016-10-04 02:33:32 +08:00
ng-if="selectedCredential.delete_time == 0 && hasPermission(selectedCredential.acl.permissions, permissions.permissions.HISTORY)">
2016-12-20 06:51:15 +08:00
<span class="fa fa-undo"></span> {{ 'revisions' | translate}}
2016-10-03 03:47:57 +08:00
</button>
<button class="button"
ng-if="selectedCredential.delete_time > 0"
2016-10-04 02:33:32 +08:00
ng-click="recoverCredential(selectedCredential) && hasPermission(selectedCredential.acl.permissions, permissions.permissions.WRITE)">
2016-12-20 06:51:15 +08:00
<span class="fa fa-recycle"></span> {{'recover' | translate}}
2016-10-03 03:47:57 +08:00
</button>
<button class="button"
ng-if="selectedCredential.delete_time > 0"
ng-click="destroyCredential(selectedCredential)">
2016-12-20 06:51:15 +08:00
<span class="fa fa-bomb"></span> {{'destroy' | translate}}
2016-10-03 03:47:57 +08:00
</button>
</div>
2016-09-15 06:11:59 +08:00
</div>
</div>
2016-10-07 18:31:17 +08:00
</div>
2016-10-07 18:31:17 +08:00
<div class="share_popup" style="display: none">
2016-12-20 06:51:15 +08:00
{{ 'sharereq.title' | translate}}<br/>
{{ 'sharereq.line1' | translate}}<br/>
{{ 'sharereq.line2' | translate}}
{{active_vault.vault_id}}
<table class="table">
<thead>
<tr>
2016-12-20 06:51:15 +08:00
<td>{{ 'label' | translate}}</td>
<td>{{ 'permissions' | translate}}</td>
<td>{{ 'received.from' | translate}}</td>
<td>{{ 'date' | translate}}</td>
</tr>
</thead>
2016-10-03 03:47:57 +08:00
<tr ng-repeat="share_request in incoming_share_requests"
ng-if="share_request.target_vault_id == active_vault.vault_id">
<td>
{{share_request.credential_label}}
</td>
<td>
{{share_request.permissions}}
</td>
<td>
{{share_request.from_user_id}}
</td>
<td>
2016-12-20 06:51:15 +08:00
{{share_request.created * 1000 | date:'dd-MM-yyyy @ HH:mm:ss'}}
</td>
<td>
2016-12-20 06:51:15 +08:00
<span class="link" ng-click="acceptShareRequest(share_request)">{{ 'accept' | translate}}</span>
| <span class="link" ng-click="declineShareRequest(share_request)">{{ 'decline' | translate}}</span>
</td>
</tr>
</table>
2016-09-15 03:12:10 +08:00
</div>