1
0
mirror of https://github.com/bitwarden/browser.git synced 2025-01-19 20:51:35 +01:00

[PM-8333] Autofill refresh button for sidebar popup (Firefox) (#9314)

* [PM-8333] Ensure title suffix is aligned with title

* [PM-8333] Add refresh button for autofill list items section for FF sidebar

* [PM-8333] Add button type
This commit is contained in:
Shane Melton 2024-05-23 01:11:16 -07:00 committed by GitHub
parent 0b950080ca
commit 75975dd71f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 77 additions and 5 deletions

View File

@ -1,5 +1,5 @@
<div class="tw-flex tw-justify-between tw-items-end tw-gap-1 tw-px-1 tw-pb-1"> <div class="tw-flex tw-justify-between tw-items-end tw-gap-1 tw-px-1 tw-pb-1">
<div> <div class="tw-flex tw-items-center tw-gap-1">
<h2 bitTypography="h6" noMargin class="tw-mb-0 tw-text-headers"> <h2 bitTypography="h6" noMargin class="tw-mb-0 tw-text-headers">
{{ title }} {{ title }}
</h2> </h2>

View File

@ -1,4 +1,4 @@
import { Meta, StoryObj, moduleMetadata } from "@storybook/angular"; import { Meta, moduleMetadata, StoryObj } from "@storybook/angular";
import { import {
CardComponent, CardComponent,
@ -64,6 +64,20 @@ export const TailingIcon: Story = {
}, },
}; };
export const TitleSuffix: Story = {
render: (args) => ({
props: args,
template: `
<popup-section-header [title]="title">
<button bitIconButton="bwi-refresh" size="small" slot="title-suffix"></button>
</popup-section-header>
`,
}),
args: {
title: "Title Suffix",
},
};
export const WithSections: Story = { export const WithSections: Story = {
render: () => ({ render: () => ({
template: ` template: `

View File

@ -2,11 +2,23 @@
*ngIf="autofillCiphers$ | async as ciphers" *ngIf="autofillCiphers$ | async as ciphers"
[ciphers]="ciphers" [ciphers]="ciphers"
[title]="'autofillSuggestions' | i18n" [title]="'autofillSuggestions' | i18n"
[showRefresh]="showRefresh"
(onRefresh)="refreshCurrentTab()"
showAutoFill showAutoFill
></app-vault-list-items-container> ></app-vault-list-items-container>
<ng-container *ngIf="showEmptyAutofillTip$ | async"> <ng-container *ngIf="showEmptyAutofillTip$ | async">
<bit-section> <bit-section>
<popup-section-header [title]="'autofillSuggestions' | i18n"></popup-section-header> <popup-section-header [title]="'autofillSuggestions' | i18n">
<button
*ngIf="showRefresh"
bitIconButton="bwi-refresh"
size="small"
slot="title-suffix"
type="button"
[appA11yTitle]="'refresh' | i18n"
(click)="refreshCurrentTab()"
></button>
</popup-section-header>
<span class="tw-text-muted tw-px-1" bitTypography="body2">{{ <span class="tw-text-muted tw-px-1" bitTypography="body2">{{
"autofillSuggestionsTip" | i18n "autofillSuggestionsTip" | i18n
}}</span> }}</span>

View File

@ -4,8 +4,9 @@ import { combineLatest, map, Observable } from "rxjs";
import { JslibModule } from "@bitwarden/angular/jslib.module"; import { JslibModule } from "@bitwarden/angular/jslib.module";
import { CipherView } from "@bitwarden/common/vault/models/view/cipher.view"; import { CipherView } from "@bitwarden/common/vault/models/view/cipher.view";
import { SectionComponent, TypographyModule } from "@bitwarden/components"; import { IconButtonModule, SectionComponent, TypographyModule } from "@bitwarden/components";
import BrowserPopupUtils from "../../../../../platform/popup/browser-popup-utils";
import { PopupSectionHeaderComponent } from "../../../../../platform/popup/popup-section-header/popup-section-header.component"; import { PopupSectionHeaderComponent } from "../../../../../platform/popup/popup-section-header/popup-section-header.component";
import { VaultPopupItemsService } from "../../../services/vault-popup-items.service"; import { VaultPopupItemsService } from "../../../services/vault-popup-items.service";
import { VaultListItemsContainerComponent } from "../vault-list-items-container/vault-list-items-container.component"; import { VaultListItemsContainerComponent } from "../vault-list-items-container/vault-list-items-container.component";
@ -19,6 +20,7 @@ import { VaultListItemsContainerComponent } from "../vault-list-items-container/
VaultListItemsContainerComponent, VaultListItemsContainerComponent,
JslibModule, JslibModule,
PopupSectionHeaderComponent, PopupSectionHeaderComponent,
IconButtonModule,
], ],
selector: "app-autofill-vault-list-items", selector: "app-autofill-vault-list-items",
templateUrl: "autofill-vault-list-items.component.html", templateUrl: "autofill-vault-list-items.component.html",
@ -31,6 +33,12 @@ export class AutofillVaultListItemsComponent {
protected autofillCiphers$: Observable<CipherView[]> = protected autofillCiphers$: Observable<CipherView[]> =
this.vaultPopupItemsService.autoFillCiphers$; this.vaultPopupItemsService.autoFillCiphers$;
/**
* Flag indicating whether the refresh button should be shown. Only shown when the popup is within the FF sidebar.
* @protected
*/
protected showRefresh: boolean = BrowserPopupUtils.inSidebar(window);
/** /**
* Observable that determines whether the empty autofill tip should be shown. * Observable that determines whether the empty autofill tip should be shown.
* The tip is shown when there are no ciphers to autofill, no filter is applied, and autofill is allowed in * The tip is shown when there are no ciphers to autofill, no filter is applied, and autofill is allowed in
@ -48,4 +56,12 @@ export class AutofillVaultListItemsComponent {
constructor(private vaultPopupItemsService: VaultPopupItemsService) { constructor(private vaultPopupItemsService: VaultPopupItemsService) {
// TODO: Migrate logic to show Autofill policy toast PM-8144 // TODO: Migrate logic to show Autofill policy toast PM-8144
} }
/**
* Refreshes the current tab to re-populate the autofill ciphers.
* @protected
*/
protected refreshCurrentTab() {
this.vaultPopupItemsService.refreshCurrentTab();
}
} }

View File

@ -1,6 +1,15 @@
<bit-section *ngIf="ciphers?.length > 0"> <bit-section *ngIf="ciphers?.length > 0">
<popup-section-header [title]="title"> <popup-section-header [title]="title">
<span bitTypography="body2" slot="end">{{ ciphers.length }}</span> <span bitTypography="body2" slot="end">{{ ciphers.length }}</span>
<button
*ngIf="showRefresh"
bitIconButton="bwi-refresh"
type="button"
size="small"
slot="title-suffix"
(click)="onRefresh.emit()"
[appA11yTitle]="'refresh' | i18n"
></button>
</popup-section-header> </popup-section-header>
<bit-item-group> <bit-item-group>
<bit-item *ngFor="let cipher of ciphers"> <bit-item *ngFor="let cipher of ciphers">

View File

@ -1,5 +1,5 @@
import { CommonModule } from "@angular/common"; import { CommonModule } from "@angular/common";
import { booleanAttribute, Component, Input } from "@angular/core"; import { booleanAttribute, Component, EventEmitter, Input, Output } from "@angular/core";
import { RouterLink } from "@angular/router"; import { RouterLink } from "@angular/router";
import { JslibModule } from "@bitwarden/angular/jslib.module"; import { JslibModule } from "@bitwarden/angular/jslib.module";
@ -33,12 +33,33 @@ import { PopupSectionHeaderComponent } from "../../../../../platform/popup/popup
standalone: true, standalone: true,
}) })
export class VaultListItemsContainerComponent { export class VaultListItemsContainerComponent {
/**
* The list of ciphers to display.
*/
@Input() @Input()
ciphers: CipherView[]; ciphers: CipherView[];
/**
* Title for the vault list item section.
*/
@Input() @Input()
title: string; title: string;
/**
* Option to show a refresh button in the section header.
*/
@Input({ transform: booleanAttribute })
showRefresh: boolean;
/**
* Event emitted when the refresh button is clicked.
*/
@Output()
onRefresh = new EventEmitter<void>();
/**
* Option to show the autofill button for each item.
*/
@Input({ transform: booleanAttribute }) @Input({ transform: booleanAttribute })
showAutoFill: boolean; showAutoFill: boolean;
} }