-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathimg-shower-component.js
101 lines (81 loc) · 3.34 KB
/
img-shower-component.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
(function ImgShowerComponent(global, d, imagesSelector) {
let images = d.querySelectorAll(imagesSelector);
let container = d.querySelector('[rel="js-img-shower-component"]');
let closeBtn = container.querySelector('[rel="js-isc-close-btn"]');
let prevBtn = container.querySelector('[rel="js-isc-prev-btn"]');
let nextBtn = container.querySelector('[rel="js-isc-next-btn"]');
let img = container.querySelector('[rel="js-isc-image"]');
//let imageHeader = container.querySelector('[rel="js-isc-image-header"]');
let addCloseHandler = curry(3, addHandler)(closeHandler)('click');
let addOpenHandler = curry(3, addHandler)(openHandler)('click');
let addFlipHandler = curry(3, addHandler)(flipHandler)('click');
const PREV_NODE = 'ISC_prevNode';
const NEXT_NODE = 'ISC_nextNode';
function linkAdjacentImages (image, i, imageList) {
image[PREV_NODE] = imageList[i - 1] || imageList[imageList.length - 1];
image[NEXT_NODE] = imageList[i + 1] || imageList[0];
}
function closeHandler(e) {
container.classList.remove('visible');
document.body.classList.remove('behindModal');
}
function openHandler(e) {
container.classList.add('visible');
document.body.classList.add('behindModal');
cloneImg(this);
}
function flipHandler(e) {
if (this === prevBtn) {
cloneImg(img[PREV_NODE]);
}
if (this === nextBtn) {
cloneImg(img[NEXT_NODE]);
}
}
function addHandler(element, type, handler) {
element.addEventListener(type, handler);
}
function cloneImg(imgElement) {
// cloneElement(element) : clonedElement
let clonedImg = imgElement.cloneNode();
clonedImg[PREV_NODE] = imgElement[PREV_NODE];
clonedImg[NEXT_NODE] = imgElement[NEXT_NODE];
// clearClassList(element)
let classList = clonedImg.classList.values();
for (className of classList) {
clonedImg.classList.remove(className);
}
// copyClassList(srcElement, destElement)
clonedImg.classList.add(...img.classList.values());
// replaceElement(containder, elToDelete, elToPut)
container.removeChild(img);
container.appendChild(clonedImg);
img = clonedImg;
}
function addZoomLabel(image) {
let zoomLabel = d.createElement('div');
let text = d.createTextNode('Увеличить 🔎');
zoomLabel.classList.add('isc-image-zoom-label');
addHandler(zoomLabel, 'click', openHandler.bind(image));
zoomLabel.appendChild(text);
image.parentNode.appendChild(zoomLabel);
}
function curry(arity, fn) {
return function curried(arg) {
if (arity == 1) {
return fn(arg);
}
else {
return curry(--arity, function wrapper(...args) {
return fn(...args.concat(arg))
});
}
};
}
addFlipHandler(prevBtn);
addFlipHandler(nextBtn);
addCloseHandler(closeBtn);
Array.prototype.forEach.call(images, linkAdjacentImages);
Array.prototype.forEach.call(images, addOpenHandler);
Array.prototype.forEach.call(images, addZoomLabel);
})(window, document, '[rel="js-portfolio-img');