mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-11 00:18:25 +01:00
- Add cssImage() to help with putting our images into LitElement CSS blocks
- Some code cleanup
This commit is contained in:
parent
85f753324d
commit
a48e6cf1d3
@ -11,7 +11,8 @@
|
|||||||
import {LionSelect} from "@lion/select";
|
import {LionSelect} from "@lion/select";
|
||||||
import {Et2InputWidget} from "../Et2InputWidget/Et2InputWidget";
|
import {Et2InputWidget} from "../Et2InputWidget/Et2InputWidget";
|
||||||
import {et2_readAttrWithDefault} from "../et2_core_xml";
|
import {et2_readAttrWithDefault} from "../et2_core_xml";
|
||||||
import {css, html, repeat} from "@lion/core";
|
import {css, html, repeat, TemplateResult} from "@lion/core";
|
||||||
|
import {cssImage} from "../Et2Widget/Et2Widget";
|
||||||
|
|
||||||
export interface SelectOption
|
export interface SelectOption
|
||||||
{
|
{
|
||||||
@ -19,8 +20,7 @@ export interface SelectOption
|
|||||||
label : String;
|
label : String;
|
||||||
// Hover help text
|
// Hover help text
|
||||||
title? : String;
|
title? : String;
|
||||||
};
|
}
|
||||||
|
|
||||||
|
|
||||||
export class Et2Select extends Et2InputWidget(LionSelect)
|
export class Et2Select extends Et2InputWidget(LionSelect)
|
||||||
{
|
{
|
||||||
@ -50,7 +50,7 @@ export class Et2Select extends Et2InputWidget(LionSelect)
|
|||||||
-moz-appearance: none;
|
-moz-appearance: none;
|
||||||
margin: 0;
|
margin: 0;
|
||||||
background: #fff no-repeat center right;
|
background: #fff no-repeat center right;
|
||||||
background-image: url('');
|
background-image: ${cssImage('arrow_down')};
|
||||||
background-size: 8px auto;
|
background-size: 8px auto;
|
||||||
background-position-x: calc(100% - 8px);
|
background-position-x: calc(100% - 8px);
|
||||||
text-indent: 5px;
|
text-indent: 5px;
|
||||||
@ -135,7 +135,7 @@ export class Et2Select extends Et2InputWidget(LionSelect)
|
|||||||
*
|
*
|
||||||
* @param {SelectOption[]} new_options
|
* @param {SelectOption[]} new_options
|
||||||
*/
|
*/
|
||||||
set_select_options(new_options : SelectOption[])
|
set_select_options(new_options : SelectOption[] | { [key : string] : string })
|
||||||
{
|
{
|
||||||
if(!Array.isArray(new_options))
|
if(!Array.isArray(new_options))
|
||||||
{
|
{
|
||||||
@ -204,7 +204,7 @@ export class Et2Select extends Et2InputWidget(LionSelect)
|
|||||||
// Read the option-tags
|
// Read the option-tags
|
||||||
let options = _node.querySelectorAll("option");
|
let options = _node.querySelectorAll("option");
|
||||||
let new_options = this._options;
|
let new_options = this._options;
|
||||||
for(var i = 0; i < options.length; i++)
|
for(let i = 0; i < options.length; i++)
|
||||||
{
|
{
|
||||||
new_options.push({
|
new_options.push({
|
||||||
value: et2_readAttrWithDefault(options[i], "value", options[i].textContent),
|
value: et2_readAttrWithDefault(options[i], "value", options[i].textContent),
|
||||||
@ -300,16 +300,20 @@ export function find_select_options(widget, attr_options?, attrs?)
|
|||||||
if(widget.getArrayMgr("sel_options"))
|
if(widget.getArrayMgr("sel_options"))
|
||||||
{
|
{
|
||||||
// Try first according to ID
|
// Try first according to ID
|
||||||
content_options = widget.getArrayMgr("sel_options").getEntry(widget.id);
|
let options = widget.getArrayMgr("sel_options").getEntry(widget.id);
|
||||||
// ID can get set to an array with 0 => ' ' - not useful
|
// ID can get set to an array with 0 => ' ' - not useful
|
||||||
if(content_options && (content_options.length == 1 && typeof content_options[0] == 'string' && content_options[0].trim() == '' ||
|
if(options && (options.length == 1 && typeof options[0] == 'string' && options[0].trim() == '' ||
|
||||||
// eg. autorepeated id "cat[3]" would pick array element 3 from cat
|
// eg. autorepeated id "cat[3]" would pick array element 3 from cat
|
||||||
typeof content_options.value != 'undefined' && typeof content_options.label != 'undefined' && widget.id.match(/\[\d+\]$/)))
|
typeof options.value != 'undefined' && typeof options.label != 'undefined' && widget.id.match(/\[\d+]$/)))
|
||||||
{
|
{
|
||||||
content_options = null;
|
content_options = null;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
content_options = options;
|
||||||
|
}
|
||||||
// We could wind up too far inside options if label,title are defined
|
// We could wind up too far inside options if label,title are defined
|
||||||
if(content_options && !isNaN(name_parts[name_parts.length - 1]) && content_options.label && content_options.title)
|
if(options && !isNaN(name_parts[name_parts.length - 1]) && options.label && options.title)
|
||||||
{
|
{
|
||||||
name_parts.pop();
|
name_parts.pop();
|
||||||
content_options = widget.getArrayMgr("sel_options").getEntry(name_parts.join('['));
|
content_options = widget.getArrayMgr("sel_options").getEntry(name_parts.join('['));
|
||||||
@ -334,7 +338,7 @@ export function find_select_options(widget, attr_options?, attrs?)
|
|||||||
let pop_that = JSON.parse(JSON.stringify(name_parts));
|
let pop_that = JSON.parse(JSON.stringify(name_parts));
|
||||||
while(pop_that.length > 1 && (!content_options || content_options.length == 0))
|
while(pop_that.length > 1 && (!content_options || content_options.length == 0))
|
||||||
{
|
{
|
||||||
var last = pop_that.pop();
|
let last = pop_that.pop();
|
||||||
content_options = widget.getArrayMgr('sel_options').getEntry(pop_that.join('['));
|
content_options = widget.getArrayMgr('sel_options').getEntry(pop_that.join('['));
|
||||||
|
|
||||||
// Double check, might have found a normal parent namespace ( eg subgrid in subgrid[selectbox] )
|
// Double check, might have found a normal parent namespace ( eg subgrid in subgrid[selectbox] )
|
||||||
@ -347,7 +351,7 @@ export function find_select_options(widget, attr_options?, attrs?)
|
|||||||
else if(content_options)
|
else if(content_options)
|
||||||
{
|
{
|
||||||
// Check for real values
|
// Check for real values
|
||||||
for(var key in content_options)
|
for(let key in content_options)
|
||||||
{
|
{
|
||||||
if(!(isNaN(<number><unknown>key) && typeof content_options[key] === 'string' ||
|
if(!(isNaN(<number><unknown>key) && typeof content_options[key] === 'string' ||
|
||||||
!isNaN(<number><unknown>key) && typeof content_options[key] === 'object' && typeof content_options[key]['value'] !== 'undefined'))
|
!isNaN(<number><unknown>key) && typeof content_options[key] === 'object' && typeof content_options[key]['value'] !== 'undefined'))
|
||||||
@ -363,7 +367,7 @@ export function find_select_options(widget, attr_options?, attrs?)
|
|||||||
|
|
||||||
// Maybe in a row, and options got stuck in ${row} instead of top level
|
// Maybe in a row, and options got stuck in ${row} instead of top level
|
||||||
// not sure this code is still needed, as server-side no longer creates ${row} or {$row} for select-options
|
// not sure this code is still needed, as server-side no longer creates ${row} or {$row} for select-options
|
||||||
var row_stuck = ['${row}', '{$row}'];
|
let row_stuck = ['${row}', '{$row}'];
|
||||||
for(let i = 0; i < row_stuck.length && (!content_options || content_options.length == 0); i++)
|
for(let i = 0; i < row_stuck.length && (!content_options || content_options.length == 0); i++)
|
||||||
{
|
{
|
||||||
// perspectiveData.row in nm, data["${row}"] in an auto-repeat grid
|
// perspectiveData.row in nm, data["${row}"] in an auto-repeat grid
|
||||||
@ -392,7 +396,7 @@ export function find_select_options(widget, attr_options?, attrs?)
|
|||||||
{
|
{
|
||||||
attr_options = content_options;
|
attr_options = content_options;
|
||||||
}
|
}
|
||||||
var content_mgr = widget.getArrayMgr('content');
|
let content_mgr = widget.getArrayMgr('content');
|
||||||
if(content_mgr)
|
if(content_mgr)
|
||||||
{
|
{
|
||||||
// If that didn't work, check according to ID
|
// If that didn't work, check according to ID
|
||||||
@ -419,11 +423,11 @@ export function find_select_options(widget, attr_options?, attrs?)
|
|||||||
{
|
{
|
||||||
for(let i in content_options)
|
for(let i in content_options)
|
||||||
{
|
{
|
||||||
var value = typeof content_options[i] == 'object' && typeof content_options[i].value !== 'undefined' ? content_options[i].value : i;
|
let value = typeof content_options[i] == 'object' && typeof content_options[i].value !== 'undefined' ? content_options[i].value : i;
|
||||||
var added = false;
|
let added = false;
|
||||||
|
|
||||||
// Override any existing
|
// Override any existing
|
||||||
for(var j in type_options)
|
for(let j in type_options)
|
||||||
{
|
{
|
||||||
if('' + type_options[j].value === '' + value)
|
if('' + type_options[j].value === '' + value)
|
||||||
{
|
{
|
||||||
@ -434,7 +438,7 @@ export function find_select_options(widget, attr_options?, attrs?)
|
|||||||
}
|
}
|
||||||
if(!added)
|
if(!added)
|
||||||
{
|
{
|
||||||
type_options.splice(i, 0, content_options[i]);
|
type_options.splice(parseInt(i), 0, content_options[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
content_options = type_options;
|
content_options = type_options;
|
||||||
|
@ -7,7 +7,7 @@ import {et2_cloneObject, et2_csvSplit} from "../et2_core_common";
|
|||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import type {IegwAppLocal} from "../../jsapi/egw_global";
|
import type {IegwAppLocal} from "../../jsapi/egw_global";
|
||||||
import {ClassWithAttributes, ClassWithInterfaces} from "../et2_core_inheritance";
|
import {ClassWithAttributes, ClassWithInterfaces} from "../et2_core_inheritance";
|
||||||
import {css, dedupeMixin} from "@lion/core";
|
import {css, dedupeMixin, unsafeCSS, CSSResult} from "@lion/core";
|
||||||
import type {et2_container} from "../et2_core_baseWidget";
|
import type {et2_container} from "../et2_core_baseWidget";
|
||||||
import type {et2_DOMWidget} from "../et2_core_DOMWidget";
|
import type {et2_DOMWidget} from "../et2_core_DOMWidget";
|
||||||
|
|
||||||
@ -1205,3 +1205,35 @@ function transformAttributes(widget, mgr : et2_arrayMgr, attributes)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Take the name of one of our images, find the full URL (including theme), and wrap it up so you can use it in a
|
||||||
|
* widget's css block.
|
||||||
|
*
|
||||||
|
* @example
|
||||||
|
* import {cssImage} from Et2Widget;
|
||||||
|
* ...
|
||||||
|
* static get styles()
|
||||||
|
* {
|
||||||
|
* return [
|
||||||
|
* ...super.styles,
|
||||||
|
* css`
|
||||||
|
* :host {
|
||||||
|
* background-image: cssImage("save");
|
||||||
|
* }
|
||||||
|
* `];
|
||||||
|
* }
|
||||||
|
* @param image_name
|
||||||
|
* @returns {CSSResult}
|
||||||
|
*/
|
||||||
|
export function cssImage(image_name : string, app_name? : string)
|
||||||
|
{
|
||||||
|
let url = egw.image(image_name, app_name);
|
||||||
|
if(url)
|
||||||
|
{
|
||||||
|
return css`url(${unsafeCSS(url)})`;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return css``;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user