blob: e9f107b415ef0a9bd7bd97046b4b1c7e7bcea7dc [file] [log] [blame]
// Copyright 2024 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import './ink_brush_selector.js';
import './ink_color_selector.js';
import './ink_size_selector.js';
import {CrLitElement} from 'chrome://resources/lit/v3_0/lit.rollup.js';
import {AnnotationBrushType} from '../constants.js';
import type {Color} from '../constants.js';
import {record, UserAction} from '../metrics.js';
import {getCss} from './viewer_side_panel.css.js';
import {getHtml} from './viewer_side_panel.html.js';
export class ViewerSidePanelElement extends CrLitElement {
static get is() {
return 'viewer-side-panel';
}
static override get styles() {
return getCss();
}
override render() {
return getHtml.bind(this)();
}
static override get properties() {
return {
currentColor: {type: Object},
currentSize: {type: Number},
currentType: {type: String},
};
}
currentColor?: Color;
currentSize: number = 0;
currentType: AnnotationBrushType = AnnotationBrushType.PEN;
constructor() {
super();
record(UserAction.OPEN_INK2_SIDE_PANEL);
}
protected shouldShowColorOptions_(): boolean {
return this.currentType !== AnnotationBrushType.ERASER;
}
}
declare global {
interface HTMLElementTagNameMap {
'viewer-side-panel': ViewerSidePanelElement;
}
}
customElements.define(ViewerSidePanelElement.is, ViewerSidePanelElement);