@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.
@@ -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"]}
@@ -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"]}
@@ -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