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