mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-20 12:58:46 +01:00
Better readonly styling
This commit is contained in:
parent
f13bf7b154
commit
fdd6f23560
@ -7,12 +7,12 @@
|
|||||||
* @author Nathan Gray
|
* @author Nathan Gray
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import {css, html, LitElement, SlotMixin} from "@lion/core";
|
import {css, html, LitElement, PropertyValues, SlotMixin} from "@lion/core";
|
||||||
import {Et2LinkAppSelect} from "./Et2LinkAppSelect";
|
import {Et2LinkAppSelect} from "./Et2LinkAppSelect";
|
||||||
import {Et2InputWidget} from "../Et2InputWidget/Et2InputWidget";
|
import {Et2InputWidget} from "../Et2InputWidget/Et2InputWidget";
|
||||||
import {FormControlMixin, ValidateMixin} from "@lion/form-core";
|
import {FormControlMixin, ValidateMixin} from "@lion/form-core";
|
||||||
import {Et2LinkSearch} from "./Et2LinkSearch";
|
import {Et2LinkSearch} from "./Et2LinkSearch";
|
||||||
import {LinkInfo} from "./Et2Link";
|
import {Et2Link, LinkInfo} from "./Et2Link";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Find and select a single entry using the link system.
|
* Find and select a single entry using the link system.
|
||||||
@ -132,8 +132,11 @@ export class Et2LinkEntry extends Et2InputWidget(FormControlMixin(ValidateMixin(
|
|||||||
// Clear initial value
|
// Clear initial value
|
||||||
this._value = undefined;
|
this._value = undefined;
|
||||||
|
|
||||||
|
if(!this.readonly)
|
||||||
|
{
|
||||||
this._bindListeners();
|
this._bindListeners();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
disconnectedCallback()
|
disconnectedCallback()
|
||||||
{
|
{
|
||||||
@ -141,6 +144,16 @@ export class Et2LinkEntry extends Et2InputWidget(FormControlMixin(ValidateMixin(
|
|||||||
this._unbindListeners();
|
this._unbindListeners();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
updated(changedProperties : PropertyValues)
|
||||||
|
{
|
||||||
|
super.updated(changedProperties);
|
||||||
|
if(changedProperties.has("readonly"))
|
||||||
|
{
|
||||||
|
this._appNode.readonly = this.readonly;
|
||||||
|
this._searchNode.readonly = this.readonly;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
set only_app(app)
|
set only_app(app)
|
||||||
{
|
{
|
||||||
this.__only_app = app || "";
|
this.__only_app = app || "";
|
||||||
@ -266,7 +279,7 @@ export class Et2LinkEntry extends Et2InputWidget(FormControlMixin(ValidateMixin(
|
|||||||
{
|
{
|
||||||
return this._searchNode?.value;
|
return this._searchNode?.value;
|
||||||
}
|
}
|
||||||
return this._searchNode ? {
|
return this._searchNode ? <LinkInfo>{
|
||||||
id: this._searchNode.value,
|
id: this._searchNode.value,
|
||||||
app: this.app,
|
app: this.app,
|
||||||
//search: this._searchNode... // content of search field
|
//search: this._searchNode... // content of search field
|
||||||
@ -328,5 +341,11 @@ export class Et2LinkEntry extends Et2InputWidget(FormControlMixin(ValidateMixin(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// @ts-ignore TypeScript is not recognizing that this widget is a LitElement
|
|
||||||
customElements.define("et2-link-entry", Et2LinkEntry);
|
customElements.define("et2-link-entry", Et2LinkEntry);
|
||||||
|
|
||||||
|
export class Et2LinkEntryReadonly extends Et2Link
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
customElements.define("et2-link-entry_ro", Et2LinkEntryReadonly);
|
||||||
|
@ -82,6 +82,10 @@ export class Et2LinkSearch extends Et2Select
|
|||||||
{
|
{
|
||||||
this._missingOption(this.value)
|
this._missingOption(this.value)
|
||||||
}
|
}
|
||||||
|
if(changedProperties.has("readonly"))
|
||||||
|
{
|
||||||
|
this.clearable = !this.readonly;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -385,6 +385,13 @@ export class Et2Select extends Et2WithSearchMixin(Et2InvokerMixin(Et2WidgetWithS
|
|||||||
tag.value = item.value;
|
tag.value = item.value;
|
||||||
tag.textContent = this.getItemLabel(item);
|
tag.textContent = this.getItemLabel(item);
|
||||||
tag.class = item.classList.value + " search_tag";
|
tag.class = item.classList.value + " search_tag";
|
||||||
|
if(this.readonly)
|
||||||
|
{
|
||||||
|
tag.removable = false;
|
||||||
|
tag.readonly = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
tag.addEventListener("dblclick", this._handleDoubleClick);
|
tag.addEventListener("dblclick", this._handleDoubleClick);
|
||||||
tag.addEventListener("click", this.handleTagInteraction);
|
tag.addEventListener("click", this.handleTagInteraction);
|
||||||
tag.addEventListener("keydown", this.handleTagInteraction);
|
tag.addEventListener("keydown", this.handleTagInteraction);
|
||||||
@ -397,6 +404,7 @@ export class Et2Select extends Et2WithSearchMixin(Et2InvokerMixin(Et2WidgetWithS
|
|||||||
this.syncValueFromItems();
|
this.syncValueFromItems();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
}
|
||||||
let image = this._createImage(item);
|
let image = this._createImage(item);
|
||||||
if(image)
|
if(image)
|
||||||
{
|
{
|
||||||
|
@ -122,7 +122,7 @@ export const Et2WithSearchMixin = <T extends Constructor<LitElement>>(superclass
|
|||||||
font-size: 120% !important;
|
font-size: 120% !important;
|
||||||
display:none;
|
display:none;
|
||||||
}
|
}
|
||||||
:host([search]) ::slotted([slot="suffix"]) {
|
:host([search]):not([readonly]) ::slotted([slot="suffix"]) {
|
||||||
display: initial;
|
display: initial;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -195,9 +195,27 @@ export const Et2WithSearchMixin = <T extends Constructor<LitElement>>(superclass
|
|||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
/* Different cursor for editable tags */
|
/* Different cursor for editable tags */
|
||||||
:host([allowfreeentries]) .search_tag::part(base) {
|
:host([allowfreeentries]):not([readonly]) .search_tag::part(base) {
|
||||||
cursor: text;
|
cursor: text;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Readonly **/
|
||||||
|
/* No border */
|
||||||
|
:host([readonly]) .form-control-input {
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
/* disable focus border */
|
||||||
|
:host([readonly]) .form-control-input:focus-within {
|
||||||
|
box-shadow: none;
|
||||||
|
}
|
||||||
|
/* no menu */
|
||||||
|
:host([readonly]) sl-menu {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
/* normal cursor */
|
||||||
|
:host([readonly]) .select__control {
|
||||||
|
cursor: initial;
|
||||||
|
}
|
||||||
`
|
`
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
@ -261,7 +279,8 @@ export const Et2WithSearchMixin = <T extends Constructor<LitElement>>(superclass
|
|||||||
this.classList.toggle("search", this.searchEnabled);
|
this.classList.toggle("search", this.searchEnabled);
|
||||||
|
|
||||||
// Missing any of the required attributes? Don't change anything.
|
// Missing any of the required attributes? Don't change anything.
|
||||||
if(!this.searchEnabled && !this.editModeEnabled)
|
// If readonly, skip it
|
||||||
|
if(!this.searchEnabled && !this.editModeEnabled || this.readonly)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -342,7 +361,7 @@ export const Et2WithSearchMixin = <T extends Constructor<LitElement>>(superclass
|
|||||||
*/
|
*/
|
||||||
public get searchEnabled() : boolean
|
public get searchEnabled() : boolean
|
||||||
{
|
{
|
||||||
return this.search || this.searchUrl.length > 0;
|
return !this.readonly && (this.search || this.searchUrl.length > 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected get _searchButtonNode()
|
protected get _searchButtonNode()
|
||||||
|
@ -29,9 +29,13 @@ export class Et2Tag extends Et2Widget(SlTag)
|
|||||||
height: 20px;
|
height: 20px;
|
||||||
width: 20px;
|
width: 20px;
|
||||||
}
|
}
|
||||||
|
.tag__content {
|
||||||
|
padding: 0px 0.2rem;
|
||||||
|
}
|
||||||
/* Avoid button getting truncated by right side of button */
|
/* Avoid button getting truncated by right side of button */
|
||||||
.tag__remove {
|
.tag__remove {
|
||||||
margin-right: 0;
|
margin-right: 0;
|
||||||
|
margin-left: 0;
|
||||||
}
|
}
|
||||||
`];
|
`];
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user