@ngutil/style 0.0.80 → 0.0.82
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/fesm2022/ngutil-style.mjs +16 -16
- package/fesm2022/ngutil-style.mjs.map +1 -1
- package/package.json +5 -6
- package/esm2022/index.mjs +0 -12
- package/esm2022/ngutil-style.mjs +0 -5
- package/esm2022/sass/animation/vars/index.mjs +0 -24
- package/esm2022/sass/index.mjs +0 -2
- package/esm2022/services/color-scheme.service.mjs +0 -19
- package/esm2022/services/dimension-watcher.service.mjs +0 -120
- package/esm2022/services/media-watcher.service.mjs +0 -39
- package/esm2022/services/position-watcher.service.mjs +0 -52
- package/esm2022/services/rect-watcher.service.mjs +0 -26
- package/esm2022/util/alignment.mjs +0 -55
- package/esm2022/util/floating-position.mjs +0 -276
- package/esm2022/util/in-animation.mjs +0 -70
- package/esm2022/util/rect.mjs +0 -90
- package/esm2022/util/sides.mjs +0 -26
|
@@ -1,276 +0,0 @@
|
|
|
1
|
-
import { clamp } from "lodash-es";
|
|
2
|
-
import { AlignHorizontalOpposite, alignmentNormalize, AlignVerticalOpposite } from "./alignment";
|
|
3
|
-
// import type { FloatingPositionOptionsNormalized } from "./position"
|
|
4
|
-
import { rectContract, rectExpand, rectMoveOrigin, rectOrigin } from "./rect";
|
|
5
|
-
import { sidesNormalize } from "./sides";
|
|
6
|
-
const ZERO_PADDING = sidesNormalize(0);
|
|
7
|
-
const ZERO_CONNECTION = { x: 0, y: 0 };
|
|
8
|
-
export function floatingPosition({ dims, options }) {
|
|
9
|
-
const padding = options.placement.padding ? sidesNormalize(options.placement.padding) : ZERO_PADDING;
|
|
10
|
-
const placement = {
|
|
11
|
-
rect: dims.placement,
|
|
12
|
-
padding: padding,
|
|
13
|
-
rectWithPadding: rectContract(dims.placement, padding),
|
|
14
|
-
area: { ...dims.placement }
|
|
15
|
-
};
|
|
16
|
-
const anchor = {
|
|
17
|
-
rect: options.anchor.margin ? rectExpand(dims.anchor, options.anchor.margin) : dims.anchor,
|
|
18
|
-
link: alignmentNormalize(options.anchor.link)
|
|
19
|
-
};
|
|
20
|
-
const minWidth = dims.constraints?.minWidth || 0;
|
|
21
|
-
const minHeight = dims.constraints?.minHeight || 0;
|
|
22
|
-
const maxWidth = dims.constraints?.maxWidth || Infinity;
|
|
23
|
-
const maxHeight = dims.constraints?.maxHeight || Infinity;
|
|
24
|
-
const content = {
|
|
25
|
-
rect: { x: 0, y: 0, ...dims.content },
|
|
26
|
-
link: alignmentNormalize(options.content.link),
|
|
27
|
-
constrained: {
|
|
28
|
-
width: clamp(dims.content.width, minWidth, maxWidth),
|
|
29
|
-
height: clamp(dims.content.height, minHeight, maxHeight)
|
|
30
|
-
}
|
|
31
|
-
};
|
|
32
|
-
const position = {
|
|
33
|
-
placement,
|
|
34
|
-
anchor,
|
|
35
|
-
content,
|
|
36
|
-
connection: ZERO_CONNECTION,
|
|
37
|
-
constrains: dims.constraints,
|
|
38
|
-
direction: "down" /* FloatingPositionDirection.Down */
|
|
39
|
-
};
|
|
40
|
-
const area = placementArea(position, anchor.link, content.link);
|
|
41
|
-
setPlacement(position, area);
|
|
42
|
-
if (options.horizontalAlt) {
|
|
43
|
-
applyAlts(position, "H" /* FloatingPositionAltAxis.Horizontal */, options.horizontalAlt);
|
|
44
|
-
}
|
|
45
|
-
if (options.verticalAlt) {
|
|
46
|
-
applyAlts(position, "V" /* FloatingPositionAltAxis.Vertical */, options.verticalAlt);
|
|
47
|
-
}
|
|
48
|
-
position.direction = floatingPositionDirection(position);
|
|
49
|
-
return position;
|
|
50
|
-
}
|
|
51
|
-
function placementArea(pos, anchorLink, contentLink) {
|
|
52
|
-
const connection = rectOrigin(pos.anchor.rect, anchorLink);
|
|
53
|
-
let { x, y } = connection;
|
|
54
|
-
const placement = pos.placement.rect;
|
|
55
|
-
const placementPad = pos.placement.padding;
|
|
56
|
-
let width = 0;
|
|
57
|
-
let height = 0;
|
|
58
|
-
switch (contentLink.horizontal) {
|
|
59
|
-
case "left":
|
|
60
|
-
case "start":
|
|
61
|
-
width = placement.width - x;
|
|
62
|
-
break;
|
|
63
|
-
case "center":
|
|
64
|
-
if (anchorLink.horizontal === "center") {
|
|
65
|
-
width = placement.width;
|
|
66
|
-
x = placement.x;
|
|
67
|
-
}
|
|
68
|
-
else {
|
|
69
|
-
const leftSize = x - placementPad.left.value;
|
|
70
|
-
const rightSize = placement.width - x - placementPad.right.value;
|
|
71
|
-
const mw = Math.max(0, Math.min(leftSize, rightSize));
|
|
72
|
-
width = mw * 2;
|
|
73
|
-
x -= mw;
|
|
74
|
-
}
|
|
75
|
-
break;
|
|
76
|
-
case "end":
|
|
77
|
-
case "right":
|
|
78
|
-
width = x - placement.x;
|
|
79
|
-
x = placement.x;
|
|
80
|
-
break;
|
|
81
|
-
}
|
|
82
|
-
switch (contentLink.vertical) {
|
|
83
|
-
case "top":
|
|
84
|
-
height = placement.height - y;
|
|
85
|
-
break;
|
|
86
|
-
case "middle":
|
|
87
|
-
if (anchorLink.vertical === "middle") {
|
|
88
|
-
height = placement.height;
|
|
89
|
-
y = placement.y;
|
|
90
|
-
}
|
|
91
|
-
else {
|
|
92
|
-
const topSize = y - placementPad.top.value;
|
|
93
|
-
const bottomSize = placement.height - y - placementPad.bottom.value;
|
|
94
|
-
const mh = Math.max(0, Math.min(topSize, bottomSize));
|
|
95
|
-
height = mh * 2;
|
|
96
|
-
y -= mh;
|
|
97
|
-
}
|
|
98
|
-
break;
|
|
99
|
-
case "bottom":
|
|
100
|
-
height = y - placement.y;
|
|
101
|
-
y = placement.y;
|
|
102
|
-
break;
|
|
103
|
-
}
|
|
104
|
-
const constraint = pos.placement.rectWithPadding;
|
|
105
|
-
const newX = Math.max(x, constraint.x);
|
|
106
|
-
const newY = Math.max(y, constraint.y);
|
|
107
|
-
const diffX = newX - x;
|
|
108
|
-
const diffY = newY - y;
|
|
109
|
-
const area = {
|
|
110
|
-
x: newX,
|
|
111
|
-
y: newY,
|
|
112
|
-
width: Math.min(newX + width - diffX, constraint.x + constraint.width) - newX,
|
|
113
|
-
height: Math.min(newY + height - diffY, constraint.y + constraint.height) - newY
|
|
114
|
-
};
|
|
115
|
-
return { area, contentLink, anchorLink, connection };
|
|
116
|
-
}
|
|
117
|
-
function setPlacement(position, { area, anchorLink, contentLink, connection }) {
|
|
118
|
-
position.placement.area = area;
|
|
119
|
-
position.anchor.link = anchorLink;
|
|
120
|
-
position.content.link = contentLink;
|
|
121
|
-
const plannedContentRect = rectMoveOrigin(position.content.rect, contentLink, connection);
|
|
122
|
-
position.connection = adjustConnection(area, plannedContentRect, connection);
|
|
123
|
-
position.content.rect = rectMoveOrigin(position.content.rect, contentLink, connection);
|
|
124
|
-
}
|
|
125
|
-
function adjustConnection(placement, content, connection) {
|
|
126
|
-
const x = Math.max(placement.x, content.x);
|
|
127
|
-
const y = Math.max(placement.y, content.y);
|
|
128
|
-
const leftDiff = x - content.x;
|
|
129
|
-
const topDiff = y - content.y;
|
|
130
|
-
const widthDiff = placement.x + placement.width - (x + content.width);
|
|
131
|
-
const heightDiff = placement.y + placement.height - (y + content.height);
|
|
132
|
-
const result = { ...connection };
|
|
133
|
-
connection.x += leftDiff;
|
|
134
|
-
connection.y += topDiff;
|
|
135
|
-
if (widthDiff < 0) {
|
|
136
|
-
connection.x += widthDiff;
|
|
137
|
-
}
|
|
138
|
-
if (heightDiff < 0) {
|
|
139
|
-
connection.y += heightDiff;
|
|
140
|
-
}
|
|
141
|
-
return result;
|
|
142
|
-
}
|
|
143
|
-
function applyAlts(pos, axis, alts) {
|
|
144
|
-
const norm = positionAltNormalize(alts);
|
|
145
|
-
for (const alt of norm) {
|
|
146
|
-
alt(pos, axis);
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
export function positionAltNormalize(input) {
|
|
150
|
-
if (Array.isArray(input)) {
|
|
151
|
-
return input;
|
|
152
|
-
}
|
|
153
|
-
else if (typeof input === "function") {
|
|
154
|
-
return [input];
|
|
155
|
-
}
|
|
156
|
-
else if (typeof input === "string") {
|
|
157
|
-
return altStringToFns(input);
|
|
158
|
-
}
|
|
159
|
-
else {
|
|
160
|
-
throw new Error(`Invalid alt position: ${input}`);
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
function altStringToFns(input) {
|
|
164
|
-
switch (input) {
|
|
165
|
-
case "none":
|
|
166
|
-
return [none];
|
|
167
|
-
case "flip":
|
|
168
|
-
return [flip];
|
|
169
|
-
case "shift":
|
|
170
|
-
return [shift];
|
|
171
|
-
case "flip-shift":
|
|
172
|
-
return [flip, shift];
|
|
173
|
-
case "greatest":
|
|
174
|
-
return [greatest];
|
|
175
|
-
case "greatest-shift":
|
|
176
|
-
return [greatest, shift];
|
|
177
|
-
case "smallest":
|
|
178
|
-
return [smallest];
|
|
179
|
-
case "smallest-shift":
|
|
180
|
-
return [smallest, shift];
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
function none(pos, axis) { }
|
|
184
|
-
function flip(pos, axis) {
|
|
185
|
-
const wh = axis === "H" /* FloatingPositionAltAxis.Horizontal */ ? "width" : "height";
|
|
186
|
-
if (pos.placement.area[wh] >= pos.content.constrained[wh]) {
|
|
187
|
-
return;
|
|
188
|
-
}
|
|
189
|
-
return greatest(pos, axis);
|
|
190
|
-
}
|
|
191
|
-
function shift(pos, axis) { }
|
|
192
|
-
function greatest(pos, axis) {
|
|
193
|
-
_bySize(pos, axis, (a, b) => a >= b);
|
|
194
|
-
}
|
|
195
|
-
function smallest(pos, axis) {
|
|
196
|
-
_bySize(pos, axis, (a, b) => a <= b);
|
|
197
|
-
}
|
|
198
|
-
function _bySize(pos, axis, cmp) {
|
|
199
|
-
const wh = axis === "H" /* FloatingPositionAltAxis.Horizontal */ ? "width" : "height";
|
|
200
|
-
const current = pos.placement.area[wh];
|
|
201
|
-
const anchorLink = oppositeLink(axis, pos.anchor.link);
|
|
202
|
-
const contentLink = oppositeLink(axis, pos.content.link);
|
|
203
|
-
const oppositePlacement = placementArea(pos, anchorLink, contentLink);
|
|
204
|
-
if (cmp(current, oppositePlacement.area[wh])) {
|
|
205
|
-
return;
|
|
206
|
-
}
|
|
207
|
-
setPlacement(pos, oppositePlacement);
|
|
208
|
-
}
|
|
209
|
-
function oppositeLink(axis, link) {
|
|
210
|
-
if (axis === "H" /* FloatingPositionAltAxis.Horizontal */) {
|
|
211
|
-
return { horizontal: AlignHorizontalOpposite[link.horizontal], vertical: link.vertical };
|
|
212
|
-
}
|
|
213
|
-
else {
|
|
214
|
-
return { horizontal: link.horizontal, vertical: AlignVerticalOpposite[link.vertical] };
|
|
215
|
-
}
|
|
216
|
-
}
|
|
217
|
-
export function floatingPositionToStyle(pos) {
|
|
218
|
-
const contentRect = pos.content.rect;
|
|
219
|
-
const placementRect = pos.placement.rect;
|
|
220
|
-
// const { width: maxWidth, height: maxHeight } = pos.placement.area
|
|
221
|
-
const style = {};
|
|
222
|
-
if (pos.content.link.horizontal === "right") {
|
|
223
|
-
style["right"] = `${placementRect.width - (contentRect.x + contentRect.width)}px`;
|
|
224
|
-
style["left"] = "auto";
|
|
225
|
-
}
|
|
226
|
-
else {
|
|
227
|
-
style["left"] = `${contentRect.x}px`;
|
|
228
|
-
style["right"] = "auto";
|
|
229
|
-
}
|
|
230
|
-
if (pos.content.link.vertical === "bottom") {
|
|
231
|
-
style["bottom"] = `${placementRect.height - (contentRect.y + contentRect.height)}px`;
|
|
232
|
-
style["top"] = "auto";
|
|
233
|
-
}
|
|
234
|
-
else {
|
|
235
|
-
style["top"] = `${contentRect.y}px`;
|
|
236
|
-
style["bottom"] = "auto";
|
|
237
|
-
}
|
|
238
|
-
// style["maxWidth"] = `${maxWidth}px`
|
|
239
|
-
// style["maxHeight"] = `${maxHeight}px`
|
|
240
|
-
return style;
|
|
241
|
-
}
|
|
242
|
-
export function floatingPositionDirection(pos) {
|
|
243
|
-
const { x: ax, y: ay, width: aw, height: ah } = pos.anchor.rect;
|
|
244
|
-
const { x: bx, y: by, width: bw, height: bh } = pos.content.rect;
|
|
245
|
-
const contentLink = pos.content.link;
|
|
246
|
-
const anchorLink = pos.anchor.link;
|
|
247
|
-
if (anchorLink.horizontal === "center" && anchorLink.vertical === "middle") {
|
|
248
|
-
if (contentLink.horizontal === "center" && contentLink.vertical === "middle") {
|
|
249
|
-
return "center" /* FloatingPositionDirection.Center */;
|
|
250
|
-
}
|
|
251
|
-
const cx = pos.connection.x;
|
|
252
|
-
if (cx <= bx) {
|
|
253
|
-
return "right" /* FloatingPositionDirection.Right */;
|
|
254
|
-
}
|
|
255
|
-
else if (cx >= bx + bw) {
|
|
256
|
-
return "left" /* FloatingPositionDirection.Left */;
|
|
257
|
-
}
|
|
258
|
-
}
|
|
259
|
-
const widthOverlapPx = Math.min(ax + aw, bx + bw) - Math.max(ax, bx);
|
|
260
|
-
const widthOverlapPercent = widthOverlapPx / Math.max(aw, bw);
|
|
261
|
-
const heightOverlapPx = Math.min(ay + ah, by + bh) - Math.max(ay, by);
|
|
262
|
-
const heightOverlapPercent = heightOverlapPx / Math.max(ah, bh);
|
|
263
|
-
if (widthOverlapPercent >= heightOverlapPercent) {
|
|
264
|
-
if (contentLink.vertical === "bottom") {
|
|
265
|
-
return "up" /* FloatingPositionDirection.Up */;
|
|
266
|
-
}
|
|
267
|
-
return "down" /* FloatingPositionDirection.Down */;
|
|
268
|
-
}
|
|
269
|
-
else {
|
|
270
|
-
if (contentLink.horizontal === "right") {
|
|
271
|
-
return "left" /* FloatingPositionDirection.Left */;
|
|
272
|
-
}
|
|
273
|
-
return "right" /* FloatingPositionDirection.Right */;
|
|
274
|
-
}
|
|
275
|
-
}
|
|
276
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"floating-position.js","sourceRoot":"","sources":["../../../../../packages/style/src/util/floating-position.ts"],"names":[],"mappings":"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","sourcesContent":["import { clamp } from \"lodash-es\"\n\nimport {\n    AlignHorizontalOpposite,\n    Alignment,\n    AlignmentInput,\n    alignmentNormalize,\n    AlignVerticalOpposite\n} from \"./alignment\"\n// import type { FloatingPositionOptionsNormalized } from \"./position\"\nimport { Dimension, Position, Rect, rectContract, rectExpand, rectMoveOrigin, rectOrigin } from \"./rect\"\nimport { Sides, SidesInput, sidesNormalize } from \"./sides\"\n\nexport interface FloatingPositionInput {\n    dims: FloatingPositionDims\n    options: FloatingPositionOptions\n}\n\nexport interface FloatingPositionDims {\n    content: Dimension\n    anchor: Rect\n    placement: Rect\n    constraints?: FloatingPositionConstraintsInput\n}\n\nexport interface FloatingPositionOptions {\n    content: FloatingPositionContentOptions\n    anchor: FloatingPositionAnchorOptions\n    placement: FloatingPositionPlacementOptions\n    horizontalAlt?: FloatingPositionAltInput\n    verticalAlt?: FloatingPositionAltInput\n}\n\nexport interface FloatingPositionContentOptions {\n    link: AlignmentInput\n}\n\nexport interface FloatingPositionConstraintsInput {\n    minWidth?: number\n    maxWidth?: number\n    minHeight?: number\n    maxHeight?: number\n}\n\nexport interface FloatingPositionAnchorOptions {\n    link: AlignmentInput\n    margin?: SidesInput\n}\n\nexport interface FloatingPositionPlacementOptions {\n    padding?: SidesInput\n}\n\nexport interface FloatingPosition {\n    content: {\n        rect: Position & Readonly<Dimension>\n        link: Alignment\n        readonly constrained: Readonly<Dimension>\n    }\n    anchor: {\n        readonly rect: Readonly<Rect>\n        link: Alignment\n    }\n    placement: {\n        readonly rect: Readonly<Rect>\n        readonly padding: Readonly<Sides>\n        readonly rectWithPadding: Readonly<Rect>\n        area: Readonly<Rect>\n    }\n    connection: Position\n    direction: FloatingPositionDirection\n    constraints?: FloatingPositionConstraintsInput\n}\n\ninterface PlacementArea {\n    anchorLink: Alignment\n    contentLink: Alignment\n    area: FloatingPosition[\"placement\"][\"area\"]\n    connection: Position\n}\n\ntype FloatingPositionAltConst =\n    | \"none\"\n    | \"flip\"\n    | \"shift\"\n    | \"flip-shift\"\n    | \"greatest\"\n    | \"greatest-shift\"\n    | \"smallest\"\n    | \"smallest-shift\"\nexport type FloatingPositionAltInput = FloatingPositionAltConst | FloatingPositionAltFunc\nexport type FloatingPositionAltFunc = (pos: FloatingPosition, axis: FloatingPositionAltAxis) => void\nexport type FloatingPositionAltNorm = Array<FloatingPositionAltFunc>\n\nexport const enum FloatingPositionAltAxis {\n    Horizontal = \"H\",\n    Vertical = \"V\"\n}\n\nconst ZERO_PADDING = sidesNormalize(0)\nconst ZERO_CONNECTION = { x: 0, y: 0 }\n\nexport function floatingPosition({ dims, options }: FloatingPositionInput): FloatingPosition {\n    const padding = options.placement.padding ? sidesNormalize(options.placement.padding) : ZERO_PADDING\n    const placement: FloatingPosition[\"placement\"] = {\n        rect: dims.placement,\n        padding: padding,\n        rectWithPadding: rectContract(dims.placement, padding),\n        area: { ...dims.placement }\n    }\n\n    const anchor: FloatingPosition[\"anchor\"] = {\n        rect: options.anchor.margin ? rectExpand(dims.anchor, options.anchor.margin) : dims.anchor,\n        link: alignmentNormalize(options.anchor.link)\n    }\n\n    const minWidth = dims.constraints?.minWidth || 0\n    const minHeight = dims.constraints?.minHeight || 0\n    const maxWidth = dims.constraints?.maxWidth || Infinity\n    const maxHeight = dims.constraints?.maxHeight || Infinity\n    const content: FloatingPosition[\"content\"] = {\n        rect: { x: 0, y: 0, ...dims.content },\n        link: alignmentNormalize(options.content.link),\n        constrained: {\n            width: clamp(dims.content.width, minWidth, maxWidth),\n            height: clamp(dims.content.height, minHeight, maxHeight)\n        }\n    }\n\n    const position = {\n        placement,\n        anchor,\n        content,\n        connection: ZERO_CONNECTION,\n        constrains: dims.constraints,\n        direction: FloatingPositionDirection.Down\n    }\n    const area = placementArea(position, anchor.link, content.link)\n    setPlacement(position, area)\n\n    if (options.horizontalAlt) {\n        applyAlts(position, FloatingPositionAltAxis.Horizontal, options.horizontalAlt)\n    }\n\n    if (options.verticalAlt) {\n        applyAlts(position, FloatingPositionAltAxis.Vertical, options.verticalAlt)\n    }\n\n    position.direction = floatingPositionDirection(position)\n    return position\n}\n\nfunction placementArea(pos: FloatingPosition, anchorLink: Alignment, contentLink: Alignment): PlacementArea {\n    const connection = rectOrigin(pos.anchor.rect, anchorLink)\n    let { x, y } = connection\n    const placement = pos.placement.rect\n    const placementPad = pos.placement.padding\n    let width = 0\n    let height = 0\n\n    switch (contentLink.horizontal) {\n        case \"left\":\n        case \"start\":\n            width = placement.width - x\n            break\n        case \"center\":\n            if (anchorLink.horizontal === \"center\") {\n                width = placement.width\n                x = placement.x\n            } else {\n                const leftSize = x - placementPad.left.value\n                const rightSize = placement.width - x - placementPad.right.value\n                const mw = Math.max(0, Math.min(leftSize, rightSize))\n                width = mw * 2\n                x -= mw\n            }\n            break\n        case \"end\":\n        case \"right\":\n            width = x - placement.x\n            x = placement.x\n            break\n    }\n\n    switch (contentLink.vertical) {\n        case \"top\":\n            height = placement.height - y\n            break\n        case \"middle\":\n            if (anchorLink.vertical === \"middle\") {\n                height = placement.height\n                y = placement.y\n            } else {\n                const topSize = y - placementPad.top.value\n                const bottomSize = placement.height - y - placementPad.bottom.value\n                const mh = Math.max(0, Math.min(topSize, bottomSize))\n                height = mh * 2\n                y -= mh\n            }\n\n            break\n        case \"bottom\":\n            height = y - placement.y\n            y = placement.y\n            break\n    }\n\n    const constraint = pos.placement.rectWithPadding\n    const newX = Math.max(x, constraint.x)\n    const newY = Math.max(y, constraint.y)\n    const diffX = newX - x\n    const diffY = newY - y\n\n    const area = {\n        x: newX,\n        y: newY,\n        width: Math.min(newX + width - diffX, constraint.x + constraint.width) - newX,\n        height: Math.min(newY + height - diffY, constraint.y + constraint.height) - newY\n    }\n\n    return { area, contentLink, anchorLink, connection }\n}\n\nfunction setPlacement(position: FloatingPosition, { area, anchorLink, contentLink, connection }: PlacementArea): void {\n    position.placement.area = area\n    position.anchor.link = anchorLink\n    position.content.link = contentLink\n\n    const plannedContentRect = rectMoveOrigin(position.content.rect, contentLink, connection)\n    position.connection = adjustConnection(area, plannedContentRect, connection)\n    position.content.rect = rectMoveOrigin(position.content.rect, contentLink, connection)\n}\n\nfunction adjustConnection(\n    placement: FloatingPosition[\"placement\"][\"area\"],\n    content: FloatingPosition[\"content\"][\"rect\"],\n    connection: FloatingPosition[\"connection\"]\n) {\n    const x = Math.max(placement.x, content.x)\n    const y = Math.max(placement.y, content.y)\n    const leftDiff = x - content.x\n    const topDiff = y - content.y\n    const widthDiff = placement.x + placement.width - (x + content.width)\n    const heightDiff = placement.y + placement.height - (y + content.height)\n\n    const result = { ...connection }\n    connection.x += leftDiff\n    connection.y += topDiff\n\n    if (widthDiff < 0) {\n        connection.x += widthDiff\n    }\n\n    if (heightDiff < 0) {\n        connection.y += heightDiff\n    }\n    return result\n}\n\nfunction applyAlts(pos: FloatingPosition, axis: FloatingPositionAltAxis, alts: FloatingPositionAltInput) {\n    const norm = positionAltNormalize(alts)\n    for (const alt of norm) {\n        alt(pos, axis)\n    }\n}\n\nexport function positionAltNormalize(\n    input: FloatingPositionAltInput | FloatingPositionAltNorm\n): FloatingPositionAltNorm {\n    if (Array.isArray(input)) {\n        return input\n    } else if (typeof input === \"function\") {\n        return [input]\n    } else if (typeof input === \"string\") {\n        return altStringToFns(input)\n    } else {\n        throw new Error(`Invalid alt position: ${input}`)\n    }\n}\n\nfunction altStringToFns(input: FloatingPositionAltConst): FloatingPositionAltNorm {\n    switch (input) {\n        case \"none\":\n            return [none]\n        case \"flip\":\n            return [flip]\n        case \"shift\":\n            return [shift]\n        case \"flip-shift\":\n            return [flip, shift]\n        case \"greatest\":\n            return [greatest]\n        case \"greatest-shift\":\n            return [greatest, shift]\n        case \"smallest\":\n            return [smallest]\n        case \"smallest-shift\":\n            return [smallest, shift]\n    }\n}\n\nfunction none(pos: FloatingPosition, axis: FloatingPositionAltAxis): void {}\n\nfunction flip(pos: FloatingPosition, axis: FloatingPositionAltAxis): void {\n    const wh: \"width\" | \"height\" = axis === FloatingPositionAltAxis.Horizontal ? \"width\" : \"height\"\n    if (pos.placement.area[wh] >= pos.content.constrained[wh]) {\n        return\n    }\n    return greatest(pos, axis)\n}\n\nfunction shift(pos: FloatingPosition, axis: FloatingPositionAltAxis): void {}\n\nfunction greatest(pos: FloatingPosition, axis: FloatingPositionAltAxis): void {\n    _bySize(pos, axis, (a, b) => a >= b)\n}\n\nfunction smallest(pos: FloatingPosition, axis: FloatingPositionAltAxis): void {\n    _bySize(pos, axis, (a, b) => a <= b)\n}\n\nfunction _bySize(pos: FloatingPosition, axis: FloatingPositionAltAxis, cmp: (a: number, b: number) => boolean): void {\n    const wh: \"width\" | \"height\" = axis === FloatingPositionAltAxis.Horizontal ? \"width\" : \"height\"\n\n    const current = pos.placement.area[wh]\n    const anchorLink = oppositeLink(axis, pos.anchor.link)\n    const contentLink = oppositeLink(axis, pos.content.link)\n    const oppositePlacement = placementArea(pos, anchorLink, contentLink)\n\n    if (cmp(current, oppositePlacement.area[wh])) {\n        return\n    }\n\n    setPlacement(pos, oppositePlacement)\n}\n\nfunction oppositeLink(axis: FloatingPositionAltAxis, link: Alignment): Alignment {\n    if (axis === FloatingPositionAltAxis.Horizontal) {\n        return { horizontal: AlignHorizontalOpposite[link.horizontal], vertical: link.vertical }\n    } else {\n        return { horizontal: link.horizontal, vertical: AlignVerticalOpposite[link.vertical] }\n    }\n}\n\nexport function floatingPositionToStyle(pos: Readonly<FloatingPosition>): Partial<CSSStyleDeclaration> {\n    const contentRect = pos.content.rect\n    const placementRect = pos.placement.rect\n    // const { width: maxWidth, height: maxHeight } = pos.placement.area\n    const style: Partial<CSSStyleDeclaration> = {}\n\n    if (pos.content.link.horizontal === \"right\") {\n        style[\"right\"] = `${placementRect.width - (contentRect.x + contentRect.width)}px`\n        style[\"left\"] = \"auto\"\n    } else {\n        style[\"left\"] = `${contentRect.x}px`\n        style[\"right\"] = \"auto\"\n    }\n\n    if (pos.content.link.vertical === \"bottom\") {\n        style[\"bottom\"] = `${placementRect.height - (contentRect.y + contentRect.height)}px`\n        style[\"top\"] = \"auto\"\n    } else {\n        style[\"top\"] = `${contentRect.y}px`\n        style[\"bottom\"] = \"auto\"\n    }\n\n    // style[\"maxWidth\"] = `${maxWidth}px`\n    // style[\"maxHeight\"] = `${maxHeight}px`\n\n    return style\n}\n\nexport const enum FloatingPositionDirection {\n    Up = \"up\",\n    Down = \"down\",\n    Left = \"left\",\n    Right = \"right\",\n    Center = \"center\"\n}\n\nexport function floatingPositionDirection(pos: Readonly<FloatingPosition>): FloatingPositionDirection {\n    const { x: ax, y: ay, width: aw, height: ah } = pos.anchor.rect\n    const { x: bx, y: by, width: bw, height: bh } = pos.content.rect\n    const contentLink = pos.content.link\n    const anchorLink = pos.anchor.link\n\n    if (anchorLink.horizontal === \"center\" && anchorLink.vertical === \"middle\") {\n        if (contentLink.horizontal === \"center\" && contentLink.vertical === \"middle\") {\n            return FloatingPositionDirection.Center\n        }\n\n        const cx = pos.connection.x\n        if (cx <= bx) {\n            return FloatingPositionDirection.Right\n        } else if (cx >= bx + bw) {\n            return FloatingPositionDirection.Left\n        }\n    }\n\n    const widthOverlapPx = Math.min(ax + aw, bx + bw) - Math.max(ax, bx)\n    const widthOverlapPercent = widthOverlapPx / Math.max(aw, bw)\n    const heightOverlapPx = Math.min(ay + ah, by + bh) - Math.max(ay, by)\n    const heightOverlapPercent = heightOverlapPx / Math.max(ah, bh)\n\n    if (widthOverlapPercent >= heightOverlapPercent) {\n        if (contentLink.vertical === \"bottom\") {\n            return FloatingPositionDirection.Up\n        }\n\n        return FloatingPositionDirection.Down\n    } else {\n        if (contentLink.horizontal === \"right\") {\n            return FloatingPositionDirection.Left\n        }\n\n        return FloatingPositionDirection.Right\n    }\n}\n"]}
|
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
import { combineLatest, distinctUntilChanged, map, Observable } from "rxjs";
|
|
2
|
-
import { __zone_symbol__, rawCancelAnimationFrame, rawRequestAnimationFrame } from "@ngutil/common";
|
|
3
|
-
const addEventListener = __zone_symbol__("addEventListener");
|
|
4
|
-
const removeEventListener = __zone_symbol__("removeEventListener");
|
|
5
|
-
export function inAnimation(el, animations) {
|
|
6
|
-
return _in(el, "animationName", "animationstart", "animationiteration", "animationend", "animationcancel", animations);
|
|
7
|
-
}
|
|
8
|
-
export function inTransition(el, properties) {
|
|
9
|
-
return _in(el, "propertyName", "transitionstart", "transitionrun", "transitionend", "transitioncancel", properties);
|
|
10
|
-
}
|
|
11
|
-
export function isAnimating(el) {
|
|
12
|
-
return combineLatest([inAnimation(el), inTransition(el)]).pipe(map(values => !!(values[0] || values[1])), distinctUntilChanged());
|
|
13
|
-
}
|
|
14
|
-
function _in(el, keyName, beginName, doingName, endName, cancelName, keys) {
|
|
15
|
-
return new Observable((dest) => {
|
|
16
|
-
const state = {};
|
|
17
|
-
const start = (event) => {
|
|
18
|
-
const key = event[keyName];
|
|
19
|
-
if (keys && keys.length > 0 && !keys.includes(key)) {
|
|
20
|
-
return;
|
|
21
|
-
}
|
|
22
|
-
if (key in state) {
|
|
23
|
-
state[key]++;
|
|
24
|
-
}
|
|
25
|
-
else {
|
|
26
|
-
state[key] = 1;
|
|
27
|
-
}
|
|
28
|
-
dest.next(Object.keys(state));
|
|
29
|
-
};
|
|
30
|
-
const doing = (event) => {
|
|
31
|
-
const key = event[keyName];
|
|
32
|
-
if (keys && keys.length > 0 && !keys.includes(key)) {
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
|
-
if (!(key in state)) {
|
|
36
|
-
state[key] = 1;
|
|
37
|
-
dest.next(Object.keys(state));
|
|
38
|
-
}
|
|
39
|
-
};
|
|
40
|
-
const end = (event) => {
|
|
41
|
-
if (event[keyName] in state) {
|
|
42
|
-
const key = event[keyName];
|
|
43
|
-
state[key]--;
|
|
44
|
-
if (state[key] <= 0) {
|
|
45
|
-
delete state[key];
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
if (Object.keys(state).length === 0) {
|
|
49
|
-
dest.next(null);
|
|
50
|
-
}
|
|
51
|
-
};
|
|
52
|
-
el[addEventListener](beginName, start);
|
|
53
|
-
el[addEventListener](doingName, doing);
|
|
54
|
-
el[addEventListener](endName, end);
|
|
55
|
-
el[addEventListener](cancelName, end);
|
|
56
|
-
const raf = rawRequestAnimationFrame(() => {
|
|
57
|
-
if (Object.keys(state).length === 0) {
|
|
58
|
-
dest.next(null);
|
|
59
|
-
}
|
|
60
|
-
});
|
|
61
|
-
return () => {
|
|
62
|
-
rawCancelAnimationFrame(raf);
|
|
63
|
-
el[removeEventListener](beginName, start);
|
|
64
|
-
el[removeEventListener](doingName, doing);
|
|
65
|
-
el[removeEventListener](endName, end);
|
|
66
|
-
el[removeEventListener](cancelName, end);
|
|
67
|
-
};
|
|
68
|
-
}).pipe(distinctUntilChanged());
|
|
69
|
-
}
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"in-animation.js","sourceRoot":"","sources":["../../../../../packages/style/src/util/in-animation.ts"],"names":[],"mappings":"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","sourcesContent":["import { combineLatest, distinctUntilChanged, map, Observable, Subscriber } from \"rxjs\"\n\nimport { __zone_symbol__, rawCancelAnimationFrame, rawRequestAnimationFrame } from \"@ngutil/common\"\n\nconst addEventListener = __zone_symbol__(\"addEventListener\")\nconst removeEventListener = __zone_symbol__(\"removeEventListener\")\n\nexport function inAnimation<T extends HTMLElement>(el: T, animations?: string[]) {\n    return _in(\n        el,\n        \"animationName\",\n        \"animationstart\",\n        \"animationiteration\",\n        \"animationend\",\n        \"animationcancel\",\n        animations\n    )\n}\n\nexport function inTransition<T extends HTMLElement>(el: T, properties?: string[]) {\n    return _in(el, \"propertyName\", \"transitionstart\", \"transitionrun\", \"transitionend\", \"transitioncancel\", properties)\n}\n\nexport function isAnimating<T extends HTMLElement>(el: T) {\n    return combineLatest([inAnimation(el), inTransition(el)]).pipe(\n        map(values => !!(values[0] || values[1])),\n        distinctUntilChanged()\n    )\n}\n\nfunction _in<T extends HTMLElement>(\n    el: T,\n    keyName: string,\n    beginName: string,\n    doingName: string,\n    endName: string,\n    cancelName: string,\n    keys?: string[]\n) {\n    return new Observable((dest: Subscriber<string[] | null>) => {\n        const state: { [key: string]: number } = {}\n\n        const start = (event: any) => {\n            const key = event[keyName]\n            if (keys && keys.length > 0 && !keys.includes(key)) {\n                return\n            }\n\n            if (key in state) {\n                state[key]++\n            } else {\n                state[key] = 1\n            }\n            dest.next(Object.keys(state))\n        }\n\n        const doing = (event: any) => {\n            const key = event[keyName]\n            if (keys && keys.length > 0 && !keys.includes(key)) {\n                return\n            }\n\n            if (!(key in state)) {\n                state[key] = 1\n                dest.next(Object.keys(state))\n            }\n        }\n\n        const end = (event: any) => {\n            if (event[keyName] in state) {\n                const key = event[keyName]\n                state[key]--\n                if (state[key] <= 0) {\n                    delete state[key]\n                }\n            }\n\n            if (Object.keys(state).length === 0) {\n                dest.next(null)\n            }\n        }\n\n        el[addEventListener](beginName, start)\n        el[addEventListener](doingName, doing)\n        el[addEventListener](endName, end)\n        el[addEventListener](cancelName, end)\n\n        const raf = rawRequestAnimationFrame(() => {\n            if (Object.keys(state).length === 0) {\n                dest.next(null)\n            }\n        })\n\n        return () => {\n            rawCancelAnimationFrame(raf)\n            el[removeEventListener](beginName, start)\n            el[removeEventListener](doingName, doing)\n            el[removeEventListener](endName, end)\n            el[removeEventListener](cancelName, end)\n        }\n    }).pipe(distinctUntilChanged())\n}\n"]}
|
package/esm2022/util/rect.mjs
DELETED
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
import { alignmentNormalize } from "./alignment";
|
|
2
|
-
import { sidesNormalize } from "./sides";
|
|
3
|
-
export function rectOrigin(rect, origin) {
|
|
4
|
-
const originNorm = alignmentNormalize(origin);
|
|
5
|
-
return { x: rectHorizontalOrigin(rect, originNorm.horizontal), y: rectVerticalOrigin(rect, originNorm.vertical) };
|
|
6
|
-
}
|
|
7
|
-
function rectHorizontalOrigin(rect, horizontal) {
|
|
8
|
-
switch (horizontal) {
|
|
9
|
-
case "start":
|
|
10
|
-
case "left":
|
|
11
|
-
return rect.x;
|
|
12
|
-
case "center":
|
|
13
|
-
return rect.x + rect.width / 2;
|
|
14
|
-
case "end":
|
|
15
|
-
case "right":
|
|
16
|
-
return rect.x + rect.width;
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
function rectVerticalOrigin(rect, vertical) {
|
|
20
|
-
switch (vertical) {
|
|
21
|
-
case "top":
|
|
22
|
-
return rect.y;
|
|
23
|
-
case "middle":
|
|
24
|
-
return rect.y + rect.height / 2;
|
|
25
|
-
case "bottom":
|
|
26
|
-
return rect.y + rect.height;
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
export function rectMoveOrigin(rect, origin, position) {
|
|
30
|
-
const originNorm = alignmentNormalize(origin);
|
|
31
|
-
return {
|
|
32
|
-
...rect,
|
|
33
|
-
x: rectMoveHorizontal(rect, originNorm.horizontal, position),
|
|
34
|
-
y: rectMoveVertical(rect, originNorm.vertical, position)
|
|
35
|
-
};
|
|
36
|
-
}
|
|
37
|
-
function rectMoveHorizontal(rect, horizontal, position) {
|
|
38
|
-
switch (horizontal) {
|
|
39
|
-
case "start":
|
|
40
|
-
case "left":
|
|
41
|
-
return position.x;
|
|
42
|
-
case "center":
|
|
43
|
-
return position.x - rect.width / 2;
|
|
44
|
-
case "end":
|
|
45
|
-
case "right":
|
|
46
|
-
return position.x - rect.width;
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
function rectMoveVertical(rect, vertical, position) {
|
|
50
|
-
switch (vertical) {
|
|
51
|
-
case "top":
|
|
52
|
-
return position.y;
|
|
53
|
-
case "middle":
|
|
54
|
-
return position.y - rect.height / 2;
|
|
55
|
-
case "bottom":
|
|
56
|
-
return position.y - rect.height;
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
export function rectConstraint(rect, constraint) {
|
|
60
|
-
const x = Math.max(rect.x, constraint.x);
|
|
61
|
-
const y = Math.max(rect.y, constraint.y);
|
|
62
|
-
return {
|
|
63
|
-
x: x,
|
|
64
|
-
y: y,
|
|
65
|
-
width: Math.min(x + rect.width, constraint.x + constraint.width) - x,
|
|
66
|
-
height: Math.min(y + rect.height, constraint.y + constraint.height) - y
|
|
67
|
-
};
|
|
68
|
-
}
|
|
69
|
-
export function rectExpand(rect, margin) {
|
|
70
|
-
const marginNorm = sidesNormalize(margin);
|
|
71
|
-
return {
|
|
72
|
-
x: rect.x - marginNorm.left.value,
|
|
73
|
-
y: rect.y - marginNorm.top.value,
|
|
74
|
-
width: rect.width + marginNorm.left.value + marginNorm.right.value,
|
|
75
|
-
height: rect.height + marginNorm.top.value + marginNorm.bottom.value
|
|
76
|
-
};
|
|
77
|
-
}
|
|
78
|
-
export function rectContract(rect, padding) {
|
|
79
|
-
const normMargin = sidesNormalize(padding);
|
|
80
|
-
return {
|
|
81
|
-
x: rect.x + normMargin.left.value,
|
|
82
|
-
y: rect.y + normMargin.top.value,
|
|
83
|
-
width: rect.width - normMargin.left.value - normMargin.right.value,
|
|
84
|
-
height: rect.height - normMargin.top.value - normMargin.bottom.value
|
|
85
|
-
};
|
|
86
|
-
}
|
|
87
|
-
export function rectContainsPoint(rect, point) {
|
|
88
|
-
return point.x >= rect.x && point.x < rect.x + rect.width && point.y >= rect.y && point.y < rect.y + rect.height;
|
|
89
|
-
}
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rect.js","sourceRoot":"","sources":["../../../../../packages/style/src/util/rect.ts"],"names":[],"mappings":"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","sourcesContent":["import { AlignHorizontal, AlignmentInput, alignmentNormalize, AlignVertical } from \"./alignment\"\nimport { SidesInput, sidesNormalize } from \"./sides\"\n\nexport interface Dimension {\n    width: number\n    height: number\n}\n\nexport interface Position {\n    x: number\n    y: number\n}\n\nexport interface Rect extends Dimension, Position {}\n\nexport function rectOrigin(rect: Rect, origin: AlignmentInput): Position {\n    const originNorm = alignmentNormalize(origin)\n    return { x: rectHorizontalOrigin(rect, originNorm.horizontal), y: rectVerticalOrigin(rect, originNorm.vertical) }\n}\n\nfunction rectHorizontalOrigin(rect: Rect, horizontal: AlignHorizontal): number {\n    switch (horizontal) {\n        case \"start\":\n        case \"left\":\n            return rect.x\n\n        case \"center\":\n            return rect.x + rect.width / 2\n\n        case \"end\":\n        case \"right\":\n            return rect.x + rect.width\n    }\n}\n\nfunction rectVerticalOrigin(rect: Rect, vertical: AlignVertical): number {\n    switch (vertical) {\n        case \"top\":\n            return rect.y\n\n        case \"middle\":\n            return rect.y + rect.height / 2\n\n        case \"bottom\":\n            return rect.y + rect.height\n    }\n}\n\nexport function rectMoveOrigin(rect: Rect | Dimension, origin: AlignmentInput, position: Position): Rect {\n    const originNorm = alignmentNormalize(origin)\n    return {\n        ...rect,\n        x: rectMoveHorizontal(rect, originNorm.horizontal, position),\n        y: rectMoveVertical(rect, originNorm.vertical, position)\n    }\n}\n\nfunction rectMoveHorizontal(rect: Dimension, horizontal: AlignHorizontal, position: Position): number {\n    switch (horizontal) {\n        case \"start\":\n        case \"left\":\n            return position.x\n\n        case \"center\":\n            return position.x - rect.width / 2\n\n        case \"end\":\n        case \"right\":\n            return position.x - rect.width\n    }\n}\n\nfunction rectMoveVertical(rect: Dimension, vertical: AlignVertical, position: Position): number {\n    switch (vertical) {\n        case \"top\":\n            return position.y\n\n        case \"middle\":\n            return position.y - rect.height / 2\n\n        case \"bottom\":\n            return position.y - rect.height\n    }\n}\n\nexport function rectConstraint(rect: Rect, constraint: Rect): Rect {\n    const x = Math.max(rect.x, constraint.x)\n    const y = Math.max(rect.y, constraint.y)\n    return {\n        x: x,\n        y: y,\n        width: Math.min(x + rect.width, constraint.x + constraint.width) - x,\n        height: Math.min(y + rect.height, constraint.y + constraint.height) - y\n    }\n}\nexport function rectExpand(rect: Rect, margin: SidesInput): Rect {\n    const marginNorm = sidesNormalize(margin)\n    return {\n        x: rect.x - marginNorm.left.value,\n        y: rect.y - marginNorm.top.value,\n        width: rect.width + marginNorm.left.value + marginNorm.right.value,\n        height: rect.height + marginNorm.top.value + marginNorm.bottom.value\n    }\n}\n\nexport function rectContract(rect: Rect, padding: SidesInput): Rect {\n    const normMargin = sidesNormalize(padding)\n    return {\n        x: rect.x + normMargin.left.value,\n        y: rect.y + normMargin.top.value,\n        width: rect.width - normMargin.left.value - normMargin.right.value,\n        height: rect.height - normMargin.top.value - normMargin.bottom.value\n    }\n}\n\nexport function rectContainsPoint(rect: Rect, point: Position): boolean {\n    return point.x >= rect.x && point.x < rect.x + rect.width && point.y >= rect.y && point.y < rect.y + rect.height\n}\n"]}
|
package/esm2022/util/sides.mjs
DELETED
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { isPlainObject, NumberWithUnit } from "@ngutil/common";
|
|
2
|
-
export function sidesNormalize(value) {
|
|
3
|
-
if (isPlainObject(value)) {
|
|
4
|
-
return {
|
|
5
|
-
top: NumberWithUnit.coerce(value.top || 0, "px"),
|
|
6
|
-
right: NumberWithUnit.coerce(value.right || 0, "px"),
|
|
7
|
-
bottom: NumberWithUnit.coerce(value.bottom || 0, "px"),
|
|
8
|
-
left: NumberWithUnit.coerce(value.left || 0, "px")
|
|
9
|
-
};
|
|
10
|
-
}
|
|
11
|
-
else if (typeof value === "number") {
|
|
12
|
-
return sidesNormalize(`${value}px`);
|
|
13
|
-
}
|
|
14
|
-
else if (typeof value !== "string") {
|
|
15
|
-
throw new Error(`Invalid sides: ${value}`);
|
|
16
|
-
}
|
|
17
|
-
const entries = value.split(/\s+/g).map(v => NumberWithUnit.coerce(v, "px"));
|
|
18
|
-
if (entries.length < 0 || entries.length > 4) {
|
|
19
|
-
throw new Error(`Cannot parse: ${value}`);
|
|
20
|
-
}
|
|
21
|
-
return compose(...entries);
|
|
22
|
-
}
|
|
23
|
-
function compose(top, right = top, bottom = top, left = right) {
|
|
24
|
-
return { top, right, bottom, left };
|
|
25
|
-
}
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zdHlsZS9zcmMvdXRpbC9zaWRlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsYUFBYSxFQUFFLGNBQWMsRUFBRSxNQUFNLGdCQUFnQixDQUFBO0FBb0I5RCxNQUFNLFVBQVUsY0FBYyxDQUFDLEtBQWlCO0lBQzVDLElBQUksYUFBYSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDdkIsT0FBTztZQUNILEdBQUcsRUFBRSxjQUFjLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxFQUFFLElBQUksQ0FBQztZQUNoRCxLQUFLLEVBQUUsY0FBYyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsS0FBSyxJQUFJLENBQUMsRUFBRSxJQUFJLENBQUM7WUFDcEQsTUFBTSxFQUFFLGNBQWMsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLE1BQU0sSUFBSSxDQUFDLEVBQUUsSUFBSSxDQUFDO1lBQ3RELElBQUksRUFBRSxjQUFjLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxJQUFJLElBQUksQ0FBQyxFQUFFLElBQUksQ0FBQztTQUNyRCxDQUFBO0lBQ0wsQ0FBQztTQUFNLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUSxFQUFFLENBQUM7UUFDbkMsT0FBTyxjQUFjLENBQUMsR0FBRyxLQUFLLElBQUksQ0FBQyxDQUFBO0lBQ3ZDLENBQUM7U0FBTSxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsRUFBRSxDQUFDO1FBQ25DLE1BQU0sSUFBSSxLQUFLLENBQUMsa0JBQWtCLEtBQUssRUFBRSxDQUFDLENBQUE7SUFDOUMsQ0FBQztJQUVELE1BQU0sT0FBTyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQXFCLENBQUE7SUFFaEcsSUFBSSxPQUFPLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxPQUFPLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQzNDLE1BQU0sSUFBSSxLQUFLLENBQUMsaUJBQWlCLEtBQUssRUFBRSxDQUFDLENBQUE7SUFDN0MsQ0FBQztJQUVELE9BQU8sT0FBTyxDQUFDLEdBQUcsT0FBTyxDQUFDLENBQUE7QUFDOUIsQ0FBQztBQUVELFNBQVMsT0FBTyxDQUNaLEdBQW1CLEVBQ25CLFFBQXdCLEdBQUcsRUFDM0IsU0FBeUIsR0FBRyxFQUM1QixPQUF1QixLQUFLO0lBRTVCLE9BQU8sRUFBRSxHQUFHLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsQ0FBQTtBQUN2QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaXNQbGFpbk9iamVjdCwgTnVtYmVyV2l0aFVuaXQgfSBmcm9tIFwiQG5ndXRpbC9jb21tb25cIlxuXG5leHBvcnQgaW50ZXJmYWNlIFNpZGVzIHtcbiAgICB0b3A6IE51bWJlcldpdGhVbml0XG4gICAgcmlnaHQ6IE51bWJlcldpdGhVbml0XG4gICAgYm90dG9tOiBOdW1iZXJXaXRoVW5pdFxuICAgIGxlZnQ6IE51bWJlcldpdGhVbml0XG59XG5cbmV4cG9ydCB0eXBlIFNpZGVzVW5pdCA9IFwicHhcIiB8IFwiJVwiXG5leHBvcnQgdHlwZSBTaWRlc051bWJlciA9IGAke251bWJlcn0ke1NpZGVzVW5pdH1gIHwgbnVtYmVyXG5leHBvcnQgdHlwZSBTaWRlc0lucHV0T2JqID0geyB0b3A/OiBTaWRlc051bWJlcjsgcmlnaHQ/OiBTaWRlc051bWJlcjsgYm90dG9tPzogU2lkZXNOdW1iZXI7IGxlZnQ/OiBTaWRlc051bWJlciB9XG5leHBvcnQgdHlwZSBTaWRlc0lucHV0ID1cbiAgICB8IFNpZGVzXG4gICAgfCBTaWRlc051bWJlclxuICAgIHwgU2lkZXNJbnB1dE9ialxuICAgIHwgYCR7U2lkZXNOdW1iZXJ9ICR7U2lkZXNOdW1iZXJ9YFxuICAgIHwgYCR7U2lkZXNOdW1iZXJ9ICR7U2lkZXNOdW1iZXJ9ICR7U2lkZXNOdW1iZXJ9YFxuICAgIHwgYCR7U2lkZXNOdW1iZXJ9ICR7U2lkZXNOdW1iZXJ9ICR7U2lkZXNOdW1iZXJ9ICR7U2lkZXNOdW1iZXJ9YFxuXG5leHBvcnQgZnVuY3Rpb24gc2lkZXNOb3JtYWxpemUodmFsdWU6IFNpZGVzSW5wdXQpOiBTaWRlcyB7XG4gICAgaWYgKGlzUGxhaW5PYmplY3QodmFsdWUpKSB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICB0b3A6IE51bWJlcldpdGhVbml0LmNvZXJjZSh2YWx1ZS50b3AgfHwgMCwgXCJweFwiKSxcbiAgICAgICAgICAgIHJpZ2h0OiBOdW1iZXJXaXRoVW5pdC5jb2VyY2UodmFsdWUucmlnaHQgfHwgMCwgXCJweFwiKSxcbiAgICAgICAgICAgIGJvdHRvbTogTnVtYmVyV2l0aFVuaXQuY29lcmNlKHZhbHVlLmJvdHRvbSB8fCAwLCBcInB4XCIpLFxuICAgICAgICAgICAgbGVmdDogTnVtYmVyV2l0aFVuaXQuY29lcmNlKHZhbHVlLmxlZnQgfHwgMCwgXCJweFwiKVxuICAgICAgICB9XG4gICAgfSBlbHNlIGlmICh0eXBlb2YgdmFsdWUgPT09IFwibnVtYmVyXCIpIHtcbiAgICAgICAgcmV0dXJuIHNpZGVzTm9ybWFsaXplKGAke3ZhbHVlfXB4YClcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiB2YWx1ZSAhPT0gXCJzdHJpbmdcIikge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYEludmFsaWQgc2lkZXM6ICR7dmFsdWV9YClcbiAgICB9XG5cbiAgICBjb25zdCBlbnRyaWVzID0gdmFsdWUuc3BsaXQoL1xccysvZykubWFwKHYgPT4gTnVtYmVyV2l0aFVuaXQuY29lcmNlKHYsIFwicHhcIikpIGFzIFtOdW1iZXJXaXRoVW5pdF1cblxuICAgIGlmIChlbnRyaWVzLmxlbmd0aCA8IDAgfHwgZW50cmllcy5sZW5ndGggPiA0KSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgQ2Fubm90IHBhcnNlOiAke3ZhbHVlfWApXG4gICAgfVxuXG4gICAgcmV0dXJuIGNvbXBvc2UoLi4uZW50cmllcylcbn1cblxuZnVuY3Rpb24gY29tcG9zZShcbiAgICB0b3A6IE51bWJlcldpdGhVbml0LFxuICAgIHJpZ2h0OiBOdW1iZXJXaXRoVW5pdCA9IHRvcCxcbiAgICBib3R0b206IE51bWJlcldpdGhVbml0ID0gdG9wLFxuICAgIGxlZnQ6IE51bWJlcldpdGhVbml0ID0gcmlnaHRcbik6IFNpZGVzIHtcbiAgICByZXR1cm4geyB0b3AsIHJpZ2h0LCBib3R0b20sIGxlZnQgfVxufVxuIl19
|