@iris.interactive/handcook 2.7.3 → 2.7.6
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
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
# Welcome to HandCook 👨🍳
|
|
2
|
-

|
|
3
3
|

|
|
4
4
|
[](#)
|
|
5
5
|
[](https://twitter.com/captain\_iris)
|
package/package.json
CHANGED
|
@@ -19,10 +19,11 @@ import LazyLoad from "vanilla-lazyload";
|
|
|
19
19
|
const hc_lazyload = function (options = {}) {
|
|
20
20
|
|
|
21
21
|
options = Object.assign({
|
|
22
|
-
elements_selector: '[data-hc-src], [data-hc-bg], [data-hc-bg-hidpi]',
|
|
22
|
+
elements_selector: '[data-hc-src], [data-hc-bg], [data-hc-bg-hidpi], [data-hc-srcset]',
|
|
23
23
|
data_src: 'hc-src',
|
|
24
24
|
data_bg: 'hc-bg',
|
|
25
|
-
data_bg_hidpi: 'hc-bg-hidpi'
|
|
25
|
+
data_bg_hidpi: 'hc-bg-hidpi',
|
|
26
|
+
data_srcset: 'hc-srcset'
|
|
26
27
|
}, options)
|
|
27
28
|
|
|
28
29
|
return new LazyLoad(options);
|
|
@@ -8,11 +8,12 @@ export class HcScrollspy {
|
|
|
8
8
|
constructor(elements = ElementEnum.scrollspy) {
|
|
9
9
|
document.querySelectorAll(elements).forEach(element => {
|
|
10
10
|
const navElement = document.querySelector(element.dataset.hcScrollspy);
|
|
11
|
-
|
|
11
|
+
const shift = element.getAttribute('data-hc-scrollspy-shift') !== null ? parseInt(element.getAttribute('data-hc-scrollspy-shift')) : 0;
|
|
12
|
+
this.activeItem(navElement, ElementEnum.scrollSmooth, shift);
|
|
12
13
|
});
|
|
13
14
|
}
|
|
14
15
|
|
|
15
|
-
|
|
16
|
+
getPartsConfig(navElement, childElement) {
|
|
16
17
|
let offsetTop = [];
|
|
17
18
|
navElement.querySelectorAll(childElement).forEach(item => {
|
|
18
19
|
const part = item.getAttribute('href') !== null ? {
|
|
@@ -25,7 +26,8 @@ export class HcScrollspy {
|
|
|
25
26
|
attribute: SmoothScrollEnum.attrHref
|
|
26
27
|
};
|
|
27
28
|
if (document.querySelector(part.id) !== null) {
|
|
28
|
-
part.value = document.querySelector(part.id).offsetTop;
|
|
29
|
+
// part.value = document.querySelector(part.id).offsetTop;
|
|
30
|
+
part.value = this.getOffset(document.querySelector(part.id)).top;
|
|
29
31
|
offsetTop = [
|
|
30
32
|
...offsetTop,
|
|
31
33
|
part
|
|
@@ -35,13 +37,13 @@ export class HcScrollspy {
|
|
|
35
37
|
return offsetTop;
|
|
36
38
|
}
|
|
37
39
|
|
|
38
|
-
activeItem(navElement, childElement) {
|
|
40
|
+
activeItem(navElement, childElement, shift = 0) {
|
|
39
41
|
let item = navElement.querySelector(`${childElement}:first-child`);
|
|
40
42
|
window.addEventListener('scroll', () => {
|
|
41
|
-
const
|
|
43
|
+
const partsConfig = this.getPartsConfig(navElement, childElement);
|
|
42
44
|
const top = window.scrollY;
|
|
43
|
-
|
|
44
|
-
if (top > (offsetTop.value -
|
|
45
|
+
partsConfig.forEach(offsetTop => {
|
|
46
|
+
if (top > (offsetTop.value - (shift + 50))) {
|
|
45
47
|
item = navElement.querySelector('[' + offsetTop.attribute + '="' + offsetTop.id + '"]');
|
|
46
48
|
}
|
|
47
49
|
})
|
|
@@ -71,6 +73,17 @@ export class HcScrollspy {
|
|
|
71
73
|
}
|
|
72
74
|
});
|
|
73
75
|
}
|
|
76
|
+
|
|
77
|
+
getOffset( element ) {
|
|
78
|
+
let x = 0;
|
|
79
|
+
let y = 0;
|
|
80
|
+
while( element && !isNaN( element.offsetLeft ) && !isNaN( element.offsetTop ) ) {
|
|
81
|
+
x += element.offsetLeft - element.scrollLeft;
|
|
82
|
+
y += element.offsetTop - element.scrollTop;
|
|
83
|
+
element = element.offsetParent;
|
|
84
|
+
}
|
|
85
|
+
return { top: y, left: x };
|
|
86
|
+
}
|
|
74
87
|
}
|
|
75
88
|
|
|
76
89
|
const hc_scrollspy = function (trigger) {
|
|
@@ -346,11 +346,11 @@ $brochure-form-field-color: var(--iris--brochure-form-field--color);
|
|
|
346
346
|
|
|
347
347
|
|
|
348
348
|
// Brochures single
|
|
349
|
-
$brochure-color: var(--iris--brochure--color);
|
|
350
|
-
$brochure-color-title: var(--iris--brochure--color-title, var(--iris--brochure-form--color));
|
|
351
|
-
$brochure-background-color: var(--iris--brochure--background-color);
|
|
352
|
-
$brochure-link-color: var(--iris--brochure--color-link);
|
|
353
|
-
$brochure-link-color-hover: var(--iris--brochure--color-link-hover);
|
|
349
|
+
$brochure-single-color: var(--iris--brochure--color);
|
|
350
|
+
$brochure-single-color-title: var(--iris--brochure--color-title, var(--iris--brochure-form--color));
|
|
351
|
+
$brochure-single-background-color: var(--iris--brochure--background-color);
|
|
352
|
+
$brochure-single-link-color: var(--iris--brochure--color-link);
|
|
353
|
+
$brochure-single-link-color-hover: var(--iris--brochure--color-link-hover);
|
|
354
354
|
|
|
355
355
|
|
|
356
356
|
// Alternative content
|