mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-05 05:29:13 +01:00
Et2VfsPath: Fix unable to click on separators, so couldn't get to root
This commit is contained in:
parent
d87ef46eea
commit
0a5c5a432b
@ -64,7 +64,9 @@ export default css`
|
|||||||
|
|
||||||
sl-breadcrumb-item::part(separator) {
|
sl-breadcrumb-item::part(separator) {
|
||||||
color: var(--input-text-color);
|
color: var(--input-text-color);
|
||||||
margin: 0 var(--sl-spacing-2x-small);
|
margin: 0;
|
||||||
|
padding: 0 var(--sl-spacing-2x-small);
|
||||||
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Sizes */
|
/* Sizes */
|
||||||
|
@ -169,13 +169,18 @@ export class Et2VfsPath extends Et2InputWidget(LitElement)
|
|||||||
|
|
||||||
protected handlePathClick(event : MouseEvent)
|
protected handlePathClick(event : MouseEvent)
|
||||||
{
|
{
|
||||||
if(event.target instanceof SlBreadcrumbItem && event.composedPath().includes(this))
|
let target = event.target;
|
||||||
|
if(target.slot == "separator")
|
||||||
|
{
|
||||||
|
target = target.parentNode;
|
||||||
|
}
|
||||||
|
if(target instanceof SlBreadcrumbItem && event.composedPath().includes(this))
|
||||||
{
|
{
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
event.stopPropagation();
|
event.stopPropagation();
|
||||||
|
|
||||||
const dirs = Array.from(event.target.parentElement.querySelectorAll('sl-breadcrumb-item')) ?? [];
|
const dirs = Array.from(target.parentElement.querySelectorAll('sl-breadcrumb-item')) ?? [];
|
||||||
let stopIndex = dirs.indexOf(event.target) + 1;
|
let stopIndex = dirs.indexOf(target) + 1;
|
||||||
let newPath = dirs.slice(0, stopIndex)
|
let newPath = dirs.slice(0, stopIndex)
|
||||||
// Strip out any extra space
|
// Strip out any extra space
|
||||||
.map(d => d.textContent.trim().replace(/\/*$/, '').trim() + "/")
|
.map(d => d.textContent.trim().replace(/\/*$/, '').trim() + "/")
|
||||||
@ -188,8 +193,13 @@ export class Et2VfsPath extends Et2InputWidget(LitElement)
|
|||||||
if(!(this.disabled || this.readonly))
|
if(!(this.disabled || this.readonly))
|
||||||
{
|
{
|
||||||
const oldValue = this.value;
|
const oldValue = this.value;
|
||||||
|
this.value = newPath.join("")
|
||||||
|
|
||||||
// No trailing slash in the value
|
// No trailing slash in the value
|
||||||
this.value = newPath.join("").replace(/\/*$/, '');
|
if(this.value !== "/" && this.value.endsWith("/"))
|
||||||
|
{
|
||||||
|
this.value = this.value.replace(/\/*$/, '');
|
||||||
|
}
|
||||||
if(oldValue != this.value)
|
if(oldValue != this.value)
|
||||||
{
|
{
|
||||||
this.updateComplete.then(() =>
|
this.updateComplete.then(() =>
|
||||||
@ -217,7 +227,7 @@ export class Et2VfsPath extends Et2InputWidget(LitElement)
|
|||||||
const hasLabel = this.label ? true : !!hasLabelSlot;
|
const hasLabel = this.label ? true : !!hasLabelSlot;
|
||||||
const hasHelpText = this.helpText ? true : !!hasHelpTextSlot;
|
const hasHelpText = this.helpText ? true : !!hasHelpTextSlot;
|
||||||
// No trailing slash in the path
|
// No trailing slash in the path
|
||||||
const pathParts = this.value === "/" ? [""] : this.value
|
const pathParts = this.value === "/" ? ["/"] : this.value
|
||||||
// Remove trailing /
|
// Remove trailing /
|
||||||
.replace(/\/*$/, '')
|
.replace(/\/*$/, '')
|
||||||
.split('/');
|
.split('/');
|
||||||
|
Loading…
Reference in New Issue
Block a user