1
0
mirror of https://github.com/bitwarden/browser.git synced 2025-01-17 20:31:50 +01:00

[PM-4290] Add pop out warning on import page (#6645)

* No longer popout automatically

* Add FilePopoutCalloutComponent to import-browser

* Hide fileSelector on base import.component when callout is shown

Extend import.component to receive an input to show/hide the FileSelector
Extend import-browser to check if the callout should be shown via the filePopoutUtilsService and pass the returning value onto the base component

* Renamed showFileSelector to hideFileSelector

The default should be to show the fileSelector, so the input should reflect that as an override.

* Added newline between ngOnInit and method below

---------

Co-authored-by: Daniel James Smith <djsmith85@users.noreply.github.com>
This commit is contained in:
Daniel James Smith 2023-10-20 15:24:42 +02:00 committed by GitHub
parent 35ed8f1d5e
commit 8dc81b603d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 19 additions and 8 deletions

View File

@ -474,10 +474,7 @@ export class SettingsComponent implements OnInit {
} }
async import() { async import() {
await this.router.navigate(["/import"]); this.router.navigate(["/import"]);
if (await BrowserApi.isPopupOpen()) {
this.popupUtilsService.popOut(window);
}
} }
export() { export() {

View File

@ -16,9 +16,11 @@
</div> </div>
</header> </header>
<div tabindex="-1" class="tw-p-4"> <div tabindex="-1" class="tw-p-4">
<tools-file-popout-callout />
<tools-import <tools-import
(formDisabled)="this.disabled = $event" (formDisabled)="this.disabled = $event"
(formLoading)="this.loading = $event" (formLoading)="this.loading = $event"
(onSuccessfulImport)="this.onSuccessfulImport($event)" (onSuccessfulImport)="this.onSuccessfulImport($event)"
[hideFileSelector]="this.hideFileSelector"
></tools-import> ></tools-import>
</div> </div>

View File

@ -1,11 +1,14 @@
import { CommonModule } from "@angular/common"; import { CommonModule } from "@angular/common";
import { Component } from "@angular/core"; import { Component, OnInit } from "@angular/core";
import { Router, RouterLink } from "@angular/router"; import { Router, RouterLink } from "@angular/router";
import { JslibModule } from "@bitwarden/angular/jslib.module"; import { JslibModule } from "@bitwarden/angular/jslib.module";
import { AsyncActionsModule, ButtonModule, DialogModule } from "@bitwarden/components"; import { AsyncActionsModule, ButtonModule, DialogModule } from "@bitwarden/components";
import { ImportComponent } from "@bitwarden/importer/ui"; import { ImportComponent } from "@bitwarden/importer/ui";
import { FilePopoutCalloutComponent } from "../../components/file-popout-callout.component";
import { FilePopoutUtilsService } from "../../services/file-popout-utils.service";
@Component({ @Component({
templateUrl: "import-browser.component.html", templateUrl: "import-browser.component.html",
standalone: true, standalone: true,
@ -17,13 +20,20 @@ import { ImportComponent } from "@bitwarden/importer/ui";
AsyncActionsModule, AsyncActionsModule,
ButtonModule, ButtonModule,
ImportComponent, ImportComponent,
FilePopoutCalloutComponent,
], ],
}) })
export class ImportBrowserComponent { export class ImportBrowserComponent implements OnInit {
protected disabled = false; protected disabled = false;
protected loading = false; protected loading = false;
constructor(private router: Router) {} protected hideFileSelector = false;
constructor(private router: Router, private filePopoutUtilsService: FilePopoutUtilsService) {}
ngOnInit(): void {
this.hideFileSelector = this.filePopoutUtilsService.showFilePopoutMessage(window);
}
protected async onSuccessfulImport(organizationId: string): Promise<void> { protected async onSuccessfulImport(organizationId: string): Promise<void> {
this.router.navigate(["/tabs/settings"]); this.router.navigate(["/tabs/settings"]);

View File

@ -344,7 +344,7 @@
and save the zip file. and save the zip file.
</ng-container> </ng-container>
</bit-callout> </bit-callout>
<bit-form-field> <bit-form-field *ngIf="!hideFileSelector">
<bit-label>{{ "selectImportFile" | i18n }}</bit-label> <bit-label>{{ "selectImportFile" | i18n }}</bit-label>
<div class="file-selector"> <div class="file-selector">
<button bitButton type="button" buttonType="secondary" (click)="fileSelector.click()"> <button bitButton type="button" buttonType="secondary" (click)="fileSelector.click()">

View File

@ -120,6 +120,8 @@ export class ImportComponent implements OnInit, OnDestroy {
}); });
} }
@Input() hideFileSelector: boolean;
protected organization: Organization; protected organization: Organization;
protected destroy$ = new Subject<void>(); protected destroy$ = new Subject<void>();