@studiometa/ui 0.1.1 → 0.2.2
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/README.md +37 -1
- package/atoms/AnchorScrollTo/AnchorScrollTo.cjs +52 -0
- package/atoms/AnchorScrollTo/AnchorScrollTo.d.ts +31 -0
- package/atoms/AnchorScrollTo/AnchorScrollTo.js +26 -0
- package/atoms/Cursor/Cursor.cjs +129 -0
- package/{Cursor.d.ts → atoms/Cursor/Cursor.d.ts} +0 -0
- package/atoms/Cursor/Cursor.js +103 -0
- package/atoms/Figure/Figure.cjs +53 -0
- package/atoms/Figure/Figure.d.ts +31 -0
- package/atoms/Figure/Figure.js +27 -0
- package/atoms/LargeText/LargeText.cjs +74 -0
- package/atoms/LargeText/LargeText.d.ts +71 -0
- package/atoms/LargeText/LargeText.js +48 -0
- package/atoms/LazyInclude/LazyInclude.cjs +72 -0
- package/atoms/LazyInclude/LazyInclude.d.ts +64 -0
- package/atoms/LazyInclude/LazyInclude.js +46 -0
- package/atoms/Prefetch/AbstractPrefetch.cjs +84 -0
- package/atoms/Prefetch/AbstractPrefetch.d.ts +52 -0
- package/atoms/Prefetch/AbstractPrefetch.js +58 -0
- package/atoms/Prefetch/PrefetchWhenOver.cjs +65 -0
- package/atoms/Prefetch/PrefetchWhenOver.d.ts +21 -0
- package/atoms/Prefetch/PrefetchWhenOver.js +35 -0
- package/atoms/Prefetch/PrefetchWhenVisible.cjs +66 -0
- package/atoms/Prefetch/PrefetchWhenVisible.d.ts +21 -0
- package/atoms/Prefetch/PrefetchWhenVisible.js +36 -0
- package/atoms/Prefetch/index.cjs +40 -0
- package/atoms/Prefetch/index.d.ts +3 -0
- package/atoms/Prefetch/index.js +8 -0
- package/atoms/index.cjs +45 -0
- package/atoms/index.d.ts +6 -0
- package/atoms/index.js +13 -0
- package/index.cjs +26 -0
- package/index.d.ts +3 -6
- package/index.js +3 -6
- package/molecules/Accordion/Accordion.cjs +65 -0
- package/{Accordion/index.d.ts → molecules/Accordion/Accordion.d.ts} +5 -6
- package/molecules/Accordion/Accordion.js +35 -0
- package/molecules/Accordion/AccordionCore.cjs +60 -0
- package/{Accordion/Accordion.d.ts → molecules/Accordion/AccordionCore.d.ts} +0 -0
- package/molecules/Accordion/AccordionCore.js +34 -0
- package/molecules/Accordion/AccordionItem.cjs +208 -0
- package/{Accordion → molecules/Accordion}/AccordionItem.d.ts +11 -13
- package/molecules/Accordion/AccordionItem.js +178 -0
- package/molecules/Modal/Modal.cjs +176 -0
- package/{Modal.d.ts → molecules/Modal/Modal.d.ts} +9 -9
- package/molecules/Modal/Modal.js +150 -0
- package/molecules/Modal/ModalWithTransition.cjs +100 -0
- package/molecules/Modal/ModalWithTransition.d.ts +29 -0
- package/molecules/Modal/ModalWithTransition.js +69 -0
- package/molecules/Panel/Panel.cjs +148 -0
- package/molecules/Panel/Panel.d.ts +42 -0
- package/molecules/Panel/Panel.js +117 -0
- package/molecules/Slider/AbstractSliderChild.cjs +74 -0
- package/molecules/Slider/AbstractSliderChild.d.ts +55 -0
- package/molecules/Slider/AbstractSliderChild.js +43 -0
- package/molecules/Slider/Slider.cjs +240 -0
- package/molecules/Slider/Slider.d.ts +245 -0
- package/molecules/Slider/Slider.js +209 -0
- package/molecules/Slider/SliderBtn.cjs +65 -0
- package/molecules/Slider/SliderBtn.d.ts +31 -0
- package/molecules/Slider/SliderBtn.js +34 -0
- package/molecules/Slider/SliderCount.cjs +50 -0
- package/molecules/Slider/SliderCount.d.ts +21 -0
- package/molecules/Slider/SliderCount.js +19 -0
- package/molecules/Slider/SliderDots.cjs +55 -0
- package/molecules/Slider/SliderDots.d.ts +33 -0
- package/molecules/Slider/SliderDots.js +24 -0
- package/molecules/Slider/SliderDrag.cjs +45 -0
- package/molecules/Slider/SliderDrag.d.ts +16 -0
- package/molecules/Slider/SliderDrag.js +19 -0
- package/molecules/Slider/SliderItem.cjs +130 -0
- package/molecules/Slider/SliderItem.d.ts +106 -0
- package/molecules/Slider/SliderItem.js +105 -0
- package/molecules/Slider/SliderProgress.cjs +54 -0
- package/molecules/Slider/SliderProgress.d.ts +27 -0
- package/molecules/Slider/SliderProgress.js +23 -0
- package/molecules/Slider/index.cjs +50 -0
- package/molecules/Slider/index.d.ts +8 -0
- package/molecules/Slider/index.js +18 -0
- package/molecules/Sticky/Sticky.cjs +133 -0
- package/molecules/Sticky/Sticky.d.ts +141 -0
- package/molecules/Sticky/Sticky.js +107 -0
- package/molecules/TableOfContent/TableOfContent.cjs +73 -0
- package/molecules/TableOfContent/TableOfContent.d.ts +59 -0
- package/molecules/TableOfContent/TableOfContent.js +42 -0
- package/molecules/TableOfContent/TableOfContentAnchor.cjs +65 -0
- package/molecules/TableOfContent/TableOfContentAnchor.d.ts +36 -0
- package/molecules/TableOfContent/TableOfContentAnchor.js +39 -0
- package/molecules/TableOfContent/index.cjs +38 -0
- package/molecules/TableOfContent/index.d.ts +2 -0
- package/molecules/TableOfContent/index.js +6 -0
- package/molecules/Tabs/Tabs.cjs +152 -0
- package/{Tabs.d.ts → molecules/Tabs/Tabs.d.ts} +2 -4
- package/molecules/Tabs/Tabs.js +126 -0
- package/molecules/index.cjs +50 -0
- package/molecules/index.d.ts +9 -0
- package/molecules/index.js +18 -0
- package/organisms/Frame/Frame.cjs +202 -0
- package/organisms/Frame/Frame.d.ts +119 -0
- package/organisms/Frame/Frame.js +171 -0
- package/organisms/Frame/FrameAnchor.cjs +48 -0
- package/organisms/Frame/FrameAnchor.d.ts +35 -0
- package/organisms/Frame/FrameAnchor.js +22 -0
- package/organisms/Frame/FrameForm.cjs +48 -0
- package/organisms/Frame/FrameForm.d.ts +32 -0
- package/organisms/Frame/FrameForm.js +22 -0
- package/organisms/Frame/FrameTarget.cjs +134 -0
- package/organisms/Frame/FrameTarget.d.ts +47 -0
- package/organisms/Frame/FrameTarget.js +109 -0
- package/organisms/Frame/index.cjs +42 -0
- package/organisms/Frame/index.d.ts +4 -0
- package/organisms/Frame/index.js +10 -0
- package/organisms/index.cjs +24 -0
- package/organisms/index.d.ts +1 -0
- package/organisms/index.js +1 -0
- package/package.json +2 -2
- package/primitives/Draggable/Draggable.cjs +64 -0
- package/{Draggable.d.ts → primitives/Draggable/Draggable.d.ts} +0 -0
- package/primitives/Draggable/Draggable.js +38 -0
- package/primitives/Sentinel/Sentinel.cjs +41 -0
- package/primitives/Sentinel/Sentinel.d.ts +12 -0
- package/primitives/Sentinel/Sentinel.js +15 -0
- package/primitives/Transition/Transition.cjs +71 -0
- package/primitives/Transition/Transition.d.ts +69 -0
- package/primitives/Transition/Transition.js +45 -0
- package/primitives/index.cjs +40 -0
- package/primitives/index.d.ts +3 -0
- package/primitives/index.js +8 -0
- package/Accordion/Accordion.js +0 -29
- package/Accordion/AccordionItem.js +0 -197
- package/Accordion/index.js +0 -12
- package/Cursor.js +0 -121
- package/Draggable.js +0 -31
- package/Modal.js +0 -167
- package/Tabs.js +0 -106
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
3
|
+
var __publicField = (obj, key, value) => {
|
|
4
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
5
|
+
return value;
|
|
6
|
+
};
|
|
7
|
+
import { Base, withMountWhenInView } from "@studiometa/js-toolkit";
|
|
8
|
+
import { damp, matrix, clamp, nextFrame } from "@studiometa/js-toolkit/utils";
|
|
9
|
+
class LargeText extends withMountWhenInView(Base, { rootMargin: "50%" }) {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments);
|
|
12
|
+
__publicField(this, "translateX", 0);
|
|
13
|
+
__publicField(this, "deltaY", 0);
|
|
14
|
+
__publicField(this, "transform", {
|
|
15
|
+
skewX: 0,
|
|
16
|
+
translateX: 0
|
|
17
|
+
});
|
|
18
|
+
__publicField(this, "width", 0);
|
|
19
|
+
}
|
|
20
|
+
mounted() {
|
|
21
|
+
this.width = this.$refs.target.clientWidth;
|
|
22
|
+
}
|
|
23
|
+
resized() {
|
|
24
|
+
this.width = this.$refs.target.clientWidth;
|
|
25
|
+
}
|
|
26
|
+
scrolled(props) {
|
|
27
|
+
this.deltaY = props.delta.y;
|
|
28
|
+
}
|
|
29
|
+
ticked() {
|
|
30
|
+
this.translateX -= Math.abs(this.deltaY) + 1;
|
|
31
|
+
this.transform.translateX = damp(this.translateX, this.transform.translateX, 0.25);
|
|
32
|
+
this.transform.skewX = damp(clamp(this.deltaY / 20 * -1, -0.5, 0.5), this.transform.skewX, 0.25);
|
|
33
|
+
if (Math.abs(this.transform.translateX) >= this.width) {
|
|
34
|
+
this.translateX = 0;
|
|
35
|
+
this.transform.translateX = 0;
|
|
36
|
+
}
|
|
37
|
+
nextFrame(() => {
|
|
38
|
+
this.$refs.target.style.transform = matrix(this.transform) + " translateZ(0px)";
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
__publicField(LargeText, "config", {
|
|
43
|
+
name: "LargeText",
|
|
44
|
+
refs: ["target"]
|
|
45
|
+
});
|
|
46
|
+
export {
|
|
47
|
+
LargeText as default
|
|
48
|
+
};
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
6
|
+
var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all)
|
|
9
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
+
};
|
|
11
|
+
var __reExport = (target, module2, copyDefault, desc) => {
|
|
12
|
+
if (module2 && typeof module2 === "object" || typeof module2 === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(module2))
|
|
14
|
+
if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
|
|
15
|
+
__defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
|
|
16
|
+
}
|
|
17
|
+
return target;
|
|
18
|
+
};
|
|
19
|
+
var __toCommonJS = /* @__PURE__ */ ((cache) => {
|
|
20
|
+
return (module2, temp) => {
|
|
21
|
+
return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
|
|
22
|
+
};
|
|
23
|
+
})(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
|
|
24
|
+
var __publicField = (obj, key, value) => {
|
|
25
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
26
|
+
return value;
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
// packages/ui/atoms/LazyInclude/LazyInclude.js
|
|
30
|
+
var LazyInclude_exports = {};
|
|
31
|
+
__export(LazyInclude_exports, {
|
|
32
|
+
default: () => LazyInclude
|
|
33
|
+
});
|
|
34
|
+
var import_js_toolkit = require("@studiometa/js-toolkit");
|
|
35
|
+
var LazyInclude = class extends import_js_toolkit.Base {
|
|
36
|
+
mounted() {
|
|
37
|
+
if (!this.$options.src) {
|
|
38
|
+
this.$log("The `src` option is missing. Define it with the `data-option-src` attribute");
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
fetch(this.$options.src).then((response) => response.text()).then((content) => {
|
|
42
|
+
this.$emit("content", content);
|
|
43
|
+
}).catch((error) => {
|
|
44
|
+
this.$emit("error", error);
|
|
45
|
+
}).finally(() => {
|
|
46
|
+
this.$emit("always");
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
onContent(content) {
|
|
50
|
+
this.$refs.loading.style.display = "none";
|
|
51
|
+
this.$el.innerHTML = content;
|
|
52
|
+
}
|
|
53
|
+
onError() {
|
|
54
|
+
this.$refs.error.style.display = "block";
|
|
55
|
+
}
|
|
56
|
+
onAlways() {
|
|
57
|
+
if (this.$options.terminateOnLoad) {
|
|
58
|
+
this.$terminate();
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
__publicField(LazyInclude, "config", {
|
|
63
|
+
name: "LazyInclude",
|
|
64
|
+
refs: ["loading", "error"],
|
|
65
|
+
emits: ["content", "error", "always"],
|
|
66
|
+
options: {
|
|
67
|
+
src: String,
|
|
68
|
+
terminateOnLoad: Boolean
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
module.exports = __toCommonJS(LazyInclude_exports);
|
|
72
|
+
if (module.exports.default) module.exports = module.exports.default;
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @typedef {{ src: string, terminateOnLoad: boolean }} LazyIncludeOptions
|
|
3
|
+
* @typedef {{ loading: HTMLElement, error: HTMLElement }} LazyIncludeRefs
|
|
4
|
+
* @typedef {LazyInclude & { $refs: LazyIncludeRefs, $options: LazyIncludeOptions }} LazyIncludeInterface
|
|
5
|
+
*/
|
|
6
|
+
/**
|
|
7
|
+
* LazyInclude class.
|
|
8
|
+
*/
|
|
9
|
+
export default class LazyInclude extends Base {
|
|
10
|
+
/**
|
|
11
|
+
* Config.
|
|
12
|
+
*/
|
|
13
|
+
static config: {
|
|
14
|
+
name: string;
|
|
15
|
+
refs: string[];
|
|
16
|
+
emits: string[];
|
|
17
|
+
options: {
|
|
18
|
+
src: StringConstructor;
|
|
19
|
+
terminateOnLoad: BooleanConstructor;
|
|
20
|
+
};
|
|
21
|
+
};
|
|
22
|
+
/**
|
|
23
|
+
* Load the lazy content on mount.
|
|
24
|
+
*
|
|
25
|
+
* @this {LazyIncludeInterface}
|
|
26
|
+
* @returns {void}
|
|
27
|
+
*/
|
|
28
|
+
mounted(): void;
|
|
29
|
+
/**
|
|
30
|
+
* Set content.
|
|
31
|
+
*
|
|
32
|
+
* @this {LazyIncludeInterface}
|
|
33
|
+
* @param {string} content
|
|
34
|
+
* @returns {void}
|
|
35
|
+
*/
|
|
36
|
+
onContent(content: string): void;
|
|
37
|
+
/**
|
|
38
|
+
* Set error.
|
|
39
|
+
*
|
|
40
|
+
* @this {LazyIncludeInterface}
|
|
41
|
+
* @returns {void}
|
|
42
|
+
*/
|
|
43
|
+
onError(): void;
|
|
44
|
+
/**
|
|
45
|
+
* Always.
|
|
46
|
+
*
|
|
47
|
+
* @this {LazyIncludeInterface}
|
|
48
|
+
* @returns {void}
|
|
49
|
+
*/
|
|
50
|
+
onAlways(): void;
|
|
51
|
+
}
|
|
52
|
+
export type LazyIncludeOptions = {
|
|
53
|
+
src: string;
|
|
54
|
+
terminateOnLoad: boolean;
|
|
55
|
+
};
|
|
56
|
+
export type LazyIncludeRefs = {
|
|
57
|
+
loading: HTMLElement;
|
|
58
|
+
error: HTMLElement;
|
|
59
|
+
};
|
|
60
|
+
export type LazyIncludeInterface = LazyInclude & {
|
|
61
|
+
$refs: LazyIncludeRefs;
|
|
62
|
+
$options: LazyIncludeOptions;
|
|
63
|
+
};
|
|
64
|
+
import { Base } from "@studiometa/js-toolkit";
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
3
|
+
var __publicField = (obj, key, value) => {
|
|
4
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
5
|
+
return value;
|
|
6
|
+
};
|
|
7
|
+
import { Base } from "@studiometa/js-toolkit";
|
|
8
|
+
class LazyInclude extends Base {
|
|
9
|
+
mounted() {
|
|
10
|
+
if (!this.$options.src) {
|
|
11
|
+
this.$log("The `src` option is missing. Define it with the `data-option-src` attribute");
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
fetch(this.$options.src).then((response) => response.text()).then((content) => {
|
|
15
|
+
this.$emit("content", content);
|
|
16
|
+
}).catch((error) => {
|
|
17
|
+
this.$emit("error", error);
|
|
18
|
+
}).finally(() => {
|
|
19
|
+
this.$emit("always");
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
onContent(content) {
|
|
23
|
+
this.$refs.loading.style.display = "none";
|
|
24
|
+
this.$el.innerHTML = content;
|
|
25
|
+
}
|
|
26
|
+
onError() {
|
|
27
|
+
this.$refs.error.style.display = "block";
|
|
28
|
+
}
|
|
29
|
+
onAlways() {
|
|
30
|
+
if (this.$options.terminateOnLoad) {
|
|
31
|
+
this.$terminate();
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
__publicField(LazyInclude, "config", {
|
|
36
|
+
name: "LazyInclude",
|
|
37
|
+
refs: ["loading", "error"],
|
|
38
|
+
emits: ["content", "error", "always"],
|
|
39
|
+
options: {
|
|
40
|
+
src: String,
|
|
41
|
+
terminateOnLoad: Boolean
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
export {
|
|
45
|
+
LazyInclude as default
|
|
46
|
+
};
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
6
|
+
var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all)
|
|
9
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
+
};
|
|
11
|
+
var __reExport = (target, module2, copyDefault, desc) => {
|
|
12
|
+
if (module2 && typeof module2 === "object" || typeof module2 === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(module2))
|
|
14
|
+
if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
|
|
15
|
+
__defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
|
|
16
|
+
}
|
|
17
|
+
return target;
|
|
18
|
+
};
|
|
19
|
+
var __toCommonJS = /* @__PURE__ */ ((cache) => {
|
|
20
|
+
return (module2, temp) => {
|
|
21
|
+
return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
|
|
22
|
+
};
|
|
23
|
+
})(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
|
|
24
|
+
var __publicField = (obj, key, value) => {
|
|
25
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
26
|
+
return value;
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
// packages/ui/atoms/Prefetch/AbstractPrefetch.js
|
|
30
|
+
var AbstractPrefetch_exports = {};
|
|
31
|
+
__export(AbstractPrefetch_exports, {
|
|
32
|
+
default: () => AbstractPrefetch
|
|
33
|
+
});
|
|
34
|
+
var import_js_toolkit = require("@studiometa/js-toolkit");
|
|
35
|
+
var _AbstractPrefetch = class extends import_js_toolkit.Base {
|
|
36
|
+
isPrefetchable(url, options) {
|
|
37
|
+
if (!url || !url.href) {
|
|
38
|
+
return false;
|
|
39
|
+
}
|
|
40
|
+
if (!options.prefetch) {
|
|
41
|
+
return false;
|
|
42
|
+
}
|
|
43
|
+
if (url.origin !== window.location.origin) {
|
|
44
|
+
return false;
|
|
45
|
+
}
|
|
46
|
+
if (!["http:", "https:"].includes(url.protocol)) {
|
|
47
|
+
return false;
|
|
48
|
+
}
|
|
49
|
+
if (url.protocol === "http:" && window.location.protocol === "https:") {
|
|
50
|
+
return false;
|
|
51
|
+
}
|
|
52
|
+
if (url.hash && url.pathname + url.search === window.location.pathname + window.location.search) {
|
|
53
|
+
return false;
|
|
54
|
+
}
|
|
55
|
+
return true;
|
|
56
|
+
}
|
|
57
|
+
prefetch(url) {
|
|
58
|
+
if (_AbstractPrefetch.prefetchedUrls.has(url.href)) {
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
if (!this.isPrefetchable(url, this.$options)) {
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
const prefetcher = document.createElement("link");
|
|
65
|
+
prefetcher.rel = "prefetch";
|
|
66
|
+
prefetcher.href = url.href;
|
|
67
|
+
document.head.appendChild(prefetcher);
|
|
68
|
+
_AbstractPrefetch.prefetchedUrls.add(url.href);
|
|
69
|
+
this.$terminate();
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
var AbstractPrefetch = _AbstractPrefetch;
|
|
73
|
+
__publicField(AbstractPrefetch, "config", {
|
|
74
|
+
name: "AbstractPrefetch",
|
|
75
|
+
options: {
|
|
76
|
+
prefetch: {
|
|
77
|
+
type: Boolean,
|
|
78
|
+
default: true
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
__publicField(AbstractPrefetch, "prefetchedUrls", /* @__PURE__ */ new Set());
|
|
83
|
+
module.exports = __toCommonJS(AbstractPrefetch_exports);
|
|
84
|
+
if (module.exports.default) module.exports = module.exports.default;
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @typedef {{ prefetch: boolean }} PrefetchOptions
|
|
3
|
+
*/
|
|
4
|
+
/**
|
|
5
|
+
* @typedef {AbstractPrefetch & {
|
|
6
|
+
* $options: PrefetchOptions
|
|
7
|
+
* }} AbstractPrefetchInterface
|
|
8
|
+
*/
|
|
9
|
+
/**
|
|
10
|
+
* AbstractPrefetch class.
|
|
11
|
+
*/
|
|
12
|
+
export default class AbstractPrefetch extends Base {
|
|
13
|
+
/**
|
|
14
|
+
* Config.
|
|
15
|
+
*/
|
|
16
|
+
static config: {
|
|
17
|
+
name: string;
|
|
18
|
+
options: {
|
|
19
|
+
prefetch: {
|
|
20
|
+
type: BooleanConstructor;
|
|
21
|
+
default: boolean;
|
|
22
|
+
};
|
|
23
|
+
};
|
|
24
|
+
};
|
|
25
|
+
/**
|
|
26
|
+
* Store prefetched URL.
|
|
27
|
+
* @type {Set<string>}
|
|
28
|
+
*/
|
|
29
|
+
static prefetchedUrls: Set<string>;
|
|
30
|
+
/**
|
|
31
|
+
* Is the given anchor prefetchable?
|
|
32
|
+
* @param {URL} url
|
|
33
|
+
* @param {PrefetchOptions} options
|
|
34
|
+
* @returns {boolean}
|
|
35
|
+
*/
|
|
36
|
+
isPrefetchable(url: URL, options: PrefetchOptions): boolean;
|
|
37
|
+
/**
|
|
38
|
+
* Prefetch the given URL and terminate the component.
|
|
39
|
+
*
|
|
40
|
+
* @this {AbstractPrefetchInterface}
|
|
41
|
+
* @param {URL} url
|
|
42
|
+
* @returns {void}
|
|
43
|
+
*/
|
|
44
|
+
prefetch(url: URL): void;
|
|
45
|
+
}
|
|
46
|
+
export type PrefetchOptions = {
|
|
47
|
+
prefetch: boolean;
|
|
48
|
+
};
|
|
49
|
+
export type AbstractPrefetchInterface = AbstractPrefetch & {
|
|
50
|
+
$options: PrefetchOptions;
|
|
51
|
+
};
|
|
52
|
+
import { Base } from "@studiometa/js-toolkit";
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
3
|
+
var __publicField = (obj, key, value) => {
|
|
4
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
5
|
+
return value;
|
|
6
|
+
};
|
|
7
|
+
import { Base } from "@studiometa/js-toolkit";
|
|
8
|
+
const _AbstractPrefetch = class extends Base {
|
|
9
|
+
isPrefetchable(url, options) {
|
|
10
|
+
if (!url || !url.href) {
|
|
11
|
+
return false;
|
|
12
|
+
}
|
|
13
|
+
if (!options.prefetch) {
|
|
14
|
+
return false;
|
|
15
|
+
}
|
|
16
|
+
if (url.origin !== window.location.origin) {
|
|
17
|
+
return false;
|
|
18
|
+
}
|
|
19
|
+
if (!["http:", "https:"].includes(url.protocol)) {
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
if (url.protocol === "http:" && window.location.protocol === "https:") {
|
|
23
|
+
return false;
|
|
24
|
+
}
|
|
25
|
+
if (url.hash && url.pathname + url.search === window.location.pathname + window.location.search) {
|
|
26
|
+
return false;
|
|
27
|
+
}
|
|
28
|
+
return true;
|
|
29
|
+
}
|
|
30
|
+
prefetch(url) {
|
|
31
|
+
if (_AbstractPrefetch.prefetchedUrls.has(url.href)) {
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
if (!this.isPrefetchable(url, this.$options)) {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
const prefetcher = document.createElement("link");
|
|
38
|
+
prefetcher.rel = "prefetch";
|
|
39
|
+
prefetcher.href = url.href;
|
|
40
|
+
document.head.appendChild(prefetcher);
|
|
41
|
+
_AbstractPrefetch.prefetchedUrls.add(url.href);
|
|
42
|
+
this.$terminate();
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
let AbstractPrefetch = _AbstractPrefetch;
|
|
46
|
+
__publicField(AbstractPrefetch, "config", {
|
|
47
|
+
name: "AbstractPrefetch",
|
|
48
|
+
options: {
|
|
49
|
+
prefetch: {
|
|
50
|
+
type: Boolean,
|
|
51
|
+
default: true
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
__publicField(AbstractPrefetch, "prefetchedUrls", /* @__PURE__ */ new Set());
|
|
56
|
+
export {
|
|
57
|
+
AbstractPrefetch as default
|
|
58
|
+
};
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __defProps = Object.defineProperties;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
6
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
7
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
8
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
9
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
10
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
11
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
12
|
+
var __spreadValues = (a, b) => {
|
|
13
|
+
for (var prop in b || (b = {}))
|
|
14
|
+
if (__hasOwnProp.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
if (__getOwnPropSymbols)
|
|
17
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
18
|
+
if (__propIsEnum.call(b, prop))
|
|
19
|
+
__defNormalProp(a, prop, b[prop]);
|
|
20
|
+
}
|
|
21
|
+
return a;
|
|
22
|
+
};
|
|
23
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
24
|
+
var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
|
|
25
|
+
var __export = (target, all) => {
|
|
26
|
+
for (var name in all)
|
|
27
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
28
|
+
};
|
|
29
|
+
var __reExport = (target, module2, copyDefault, desc) => {
|
|
30
|
+
if (module2 && typeof module2 === "object" || typeof module2 === "function") {
|
|
31
|
+
for (let key of __getOwnPropNames(module2))
|
|
32
|
+
if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
|
|
33
|
+
__defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
|
|
34
|
+
}
|
|
35
|
+
return target;
|
|
36
|
+
};
|
|
37
|
+
var __toESM = (module2, isNodeMode) => {
|
|
38
|
+
return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", !isNodeMode && module2 && module2.__esModule ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
|
|
39
|
+
};
|
|
40
|
+
var __toCommonJS = /* @__PURE__ */ ((cache) => {
|
|
41
|
+
return (module2, temp) => {
|
|
42
|
+
return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
|
|
43
|
+
};
|
|
44
|
+
})(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
|
|
45
|
+
var __publicField = (obj, key, value) => {
|
|
46
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
47
|
+
return value;
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
// packages/ui/atoms/Prefetch/PrefetchWhenOver.js
|
|
51
|
+
var PrefetchWhenOver_exports = {};
|
|
52
|
+
__export(PrefetchWhenOver_exports, {
|
|
53
|
+
default: () => PrefetchWhenOver
|
|
54
|
+
});
|
|
55
|
+
var import_AbstractPrefetch = __toESM(require("./AbstractPrefetch.cjs"), 1);
|
|
56
|
+
var PrefetchWhenOver = class extends import_AbstractPrefetch.default {
|
|
57
|
+
onMouseenter() {
|
|
58
|
+
this.prefetch(new URL(this.$el.href));
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
__publicField(PrefetchWhenOver, "config", __spreadProps(__spreadValues({}, import_AbstractPrefetch.default.config), {
|
|
62
|
+
name: "PrefetchWhenOver"
|
|
63
|
+
}));
|
|
64
|
+
module.exports = __toCommonJS(PrefetchWhenOver_exports);
|
|
65
|
+
if (module.exports.default) module.exports = module.exports.default;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @typedef {PrefetchWhenOver & {
|
|
3
|
+
* $el: HTMLAnchorElement
|
|
4
|
+
* }} PrefetchWhenOverInterface
|
|
5
|
+
*/
|
|
6
|
+
/**
|
|
7
|
+
* PrefetchWhenOver class.
|
|
8
|
+
*/
|
|
9
|
+
export default class PrefetchWhenOver extends AbstractPrefetch {
|
|
10
|
+
/**
|
|
11
|
+
* Prefetch on mouseenter.
|
|
12
|
+
*
|
|
13
|
+
* @this {PrefetchWhenOverInterface}
|
|
14
|
+
* @returns {void}
|
|
15
|
+
*/
|
|
16
|
+
onMouseenter(): void;
|
|
17
|
+
}
|
|
18
|
+
export type PrefetchWhenOverInterface = PrefetchWhenOver & {
|
|
19
|
+
$el: HTMLAnchorElement;
|
|
20
|
+
};
|
|
21
|
+
import AbstractPrefetch from "./AbstractPrefetch.js";
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defProps = Object.defineProperties;
|
|
3
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
4
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
7
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
8
|
+
var __spreadValues = (a, b) => {
|
|
9
|
+
for (var prop in b || (b = {}))
|
|
10
|
+
if (__hasOwnProp.call(b, prop))
|
|
11
|
+
__defNormalProp(a, prop, b[prop]);
|
|
12
|
+
if (__getOwnPropSymbols)
|
|
13
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
14
|
+
if (__propIsEnum.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
}
|
|
17
|
+
return a;
|
|
18
|
+
};
|
|
19
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
20
|
+
var __publicField = (obj, key, value) => {
|
|
21
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
22
|
+
return value;
|
|
23
|
+
};
|
|
24
|
+
import AbstractPrefetch from "./AbstractPrefetch.js";
|
|
25
|
+
class PrefetchWhenOver extends AbstractPrefetch {
|
|
26
|
+
onMouseenter() {
|
|
27
|
+
this.prefetch(new URL(this.$el.href));
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
__publicField(PrefetchWhenOver, "config", __spreadProps(__spreadValues({}, AbstractPrefetch.config), {
|
|
31
|
+
name: "PrefetchWhenOver"
|
|
32
|
+
}));
|
|
33
|
+
export {
|
|
34
|
+
PrefetchWhenOver as default
|
|
35
|
+
};
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __defProps = Object.defineProperties;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
6
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
7
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
8
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
9
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
10
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
11
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
12
|
+
var __spreadValues = (a, b) => {
|
|
13
|
+
for (var prop in b || (b = {}))
|
|
14
|
+
if (__hasOwnProp.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
if (__getOwnPropSymbols)
|
|
17
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
18
|
+
if (__propIsEnum.call(b, prop))
|
|
19
|
+
__defNormalProp(a, prop, b[prop]);
|
|
20
|
+
}
|
|
21
|
+
return a;
|
|
22
|
+
};
|
|
23
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
24
|
+
var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
|
|
25
|
+
var __export = (target, all) => {
|
|
26
|
+
for (var name in all)
|
|
27
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
28
|
+
};
|
|
29
|
+
var __reExport = (target, module2, copyDefault, desc) => {
|
|
30
|
+
if (module2 && typeof module2 === "object" || typeof module2 === "function") {
|
|
31
|
+
for (let key of __getOwnPropNames(module2))
|
|
32
|
+
if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
|
|
33
|
+
__defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
|
|
34
|
+
}
|
|
35
|
+
return target;
|
|
36
|
+
};
|
|
37
|
+
var __toESM = (module2, isNodeMode) => {
|
|
38
|
+
return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", !isNodeMode && module2 && module2.__esModule ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
|
|
39
|
+
};
|
|
40
|
+
var __toCommonJS = /* @__PURE__ */ ((cache) => {
|
|
41
|
+
return (module2, temp) => {
|
|
42
|
+
return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
|
|
43
|
+
};
|
|
44
|
+
})(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
|
|
45
|
+
var __publicField = (obj, key, value) => {
|
|
46
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
47
|
+
return value;
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
// packages/ui/atoms/Prefetch/PrefetchWhenVisible.js
|
|
51
|
+
var PrefetchWhenVisible_exports = {};
|
|
52
|
+
__export(PrefetchWhenVisible_exports, {
|
|
53
|
+
default: () => PrefetchWhenVisible
|
|
54
|
+
});
|
|
55
|
+
var import_js_toolkit = require("@studiometa/js-toolkit");
|
|
56
|
+
var import_AbstractPrefetch = __toESM(require("./AbstractPrefetch.cjs"), 1);
|
|
57
|
+
var PrefetchWhenVisible = class extends (0, import_js_toolkit.withMountWhenInView)(import_AbstractPrefetch.default) {
|
|
58
|
+
mounted() {
|
|
59
|
+
this.prefetch(new URL(this.$el.href));
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
__publicField(PrefetchWhenVisible, "config", __spreadProps(__spreadValues({}, import_AbstractPrefetch.default.config), {
|
|
63
|
+
name: "PrefetchWhenVisible"
|
|
64
|
+
}));
|
|
65
|
+
module.exports = __toCommonJS(PrefetchWhenVisible_exports);
|
|
66
|
+
if (module.exports.default) module.exports = module.exports.default;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @typedef {PrefetchWhenVisible & {
|
|
3
|
+
* $el: HTMLAnchorElement
|
|
4
|
+
* }} PrefetchWhenVisibleInterface
|
|
5
|
+
*/
|
|
6
|
+
/**
|
|
7
|
+
* PrefetchWhenVisible class.
|
|
8
|
+
*/
|
|
9
|
+
export default class PrefetchWhenVisible extends AbstractPrefetch {
|
|
10
|
+
/**
|
|
11
|
+
* Prefetch on mount.
|
|
12
|
+
*
|
|
13
|
+
* @this {PrefetchWhenVisibleInterface}
|
|
14
|
+
* @returns {void}
|
|
15
|
+
*/
|
|
16
|
+
mounted(): void;
|
|
17
|
+
}
|
|
18
|
+
export type PrefetchWhenVisibleInterface = PrefetchWhenVisible & {
|
|
19
|
+
$el: HTMLAnchorElement;
|
|
20
|
+
};
|
|
21
|
+
import AbstractPrefetch from "./AbstractPrefetch.js";
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defProps = Object.defineProperties;
|
|
3
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
4
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
7
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
8
|
+
var __spreadValues = (a, b) => {
|
|
9
|
+
for (var prop in b || (b = {}))
|
|
10
|
+
if (__hasOwnProp.call(b, prop))
|
|
11
|
+
__defNormalProp(a, prop, b[prop]);
|
|
12
|
+
if (__getOwnPropSymbols)
|
|
13
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
14
|
+
if (__propIsEnum.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
}
|
|
17
|
+
return a;
|
|
18
|
+
};
|
|
19
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
20
|
+
var __publicField = (obj, key, value) => {
|
|
21
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
22
|
+
return value;
|
|
23
|
+
};
|
|
24
|
+
import { withMountWhenInView } from "@studiometa/js-toolkit";
|
|
25
|
+
import AbstractPrefetch from "./AbstractPrefetch.js";
|
|
26
|
+
class PrefetchWhenVisible extends withMountWhenInView(AbstractPrefetch) {
|
|
27
|
+
mounted() {
|
|
28
|
+
this.prefetch(new URL(this.$el.href));
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
__publicField(PrefetchWhenVisible, "config", __spreadProps(__spreadValues({}, AbstractPrefetch.config), {
|
|
32
|
+
name: "PrefetchWhenVisible"
|
|
33
|
+
}));
|
|
34
|
+
export {
|
|
35
|
+
PrefetchWhenVisible as default
|
|
36
|
+
};
|