@spectrum-web-components/split-view 1.1.0-beta.9 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +4 -4
- package/sp-split-view.d.ts +0 -6
- package/sp-split-view.dev.js +0 -5
- package/sp-split-view.dev.js.map +0 -7
- package/sp-split-view.js +0 -2
- package/sp-split-view.js.map +0 -7
- package/src/SplitView.d.ts +0 -68
- package/src/SplitView.dev.js +0 -370
- package/src/SplitView.dev.js.map +0 -7
- package/src/SplitView.js +0 -26
- package/src/SplitView.js.map +0 -7
- package/src/index.d.ts +0 -1
- package/src/index.dev.js +0 -3
- package/src/index.dev.js.map +0 -7
- package/src/index.js +0 -2
- package/src/index.js.map +0 -7
- package/src/spectrum-split-view.css.d.ts +0 -2
- package/src/spectrum-split-view.css.dev.js +0 -7
- package/src/spectrum-split-view.css.dev.js.map +0 -7
- package/src/spectrum-split-view.css.js +0 -4
- package/src/spectrum-split-view.css.js.map +0 -7
- package/src/split-view-overrides.css.d.ts +0 -2
- package/src/split-view-overrides.css.dev.js +0 -7
- package/src/split-view-overrides.css.dev.js.map +0 -7
- package/src/split-view-overrides.css.js +0 -4
- package/src/split-view-overrides.css.js.map +0 -7
- package/src/split-view.css.d.ts +0 -2
- package/src/split-view.css.dev.js +0 -7
- package/src/split-view.css.dev.js.map +0 -7
- package/src/split-view.css.js +0 -4
- package/src/split-view.css.js.map +0 -7
- package/src/types.d.ts +0 -13
- package/src/types.dev.js +0 -2
- package/src/types.dev.js.map +0 -7
- package/src/types.js +0 -2
- package/src/types.js.map +0 -7
- package/stories/split-view.stories.js +0 -286
- package/stories/split-view.stories.js.map +0 -7
- package/test/benchmark/basic-test.js +0 -11
- package/test/benchmark/basic-test.js.map +0 -7
- package/test/split-view-memory.test.js +0 -8
- package/test/split-view-memory.test.js.map +0 -7
- package/test/split-view.test-vrt.js +0 -5
- package/test/split-view.test-vrt.js.map +0 -7
- package/test/split-view.test.js +0 -977
- package/test/split-view.test.js.map +0 -7
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@spectrum-web-components/split-view",
|
3
|
-
"version": "1.1.0
|
3
|
+
"version": "1.1.0",
|
4
4
|
"publishConfig": {
|
5
5
|
"access": "public"
|
6
6
|
},
|
@@ -62,10 +62,10 @@
|
|
62
62
|
"lit-html"
|
63
63
|
],
|
64
64
|
"dependencies": {
|
65
|
-
"@spectrum-web-components/base": "^1.1.0
|
65
|
+
"@spectrum-web-components/base": "^1.1.0"
|
66
66
|
},
|
67
67
|
"devDependencies": {
|
68
|
-
"@spectrum-css/splitview": "
|
68
|
+
"@spectrum-css/splitview": "6.0.0-s2-foundations.16"
|
69
69
|
},
|
70
70
|
"types": "./src/index.d.ts",
|
71
71
|
"customElements": "custom-elements.json",
|
@@ -73,5 +73,5 @@
|
|
73
73
|
"./sp-*.js",
|
74
74
|
"./**/*.dev.js"
|
75
75
|
],
|
76
|
-
"gitHead": "
|
76
|
+
"gitHead": "e3c6e52501451acc6fa85b10dd718267b80a01ab"
|
77
77
|
}
|
package/sp-split-view.d.ts
DELETED
package/sp-split-view.dev.js
DELETED
package/sp-split-view.dev.js.map
DELETED
@@ -1,7 +0,0 @@
|
|
1
|
-
{
|
2
|
-
"version": 3,
|
3
|
-
"sources": ["sp-split-view.ts"],
|
4
|
-
"sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport { SplitView } from './src/SplitView.dev.js'\nimport { defineElement } from '@spectrum-web-components/base/src/define-element.js';\n\ndefineElement('sp-split-view', SplitView);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'sp-split-view': SplitView;\n }\n}\n"],
|
5
|
-
"mappings": ";AAYA,SAAS,iBAAiB;AAC1B,SAAS,qBAAqB;AAE9B,cAAc,iBAAiB,SAAS;",
|
6
|
-
"names": []
|
7
|
-
}
|
package/sp-split-view.js
DELETED
package/sp-split-view.js.map
DELETED
@@ -1,7 +0,0 @@
|
|
1
|
-
{
|
2
|
-
"version": 3,
|
3
|
-
"sources": ["sp-split-view.ts"],
|
4
|
-
"sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport { SplitView } from './src/SplitView.js';\nimport { defineElement } from '@spectrum-web-components/base/src/define-element.js';\n\ndefineElement('sp-split-view', SplitView);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'sp-split-view': SplitView;\n }\n}\n"],
|
5
|
-
"mappings": "aAYA,OAAS,aAAAA,MAAiB,qBAC1B,OAAS,iBAAAC,MAAqB,sDAE9BA,EAAc,gBAAiBD,CAAS",
|
6
|
-
"names": ["SplitView", "defineElement"]
|
7
|
-
}
|
package/src/SplitView.d.ts
DELETED
@@ -1,68 +0,0 @@
|
|
1
|
-
import { CSSResultArray, PropertyValues, SpectrumElement, TemplateResult } from '@spectrum-web-components/base';
|
2
|
-
/**
|
3
|
-
* @element sp-split-view
|
4
|
-
*
|
5
|
-
* @slot Two sibling elements to be sized by the element attritubes
|
6
|
-
* @fires change - Announces the new position of the splitter
|
7
|
-
*/
|
8
|
-
export declare class SplitView extends SpectrumElement {
|
9
|
-
static get styles(): CSSResultArray;
|
10
|
-
controlledEl?: HTMLElement;
|
11
|
-
vertical: boolean;
|
12
|
-
resizable: boolean;
|
13
|
-
collapsible: boolean;
|
14
|
-
/** The minimum size of the primary pane */
|
15
|
-
primaryMin: number;
|
16
|
-
/** The maximum size of the primary pane */
|
17
|
-
primaryMax: number;
|
18
|
-
/**
|
19
|
-
* The start size of the primary pane, can be a real pixel number|string, percentage or "auto"
|
20
|
-
* For example: "100", "120px", "75%" or "auto" are valid values
|
21
|
-
* @type {number | number + "px" | number + "%" | "auto"}
|
22
|
-
* @attr
|
23
|
-
*/
|
24
|
-
primarySize?: string;
|
25
|
-
/** The minimum size of the secondary pane */
|
26
|
-
secondaryMin: number;
|
27
|
-
/** The maximum size of the secondary pane */
|
28
|
-
secondaryMax: number;
|
29
|
-
/** The current splitter position of split-view */
|
30
|
-
splitterPos?: number;
|
31
|
-
/** The current size of first pane of split-view */
|
32
|
-
private firstPaneSize;
|
33
|
-
label?: string;
|
34
|
-
private enoughChildren;
|
35
|
-
private viewSize;
|
36
|
-
private paneSlot;
|
37
|
-
private splitter;
|
38
|
-
private offset;
|
39
|
-
private minPos;
|
40
|
-
private maxPos;
|
41
|
-
private observer?;
|
42
|
-
private rect?;
|
43
|
-
private _splitterSize?;
|
44
|
-
constructor();
|
45
|
-
connectedCallback(): void;
|
46
|
-
disconnectedCallback(): void;
|
47
|
-
/**
|
48
|
-
* @private
|
49
|
-
**/
|
50
|
-
get splitterSize(): number;
|
51
|
-
protected render(): TemplateResult;
|
52
|
-
private controlledElIDApplied;
|
53
|
-
private onContentSlotChange;
|
54
|
-
private onPointerdown;
|
55
|
-
private onPointermove;
|
56
|
-
private onPointerup;
|
57
|
-
private getOffset;
|
58
|
-
private getPosition;
|
59
|
-
private movePosition;
|
60
|
-
private onKeydown;
|
61
|
-
private checkResize;
|
62
|
-
private updateMinMax;
|
63
|
-
private updatePosition;
|
64
|
-
private getLimitedPosition;
|
65
|
-
private calcStartPos;
|
66
|
-
private dispatchChangeEvent;
|
67
|
-
protected willUpdate(changed: PropertyValues): void;
|
68
|
-
}
|
package/src/SplitView.dev.js
DELETED
@@ -1,370 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
var __defProp = Object.defineProperty;
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
4
|
-
var __decorateClass = (decorators, target, key, kind) => {
|
5
|
-
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
6
|
-
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
7
|
-
if (decorator = decorators[i])
|
8
|
-
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
9
|
-
if (kind && result) __defProp(target, key, result);
|
10
|
-
return result;
|
11
|
-
};
|
12
|
-
import {
|
13
|
-
html,
|
14
|
-
nothing,
|
15
|
-
SpectrumElement
|
16
|
-
} from "@spectrum-web-components/base";
|
17
|
-
import {
|
18
|
-
classMap,
|
19
|
-
ifDefined
|
20
|
-
} from "@spectrum-web-components/base/src/directives.js";
|
21
|
-
import {
|
22
|
-
property,
|
23
|
-
query,
|
24
|
-
state
|
25
|
-
} from "@spectrum-web-components/base/src/decorators.js";
|
26
|
-
import { streamingListener } from "@spectrum-web-components/base/src/streaming-listener.js";
|
27
|
-
import { randomID } from "@spectrum-web-components/shared/src/random-id.js";
|
28
|
-
import styles from "./split-view.css.js";
|
29
|
-
const DEFAULT_MAX_SIZE = 3840;
|
30
|
-
const SPLITTERSIZE = 2;
|
31
|
-
const ARROW_KEY_CHANGE_VALUE = 10;
|
32
|
-
const PAGEUPDOWN_KEY_CHANGE_VALUE = 50;
|
33
|
-
const COLLAPSE_THREASHOLD = 50;
|
34
|
-
export class SplitView extends SpectrumElement {
|
35
|
-
constructor() {
|
36
|
-
super();
|
37
|
-
this.vertical = false;
|
38
|
-
this.resizable = false;
|
39
|
-
this.collapsible = false;
|
40
|
-
this.primaryMin = 0;
|
41
|
-
this.primaryMax = DEFAULT_MAX_SIZE;
|
42
|
-
this.secondaryMin = 0;
|
43
|
-
this.secondaryMax = DEFAULT_MAX_SIZE;
|
44
|
-
this.firstPaneSize = "auto";
|
45
|
-
this.enoughChildren = false;
|
46
|
-
this.viewSize = 0;
|
47
|
-
this.offset = 0;
|
48
|
-
this.minPos = 0;
|
49
|
-
this.maxPos = DEFAULT_MAX_SIZE;
|
50
|
-
this.controlledElIDApplied = false;
|
51
|
-
const RO = window.ResizeObserver;
|
52
|
-
if (RO) {
|
53
|
-
this.observer = new RO(() => {
|
54
|
-
this.rect = void 0;
|
55
|
-
this.updateMinMax();
|
56
|
-
});
|
57
|
-
}
|
58
|
-
}
|
59
|
-
static get styles() {
|
60
|
-
return [styles];
|
61
|
-
}
|
62
|
-
connectedCallback() {
|
63
|
-
var _a;
|
64
|
-
super.connectedCallback();
|
65
|
-
(_a = this.observer) == null ? void 0 : _a.observe(this);
|
66
|
-
}
|
67
|
-
disconnectedCallback() {
|
68
|
-
var _a;
|
69
|
-
(_a = this.observer) == null ? void 0 : _a.unobserve(this);
|
70
|
-
super.disconnectedCallback();
|
71
|
-
}
|
72
|
-
/**
|
73
|
-
* @private
|
74
|
-
**/
|
75
|
-
get splitterSize() {
|
76
|
-
if (!this._splitterSize) {
|
77
|
-
this._splitterSize = this.splitter && Math.round(
|
78
|
-
parseFloat(
|
79
|
-
window.getComputedStyle(this.splitter).getPropertyValue(
|
80
|
-
this.vertical ? "height" : "width"
|
81
|
-
)
|
82
|
-
)
|
83
|
-
) || SPLITTERSIZE;
|
84
|
-
}
|
85
|
-
return this._splitterSize;
|
86
|
-
}
|
87
|
-
render() {
|
88
|
-
var _a, _b;
|
89
|
-
const splitterClasses = {
|
90
|
-
"is-resized-start": this.splitterPos === this.minPos,
|
91
|
-
"is-resized-end": this.splitterPos && this.splitterPos > this.splitterSize && this.splitterPos === this.maxPos,
|
92
|
-
"is-collapsed-start": this.splitterPos === 0,
|
93
|
-
"is-collapsed-end": this.splitterPos && this.splitterPos >= Math.max(
|
94
|
-
this.splitterSize,
|
95
|
-
this.viewSize - this.splitterSize
|
96
|
-
)
|
97
|
-
};
|
98
|
-
const label = this.resizable ? this.label || "Resize the panels" : void 0;
|
99
|
-
return html`
|
100
|
-
<slot
|
101
|
-
id=${ifDefined(
|
102
|
-
this.resizable ? (_a = this.controlledEl) == null ? void 0 : _a.id : void 0
|
103
|
-
)}
|
104
|
-
@slotchange=${this.onContentSlotChange}
|
105
|
-
style="--spectrum-split-view-first-pane-size: ${this.firstPaneSize}"
|
106
|
-
></slot>
|
107
|
-
${this.enoughChildren ? html`
|
108
|
-
<div
|
109
|
-
id="splitter"
|
110
|
-
class=${classMap(splitterClasses)}
|
111
|
-
role="separator"
|
112
|
-
aria-controls=${ifDefined(
|
113
|
-
this.resizable ? (_b = this.controlledEl) == null ? void 0 : _b.id : void 0
|
114
|
-
)}
|
115
|
-
aria-label=${ifDefined(label)}
|
116
|
-
aria-orientation=${this.vertical ? "horizontal" : "vertical"}
|
117
|
-
aria-valuenow=${Math.round(
|
118
|
-
parseFloat(this.firstPaneSize) / this.viewSize * 100
|
119
|
-
)}
|
120
|
-
tabindex=${ifDefined(
|
121
|
-
this.resizable ? "0" : void 0
|
122
|
-
)}
|
123
|
-
@keydown=${this.onKeydown}
|
124
|
-
${streamingListener({
|
125
|
-
start: ["pointerdown", this.onPointerdown],
|
126
|
-
streamInside: ["pointermove", this.onPointermove],
|
127
|
-
end: [
|
128
|
-
[
|
129
|
-
"pointerup",
|
130
|
-
"pointercancel",
|
131
|
-
"pointerleave"
|
132
|
-
],
|
133
|
-
this.onPointerup
|
134
|
-
]
|
135
|
-
})}
|
136
|
-
>
|
137
|
-
${this.resizable ? html`
|
138
|
-
<div id="gripper"></div>
|
139
|
-
` : nothing}
|
140
|
-
</div>
|
141
|
-
` : nothing}
|
142
|
-
`;
|
143
|
-
}
|
144
|
-
onContentSlotChange(event) {
|
145
|
-
if (this.controlledEl && this.controlledElIDApplied) {
|
146
|
-
this.controlledEl.removeAttribute("id");
|
147
|
-
this.controlledElIDApplied = false;
|
148
|
-
}
|
149
|
-
this.controlledEl = event.target.assignedElements()[0];
|
150
|
-
if (this.controlledEl && !this.controlledEl.id) {
|
151
|
-
this.controlledEl.id = `${this.tagName.toLowerCase()}-${randomID()}`;
|
152
|
-
this.controlledElIDApplied = true;
|
153
|
-
}
|
154
|
-
this.enoughChildren = this.children.length > 1;
|
155
|
-
this.checkResize();
|
156
|
-
}
|
157
|
-
onPointerdown(event) {
|
158
|
-
if (!this.resizable || event.button && event.button !== 0) {
|
159
|
-
event.preventDefault();
|
160
|
-
return;
|
161
|
-
}
|
162
|
-
this.splitter.setPointerCapture(event.pointerId);
|
163
|
-
this.offset = this.getOffset();
|
164
|
-
}
|
165
|
-
onPointermove(event) {
|
166
|
-
event.preventDefault();
|
167
|
-
let pos = this.vertical || this.isLTR ? this.getPosition(event) - this.offset : this.offset - this.getPosition(event);
|
168
|
-
if (this.collapsible && pos < this.minPos - COLLAPSE_THREASHOLD) {
|
169
|
-
pos = 0;
|
170
|
-
}
|
171
|
-
if (this.collapsible && pos > this.maxPos + COLLAPSE_THREASHOLD) {
|
172
|
-
pos = this.viewSize - this.splitterSize;
|
173
|
-
}
|
174
|
-
this.updatePosition(pos);
|
175
|
-
}
|
176
|
-
onPointerup(event) {
|
177
|
-
this.splitter.releasePointerCapture(event.pointerId);
|
178
|
-
}
|
179
|
-
getOffset() {
|
180
|
-
if (!this.rect) {
|
181
|
-
this.rect = this.getBoundingClientRect();
|
182
|
-
}
|
183
|
-
const offsetX = this.isLTR ? this.rect.left : this.rect.right;
|
184
|
-
return this.vertical ? this.rect.top : offsetX;
|
185
|
-
}
|
186
|
-
getPosition(event) {
|
187
|
-
return this.vertical ? event.clientY : event.clientX;
|
188
|
-
}
|
189
|
-
movePosition(event, offset) {
|
190
|
-
event.preventDefault();
|
191
|
-
if (this.splitterPos !== void 0) {
|
192
|
-
this.updatePosition(this.splitterPos + offset);
|
193
|
-
}
|
194
|
-
}
|
195
|
-
onKeydown(event) {
|
196
|
-
if (!this.resizable) {
|
197
|
-
return;
|
198
|
-
}
|
199
|
-
let direction = 0;
|
200
|
-
const isLTRorVertical = this.isLTR || this.vertical;
|
201
|
-
switch (event.key) {
|
202
|
-
case "Home":
|
203
|
-
event.preventDefault();
|
204
|
-
this.updatePosition(this.collapsible ? 0 : this.minPos);
|
205
|
-
return;
|
206
|
-
case "End":
|
207
|
-
event.preventDefault();
|
208
|
-
this.updatePosition(
|
209
|
-
this.collapsible ? this.viewSize - this.splitterSize : this.maxPos
|
210
|
-
);
|
211
|
-
return;
|
212
|
-
case "ArrowLeft":
|
213
|
-
direction = isLTRorVertical ? -1 : 1;
|
214
|
-
break;
|
215
|
-
case "ArrowRight":
|
216
|
-
direction = isLTRorVertical ? 1 : -1;
|
217
|
-
break;
|
218
|
-
case "ArrowUp":
|
219
|
-
direction = this.vertical ? -1 : 1;
|
220
|
-
break;
|
221
|
-
case "ArrowDown":
|
222
|
-
direction = this.vertical ? 1 : -1;
|
223
|
-
break;
|
224
|
-
case "PageUp":
|
225
|
-
direction = this.vertical ? -1 : 1;
|
226
|
-
break;
|
227
|
-
case "PageDown":
|
228
|
-
direction = this.vertical ? 1 : -1;
|
229
|
-
break;
|
230
|
-
}
|
231
|
-
if (direction !== 0) {
|
232
|
-
const moveBy = event.key.startsWith("Page") ? PAGEUPDOWN_KEY_CHANGE_VALUE : ARROW_KEY_CHANGE_VALUE;
|
233
|
-
this.movePosition(event, moveBy * direction);
|
234
|
-
}
|
235
|
-
}
|
236
|
-
async checkResize() {
|
237
|
-
if (!this.enoughChildren) {
|
238
|
-
return;
|
239
|
-
}
|
240
|
-
this.updateMinMax();
|
241
|
-
if (this.splitterPos === void 0) {
|
242
|
-
const startPos = await this.calcStartPos();
|
243
|
-
this.updatePosition(startPos);
|
244
|
-
}
|
245
|
-
}
|
246
|
-
updateMinMax() {
|
247
|
-
this.viewSize = this.vertical ? this.offsetHeight : this.offsetWidth;
|
248
|
-
this.minPos = Math.max(
|
249
|
-
this.primaryMin,
|
250
|
-
this.viewSize - this.secondaryMax
|
251
|
-
);
|
252
|
-
this.maxPos = Math.min(
|
253
|
-
this.primaryMax,
|
254
|
-
this.viewSize - Math.max(this.secondaryMin, this.splitterSize)
|
255
|
-
);
|
256
|
-
}
|
257
|
-
updatePosition(x) {
|
258
|
-
let pos = this.getLimitedPosition(x);
|
259
|
-
if (this.collapsible && x <= 0) {
|
260
|
-
pos = 0;
|
261
|
-
}
|
262
|
-
if (this.collapsible && x > this.maxPos && x >= this.viewSize - this.splitterSize) {
|
263
|
-
pos = this.viewSize - this.splitterSize;
|
264
|
-
}
|
265
|
-
if (pos !== this.splitterPos) {
|
266
|
-
this.splitterPos = pos;
|
267
|
-
this.dispatchChangeEvent();
|
268
|
-
}
|
269
|
-
}
|
270
|
-
getLimitedPosition(input) {
|
271
|
-
if (input <= this.minPos) {
|
272
|
-
return this.minPos;
|
273
|
-
}
|
274
|
-
if (input >= this.maxPos) {
|
275
|
-
return this.maxPos;
|
276
|
-
}
|
277
|
-
return Math.max(this.minPos, Math.min(this.maxPos, input));
|
278
|
-
}
|
279
|
-
async calcStartPos() {
|
280
|
-
if (this.primarySize !== void 0 && /^\d+(px)?$/.test(this.primarySize)) {
|
281
|
-
return parseInt(this.primarySize, 10);
|
282
|
-
}
|
283
|
-
if (this.primarySize !== void 0 && /^\d+%$/.test(this.primarySize)) {
|
284
|
-
return parseInt(this.primarySize, 10) * this.viewSize / 100;
|
285
|
-
}
|
286
|
-
if (this.primarySize === "auto") {
|
287
|
-
this.firstPaneSize = "auto";
|
288
|
-
const nodes = this.paneSlot.assignedNodes({ flatten: true });
|
289
|
-
const firstEl = nodes.find(
|
290
|
-
(node) => node instanceof HTMLElement
|
291
|
-
);
|
292
|
-
if (typeof firstEl.updateComplete !== "undefined") {
|
293
|
-
await firstEl.updateComplete;
|
294
|
-
}
|
295
|
-
if (firstEl) {
|
296
|
-
const size = window.getComputedStyle(firstEl).getPropertyValue(this.vertical ? "height" : "width");
|
297
|
-
const size_i = parseFloat(size);
|
298
|
-
if (!isNaN(size_i)) {
|
299
|
-
return this.getLimitedPosition(Math.ceil(size_i));
|
300
|
-
}
|
301
|
-
}
|
302
|
-
}
|
303
|
-
return this.viewSize / 2;
|
304
|
-
}
|
305
|
-
dispatchChangeEvent() {
|
306
|
-
const changeEvent = new Event("change", {
|
307
|
-
bubbles: true,
|
308
|
-
composed: true
|
309
|
-
});
|
310
|
-
this.dispatchEvent(changeEvent);
|
311
|
-
}
|
312
|
-
willUpdate(changed) {
|
313
|
-
if (!this.hasUpdated || changed.has("primarySize")) {
|
314
|
-
this.splitterPos = void 0;
|
315
|
-
this.checkResize();
|
316
|
-
}
|
317
|
-
if (changed.has("splitterPos") && this.splitterPos !== void 0 && this.enoughChildren) {
|
318
|
-
this.firstPaneSize = `${Math.round(this.splitterPos)}px`;
|
319
|
-
}
|
320
|
-
}
|
321
|
-
}
|
322
|
-
__decorateClass([
|
323
|
-
state()
|
324
|
-
], SplitView.prototype, "controlledEl", 2);
|
325
|
-
__decorateClass([
|
326
|
-
property({ type: Boolean, reflect: true })
|
327
|
-
], SplitView.prototype, "vertical", 2);
|
328
|
-
__decorateClass([
|
329
|
-
property({ type: Boolean, reflect: true })
|
330
|
-
], SplitView.prototype, "resizable", 2);
|
331
|
-
__decorateClass([
|
332
|
-
property({ type: Boolean, reflect: true })
|
333
|
-
], SplitView.prototype, "collapsible", 2);
|
334
|
-
__decorateClass([
|
335
|
-
property({ type: Number, attribute: "primary-min" })
|
336
|
-
], SplitView.prototype, "primaryMin", 2);
|
337
|
-
__decorateClass([
|
338
|
-
property({ type: Number, attribute: "primary-max" })
|
339
|
-
], SplitView.prototype, "primaryMax", 2);
|
340
|
-
__decorateClass([
|
341
|
-
property({ type: String, attribute: "primary-size" })
|
342
|
-
], SplitView.prototype, "primarySize", 2);
|
343
|
-
__decorateClass([
|
344
|
-
property({ type: Number, attribute: "secondary-min" })
|
345
|
-
], SplitView.prototype, "secondaryMin", 2);
|
346
|
-
__decorateClass([
|
347
|
-
property({ type: Number, attribute: "secondary-max" })
|
348
|
-
], SplitView.prototype, "secondaryMax", 2);
|
349
|
-
__decorateClass([
|
350
|
-
property({ type: Number, reflect: true, attribute: "splitter-pos" })
|
351
|
-
], SplitView.prototype, "splitterPos", 2);
|
352
|
-
__decorateClass([
|
353
|
-
property({ type: String, attribute: false })
|
354
|
-
], SplitView.prototype, "firstPaneSize", 2);
|
355
|
-
__decorateClass([
|
356
|
-
property()
|
357
|
-
], SplitView.prototype, "label", 2);
|
358
|
-
__decorateClass([
|
359
|
-
property({ type: Boolean, attribute: false })
|
360
|
-
], SplitView.prototype, "enoughChildren", 2);
|
361
|
-
__decorateClass([
|
362
|
-
property({ type: Number })
|
363
|
-
], SplitView.prototype, "viewSize", 2);
|
364
|
-
__decorateClass([
|
365
|
-
query("slot")
|
366
|
-
], SplitView.prototype, "paneSlot", 2);
|
367
|
-
__decorateClass([
|
368
|
-
query("#splitter")
|
369
|
-
], SplitView.prototype, "splitter", 2);
|
370
|
-
//# sourceMappingURL=SplitView.dev.js.map
|
package/src/SplitView.dev.js.map
DELETED
@@ -1,7 +0,0 @@
|
|
1
|
-
{
|
2
|
-
"version": 3,
|
3
|
-
"sources": ["SplitView.ts"],
|
4
|
-
"sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport {\n CSSResultArray,\n html,\n LitElement,\n nothing,\n PropertyValues,\n SpectrumElement,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n classMap,\n ifDefined,\n} from '@spectrum-web-components/base/src/directives.js';\nimport {\n property,\n query,\n state,\n} from '@spectrum-web-components/base/src/decorators.js';\nimport { streamingListener } from '@spectrum-web-components/base/src/streaming-listener.js';\nimport { randomID } from '@spectrum-web-components/shared/src/random-id.js';\n\nimport { WithSWCResizeObserver } from './types';\n\nimport styles from './split-view.css.js';\n\nconst DEFAULT_MAX_SIZE = 3840;\n\nconst SPLITTERSIZE = 2;\n\nconst ARROW_KEY_CHANGE_VALUE = 10;\n\nconst PAGEUPDOWN_KEY_CHANGE_VALUE = 50;\n\nconst COLLAPSE_THREASHOLD = 50;\n\n/**\n * @element sp-split-view\n *\n * @slot Two sibling elements to be sized by the element attritubes\n * @fires change - Announces the new position of the splitter\n */\nexport class SplitView extends SpectrumElement {\n public static override get styles(): CSSResultArray {\n return [styles];\n }\n\n @state()\n public controlledEl?: HTMLElement;\n\n @property({ type: Boolean, reflect: true })\n public vertical = false;\n\n @property({ type: Boolean, reflect: true })\n public resizable = false;\n\n @property({ type: Boolean, reflect: true })\n public collapsible = false;\n\n /** The minimum size of the primary pane */\n @property({ type: Number, attribute: 'primary-min' })\n public primaryMin = 0;\n\n /** The maximum size of the primary pane */\n @property({ type: Number, attribute: 'primary-max' })\n public primaryMax = DEFAULT_MAX_SIZE;\n\n /**\n * The start size of the primary pane, can be a real pixel number|string, percentage or \"auto\"\n * For example: \"100\", \"120px\", \"75%\" or \"auto\" are valid values\n * @type {number |\u00A0number + \"px\" | number + \"%\" | \"auto\"}\n * @attr\n */\n @property({ type: String, attribute: 'primary-size' })\n public primarySize?: string;\n\n /** The minimum size of the secondary pane */\n @property({ type: Number, attribute: 'secondary-min' })\n public secondaryMin = 0;\n\n /** The maximum size of the secondary pane */\n @property({ type: Number, attribute: 'secondary-max' })\n public secondaryMax = DEFAULT_MAX_SIZE;\n\n /** The current splitter position of split-view */\n @property({ type: Number, reflect: true, attribute: 'splitter-pos' })\n public splitterPos?: number;\n\n /** The current size of first pane of split-view */\n @property({ type: String, attribute: false })\n private firstPaneSize = 'auto';\n\n @property()\n public label?: string;\n\n @property({ type: Boolean, attribute: false })\n private enoughChildren = false;\n\n @property({ type: Number })\n private viewSize = 0;\n\n @query('slot')\n private paneSlot!: HTMLSlotElement;\n\n @query('#splitter')\n private splitter!: HTMLDivElement;\n\n private offset = 0;\n\n private minPos = 0;\n\n private maxPos = DEFAULT_MAX_SIZE;\n\n private observer?: WithSWCResizeObserver['ResizeObserver'];\n\n private rect?: DOMRect;\n\n private _splitterSize?: number;\n\n public constructor() {\n super();\n const RO = (window as unknown as WithSWCResizeObserver).ResizeObserver;\n if (RO) {\n this.observer = new RO(() => {\n this.rect = undefined;\n this.updateMinMax();\n });\n }\n }\n\n public override connectedCallback(): void {\n super.connectedCallback();\n this.observer?.observe(this);\n }\n\n public override disconnectedCallback(): void {\n this.observer?.unobserve(this);\n super.disconnectedCallback();\n }\n\n /**\n * @private\n **/\n public get splitterSize(): number {\n if (!this._splitterSize) {\n this._splitterSize =\n (this.splitter &&\n Math.round(\n parseFloat(\n window\n .getComputedStyle(this.splitter)\n .getPropertyValue(\n this.vertical ? 'height' : 'width'\n )\n )\n )) ||\n SPLITTERSIZE;\n }\n return this._splitterSize;\n }\n\n protected override render(): TemplateResult {\n const splitterClasses = {\n 'is-resized-start': this.splitterPos === this.minPos,\n 'is-resized-end': (this.splitterPos &&\n this.splitterPos > this.splitterSize &&\n this.splitterPos === this.maxPos) as boolean,\n 'is-collapsed-start': this.splitterPos === 0,\n 'is-collapsed-end': (this.splitterPos &&\n this.splitterPos >=\n Math.max(\n this.splitterSize,\n this.viewSize - this.splitterSize\n )) as boolean,\n };\n const label = this.resizable\n ? this.label || 'Resize the panels'\n : undefined;\n\n return html`\n <slot\n id=${ifDefined(\n this.resizable ? this.controlledEl?.id : undefined\n )}\n @slotchange=${this.onContentSlotChange}\n style=\"--spectrum-split-view-first-pane-size: ${this\n .firstPaneSize}\"\n ></slot>\n ${this.enoughChildren\n ? html`\n <div\n id=\"splitter\"\n class=${classMap(splitterClasses)}\n role=\"separator\"\n aria-controls=${ifDefined(\n this.resizable ? this.controlledEl?.id : undefined\n )}\n aria-label=${ifDefined(label)}\n aria-orientation=${this.vertical\n ? 'horizontal'\n : 'vertical'}\n aria-valuenow=${Math.round(\n (parseFloat(this.firstPaneSize) / this.viewSize) *\n 100\n )}\n tabindex=${ifDefined(\n this.resizable ? '0' : undefined\n )}\n @keydown=${this.onKeydown}\n ${streamingListener({\n start: ['pointerdown', this.onPointerdown],\n streamInside: ['pointermove', this.onPointermove],\n end: [\n [\n 'pointerup',\n 'pointercancel',\n 'pointerleave',\n ],\n this.onPointerup,\n ],\n })}\n >\n ${this.resizable\n ? html`\n <div id=\"gripper\"></div>\n `\n : nothing}\n </div>\n `\n : nothing}\n `;\n }\n\n private controlledElIDApplied = false;\n\n private onContentSlotChange(\n event: Event & { target: HTMLSlotElement }\n ): void {\n if (this.controlledEl && this.controlledElIDApplied) {\n this.controlledEl.removeAttribute('id');\n this.controlledElIDApplied = false;\n }\n this.controlledEl = event.target.assignedElements()[0] as HTMLElement;\n if (this.controlledEl && !this.controlledEl.id) {\n this.controlledEl.id = `${this.tagName.toLowerCase()}-${randomID()}`;\n this.controlledElIDApplied = true;\n }\n this.enoughChildren = this.children.length > 1;\n this.checkResize();\n }\n\n private onPointerdown(event: PointerEvent): void {\n if (!this.resizable || (event.button && event.button !== 0)) {\n event.preventDefault();\n return;\n }\n this.splitter.setPointerCapture(event.pointerId);\n this.offset = this.getOffset();\n }\n\n private onPointermove(event: PointerEvent): void {\n event.preventDefault();\n let pos =\n this.vertical || this.isLTR\n ? this.getPosition(event) - this.offset\n : this.offset - this.getPosition(event);\n if (this.collapsible && pos < this.minPos - COLLAPSE_THREASHOLD) {\n pos = 0;\n }\n if (this.collapsible && pos > this.maxPos + COLLAPSE_THREASHOLD) {\n pos = this.viewSize - this.splitterSize;\n }\n this.updatePosition(pos);\n }\n\n private onPointerup(event: PointerEvent): void {\n this.splitter.releasePointerCapture(event.pointerId);\n }\n\n private getOffset(): number {\n if (!this.rect) {\n this.rect = this.getBoundingClientRect();\n }\n const offsetX = this.isLTR ? this.rect.left : this.rect.right;\n return this.vertical ? this.rect.top : offsetX;\n }\n\n private getPosition(event: PointerEvent): number {\n return this.vertical ? event.clientY : event.clientX;\n }\n\n private movePosition(event: KeyboardEvent, offset: number): void {\n event.preventDefault();\n if (this.splitterPos !== undefined) {\n this.updatePosition(this.splitterPos + offset);\n }\n }\n\n private onKeydown(event: KeyboardEvent): void {\n if (!this.resizable) {\n return;\n }\n let direction = 0;\n const isLTRorVertical = this.isLTR || this.vertical;\n switch (event.key) {\n case 'Home':\n event.preventDefault();\n this.updatePosition(this.collapsible ? 0 : this.minPos);\n return;\n case 'End':\n event.preventDefault();\n this.updatePosition(\n this.collapsible\n ? this.viewSize - this.splitterSize\n : this.maxPos\n );\n return;\n case 'ArrowLeft':\n direction = isLTRorVertical ? -1 : 1;\n break;\n case 'ArrowRight':\n direction = isLTRorVertical ? 1 : -1;\n break;\n case 'ArrowUp':\n direction = this.vertical ? -1 : 1;\n break;\n case 'ArrowDown':\n direction = this.vertical ? 1 : -1;\n break;\n case 'PageUp':\n direction = this.vertical ? -1 : 1;\n break;\n case 'PageDown':\n direction = this.vertical ? 1 : -1;\n break;\n }\n if (direction !== 0) {\n const moveBy = event.key.startsWith('Page')\n ? PAGEUPDOWN_KEY_CHANGE_VALUE\n : ARROW_KEY_CHANGE_VALUE;\n this.movePosition(event, moveBy * direction);\n }\n }\n\n private async checkResize(): Promise<void> {\n if (!this.enoughChildren) {\n return;\n }\n this.updateMinMax();\n if (this.splitterPos === undefined) {\n const startPos = await this.calcStartPos();\n this.updatePosition(startPos);\n }\n }\n\n private updateMinMax(): void {\n this.viewSize = this.vertical ? this.offsetHeight : this.offsetWidth;\n this.minPos = Math.max(\n this.primaryMin,\n this.viewSize - this.secondaryMax\n );\n this.maxPos = Math.min(\n this.primaryMax,\n this.viewSize - Math.max(this.secondaryMin, this.splitterSize)\n );\n }\n\n private updatePosition(x: number): void {\n let pos = this.getLimitedPosition(x);\n if (this.collapsible && x <= 0) {\n pos = 0;\n }\n if (\n this.collapsible &&\n x > this.maxPos &&\n x >= this.viewSize - this.splitterSize\n ) {\n pos = this.viewSize - this.splitterSize;\n }\n if (pos !== this.splitterPos) {\n this.splitterPos = pos;\n this.dispatchChangeEvent();\n }\n }\n\n private getLimitedPosition(input: number): number {\n if (input <= this.minPos) {\n return this.minPos;\n }\n if (input >= this.maxPos) {\n return this.maxPos;\n }\n return Math.max(this.minPos, Math.min(this.maxPos, input));\n }\n\n private async calcStartPos(): Promise<number> {\n if (\n this.primarySize !== undefined &&\n /^\\d+(px)?$/.test(this.primarySize)\n ) {\n return parseInt(this.primarySize, 10);\n }\n if (this.primarySize !== undefined && /^\\d+%$/.test(this.primarySize)) {\n return (parseInt(this.primarySize, 10) * this.viewSize) / 100;\n }\n if (this.primarySize === 'auto') {\n this.firstPaneSize = 'auto';\n const nodes = this.paneSlot.assignedNodes({ flatten: true });\n const firstEl = nodes.find(\n (node) => node instanceof HTMLElement\n ) as LitElement;\n if (typeof firstEl.updateComplete !== 'undefined') {\n await firstEl.updateComplete;\n }\n if (firstEl) {\n const size = window\n .getComputedStyle(firstEl)\n .getPropertyValue(this.vertical ? 'height' : 'width');\n const size_i = parseFloat(size);\n if (!isNaN(size_i)) {\n return this.getLimitedPosition(Math.ceil(size_i));\n }\n }\n }\n return this.viewSize / 2;\n }\n\n private dispatchChangeEvent(): void {\n const changeEvent = new Event('change', {\n bubbles: true,\n composed: true,\n });\n this.dispatchEvent(changeEvent);\n }\n\n protected override willUpdate(changed: PropertyValues): void {\n if (!this.hasUpdated || changed.has('primarySize')) {\n this.splitterPos = undefined;\n this.checkResize();\n }\n if (\n changed.has('splitterPos') &&\n this.splitterPos !== undefined &&\n this.enoughChildren\n ) {\n this.firstPaneSize = `${Math.round(this.splitterPos)}px`;\n }\n }\n}\n"],
|
5
|
-
"mappings": "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",
|
6
|
-
"names": []
|
7
|
-
}
|
package/src/SplitView.js
DELETED
@@ -1,26 +0,0 @@
|
|
1
|
-
"use strict";var v=Object.defineProperty;var f=Object.getOwnPropertyDescriptor;var s=(l,a,t,e)=>{for(var i=e>1?void 0:e?f(a,t):a,o=l.length-1,h;o>=0;o--)(h=l[o])&&(i=(e?h(a,t,i):h(i))||i);return e&&i&&v(a,t,i),i};import{html as p,nothing as c,SpectrumElement as b}from"@spectrum-web-components/base";import{classMap as P,ifDefined as n}from"@spectrum-web-components/base/src/directives.js";import{property as r,query as u,state as z}from"@spectrum-web-components/base/src/decorators.js";import{streamingListener as y}from"@spectrum-web-components/base/src/streaming-listener.js";import{randomID as E}from"@spectrum-web-components/shared/src/random-id.js";import S from"./split-view.css.js";const d=3840,g=2,M=10,C=50,m=50;export class SplitView extends b{constructor(){super();this.vertical=!1;this.resizable=!1;this.collapsible=!1;this.primaryMin=0;this.primaryMax=d;this.secondaryMin=0;this.secondaryMax=d;this.firstPaneSize="auto";this.enoughChildren=!1;this.viewSize=0;this.offset=0;this.minPos=0;this.maxPos=d;this.controlledElIDApplied=!1;const t=window.ResizeObserver;t&&(this.observer=new t(()=>{this.rect=void 0,this.updateMinMax()}))}static get styles(){return[S]}connectedCallback(){var t;super.connectedCallback(),(t=this.observer)==null||t.observe(this)}disconnectedCallback(){var t;(t=this.observer)==null||t.unobserve(this),super.disconnectedCallback()}get splitterSize(){return this._splitterSize||(this._splitterSize=this.splitter&&Math.round(parseFloat(window.getComputedStyle(this.splitter).getPropertyValue(this.vertical?"height":"width")))||g),this._splitterSize}render(){var i,o;const t={"is-resized-start":this.splitterPos===this.minPos,"is-resized-end":this.splitterPos&&this.splitterPos>this.splitterSize&&this.splitterPos===this.maxPos,"is-collapsed-start":this.splitterPos===0,"is-collapsed-end":this.splitterPos&&this.splitterPos>=Math.max(this.splitterSize,this.viewSize-this.splitterSize)},e=this.resizable?this.label||"Resize the panels":void 0;return p`
|
2
|
-
<slot
|
3
|
-
id=${n(this.resizable?(i=this.controlledEl)==null?void 0:i.id:void 0)}
|
4
|
-
@slotchange=${this.onContentSlotChange}
|
5
|
-
style="--spectrum-split-view-first-pane-size: ${this.firstPaneSize}"
|
6
|
-
></slot>
|
7
|
-
${this.enoughChildren?p`
|
8
|
-
<div
|
9
|
-
id="splitter"
|
10
|
-
class=${P(t)}
|
11
|
-
role="separator"
|
12
|
-
aria-controls=${n(this.resizable?(o=this.controlledEl)==null?void 0:o.id:void 0)}
|
13
|
-
aria-label=${n(e)}
|
14
|
-
aria-orientation=${this.vertical?"horizontal":"vertical"}
|
15
|
-
aria-valuenow=${Math.round(parseFloat(this.firstPaneSize)/this.viewSize*100)}
|
16
|
-
tabindex=${n(this.resizable?"0":void 0)}
|
17
|
-
@keydown=${this.onKeydown}
|
18
|
-
${y({start:["pointerdown",this.onPointerdown],streamInside:["pointermove",this.onPointermove],end:[["pointerup","pointercancel","pointerleave"],this.onPointerup]})}
|
19
|
-
>
|
20
|
-
${this.resizable?p`
|
21
|
-
<div id="gripper"></div>
|
22
|
-
`:c}
|
23
|
-
</div>
|
24
|
-
`:c}
|
25
|
-
`}onContentSlotChange(t){this.controlledEl&&this.controlledElIDApplied&&(this.controlledEl.removeAttribute("id"),this.controlledElIDApplied=!1),this.controlledEl=t.target.assignedElements()[0],this.controlledEl&&!this.controlledEl.id&&(this.controlledEl.id=`${this.tagName.toLowerCase()}-${E()}`,this.controlledElIDApplied=!0),this.enoughChildren=this.children.length>1,this.checkResize()}onPointerdown(t){if(!this.resizable||t.button&&t.button!==0){t.preventDefault();return}this.splitter.setPointerCapture(t.pointerId),this.offset=this.getOffset()}onPointermove(t){t.preventDefault();let e=this.vertical||this.isLTR?this.getPosition(t)-this.offset:this.offset-this.getPosition(t);this.collapsible&&e<this.minPos-m&&(e=0),this.collapsible&&e>this.maxPos+m&&(e=this.viewSize-this.splitterSize),this.updatePosition(e)}onPointerup(t){this.splitter.releasePointerCapture(t.pointerId)}getOffset(){this.rect||(this.rect=this.getBoundingClientRect());const t=this.isLTR?this.rect.left:this.rect.right;return this.vertical?this.rect.top:t}getPosition(t){return this.vertical?t.clientY:t.clientX}movePosition(t,e){t.preventDefault(),this.splitterPos!==void 0&&this.updatePosition(this.splitterPos+e)}onKeydown(t){if(!this.resizable)return;let e=0;const i=this.isLTR||this.vertical;switch(t.key){case"Home":t.preventDefault(),this.updatePosition(this.collapsible?0:this.minPos);return;case"End":t.preventDefault(),this.updatePosition(this.collapsible?this.viewSize-this.splitterSize:this.maxPos);return;case"ArrowLeft":e=i?-1:1;break;case"ArrowRight":e=i?1:-1;break;case"ArrowUp":e=this.vertical?-1:1;break;case"ArrowDown":e=this.vertical?1:-1;break;case"PageUp":e=this.vertical?-1:1;break;case"PageDown":e=this.vertical?1:-1;break}if(e!==0){const o=t.key.startsWith("Page")?C:M;this.movePosition(t,o*e)}}async checkResize(){if(this.enoughChildren&&(this.updateMinMax(),this.splitterPos===void 0)){const t=await this.calcStartPos();this.updatePosition(t)}}updateMinMax(){this.viewSize=this.vertical?this.offsetHeight:this.offsetWidth,this.minPos=Math.max(this.primaryMin,this.viewSize-this.secondaryMax),this.maxPos=Math.min(this.primaryMax,this.viewSize-Math.max(this.secondaryMin,this.splitterSize))}updatePosition(t){let e=this.getLimitedPosition(t);this.collapsible&&t<=0&&(e=0),this.collapsible&&t>this.maxPos&&t>=this.viewSize-this.splitterSize&&(e=this.viewSize-this.splitterSize),e!==this.splitterPos&&(this.splitterPos=e,this.dispatchChangeEvent())}getLimitedPosition(t){return t<=this.minPos?this.minPos:t>=this.maxPos?this.maxPos:Math.max(this.minPos,Math.min(this.maxPos,t))}async calcStartPos(){if(this.primarySize!==void 0&&/^\d+(px)?$/.test(this.primarySize))return parseInt(this.primarySize,10);if(this.primarySize!==void 0&&/^\d+%$/.test(this.primarySize))return parseInt(this.primarySize,10)*this.viewSize/100;if(this.primarySize==="auto"){this.firstPaneSize="auto";const e=this.paneSlot.assignedNodes({flatten:!0}).find(i=>i instanceof HTMLElement);if(typeof e.updateComplete!="undefined"&&await e.updateComplete,e){const i=window.getComputedStyle(e).getPropertyValue(this.vertical?"height":"width"),o=parseFloat(i);if(!isNaN(o))return this.getLimitedPosition(Math.ceil(o))}}return this.viewSize/2}dispatchChangeEvent(){const t=new Event("change",{bubbles:!0,composed:!0});this.dispatchEvent(t)}willUpdate(t){(!this.hasUpdated||t.has("primarySize"))&&(this.splitterPos=void 0,this.checkResize()),t.has("splitterPos")&&this.splitterPos!==void 0&&this.enoughChildren&&(this.firstPaneSize=`${Math.round(this.splitterPos)}px`)}}s([z()],SplitView.prototype,"controlledEl",2),s([r({type:Boolean,reflect:!0})],SplitView.prototype,"vertical",2),s([r({type:Boolean,reflect:!0})],SplitView.prototype,"resizable",2),s([r({type:Boolean,reflect:!0})],SplitView.prototype,"collapsible",2),s([r({type:Number,attribute:"primary-min"})],SplitView.prototype,"primaryMin",2),s([r({type:Number,attribute:"primary-max"})],SplitView.prototype,"primaryMax",2),s([r({type:String,attribute:"primary-size"})],SplitView.prototype,"primarySize",2),s([r({type:Number,attribute:"secondary-min"})],SplitView.prototype,"secondaryMin",2),s([r({type:Number,attribute:"secondary-max"})],SplitView.prototype,"secondaryMax",2),s([r({type:Number,reflect:!0,attribute:"splitter-pos"})],SplitView.prototype,"splitterPos",2),s([r({type:String,attribute:!1})],SplitView.prototype,"firstPaneSize",2),s([r()],SplitView.prototype,"label",2),s([r({type:Boolean,attribute:!1})],SplitView.prototype,"enoughChildren",2),s([r({type:Number})],SplitView.prototype,"viewSize",2),s([u("slot")],SplitView.prototype,"paneSlot",2),s([u("#splitter")],SplitView.prototype,"splitter",2);
|
26
|
-
//# sourceMappingURL=SplitView.js.map
|