|
1 | 1 | import * as ko from "knockout"; |
2 | | -import { Keys, MouseButtons } from "@paperbits/common"; |
3 | | -import { Events } from "@paperbits/common/events"; |
| 2 | +import { CollapseBehavior } from "@paperbits/common/behaviors/collapseBehavior"; |
4 | 3 |
|
5 | 4 | ko.bindingHandlers["collapse"] = { |
6 | 5 | init: (triggerElement: HTMLElement, valueAccessor) => { |
7 | 6 | // timeout to let other bindings to bind id for collapsable container |
8 | | - |
9 | | - const expanded: boolean = true; |
10 | | - |
11 | 7 | setTimeout(() => { |
12 | 8 | const targetSelector = ko.unwrap(valueAccessor()); |
13 | | - const targetElement = document.querySelector(targetSelector); |
14 | | - |
15 | | - if (!targetElement) { |
16 | | - return; |
17 | | - } |
18 | | - |
19 | | - const visibleObservable = ko.observable(expanded); |
20 | | - |
21 | | - if (!triggerElement.hasAttribute("aria-label")) { |
22 | | - triggerElement.setAttribute("aria-label", "Toggle section"); |
23 | | - } |
24 | | - |
25 | | - triggerElement.setAttribute("role", "button"); |
26 | | - triggerElement.setAttribute("aria-expanded", expanded.toString()); |
27 | | - |
28 | | - targetElement.setAttribute("role", "region"); |
29 | | - targetElement.setAttribute("aria-hidden", (!expanded).toString()); |
30 | | - |
31 | | - const toggle = (): void => { |
32 | | - const newValue = !visibleObservable(); |
33 | | - visibleObservable(newValue); |
34 | | - triggerElement.setAttribute("aria-expanded", newValue.toString()); |
35 | | - |
36 | | - if (!targetElement) { |
37 | | - return; |
38 | | - } |
39 | | - |
40 | | - targetElement.setAttribute("aria-hidden", (!newValue).toString()); |
41 | | - }; |
42 | | - |
43 | | - const onPointerDown = (event: MouseEvent): void => { |
44 | | - if (event.button !== MouseButtons.Main) { |
45 | | - return; |
46 | | - } |
47 | | - toggle(); |
48 | | - }; |
49 | | - |
50 | | - const onClick = (event: MouseEvent): void => { |
51 | | - event.preventDefault(); |
52 | | - event.stopImmediatePropagation(); |
53 | | - }; |
54 | | - |
55 | | - const onKeyDown = (event: KeyboardEvent): void => { |
56 | | - if (event.key === Keys.Enter || event.key === Keys.Space) { |
57 | | - toggle(); |
58 | | - } |
59 | | - }; |
60 | | - |
61 | | - triggerElement.addEventListener(Events.Click, onClick); |
62 | | - triggerElement.addEventListener(Events.KeyDown, onKeyDown); |
63 | | - triggerElement.addEventListener(Events.MouseDown, onPointerDown); |
64 | | - |
65 | | - ko.applyBindingsToNode(targetElement, { |
66 | | - css: { collapsed: ko.pureComputed(() => !visibleObservable()) } |
67 | | - }, null); |
68 | | - |
69 | | - ko.applyBindingsToNode(triggerElement, { |
70 | | - css: { collapsed: ko.pureComputed(() => !visibleObservable()) } |
71 | | - }, null); |
| 9 | + const behaviorHandle = CollapseBehavior.attach(triggerElement, targetSelector); |
72 | 10 |
|
73 | 11 | ko.utils.domNodeDisposal.addDisposeCallback(triggerElement, () => { |
74 | | - triggerElement.removeEventListener(Events.Click, onClick); |
75 | | - triggerElement.removeEventListener(Events.KeyDown, onKeyDown); |
76 | | - triggerElement.removeEventListener(Events.MouseDown, onPointerDown); |
| 12 | + if (behaviorHandle && behaviorHandle.detach) { |
| 13 | + behaviorHandle.detach(); |
| 14 | + } |
77 | 15 | }); |
78 | 16 | }, 100); |
79 | 17 | } |
|
0 commit comments