mirror of
https://github.com/bitwarden/browser.git
synced 2025-01-06 18:57:56 +01:00
add/edit cipher modal
This commit is contained in:
parent
0fb66e247a
commit
a52aadd37d
@ -23,6 +23,7 @@ import { RegisterComponent } from './accounts/register.component';
|
|||||||
import { TwoFactorOptionsComponent } from './accounts/two-factor-options.component';
|
import { TwoFactorOptionsComponent } from './accounts/two-factor-options.component';
|
||||||
import { TwoFactorComponent } from './accounts/two-factor.component';
|
import { TwoFactorComponent } from './accounts/two-factor.component';
|
||||||
|
|
||||||
|
import { AddEditComponent } from './vault/add-edit.component';
|
||||||
import { AttachmentsComponent } from './vault/attachments.component';
|
import { AttachmentsComponent } from './vault/attachments.component';
|
||||||
import { CiphersComponent } from './vault/ciphers.component';
|
import { CiphersComponent } from './vault/ciphers.component';
|
||||||
import { FolderAddEditComponent } from './vault/folder-add-edit.component';
|
import { FolderAddEditComponent } from './vault/folder-add-edit.component';
|
||||||
@ -59,6 +60,7 @@ import { Folder } from 'jslib/models/domain';
|
|||||||
ToasterModule,
|
ToasterModule,
|
||||||
],
|
],
|
||||||
declarations: [
|
declarations: [
|
||||||
|
AddEditComponent,
|
||||||
ApiActionDirective,
|
ApiActionDirective,
|
||||||
AppComponent,
|
AppComponent,
|
||||||
AttachmentsComponent,
|
AttachmentsComponent,
|
||||||
@ -84,6 +86,7 @@ import { Folder } from 'jslib/models/domain';
|
|||||||
VaultComponent,
|
VaultComponent,
|
||||||
],
|
],
|
||||||
entryComponents: [
|
entryComponents: [
|
||||||
|
AddEditComponent,
|
||||||
AttachmentsComponent,
|
AttachmentsComponent,
|
||||||
FolderAddEditComponent,
|
FolderAddEditComponent,
|
||||||
ModalComponent,
|
ModalComponent,
|
||||||
|
@ -1,4 +1,7 @@
|
|||||||
<form #form (ngSubmit)="submit()" [appApiAction]="formPromise">
|
<div class="modal fade">
|
||||||
|
<div class="modal-dialog modal-lg">
|
||||||
|
<form class="modal-content" #form (ngSubmit)="submit()" [appApiAction]="formPromise">
|
||||||
|
<div class="modal-body">
|
||||||
<div class="content">
|
<div class="content">
|
||||||
<div class="inner-content" *ngIf="cipher">
|
<div class="inner-content" *ngIf="cipher">
|
||||||
<div class="box">
|
<div class="box">
|
||||||
@ -20,46 +23,37 @@
|
|||||||
<div *ngIf="cipher.type === cipherType.Login">
|
<div *ngIf="cipher.type === cipherType.Login">
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="loginUsername">{{'username' | i18n}}</label>
|
<label for="loginUsername">{{'username' | i18n}}</label>
|
||||||
<input id="loginUsername" type="text" name="Login.Username"
|
<input id="loginUsername" type="text" name="Login.Username" [(ngModel)]="cipher.login.username">
|
||||||
[(ngModel)]="cipher.login.username">
|
|
||||||
</div>
|
</div>
|
||||||
<div class="box-content-row box-content-row-flex" appBoxRow>
|
<div class="box-content-row box-content-row-flex" appBoxRow>
|
||||||
<div class="row-main">
|
<div class="row-main">
|
||||||
<label for="loginPassword">{{'password' | i18n}}</label>
|
<label for="loginPassword">{{'password' | i18n}}</label>
|
||||||
<input id="loginPassword" class="monospaced"
|
<input id="loginPassword" class="monospaced" type="{{showPassword ? 'text' : 'password'}}" name="Login.Password" [(ngModel)]="cipher.login.password">
|
||||||
type="{{showPassword ? 'text' : 'password'}}" name="Login.Password"
|
|
||||||
[(ngModel)]="cipher.login.password">
|
|
||||||
</div>
|
</div>
|
||||||
<div class="action-buttons">
|
<div class="action-buttons">
|
||||||
<button type="button" #checkPasswordBtn class="row-btn btn" appBlurClick
|
<button type="button" #checkPasswordBtn class="row-btn btn" appBlurClick title="{{'checkPassword' | i18n}}" (click)="checkPassword()"
|
||||||
title="{{'checkPassword' | i18n}}" (click)="checkPassword()"
|
|
||||||
[appApiAction]="checkPasswordPromise" [disabled]="checkPasswordBtn.loading">
|
[appApiAction]="checkPasswordPromise" [disabled]="checkPasswordBtn.loading">
|
||||||
<i class="fa fa-lg fa-check-circle" [hidden]="checkPasswordBtn.loading"></i>
|
<i class="fa fa-lg fa-check-circle" [hidden]="checkPasswordBtn.loading"></i>
|
||||||
<i class="fa fa-lg fa-spinner fa-spin" [hidden]="!checkPasswordBtn.loading"></i>
|
<i class="fa fa-lg fa-spinner fa-spin" [hidden]="!checkPasswordBtn.loading"></i>
|
||||||
</button>
|
</button>
|
||||||
<a class="row-btn" href="#" appStopClick appBlurClick
|
<a class="row-btn" href="#" appStopClick appBlurClick title="{{'toggleVisibility' | i18n}}" (click)="togglePassword()">
|
||||||
title="{{'toggleVisibility' | i18n}}" (click)="togglePassword()">
|
<i class="fa fa-lg" [ngClass]="{'fa-eye': !showPassword, 'fa-eye-slash': showPassword}"></i>
|
||||||
<i class="fa fa-lg"
|
|
||||||
[ngClass]="{'fa-eye': !showPassword, 'fa-eye-slash': showPassword}"></i>
|
|
||||||
</a>
|
</a>
|
||||||
<a class="row-btn" href="#" appStopClick appBlurClick
|
<a class="row-btn" href="#" appStopClick appBlurClick title="{{'generatePassword' | i18n}}" (click)="generatePassword()">
|
||||||
title="{{'generatePassword' | i18n}}" (click)="generatePassword()">
|
|
||||||
<i class="fa fa-lg fa-refresh"></i>
|
<i class="fa fa-lg fa-refresh"></i>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="loginTotp">{{'authenticatorKeyTotp' | i18n}}</label>
|
<label for="loginTotp">{{'authenticatorKeyTotp' | i18n}}</label>
|
||||||
<input id="loginTotp" type="text" name="Login.Totp" class="monospaced"
|
<input id="loginTotp" type="text" name="Login.Totp" class="monospaced" [(ngModel)]="cipher.login.totp">
|
||||||
[(ngModel)]="cipher.login.totp">
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- Card -->
|
<!-- Card -->
|
||||||
<div *ngIf="cipher.type === cipherType.Card">
|
<div *ngIf="cipher.type === cipherType.Card">
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="cardCardholderName">{{'cardholderName' | i18n}}</label>
|
<label for="cardCardholderName">{{'cardholderName' | i18n}}</label>
|
||||||
<input id="cardCardholderName" type="text" name="Card.CardCardholderName"
|
<input id="cardCardholderName" type="text" name="Card.CardCardholderName" [(ngModel)]="cipher.card.cardholderName">
|
||||||
[(ngModel)]="cipher.card.cardholderName">
|
|
||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="cardNumber">{{'number' | i18n}}</label>
|
<label for="cardNumber">{{'number' | i18n}}</label>
|
||||||
@ -79,8 +73,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="cardExpYear">{{'expirationYear' | i18n}}</label>
|
<label for="cardExpYear">{{'expirationYear' | i18n}}</label>
|
||||||
<input id="cardExpYear" type="text" name="Card.ExpYear" [(ngModel)]="cipher.card.expYear"
|
<input id="cardExpYear" type="text" name="Card.ExpYear" [(ngModel)]="cipher.card.expYear" placeholder="{{'ex' | i18n}} 2019">
|
||||||
placeholder="{{'ex' | i18n}} 2019">
|
|
||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="cardCode">{{'securityCode' | i18n}}</label>
|
<label for="cardCode">{{'securityCode' | i18n}}</label>
|
||||||
@ -97,28 +90,23 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="idFirstName">{{'firstName' | i18n}}</label>
|
<label for="idFirstName">{{'firstName' | i18n}}</label>
|
||||||
<input id="idFirstName" type="text" name="Identity.FirstName"
|
<input id="idFirstName" type="text" name="Identity.FirstName" [(ngModel)]="cipher.identity.firstName">
|
||||||
[(ngModel)]="cipher.identity.firstName">
|
|
||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="idMiddleName">{{'middleName' | i18n}}</label>
|
<label for="idMiddleName">{{'middleName' | i18n}}</label>
|
||||||
<input id="idMiddleName" type="text" name="Identity.MiddleName"
|
<input id="idMiddleName" type="text" name="Identity.MiddleName" [(ngModel)]="cipher.identity.middleName">
|
||||||
[(ngModel)]="cipher.identity.middleName">
|
|
||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="idLastName">{{'lastName' | i18n}}</label>
|
<label for="idLastName">{{'lastName' | i18n}}</label>
|
||||||
<input id="idLastName" type="text" name="Identity.LastName"
|
<input id="idLastName" type="text" name="Identity.LastName" [(ngModel)]="cipher.identity.lastName">
|
||||||
[(ngModel)]="cipher.identity.lastName">
|
|
||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="idUsername">{{'username' | i18n}}</label>
|
<label for="idUsername">{{'username' | i18n}}</label>
|
||||||
<input id="idUsername" type="text" name="Identity.Username"
|
<input id="idUsername" type="text" name="Identity.Username" [(ngModel)]="cipher.identity.username">
|
||||||
[(ngModel)]="cipher.identity.username">
|
|
||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="idCompany">{{'company' | i18n}}</label>
|
<label for="idCompany">{{'company' | i18n}}</label>
|
||||||
<input id="idCompany" type="text" name="Identity.Company"
|
<input id="idCompany" type="text" name="Identity.Company" [(ngModel)]="cipher.identity.company">
|
||||||
[(ngModel)]="cipher.identity.company">
|
|
||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="idSsn">{{'ssn' | i18n}}</label>
|
<label for="idSsn">{{'ssn' | i18n}}</label>
|
||||||
@ -126,13 +114,11 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="idPassportNumber">{{'passportNumber' | i18n}}</label>
|
<label for="idPassportNumber">{{'passportNumber' | i18n}}</label>
|
||||||
<input id="idPassportNumber" type="text" name="Identity.PassportNumber"
|
<input id="idPassportNumber" type="text" name="Identity.PassportNumber" [(ngModel)]="cipher.identity.passportNumber">
|
||||||
[(ngModel)]="cipher.identity.passportNumber">
|
|
||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="idLicenseNumber">{{'licenseNumber' | i18n}}</label>
|
<label for="idLicenseNumber">{{'licenseNumber' | i18n}}</label>
|
||||||
<input id="idLicenseNumber" type="text" name="Identity.LicenseNumber"
|
<input id="idLicenseNumber" type="text" name="Identity.LicenseNumber" [(ngModel)]="cipher.identity.licenseNumber">
|
||||||
[(ngModel)]="cipher.identity.licenseNumber">
|
|
||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="idEmail">{{'email' | i18n}}</label>
|
<label for="idEmail">{{'email' | i18n}}</label>
|
||||||
@ -144,18 +130,15 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="idAddress1">{{'address1' | i18n}}</label>
|
<label for="idAddress1">{{'address1' | i18n}}</label>
|
||||||
<input id="idAddress1" type="text" name="Identity.Address1"
|
<input id="idAddress1" type="text" name="Identity.Address1" [(ngModel)]="cipher.identity.address1">
|
||||||
[(ngModel)]="cipher.identity.address1">
|
|
||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="idAddress2">{{'address2' | i18n}}</label>
|
<label for="idAddress2">{{'address2' | i18n}}</label>
|
||||||
<input id="idAddress2" type="text" name="Identity.Address2"
|
<input id="idAddress2" type="text" name="Identity.Address2" [(ngModel)]="cipher.identity.address2">
|
||||||
[(ngModel)]="cipher.identity.address2">
|
|
||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="idAddress3">{{'address3' | i18n}}</label>
|
<label for="idAddress3">{{'address3' | i18n}}</label>
|
||||||
<input id="idAddress3" type="text" name="Identity.Address3"
|
<input id="idAddress3" type="text" name="Identity.Address3" [(ngModel)]="cipher.identity.address3">
|
||||||
[(ngModel)]="cipher.identity.address3">
|
|
||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="idCity">{{'cityTown' | i18n}}</label>
|
<label for="idCity">{{'cityTown' | i18n}}</label>
|
||||||
@ -167,13 +150,11 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="idPostalCode">{{'zipPostalCode' | i18n}}</label>
|
<label for="idPostalCode">{{'zipPostalCode' | i18n}}</label>
|
||||||
<input id="idPostalCode" type="text" name="Identity.PostalCode"
|
<input id="idPostalCode" type="text" name="Identity.PostalCode" [(ngModel)]="cipher.identity.postalCode">
|
||||||
[(ngModel)]="cipher.identity.postalCode">
|
|
||||||
</div>
|
</div>
|
||||||
<div class="box-content-row" appBoxRow>
|
<div class="box-content-row" appBoxRow>
|
||||||
<label for="idCountry">{{'country' | i18n}}</label>
|
<label for="idCountry">{{'country' | i18n}}</label>
|
||||||
<input id="idCountry" type="text" name="Identity.Country"
|
<input id="idCountry" type="text" name="Identity.Country" [(ngModel)]="cipher.identity.country">
|
||||||
[(ngModel)]="cipher.identity.country">
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -181,27 +162,23 @@
|
|||||||
<div class="box" *ngIf="cipher.type === cipherType.Login">
|
<div class="box" *ngIf="cipher.type === cipherType.Login">
|
||||||
<div class="box-content">
|
<div class="box-content">
|
||||||
<ng-container *ngIf="cipher.login.hasUris">
|
<ng-container *ngIf="cipher.login.hasUris">
|
||||||
<div class="box-content-row box-content-row-multi" appBoxRow
|
<div class="box-content-row box-content-row-multi" appBoxRow *ngFor="let u of cipher.login.uris; let i = index">
|
||||||
*ngFor="let u of cipher.login.uris; let i = index">
|
|
||||||
<a href="#" appStopClick (click)="removeUri(u)" title="{{'remove' | i18n}}">
|
<a href="#" appStopClick (click)="removeUri(u)" title="{{'remove' | i18n}}">
|
||||||
<i class="fa fa-minus-circle fa-lg"></i>
|
<i class="fa fa-minus-circle fa-lg"></i>
|
||||||
</a>
|
</a>
|
||||||
<div class="row-main">
|
<div class="row-main">
|
||||||
<label for="loginUri{{i}}">{{'uriPosition' | i18n : (i + 1)}}</label>
|
<label for="loginUri{{i}}">{{'uriPosition' | i18n : (i + 1)}}</label>
|
||||||
<input id="loginUri{{i}}" type="text" name="Login.Uris[{{i}}].Uri" [(ngModel)]="u.uri"
|
<input id="loginUri{{i}}" type="text" name="Login.Uris[{{i}}].Uri" [(ngModel)]="u.uri" placeholder="{{'ex' | i18n}} https://google.com">
|
||||||
placeholder="{{'ex' | i18n}} https://google.com">
|
|
||||||
<label for="loginUriMatch{{i}}" class="sr-only">
|
<label for="loginUriMatch{{i}}" class="sr-only">
|
||||||
{{'matchDetection' | i18n}} {{(i + 1)}}
|
{{'matchDetection' | i18n}} {{(i + 1)}}
|
||||||
</label>
|
</label>
|
||||||
<select id="loginUriMatch{{i}}" name="Login.Uris[{{i}}].Match" [(ngModel)]="u.match"
|
<select id="loginUriMatch{{i}}" name="Login.Uris[{{i}}].Match" [(ngModel)]="u.match" [hidden]="u.showOptions === false || (u.showOptions == null && u.match == null)"
|
||||||
[hidden]="u.showOptions === false || (u.showOptions == null && u.match == null)"
|
|
||||||
(change)="loginUriMatchChanged(u)">
|
(change)="loginUriMatchChanged(u)">
|
||||||
<option *ngFor="let o of uriMatchOptions" [ngValue]="o.value">{{o.name}}</option>
|
<option *ngFor="let o of uriMatchOptions" [ngValue]="o.value">{{o.name}}</option>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
<div class="action-buttons">
|
<div class="action-buttons">
|
||||||
<a class="row-btn" href="#" appStopClick appBlurClick
|
<a class="row-btn" href="#" appStopClick appBlurClick title="{{'toggleOptions' | i18n}}" (click)="toggleUriOptions(u)">
|
||||||
title="{{'toggleOptions' | i18n}}" (click)="toggleUriOptions(u)">
|
|
||||||
<i class="fa fa-lg fa-cog"></i>
|
<i class="fa fa-lg fa-cog"></i>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
@ -224,8 +201,7 @@
|
|||||||
<label for="favorite">{{'favorite' | i18n}}</label>
|
<label for="favorite">{{'favorite' | i18n}}</label>
|
||||||
<input id="favorite" type="checkbox" name="Favorite" [(ngModel)]="cipher.favorite">
|
<input id="favorite" type="checkbox" name="Favorite" [(ngModel)]="cipher.favorite">
|
||||||
</div>
|
</div>
|
||||||
<a class="box-content-row box-content-row-flex text-default" href="#" appStopClick appBlurClick
|
<a class="box-content-row box-content-row-flex text-default" href="#" appStopClick appBlurClick (click)="attachments()" *ngIf="editMode">
|
||||||
(click)="attachments()" *ngIf="editMode">
|
|
||||||
<div class="row-main">{{'attachments' | i18n}}</div>
|
<div class="row-main">{{'attachments' | i18n}}</div>
|
||||||
<i class="fa fa-chevron-right row-sub-icon"></i>
|
<i class="fa fa-chevron-right row-sub-icon"></i>
|
||||||
</a>
|
</a>
|
||||||
@ -247,31 +223,23 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="box-content">
|
<div class="box-content">
|
||||||
<ng-container *ngIf="cipher.hasFields">
|
<ng-container *ngIf="cipher.hasFields">
|
||||||
<div class="box-content-row box-content-row-multi" appBoxRow
|
<div class="box-content-row box-content-row-multi" appBoxRow *ngFor="let f of cipher.fields; let i = index" [ngClass]="{'box-content-row-checkbox': f.type === fieldType.Boolean}">
|
||||||
*ngFor="let f of cipher.fields; let i = index"
|
|
||||||
[ngClass]="{'box-content-row-checkbox': f.type === fieldType.Boolean}">
|
|
||||||
<a href="#" appStopClick (click)="removeField(f)" title="{{'remove' | i18n}}">
|
<a href="#" appStopClick (click)="removeField(f)" title="{{'remove' | i18n}}">
|
||||||
<i class="fa fa-minus-circle fa-lg"></i>
|
<i class="fa fa-minus-circle fa-lg"></i>
|
||||||
</a>
|
</a>
|
||||||
<label for="fieldName{{i}}" class="sr-only">{{'name' | i18n}}</label>
|
<label for="fieldName{{i}}" class="sr-only">{{'name' | i18n}}</label>
|
||||||
<label for="fieldValue{{i}}" class="sr-only">{{'value' | i18n}}</label>
|
<label for="fieldValue{{i}}" class="sr-only">{{'value' | i18n}}</label>
|
||||||
<div class="row-main">
|
<div class="row-main">
|
||||||
<input id="fieldName{{i}}" type="text" name="Field.Name{{i}}" [(ngModel)]="f.name"
|
<input id="fieldName{{i}}" type="text" name="Field.Name{{i}}" [(ngModel)]="f.name" class="row-label" placeholder="{{'name' | i18n}}">
|
||||||
class="row-label" placeholder="{{'name' | i18n}}">
|
<input id="fieldValue{{i}}" type="text" name="Field.Value{{i}}" [(ngModel)]="f.value" *ngIf="f.type === fieldType.Text" placeholder="{{'value' | i18n}}">
|
||||||
<input id="fieldValue{{i}}" type="text" name="Field.Value{{i}}" [(ngModel)]="f.value"
|
<input id="fieldValue{{i}}" type="{{f.showValue ? 'text' : 'password'}}" name="Field.Value{{i}}" [(ngModel)]="f.value" class="monospaced"
|
||||||
*ngIf="f.type === fieldType.Text" placeholder="{{'value' | i18n}}">
|
|
||||||
<input id="fieldValue{{i}}" type="{{f.showValue ? 'text' : 'password'}}"
|
|
||||||
name="Field.Value{{i}}" [(ngModel)]="f.value" class="monospaced"
|
|
||||||
*ngIf="f.type === fieldType.Hidden" placeholder="{{'value' | i18n}}">
|
*ngIf="f.type === fieldType.Hidden" placeholder="{{'value' | i18n}}">
|
||||||
</div>
|
</div>
|
||||||
<input id="fieldValue{{i}}" name="Field.Value{{i}}" type="checkbox"
|
<input id="fieldValue{{i}}" name="Field.Value{{i}}" type="checkbox" [(ngModel)]="f.value" *ngIf="f.type === fieldType.Boolean"
|
||||||
[(ngModel)]="f.value" *ngIf="f.type === fieldType.Boolean"
|
|
||||||
appTrueFalseValue trueValue="true" falseValue="false">
|
appTrueFalseValue trueValue="true" falseValue="false">
|
||||||
<div class="action-buttons" *ngIf="f.type === fieldType.Hidden">
|
<div class="action-buttons" *ngIf="f.type === fieldType.Hidden">
|
||||||
<a class="row-btn" href="#" appStopClick appBlurClick
|
<a class="row-btn" href="#" appStopClick appBlurClick title="{{'toggleVisibility' | i18n}}" (click)="toggleFieldValue(f)">
|
||||||
title="{{'toggleVisibility' | i18n}}" (click)="toggleFieldValue(f)">
|
<i class="fa fa-lg" [ngClass]="{'fa-eye': !f.showValue, 'fa-eye-slash': f.showValue}"></i>
|
||||||
<i class="fa fa-lg"
|
|
||||||
[ngClass]="{'fa-eye': !f.showValue, 'fa-eye-slash': f.showValue}"></i>
|
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -298,12 +266,14 @@
|
|||||||
{{'cancel' | i18n}}
|
{{'cancel' | i18n}}
|
||||||
</button>
|
</button>
|
||||||
<div class="right">
|
<div class="right">
|
||||||
<button #deleteBtn appBlurClick type="button" (click)="delete()" class="danger"
|
<button #deleteBtn appBlurClick type="button" (click)="delete()" class="danger" title="{{'delete' | i18n}}" *ngIf="editMode"
|
||||||
title="{{'delete' | i18n}}" *ngIf="editMode" [disabled]="deleteBtn.loading"
|
[disabled]="deleteBtn.loading" [appApiAction]="deletePromise">
|
||||||
[appApiAction]="deletePromise">
|
|
||||||
<i class="fa fa-trash-o fa-lg fa-fw" [hidden]="deleteBtn.loading"></i>
|
<i class="fa fa-trash-o fa-lg fa-fw" [hidden]="deleteBtn.loading"></i>
|
||||||
<i class="fa fa-spinner fa-spin fa-lg fa-fw" [hidden]="!deleteBtn.loading"></i>
|
<i class="fa fa-spinner fa-spin fa-lg fa-fw" [hidden]="!deleteBtn.loading"></i>
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
</form>
|
</form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import {
|
import {
|
||||||
Component,
|
Component,
|
||||||
OnChanges,
|
OnInit,
|
||||||
} from '@angular/core';
|
} from '@angular/core';
|
||||||
|
|
||||||
import { ToasterService } from 'angular2-toaster';
|
import { ToasterService } from 'angular2-toaster';
|
||||||
@ -19,7 +19,7 @@ import { AddEditComponent as BaseAddEditComponent } from 'jslib/angular/componen
|
|||||||
selector: 'app-vault-add-edit',
|
selector: 'app-vault-add-edit',
|
||||||
templateUrl: 'add-edit.component.html',
|
templateUrl: 'add-edit.component.html',
|
||||||
})
|
})
|
||||||
export class AddEditComponent extends BaseAddEditComponent implements OnChanges {
|
export class AddEditComponent extends BaseAddEditComponent implements OnInit {
|
||||||
constructor(cipherService: CipherService, folderService: FolderService,
|
constructor(cipherService: CipherService, folderService: FolderService,
|
||||||
i18nService: I18nService, platformUtilsService: PlatformUtilsService,
|
i18nService: I18nService, platformUtilsService: PlatformUtilsService,
|
||||||
analytics: Angulartics2, toasterService: ToasterService,
|
analytics: Angulartics2, toasterService: ToasterService,
|
||||||
@ -28,7 +28,7 @@ export class AddEditComponent extends BaseAddEditComponent implements OnChanges
|
|||||||
toasterService, auditService, stateService);
|
toasterService, auditService, stateService);
|
||||||
}
|
}
|
||||||
|
|
||||||
async ngOnChanges() {
|
async ngOnInit() {
|
||||||
await super.load();
|
await super.load();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,20 +30,17 @@
|
|||||||
<div class="container page-content">
|
<div class="container page-content">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-3">
|
<div class="col-3">
|
||||||
<app-vault-groupings
|
<app-vault-groupings (onAllClicked)="clearGroupingFilters()" (onFavoritesClicked)="filterFavorites()" (onCipherTypeClicked)="filterCipherType($event)"
|
||||||
(onAllClicked)="clearGroupingFilters()"
|
(onFolderClicked)="filterFolder($event.id)" (onAddFolder)="addFolder()" (onEditFolder)="editFolder($event.id)"
|
||||||
(onFavoritesClicked)="filterFavorites()"
|
(onCollectionClicked)="filterCollection($event.id)" (onSearchTextChanged)="filterSearchText($event)">
|
||||||
(onCipherTypeClicked)="filterCipherType($event)"
|
|
||||||
(onFolderClicked)="filterFolder($event.id)"
|
|
||||||
(onAddFolder)="addFolder()"
|
|
||||||
(onEditFolder)="editFolder($event.id)"
|
|
||||||
(onCollectionClicked)="filterCollection($event.id)"
|
|
||||||
(onSearchTextChanged)="filterSearchText($event)">
|
|
||||||
</app-vault-groupings>
|
</app-vault-groupings>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-6">
|
<div class="col-6">
|
||||||
<app-vault-ciphers
|
<button type="button" class="btn btn-secondary btn-sm pull-right" (click)="addCipher()">
|
||||||
(onCipherClicked)="editCipher($event)">
|
<i class="fa fa-plus"></i>
|
||||||
|
</button>
|
||||||
|
<h1>My Vault</h1>
|
||||||
|
<app-vault-ciphers (onCipherClicked)="editCipher($event)">
|
||||||
</app-vault-ciphers>
|
</app-vault-ciphers>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-3">
|
<div class="col-3">
|
||||||
@ -70,3 +67,4 @@
|
|||||||
</div>
|
</div>
|
||||||
<ng-template #attachments></ng-template>
|
<ng-template #attachments></ng-template>
|
||||||
<ng-template #folderAddEdit></ng-template>
|
<ng-template #folderAddEdit></ng-template>
|
||||||
|
<ng-template #cipherAddEdit></ng-template>
|
||||||
|
@ -18,6 +18,7 @@ import { FolderView } from 'jslib/models/view/folderView';
|
|||||||
|
|
||||||
import { ModalComponent } from '../modal.component';
|
import { ModalComponent } from '../modal.component';
|
||||||
|
|
||||||
|
import { AddEditComponent } from './add-edit.component';
|
||||||
import { AttachmentsComponent } from './attachments.component';
|
import { AttachmentsComponent } from './attachments.component';
|
||||||
import { CiphersComponent } from './ciphers.component';
|
import { CiphersComponent } from './ciphers.component';
|
||||||
import { FolderAddEditComponent } from './folder-add-edit.component';
|
import { FolderAddEditComponent } from './folder-add-edit.component';
|
||||||
@ -35,6 +36,7 @@ export class VaultComponent implements OnInit {
|
|||||||
@ViewChild(CiphersComponent) ciphersComponent: CiphersComponent;
|
@ViewChild(CiphersComponent) ciphersComponent: CiphersComponent;
|
||||||
@ViewChild('attachments', { read: ViewContainerRef }) attachmentsModalRef: ViewContainerRef;
|
@ViewChild('attachments', { read: ViewContainerRef }) attachmentsModalRef: ViewContainerRef;
|
||||||
@ViewChild('folderAddEdit', { read: ViewContainerRef }) folderAddEditModalRef: ViewContainerRef;
|
@ViewChild('folderAddEdit', { read: ViewContainerRef }) folderAddEditModalRef: ViewContainerRef;
|
||||||
|
@ViewChild('cipherAddEdit', { read: ViewContainerRef }) cipherAddEditRef: ViewContainerRef;
|
||||||
|
|
||||||
cipherId: string = null;
|
cipherId: string = null;
|
||||||
favorites: boolean = false;
|
favorites: boolean = false;
|
||||||
@ -80,14 +82,6 @@ export class VaultComponent implements OnInit {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
editCipher(cipher: CipherView) {
|
|
||||||
console.log(cipher);
|
|
||||||
}
|
|
||||||
|
|
||||||
addCipher(type: CipherType = null) {
|
|
||||||
//
|
|
||||||
}
|
|
||||||
|
|
||||||
async clearGroupingFilters() {
|
async clearGroupingFilters() {
|
||||||
this.ciphersComponent.searchPlaceholder = this.i18nService.t('searchVault');
|
this.ciphersComponent.searchPlaceholder = this.i18nService.t('searchVault');
|
||||||
await this.ciphersComponent.load();
|
await this.ciphersComponent.load();
|
||||||
@ -194,6 +188,37 @@ export class VaultComponent implements OnInit {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
addCipher() {
|
||||||
|
const component = this.editCipher(null);
|
||||||
|
component.type = this.type;
|
||||||
|
component.folderId = this.folderId === 'none' ? null : this.folderId;
|
||||||
|
}
|
||||||
|
|
||||||
|
editCipher(cipher: CipherView) {
|
||||||
|
if (this.modal != null) {
|
||||||
|
this.modal.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
const factory = this.componentFactoryResolver.resolveComponentFactory(ModalComponent);
|
||||||
|
this.modal = this.cipherAddEditRef.createComponent(factory).instance;
|
||||||
|
const childComponent = this.modal.show<AddEditComponent>(
|
||||||
|
AddEditComponent, this.cipherAddEditRef);
|
||||||
|
|
||||||
|
childComponent.cipherId = cipher == null ? null : cipher.id;
|
||||||
|
childComponent.onSavedCipher.subscribe(async (cipher: CipherView) => {
|
||||||
|
this.modal.close();
|
||||||
|
});
|
||||||
|
childComponent.onDeletedCipher.subscribe(async (cipher: CipherView) => {
|
||||||
|
this.modal.close();
|
||||||
|
});
|
||||||
|
|
||||||
|
this.modal.onClosed.subscribe(() => {
|
||||||
|
this.modal = null;
|
||||||
|
});
|
||||||
|
|
||||||
|
return childComponent;
|
||||||
|
}
|
||||||
|
|
||||||
private clearFilters() {
|
private clearFilters() {
|
||||||
this.folderId = null;
|
this.folderId = null;
|
||||||
this.collectionId = null;
|
this.collectionId = null;
|
||||||
|
Loading…
Reference in New Issue
Block a user