mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-23 22:38:54 +01:00
84 lines
1.6 KiB
TypeScript
84 lines
1.6 KiB
TypeScript
|
/**
|
||
|
* EGroupware eTemplate2 - Textbox widget (WebComponent)
|
||
|
*
|
||
|
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
||
|
* @package etemplate
|
||
|
* @subpackage api
|
||
|
* @link https://www.egroupware.org
|
||
|
* @author Nathan Gray
|
||
|
*/
|
||
|
|
||
|
|
||
|
import {css, html} from "@lion/core";
|
||
|
import {LionTextarea} from "@lion/textarea";
|
||
|
import {Et2InputWidget} from "../Et2InputWidget/Et2InputWidget";
|
||
|
import {Et2Widget} from "../Et2Widget/Et2Widget";
|
||
|
|
||
|
|
||
|
export class Et2Textarea extends Et2InputWidget(LionTextarea)
|
||
|
{
|
||
|
static get styles()
|
||
|
{
|
||
|
return [
|
||
|
...super.styles,
|
||
|
css`
|
||
|
:host {
|
||
|
display: flex;
|
||
|
flex-direction: column;
|
||
|
width: 100%;
|
||
|
height: 100%;
|
||
|
}
|
||
|
`,
|
||
|
];
|
||
|
}
|
||
|
|
||
|
static get properties()
|
||
|
{
|
||
|
return {
|
||
|
...super.properties,
|
||
|
/**
|
||
|
* Specify the width of the text area.
|
||
|
* If not set, it will expand to fill the space available.
|
||
|
*/
|
||
|
width: {type: String, reflect: true},
|
||
|
/**
|
||
|
* Specify the height of the text area.
|
||
|
* If not set, it will expand to fill the space available.
|
||
|
*/
|
||
|
height: {type: String, reflect: true},
|
||
|
onkeypress: Function,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
constructor()
|
||
|
{
|
||
|
super();
|
||
|
}
|
||
|
|
||
|
connectedCallback()
|
||
|
{
|
||
|
super.connectedCallback();
|
||
|
}
|
||
|
|
||
|
set width(value)
|
||
|
{
|
||
|
if(this._inputNode)
|
||
|
{
|
||
|
this._inputNode.style.width = value;
|
||
|
}
|
||
|
this.resizeTextarea();
|
||
|
}
|
||
|
|
||
|
set height(value)
|
||
|
{
|
||
|
if(this._inputNode)
|
||
|
{
|
||
|
this._inputNode.style.height = value;
|
||
|
}
|
||
|
this.resizeTextarea();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// @ts-ignore TypeScript is not recognizing that Et2Textarea is a LitElement
|
||
|
customElements.define("et2-textarea", Et2Textarea);
|