1fb726d48Sopenharmony_ci/*
2fb726d48Sopenharmony_ci * Copyright (C) 2022 Huawei Device Co., Ltd.
3fb726d48Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4fb726d48Sopenharmony_ci * you may not use this file except in compliance with the License.
5fb726d48Sopenharmony_ci * You may obtain a copy of the License at
6fb726d48Sopenharmony_ci *
7fb726d48Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8fb726d48Sopenharmony_ci *
9fb726d48Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10fb726d48Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11fb726d48Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12fb726d48Sopenharmony_ci * See the License for the specific language governing permissions and
13fb726d48Sopenharmony_ci * limitations under the License.
14fb726d48Sopenharmony_ci */
15fb726d48Sopenharmony_ci
16fb726d48Sopenharmony_ciimport { BaseElement, element } from '../../base-ui/BaseElement';
17fb726d48Sopenharmony_ciimport { SpKeyboardHtml } from './SpKeyboard.html';
18fb726d48Sopenharmony_ciimport { SpSystemTrace } from './SpSystemTrace';
19fb726d48Sopenharmony_ci
20fb726d48Sopenharmony_ci@element('sp-keyboard')
21fb726d48Sopenharmony_ciexport class SpKeyboard extends BaseElement {
22fb726d48Sopenharmony_ci  initElements(): void {
23fb726d48Sopenharmony_ci    let parentElement = this.parentNode as HTMLElement;
24fb726d48Sopenharmony_ci    parentElement.style.overflow = 'hidden';
25fb726d48Sopenharmony_ci    let closeWindow = this.shadowRoot?.querySelector('.close-icon');
26fb726d48Sopenharmony_ci    let keyboardDiv = document
27fb726d48Sopenharmony_ci      .querySelector('body > sp-application')!
28fb726d48Sopenharmony_ci      .shadowRoot!.querySelector<SpKeyboard>('#sp-keyboard')!;
29fb726d48Sopenharmony_ci    let shadow_box = this.shadowRoot?.querySelector('.shadow-box')!;
30fb726d48Sopenharmony_ci    closeWindow!.addEventListener('click', () => {
31fb726d48Sopenharmony_ci      keyboardDiv.style.visibility = 'hidden';
32fb726d48Sopenharmony_ci      SpSystemTrace.keyboardFlar = true;
33fb726d48Sopenharmony_ci    });
34fb726d48Sopenharmony_ci    shadow_box!.addEventListener('click', () => {
35fb726d48Sopenharmony_ci      keyboardDiv.style.visibility = 'hidden';
36fb726d48Sopenharmony_ci      SpSystemTrace.keyboardFlar = true;
37fb726d48Sopenharmony_ci    });
38fb726d48Sopenharmony_ci  }
39fb726d48Sopenharmony_ci
40fb726d48Sopenharmony_ci  initHtml(): string {
41fb726d48Sopenharmony_ci    return SpKeyboardHtml;
42fb726d48Sopenharmony_ci  }
43fb726d48Sopenharmony_ci}
44