/*
* Copyright (C) 2022 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { BaseElement, element } from '../BaseElement.js';
let textColor = '';
@element('lit-main-menu-item')
export class LitMainMenuItem extends BaseElement {
private titleEl: HTMLElement | null | undefined;
private rootEL: HTMLElement | null | undefined;
private iconEl: HTMLElement | null | undefined;
private fileEL: HTMLInputElement | undefined | null;
static get observedAttributes() {
return ['title', 'icon', 'file', 'disabled'];
}
get title(): string {
return this.getAttribute('title') || '';
}
set title(val: string) {
this.setAttribute('title', val);
}
get disabled(): boolean {
return this.hasAttribute('disabled');
}
set disabled(val: boolean) {
if (val) {
this.setAttribute('disabled', val.toString());
this.fileEL?.setAttribute('disabled', val.toString());
} else {
this.removeAttribute('disabled');
this.fileEL?.removeAttribute('disabled');
}
}
get back(): boolean {
return this.hasAttribute('back');
}
set back(isShowBack: boolean) {
if (isShowBack) {
this.setAttribute('back', '');
} else {
this.removeAttribute('back');
}
}
initElements(): void {
this.rootEL = this.shadowRoot?.querySelector('.root');
this.titleEl = this.shadowRoot?.querySelector('.name');
this.iconEl = this.shadowRoot?.querySelector('.icon');
this.fileEL = this.shadowRoot?.querySelector('.file');
let backgroundColor = sessionStorage.getItem('backgroundColor');
if (backgroundColor == 'rgb(38, 47, 60)') {
textColor = 'white';
this.style.color = 'white';
} else {
textColor = 'black';
this.style.color = 'black';
}
}
isFile(): boolean {
if (this.hasAttribute('file')) {
if (this.fileEL) {
return true;
}
}
return false;
}
connectedCallback() {
if (this.hasAttribute('file')) {
if (this.fileEL) {
this.fileEL.addEventListener('change', () => {
let files = this.fileEL!.files;
if (files && files.length > 0) {
this.dispatchEvent(
new CustomEvent('file-change', {
// @ts-ignore
target: this,
detail: files[0],
})
);
if (this.fileEL) this.fileEL.value = '';
}
});
}
}
this.addEventListener('click', (e) => {
e.stopPropagation();
});
}
initHtml(): string {
return `
`;
}
attributeChangedCallback(name: string, oldValue: string, newValue: string) {
switch (name) {
case 'title':
if (this.titleEl) this.titleEl.textContent = newValue;
break;
case 'icon':
if (this.iconEl) this.iconEl.setAttribute('name', newValue);
break;
}
}
}