mirror of
https://github.com/bitwarden/browser
synced 2025-12-19 17:53:39 +00:00
* [CL-58] feat: add support for modyfing button types from directives * [CL-58] feat: set button type secondary when used as prefix/suffix * [CL-58] chore: add example using suffix to async actions story * [CL-58] feat: update story with examples * [CL-58] feat: allow buttons to have their style unset * [CL-58] feat: move all styling into prefix/suffix * [CL-58] fix: static content prefix/suffix * [CL-58] fix: add missing bitFormButton to bitAction * [CL-58] fix: disabled opacity not overriding correctly * [CL-58] feat: change hover color to muted * [CL-58] feat: replace undefined with unstyled * [CL-58] fix: focus borders on input and prefix/suffix * [CL-58] feat: update production code to use icon button correctly * [CL-58] refactor: move out button type to common place * [CL-58] fix: buttons not migrated correctly * [CL-58] feat: use icon button in password toggle * [CL-58] fix: remove button icon stories * [SM-358] Migrate password toggles (#4129) * [CL-58] fix: missing i18n service in story * [CL-58] fix: missing bitIconButton directive in export comp Co-authored-by: Oscar Hinton <Hinton@users.noreply.github.com> Co-authored-by: Thomas Rittson <trittson@bitwarden.com>
71 lines
1.7 KiB
TypeScript
71 lines
1.7 KiB
TypeScript
import {
|
|
AfterContentInit,
|
|
Directive,
|
|
EventEmitter,
|
|
Host,
|
|
HostBinding,
|
|
HostListener,
|
|
Input,
|
|
OnChanges,
|
|
Output,
|
|
} from "@angular/core";
|
|
|
|
import { I18nService } from "@bitwarden/common/abstractions/i18n.service";
|
|
|
|
import { BitIconButtonComponent } from "../icon-button/icon-button.component";
|
|
|
|
import { BitFormFieldComponent } from "./form-field.component";
|
|
|
|
@Directive({
|
|
selector: "[bitPasswordInputToggle]",
|
|
})
|
|
export class BitPasswordInputToggleDirective implements AfterContentInit, OnChanges {
|
|
/**
|
|
* Whether the input is toggled to show the password.
|
|
*/
|
|
@HostBinding("attr.aria-pressed") @Input() toggled = false;
|
|
@Output() toggledChange = new EventEmitter<boolean>();
|
|
|
|
@HostBinding("attr.title") title = this.i18nService.t("toggleVisibility");
|
|
@HostBinding("attr.aria-label") label = this.i18nService.t("toggleVisibility");
|
|
|
|
/**
|
|
* Click handler to toggle the state of the input type.
|
|
*/
|
|
@HostListener("click") onClick() {
|
|
this.toggled = !this.toggled;
|
|
this.toggledChange.emit(this.toggled);
|
|
|
|
this.update();
|
|
|
|
this.formField.input?.focus();
|
|
}
|
|
|
|
constructor(
|
|
@Host() private button: BitIconButtonComponent,
|
|
private formField: BitFormFieldComponent,
|
|
private i18nService: I18nService
|
|
) {}
|
|
|
|
get icon() {
|
|
return this.toggled ? "bwi-eye-slash" : "bwi-eye";
|
|
}
|
|
|
|
ngOnChanges(): void {
|
|
this.update();
|
|
}
|
|
|
|
ngAfterContentInit(): void {
|
|
this.toggled = this.formField.input.type !== "password";
|
|
this.button.icon = this.icon;
|
|
}
|
|
|
|
private update() {
|
|
this.button.icon = this.icon;
|
|
if (this.formField.input?.type != null) {
|
|
this.formField.input.type = this.toggled ? "text" : "password";
|
|
this.formField.input.spellcheck = this.toggled ? false : undefined;
|
|
}
|
|
}
|
|
}
|