mirror of
https://github.com/bitwarden/browser.git
synced 2025-01-04 18:37:45 +01:00
billing updates
This commit is contained in:
parent
4557366154
commit
9a23d5fa97
@ -63,14 +63,14 @@
|
|||||||
<button type="button" class="btn btn-outline-secondary" (click)="updateLicense()">
|
<button type="button" class="btn btn-outline-secondary" (click)="updateLicense()">
|
||||||
{{'updateLicense' | i18n}}
|
{{'updateLicense' | i18n}}
|
||||||
</button>
|
</button>
|
||||||
<a href="https://vault.bitwarden.com/#/settings/billing" target="_blank" rel="noopener" class="btn btn-outline-secondary">
|
<a href="https://vault.bitwarden.com" target="_blank" rel="noopener" class="btn btn-outline-secondary">
|
||||||
{{'manageSubscription' | i18n}}
|
{{'manageSubscription' | i18n}}
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
<div class="card mt-3" *ngIf="showUpdateLicense">
|
<div class="card mt-3" *ngIf="showUpdateLicense">
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<h3 class="card-body-header">{{'updateLicense' | i18n}}</h3>
|
<h3 class="card-body-header">{{'updateLicense' | i18n}}</h3>
|
||||||
<app-update-license [user]="false" (onUpdated)="closeUpdateLicense(true)" (onCanceled)="closeUpdateLicense(false)"></app-update-license>
|
<app-update-license [organizationId]="organizationId" (onUpdated)="closeUpdateLicense(true)" (onCanceled)="closeUpdateLicense(false)"></app-update-license>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</ng-container>
|
</ng-container>
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
<form #form (ngSubmit)="submit()" [appApiAction]="formPromise" ngNativeValidate>
|
<form #form (ngSubmit)="submit()" [appApiAction]="formPromise" ngNativeValidate>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="file">{{'licenseFile' | i18n}}</label>
|
<label for="file" class="sr-only">{{'licenseFile' | i18n}}</label>
|
||||||
<input type="file" id="file" class="form-control-file" name="file" required>
|
<input type="file" id="file" class="form-control-file" name="file" required>
|
||||||
<small class="form-text text-muted">{{'licenseFileDesc' | i18n : (user ? 'bitwarden_premium_license.json' : 'bitwarden_organization_license.json')}}</small>
|
<small class="form-text text-muted">{{'licenseFileDesc' | i18n : (user ? 'bitwarden_premium_license.json' : 'bitwarden_organization_license.json')}}</small>
|
||||||
</div>
|
</div>
|
||||||
<button type="submit" class="btn btn-primary btn-submit" [disabled]="form.loading">
|
<button type="submit" class="btn btn-primary btn-submit" [disabled]="form.loading">
|
||||||
<i class="fa fa-spinner fa-spin"></i>
|
<i class="fa fa-spinner fa-spin" title="{{'loading' | i18n}}"></i>
|
||||||
<span>{{'submit' | i18n}}</span>
|
<span>{{'submit' | i18n}}</span>
|
||||||
</button>
|
</button>
|
||||||
<button type="button" class="btn btn-outline-secondary" (click)="cancel()">
|
<button type="button" class="btn btn-outline-secondary" (click)="cancel()">
|
||||||
|
@ -16,7 +16,7 @@ import { I18nService } from 'jslib/abstractions/i18n.service';
|
|||||||
templateUrl: 'update-license.component.html',
|
templateUrl: 'update-license.component.html',
|
||||||
})
|
})
|
||||||
export class UpdateLicenseComponent {
|
export class UpdateLicenseComponent {
|
||||||
@Input() user = true;
|
@Input() organizationId: string;
|
||||||
@Output() onUpdated = new EventEmitter();
|
@Output() onUpdated = new EventEmitter();
|
||||||
@Output() onCanceled = new EventEmitter();
|
@Output() onCanceled = new EventEmitter();
|
||||||
|
|
||||||
@ -38,10 +38,10 @@ export class UpdateLicenseComponent {
|
|||||||
const fd = new FormData();
|
const fd = new FormData();
|
||||||
fd.append('license', files[0]);
|
fd.append('license', files[0]);
|
||||||
|
|
||||||
if (this.user) {
|
if (this.organizationId == null) {
|
||||||
this.formPromise = this.apiService.postAccountLicense(fd);
|
this.formPromise = this.apiService.postAccountLicense(fd);
|
||||||
} else {
|
} else {
|
||||||
// TODO
|
this.formPromise = this.apiService.postOrganizationLicenseUpdate(this.organizationId, fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
await this.formPromise;
|
await this.formPromise;
|
||||||
|
@ -17,6 +17,10 @@
|
|||||||
<span>{{'reinstateSubscription' | i18n}}</span>
|
<span>{{'reinstateSubscription' | i18n}}</span>
|
||||||
</button>
|
</button>
|
||||||
</app-callout>
|
</app-callout>
|
||||||
|
<dl>
|
||||||
|
<dt>{{'subscription' | i18n}}</dt>
|
||||||
|
<dd>{{'premiumMembership' | i18n}}</dd>
|
||||||
|
</dl>
|
||||||
<dl *ngIf="selfHosted">
|
<dl *ngIf="selfHosted">
|
||||||
<dt>{{'expiration' | i18n}}</dt>
|
<dt>{{'expiration' | i18n}}</dt>
|
||||||
<dd *ngIf="billing.expiration">{{billing.expiration | date:'mediumDate'}}</dd>
|
<dd *ngIf="billing.expiration">{{billing.expiration | date:'mediumDate'}}</dd>
|
||||||
@ -64,7 +68,7 @@
|
|||||||
<div class="card mt-3" *ngIf="showUpdateLicense">
|
<div class="card mt-3" *ngIf="showUpdateLicense">
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<h3 class="card-body-header">{{'updateLicense' | i18n}}</h3>
|
<h3 class="card-body-header">{{'updateLicense' | i18n}}</h3>
|
||||||
<app-update-license [user]="true" (onUpdated)="closeUpdateLicense(true)" (onCanceled)="closeUpdateLicense(false)"></app-update-license>
|
<app-update-license (onUpdated)="closeUpdateLicense(true)" (onCanceled)="closeUpdateLicense(false)"></app-update-license>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</ng-container>
|
</ng-container>
|
||||||
|
@ -1020,7 +1020,8 @@
|
|||||||
"message": "Enabled"
|
"message": "Enabled"
|
||||||
},
|
},
|
||||||
"premium": {
|
"premium": {
|
||||||
"message": "Premium"
|
"message": "Premium",
|
||||||
|
"description": "Premium Membership"
|
||||||
},
|
},
|
||||||
"premiumMembership": {
|
"premiumMembership": {
|
||||||
"message": "Premium Membership"
|
"message": "Premium Membership"
|
||||||
@ -2294,5 +2295,11 @@
|
|||||||
},
|
},
|
||||||
"updateEncryptionKeyWarning": {
|
"updateEncryptionKeyWarning": {
|
||||||
"message": "After updating your encryption key, you are required to log out and back in to all Bitwarden applications that you are currently using (such as the mobile app or browser extensions). Failure to log out and back in (which downloads your new encryption key) may result in data corruption. We will attempt to log you out automatically, however, it may be delayed."
|
"message": "After updating your encryption key, you are required to log out and back in to all Bitwarden applications that you are currently using (such as the mobile app or browser extensions). Failure to log out and back in (which downloads your new encryption key) may result in data corruption. We will attempt to log you out automatically, however, it may be delayed."
|
||||||
|
},
|
||||||
|
"subscription": {
|
||||||
|
"message": "Subscription"
|
||||||
|
},
|
||||||
|
"loading": {
|
||||||
|
"message": "Loading"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user