2021-06-23 23:39:58 +02:00
|
|
|
/**
|
|
|
|
* EGroupware eTemplate2 - Button widget
|
|
|
|
*
|
|
|
|
* @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
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2021-07-14 17:49:36 +02:00
|
|
|
import BXButton from "../../../node_modules/carbon-web-components/es/components/button/button"
|
|
|
|
import {css} from "../../../node_modules/lit-element/lit-element.js";
|
|
|
|
import {Et2InputWidget} from "./et2_core_inputWidget";
|
|
|
|
import {Et2Widget} from "./et2_core_inheritance";
|
|
|
|
|
|
|
|
export class Et2Button extends Et2InputWidget(Et2Widget(BXButton))
|
2021-06-23 23:39:58 +02:00
|
|
|
{
|
2021-07-15 00:11:20 +02:00
|
|
|
private _icon: HTMLImageElement;
|
2021-07-14 17:49:36 +02:00
|
|
|
static get properties() {
|
|
|
|
return {
|
2021-07-15 00:11:20 +02:00
|
|
|
image: {type: String},
|
|
|
|
onclick: {type: Function}
|
2021-07-14 17:49:36 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
static get styles()
|
|
|
|
{
|
|
|
|
debugger;
|
|
|
|
return [
|
|
|
|
super.styles,
|
|
|
|
css`
|
|
|
|
/* Custom CSS */
|
|
|
|
`
|
|
|
|
];
|
|
|
|
}
|
|
|
|
constructor()
|
|
|
|
{
|
|
|
|
super();
|
2021-07-15 00:11:20 +02:00
|
|
|
|
|
|
|
// Property default values
|
2021-07-14 17:49:36 +02:00
|
|
|
this.image = '';
|
2021-07-15 00:11:20 +02:00
|
|
|
|
|
|
|
// Create icon since BXButton puts it as child, we put it as attribute
|
|
|
|
this._icon = document.createElement("img");
|
|
|
|
this._icon.slot="icon";
|
|
|
|
// Do not add this._icon here, no children can be added in constructor
|
|
|
|
|
|
|
|
this.onclick = () => {
|
|
|
|
debugger;
|
|
|
|
this.getInstanceManager().submit(this);
|
|
|
|
};
|
2021-07-14 17:49:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
connectedCallback() {
|
|
|
|
super.connectedCallback();
|
|
|
|
|
|
|
|
this.classList.add("et2_button")
|
|
|
|
debugger;
|
|
|
|
if(this.image)
|
|
|
|
{
|
2021-07-15 00:11:20 +02:00
|
|
|
this._icon.src = egw.image(this.image);
|
|
|
|
this.appendChild(this._icon);
|
2021-07-14 17:49:36 +02:00
|
|
|
}
|
|
|
|
}
|
2021-06-23 23:39:58 +02:00
|
|
|
}
|
2021-06-24 00:26:25 +02:00
|
|
|
customElements.define("et2-button",Et2Button);
|