mirror of
https://github.com/bitwarden/browser
synced 2025-12-17 16:53:34 +00:00
* Move event.service to it's own folder Move abstractions/event.service to abstractions/event/event.service Move services/event.service to services/event/event.service Fix all the imports * Extract event-upload from event.service Move `uploadEvents` from `EventService` to `EventUploadService` Create event-upload-service-factory Fix wiring up all the dependencies * Remove clearEvents from EventService clearEvents is only related to uploading events and can be moved into EventUploadService Change the logout-method to only call EventUploadService.uploadEvents as that also calls clearEvents internally * Rename EventService to EventCollectionService Rename libs\common\abstraction\event\event.service.ts to libs\common\abstractions\event\event-collection.service.ts Rename libs\common\services\event\event.service.ts to libs\common\services\event\event-collection.service.ts Fix all the imports Fix up service regristration/instantiation Reanme \browser\src\background\service_factories\event-service.factory.ts to \browser\src\background\service_factories\event-collection-service.factory.ts * Move interval to upload events to EventUploadSvc Move the `init()` from event-collection.service to event-upload.service Change call-site in web, desktop, browser
47 lines
1.3 KiB
TypeScript
47 lines
1.3 KiB
TypeScript
import { Directive, Input } from "@angular/core";
|
|
|
|
import { EventCollectionService } from "@bitwarden/common/abstractions/event/event-collection.service";
|
|
import { EventType } from "@bitwarden/common/enums/eventType";
|
|
import { FieldType } from "@bitwarden/common/enums/fieldType";
|
|
import { CipherView } from "@bitwarden/common/models/view/cipher.view";
|
|
import { FieldView } from "@bitwarden/common/models/view/field.view";
|
|
|
|
@Directive()
|
|
export class ViewCustomFieldsComponent {
|
|
@Input() cipher: CipherView;
|
|
@Input() promptPassword: () => Promise<boolean>;
|
|
@Input() copy: (value: string, typeI18nKey: string, aType: string) => void;
|
|
|
|
fieldType = FieldType;
|
|
|
|
constructor(private eventCollectionService: EventCollectionService) {}
|
|
|
|
async toggleFieldValue(field: FieldView) {
|
|
if (!(await this.promptPassword())) {
|
|
return;
|
|
}
|
|
|
|
const f = field as any;
|
|
f.showValue = !f.showValue;
|
|
f.showCount = false;
|
|
if (f.showValue) {
|
|
this.eventCollectionService.collect(
|
|
EventType.Cipher_ClientToggledHiddenFieldVisible,
|
|
this.cipher.id
|
|
);
|
|
}
|
|
}
|
|
|
|
async toggleFieldCount(field: FieldView) {
|
|
if (!field.showValue) {
|
|
return;
|
|
}
|
|
|
|
field.showCount = !field.showCount;
|
|
}
|
|
|
|
setTextDataOnDrag(event: DragEvent, data: string) {
|
|
event.dataTransfer.setData("text", data);
|
|
}
|
|
}
|