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