cx 26.0.5 → 26.0.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/build/data/ArrayElementView.spec.js +1 -1
- package/build/hooks/store.spec.js +1 -1
- package/build/hooks/useTrigger.spec.js +1 -1
- package/build/ui/Controller.spec.js +6 -2
- package/build/ui/app/startAppLoop.d.ts +3 -2
- package/build/ui/app/startHotAppLoop.d.ts +3 -2
- package/build/ui/layout/ContentPlaceholder.spec.js +12 -12
- package/build.js +129 -129
- package/dist/manifest.js +844 -844
- package/package.json +2 -2
- package/src/charts/Chart.ts +108 -108
- package/src/data/ArrayElementView.ts +90 -90
- package/src/data/AugmentedViewBase.ts +88 -88
- package/src/data/Binding.ts +104 -104
- package/src/data/ExposedRecordView.ts +95 -95
- package/src/data/ExposedValueView.ts +89 -89
- package/src/data/Expression.spec.ts +229 -229
- package/src/data/Expression.ts +233 -233
- package/src/data/Grouper.spec.ts +57 -57
- package/src/data/Grouper.ts +158 -158
- package/src/data/NestedDataView.ts +43 -43
- package/src/data/ReadOnlyDataView.ts +39 -39
- package/src/data/Ref.ts +104 -104
- package/src/data/Selector.ts +10 -10
- package/src/data/Store.ts +52 -52
- package/src/data/StoreProxy.ts +19 -19
- package/src/data/StoreRef.ts +66 -66
- package/src/data/StringTemplate.spec.ts +132 -132
- package/src/data/StringTemplate.ts +93 -93
- package/src/data/StructuredSelector.spec.ts +113 -113
- package/src/data/StructuredSelector.ts +146 -146
- package/src/data/SubscribableView.ts +63 -63
- package/src/data/ZoomIntoPropertyView.spec.ts +64 -64
- package/src/data/ZoomIntoPropertyView.ts +45 -45
- package/src/data/computable.spec.ts +62 -62
- package/src/data/createAccessorModelProxy.ts +60 -60
- package/src/data/createStructuredSelector.ts +62 -62
- package/src/data/getAccessor.spec.ts +11 -11
- package/src/data/getAccessor.ts +74 -74
- package/src/data/getSelector.spec.ts +43 -43
- package/src/data/getSelector.ts +66 -66
- package/src/data/ops/filter.spec.ts +35 -35
- package/src/data/ops/filter.ts +9 -9
- package/src/data/ops/merge.ts +13 -13
- package/src/data/ops/removeTreeNodes.spec.ts +37 -37
- package/src/data/ops/removeTreeNodes.ts +15 -15
- package/src/data/ops/updateArray.spec.ts +69 -69
- package/src/data/ops/updateArray.ts +31 -31
- package/src/data/ops/updateTree.ts +23 -23
- package/src/data/test-types.ts +7 -7
- package/src/hooks/useTrigger.ts +26 -26
- package/src/index.scss +6 -6
- package/src/jsx-runtime.ts +72 -72
- package/src/svg/BoundedObject.ts +101 -101
- package/src/ui/CSSHelper.ts +17 -17
- package/src/ui/ContentResolver.ts +124 -124
- package/src/ui/Controller.ts +189 -189
- package/src/ui/Culture.ts +159 -159
- package/src/ui/DataProxy.ts +55 -55
- package/src/ui/FocusManager.ts +171 -171
- package/src/ui/Instance.ts +868 -868
- package/src/ui/RenderingContext.ts +99 -99
- package/src/ui/Rescope.ts +49 -49
- package/src/ui/StructuredInstanceDataAccessor.ts +32 -32
- package/src/ui/VDOM.ts +34 -34
- package/src/ui/adapter/ArrayAdapter.spec.ts +55 -55
- package/src/ui/adapter/ArrayAdapter.ts +226 -226
- package/src/ui/adapter/TreeAdapter.spec.ts +76 -76
- package/src/ui/adapter/TreeAdapter.ts +185 -185
- package/src/ui/app/History.ts +133 -133
- package/src/ui/app/Url.spec.ts +50 -50
- package/src/ui/app/startAppLoop.tsx +2 -1
- package/src/ui/app/startHotAppLoop.ts +2 -1
- package/src/ui/createFunctionalComponent.ts +65 -65
- package/src/ui/index.ts +45 -45
- package/src/ui/layout/Content.ts +30 -30
- package/src/ui/layout/FirstVisibleChildLayout.ts +60 -60
- package/src/ui/selection/KeySelection.ts +165 -165
- package/src/ui/selection/PropertySelection.ts +87 -87
- package/src/ui/selection/Selection.ts +118 -118
- package/src/util/Format.ts +267 -267
- package/src/util/browserSupportsPassiveEventHandlers.ts +20 -20
- package/src/util/color/rgbToHsl.ts +35 -35
- package/src/util/getActiveElement.ts +4 -4
- package/src/util/hasKey.ts +18 -18
- package/src/util/index.ts +55 -55
- package/src/util/innerTextTrim.ts +10 -10
- package/src/util/isArray.ts +3 -3
- package/src/util/isDataRecord.ts +5 -5
- package/src/util/isDefined.ts +3 -3
- package/src/util/isString.ts +3 -3
- package/src/widgets/Sandbox.ts +103 -103
- package/src/widgets/autoFocus.ts +9 -9
- package/src/widgets/cx.ts +63 -63
- package/src/widgets/drag-drop/ops.tsx +1 -1
- package/src/widgets/grid/GridCell.ts +143 -143
- package/src/widgets/icons/calendar.tsx +17 -17
- package/src/widgets/icons/check.tsx +13 -13
- package/src/widgets/icons/clear.tsx +15 -15
- package/src/widgets/icons/close.tsx +20 -20
- package/src/widgets/icons/cx.tsx +38 -38
- package/src/widgets/icons/drop-down.tsx +15 -15
- package/src/widgets/icons/file.tsx +13 -13
- package/src/widgets/icons/folder-open.tsx +15 -15
- package/src/widgets/icons/folder.tsx +13 -13
- package/src/widgets/icons/forward.tsx +22 -22
- package/src/widgets/icons/loading.tsx +24 -24
- package/src/widgets/icons/menu.tsx +17 -17
- package/src/widgets/icons/pixel-picker.tsx +18 -18
- package/src/widgets/icons/search.tsx +13 -13
- package/src/widgets/icons/sort-asc.tsx +14 -14
- package/src/widgets/icons/square.tsx +18 -18
- package/src/widgets/nav/Route.ts +142 -142
- package/src/widgets/overlay/ContextMenu.ts +42 -42
- package/src/widgets/overlay/Dropdown.tsx +762 -762
- package/src/widgets/overlay/MsgBox.tsx +141 -141
- package/src/widgets/overlay/Toast.ts +111 -111
- package/src/widgets/overlay/Window.tsx +299 -299
- package/src/widgets/overlay/alerts.ts +46 -46
- package/src/widgets/overlay/captureMouse.ts +195 -195
- package/src/widgets/overlay/createHotPromiseWindowFactory.ts +72 -72
- package/src/widgets/overlay/index.d.ts +11 -11
- package/src/widgets/overlay/index.ts +11 -11
- package/src/widgets/overlay/tooltip-ops.ts +173 -173
- package/build/ui/PureContainer.spec.d.ts +0 -1
- package/build/ui/PureContainer.spec.js +0 -149
- package/dist/manifest.d.ts +0 -1443
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
export * from "./Overlay";
|
|
2
|
-
export * from "./Dropdown";
|
|
3
|
-
export * from "./tooltip-ops";
|
|
4
|
-
export * from "./Tooltip";
|
|
5
|
-
export * from "./Window";
|
|
6
|
-
export * from "./MsgBox";
|
|
7
|
-
export * from "./Toast";
|
|
8
|
-
export * from "./captureMouse";
|
|
9
|
-
export * from "./ContextMenu";
|
|
10
|
-
export * from "./FlyweightTooltipTracker";
|
|
11
|
-
export * from "./createHotPromiseWindowFactory";
|
|
1
|
+
export * from "./Overlay";
|
|
2
|
+
export * from "./Dropdown";
|
|
3
|
+
export * from "./tooltip-ops";
|
|
4
|
+
export * from "./Tooltip";
|
|
5
|
+
export * from "./Window";
|
|
6
|
+
export * from "./MsgBox";
|
|
7
|
+
export * from "./Toast";
|
|
8
|
+
export * from "./captureMouse";
|
|
9
|
+
export * from "./ContextMenu";
|
|
10
|
+
export * from "./FlyweightTooltipTracker";
|
|
11
|
+
export * from "./createHotPromiseWindowFactory";
|
|
@@ -1,173 +1,173 @@
|
|
|
1
|
-
import { BooleanProp, StringProp } from "../../ui/Prop";
|
|
2
|
-
import { Instance } from "../../ui/Instance";
|
|
3
|
-
import { DropdownConfig } from "./Dropdown";
|
|
4
|
-
import type { TooltipInstance } from "./Tooltip";
|
|
5
|
-
|
|
6
|
-
export interface TooltipConfig extends DropdownConfig {
|
|
7
|
-
/** Text to be displayed inside the tooltip. */
|
|
8
|
-
text?: StringProp;
|
|
9
|
-
|
|
10
|
-
/** Text to be displayed in the header. */
|
|
11
|
-
title?: StringProp;
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Set to true to make the tooltip always visible.
|
|
15
|
-
* This is useful e.g. in product tours, when instructions need to be shown, even if the mouse pointer is not around.
|
|
16
|
-
*/
|
|
17
|
-
alwaysVisible?: BooleanProp;
|
|
18
|
-
|
|
19
|
-
/** Base CSS class to be applied to the field. Defaults to 'tooltip'. */
|
|
20
|
-
baseClass?: string;
|
|
21
|
-
|
|
22
|
-
/**
|
|
23
|
-
* Set to `true` to append the set `animate` state after the initial render.
|
|
24
|
-
* Appended CSS class may be used to add show/hide animations.
|
|
25
|
-
*/
|
|
26
|
-
animate?: boolean;
|
|
27
|
-
|
|
28
|
-
/** Set to `true` to make the tooltip follow the mouse movement. */
|
|
29
|
-
trackMouse?: boolean;
|
|
30
|
-
|
|
31
|
-
trackMouseX?: boolean;
|
|
32
|
-
trackMouseY?: boolean;
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
* This property controls how tooltips behave on touch events.
|
|
36
|
-
* Default value is `toggle` which means that the tooltip is shown on first tap and closed on the second tap.
|
|
37
|
-
* Use `ignore` to skip showing tooltips on touch events.
|
|
38
|
-
*/
|
|
39
|
-
touchBehavior?: string;
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* Set to true to rely on browser's window mousemove event for getting mouse coordinates
|
|
43
|
-
* instead of using the element that tooltip is attached to.
|
|
44
|
-
*/
|
|
45
|
-
globalMouseTracking?: boolean;
|
|
46
|
-
|
|
47
|
-
/** Tooltips are hidden as soon as the mouse leaves the related widget. Set this to true to keep the tooltip
|
|
48
|
-
* while the mouse is inside the tooltip itself. */
|
|
49
|
-
mouseTrap?: boolean;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
export type TooltipProp = TooltipConfig | StringProp;
|
|
53
|
-
|
|
54
|
-
/**
|
|
55
|
-
* Options passed to tooltip functions
|
|
56
|
-
*/
|
|
57
|
-
export interface TooltipOptions {
|
|
58
|
-
target?: Element;
|
|
59
|
-
tooltipName?: string;
|
|
60
|
-
data?: any;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
export interface TooltipParentInstance {
|
|
64
|
-
tooltips: { [key: string]: TooltipInstance };
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
/**
|
|
68
|
-
* Tooltip operations implementation interface
|
|
69
|
-
* This is the actual implementation that gets wired via wireTooltipOps
|
|
70
|
-
*/
|
|
71
|
-
export interface TooltipOperations {
|
|
72
|
-
tooltipMouseMove(
|
|
73
|
-
e: MouseEvent | TouchEvent | React.MouseEvent | React.TouchEvent | Element,
|
|
74
|
-
parentInstance: Instance & TooltipParentInstance,
|
|
75
|
-
tooltip: TooltipProp | undefined,
|
|
76
|
-
options?: TooltipOptions,
|
|
77
|
-
): void;
|
|
78
|
-
|
|
79
|
-
tooltipMouseLeave(
|
|
80
|
-
e: MouseEvent | React.MouseEvent | Element,
|
|
81
|
-
parentInstance: Instance & TooltipParentInstance,
|
|
82
|
-
tooltip: TooltipProp | undefined,
|
|
83
|
-
options?: TooltipOptions,
|
|
84
|
-
): void;
|
|
85
|
-
|
|
86
|
-
tooltipParentDidMount(
|
|
87
|
-
element: Element,
|
|
88
|
-
parentInstance: Instance & TooltipParentInstance,
|
|
89
|
-
tooltip: TooltipProp | undefined,
|
|
90
|
-
options?: TooltipOptions,
|
|
91
|
-
): void;
|
|
92
|
-
|
|
93
|
-
tooltipParentWillReceiveProps(
|
|
94
|
-
element: Element,
|
|
95
|
-
parentInstance: Instance & TooltipParentInstance,
|
|
96
|
-
tooltip: TooltipProp | undefined,
|
|
97
|
-
options?: TooltipOptions,
|
|
98
|
-
): void;
|
|
99
|
-
|
|
100
|
-
tooltipParentWillUnmount(parentInstance: Instance & TooltipParentInstance): void;
|
|
101
|
-
|
|
102
|
-
tooltipParentDidUpdate(
|
|
103
|
-
element: Element,
|
|
104
|
-
parentInstance: Instance & TooltipParentInstance,
|
|
105
|
-
tooltip: TooltipProp | undefined,
|
|
106
|
-
): void;
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
let impl: TooltipOperations | false = false;
|
|
110
|
-
|
|
111
|
-
export function tooltipMouseMove(
|
|
112
|
-
e: MouseEvent | TouchEvent | React.MouseEvent | React.TouchEvent | Element,
|
|
113
|
-
parentInstance: Instance & TooltipParentInstance,
|
|
114
|
-
tooltip: TooltipProp | undefined,
|
|
115
|
-
options?: TooltipOptions,
|
|
116
|
-
): void {
|
|
117
|
-
if (impl && tooltip) {
|
|
118
|
-
impl.tooltipMouseMove.call(impl, e, parentInstance, tooltip, options);
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
export function tooltipMouseLeave(
|
|
123
|
-
e: MouseEvent | React.MouseEvent | Element,
|
|
124
|
-
parentInstance: Instance & TooltipParentInstance,
|
|
125
|
-
tooltip: TooltipProp | undefined,
|
|
126
|
-
options?: TooltipOptions,
|
|
127
|
-
): void {
|
|
128
|
-
if (impl && tooltip) {
|
|
129
|
-
impl.tooltipMouseLeave.call(impl, e, parentInstance, tooltip, options);
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
export function tooltipParentDidMount(
|
|
134
|
-
element: Element,
|
|
135
|
-
parentInstance: Instance & TooltipParentInstance,
|
|
136
|
-
tooltip: TooltipProp | undefined,
|
|
137
|
-
options?: TooltipOptions,
|
|
138
|
-
): void {
|
|
139
|
-
if (impl) {
|
|
140
|
-
impl.tooltipParentDidMount.call(impl, element, parentInstance, tooltip, options);
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
export function tooltipParentWillReceiveProps(
|
|
145
|
-
element: Element,
|
|
146
|
-
parentInstance: Instance & TooltipParentInstance,
|
|
147
|
-
tooltip: TooltipProp | undefined,
|
|
148
|
-
options?: TooltipOptions,
|
|
149
|
-
): void {
|
|
150
|
-
if (impl) {
|
|
151
|
-
impl.tooltipParentWillReceiveProps.call(impl, element, parentInstance, tooltip, options);
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
export function tooltipParentWillUnmount(parentInstance: Instance & TooltipParentInstance): void {
|
|
156
|
-
if (impl) {
|
|
157
|
-
impl.tooltipParentWillUnmount.call(impl, parentInstance);
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
export function tooltipParentDidUpdate(
|
|
162
|
-
element: Element,
|
|
163
|
-
parentInstance: Instance & TooltipParentInstance,
|
|
164
|
-
tooltip: TooltipProp | undefined,
|
|
165
|
-
): void {
|
|
166
|
-
if (impl) {
|
|
167
|
-
impl.tooltipParentDidUpdate.call(impl, element, parentInstance, tooltip);
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
export function wireTooltipOps(ops: TooltipOperations): void {
|
|
172
|
-
impl = ops;
|
|
173
|
-
}
|
|
1
|
+
import { BooleanProp, StringProp } from "../../ui/Prop";
|
|
2
|
+
import { Instance } from "../../ui/Instance";
|
|
3
|
+
import { DropdownConfig } from "./Dropdown";
|
|
4
|
+
import type { TooltipInstance } from "./Tooltip";
|
|
5
|
+
|
|
6
|
+
export interface TooltipConfig extends DropdownConfig {
|
|
7
|
+
/** Text to be displayed inside the tooltip. */
|
|
8
|
+
text?: StringProp;
|
|
9
|
+
|
|
10
|
+
/** Text to be displayed in the header. */
|
|
11
|
+
title?: StringProp;
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Set to true to make the tooltip always visible.
|
|
15
|
+
* This is useful e.g. in product tours, when instructions need to be shown, even if the mouse pointer is not around.
|
|
16
|
+
*/
|
|
17
|
+
alwaysVisible?: BooleanProp;
|
|
18
|
+
|
|
19
|
+
/** Base CSS class to be applied to the field. Defaults to 'tooltip'. */
|
|
20
|
+
baseClass?: string;
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Set to `true` to append the set `animate` state after the initial render.
|
|
24
|
+
* Appended CSS class may be used to add show/hide animations.
|
|
25
|
+
*/
|
|
26
|
+
animate?: boolean;
|
|
27
|
+
|
|
28
|
+
/** Set to `true` to make the tooltip follow the mouse movement. */
|
|
29
|
+
trackMouse?: boolean;
|
|
30
|
+
|
|
31
|
+
trackMouseX?: boolean;
|
|
32
|
+
trackMouseY?: boolean;
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* This property controls how tooltips behave on touch events.
|
|
36
|
+
* Default value is `toggle` which means that the tooltip is shown on first tap and closed on the second tap.
|
|
37
|
+
* Use `ignore` to skip showing tooltips on touch events.
|
|
38
|
+
*/
|
|
39
|
+
touchBehavior?: string;
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Set to true to rely on browser's window mousemove event for getting mouse coordinates
|
|
43
|
+
* instead of using the element that tooltip is attached to.
|
|
44
|
+
*/
|
|
45
|
+
globalMouseTracking?: boolean;
|
|
46
|
+
|
|
47
|
+
/** Tooltips are hidden as soon as the mouse leaves the related widget. Set this to true to keep the tooltip
|
|
48
|
+
* while the mouse is inside the tooltip itself. */
|
|
49
|
+
mouseTrap?: boolean;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
export type TooltipProp = TooltipConfig | StringProp;
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Options passed to tooltip functions
|
|
56
|
+
*/
|
|
57
|
+
export interface TooltipOptions {
|
|
58
|
+
target?: Element;
|
|
59
|
+
tooltipName?: string;
|
|
60
|
+
data?: any;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
export interface TooltipParentInstance {
|
|
64
|
+
tooltips: { [key: string]: TooltipInstance };
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* Tooltip operations implementation interface
|
|
69
|
+
* This is the actual implementation that gets wired via wireTooltipOps
|
|
70
|
+
*/
|
|
71
|
+
export interface TooltipOperations {
|
|
72
|
+
tooltipMouseMove(
|
|
73
|
+
e: MouseEvent | TouchEvent | React.MouseEvent | React.TouchEvent | Element,
|
|
74
|
+
parentInstance: Instance & TooltipParentInstance,
|
|
75
|
+
tooltip: TooltipProp | undefined,
|
|
76
|
+
options?: TooltipOptions,
|
|
77
|
+
): void;
|
|
78
|
+
|
|
79
|
+
tooltipMouseLeave(
|
|
80
|
+
e: MouseEvent | React.MouseEvent | Element,
|
|
81
|
+
parentInstance: Instance & TooltipParentInstance,
|
|
82
|
+
tooltip: TooltipProp | undefined,
|
|
83
|
+
options?: TooltipOptions,
|
|
84
|
+
): void;
|
|
85
|
+
|
|
86
|
+
tooltipParentDidMount(
|
|
87
|
+
element: Element,
|
|
88
|
+
parentInstance: Instance & TooltipParentInstance,
|
|
89
|
+
tooltip: TooltipProp | undefined,
|
|
90
|
+
options?: TooltipOptions,
|
|
91
|
+
): void;
|
|
92
|
+
|
|
93
|
+
tooltipParentWillReceiveProps(
|
|
94
|
+
element: Element,
|
|
95
|
+
parentInstance: Instance & TooltipParentInstance,
|
|
96
|
+
tooltip: TooltipProp | undefined,
|
|
97
|
+
options?: TooltipOptions,
|
|
98
|
+
): void;
|
|
99
|
+
|
|
100
|
+
tooltipParentWillUnmount(parentInstance: Instance & TooltipParentInstance): void;
|
|
101
|
+
|
|
102
|
+
tooltipParentDidUpdate(
|
|
103
|
+
element: Element,
|
|
104
|
+
parentInstance: Instance & TooltipParentInstance,
|
|
105
|
+
tooltip: TooltipProp | undefined,
|
|
106
|
+
): void;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
let impl: TooltipOperations | false = false;
|
|
110
|
+
|
|
111
|
+
export function tooltipMouseMove(
|
|
112
|
+
e: MouseEvent | TouchEvent | React.MouseEvent | React.TouchEvent | Element,
|
|
113
|
+
parentInstance: Instance & TooltipParentInstance,
|
|
114
|
+
tooltip: TooltipProp | undefined,
|
|
115
|
+
options?: TooltipOptions,
|
|
116
|
+
): void {
|
|
117
|
+
if (impl && tooltip) {
|
|
118
|
+
impl.tooltipMouseMove.call(impl, e, parentInstance, tooltip, options);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
export function tooltipMouseLeave(
|
|
123
|
+
e: MouseEvent | React.MouseEvent | Element,
|
|
124
|
+
parentInstance: Instance & TooltipParentInstance,
|
|
125
|
+
tooltip: TooltipProp | undefined,
|
|
126
|
+
options?: TooltipOptions,
|
|
127
|
+
): void {
|
|
128
|
+
if (impl && tooltip) {
|
|
129
|
+
impl.tooltipMouseLeave.call(impl, e, parentInstance, tooltip, options);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
export function tooltipParentDidMount(
|
|
134
|
+
element: Element,
|
|
135
|
+
parentInstance: Instance & TooltipParentInstance,
|
|
136
|
+
tooltip: TooltipProp | undefined,
|
|
137
|
+
options?: TooltipOptions,
|
|
138
|
+
): void {
|
|
139
|
+
if (impl) {
|
|
140
|
+
impl.tooltipParentDidMount.call(impl, element, parentInstance, tooltip, options);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
export function tooltipParentWillReceiveProps(
|
|
145
|
+
element: Element,
|
|
146
|
+
parentInstance: Instance & TooltipParentInstance,
|
|
147
|
+
tooltip: TooltipProp | undefined,
|
|
148
|
+
options?: TooltipOptions,
|
|
149
|
+
): void {
|
|
150
|
+
if (impl) {
|
|
151
|
+
impl.tooltipParentWillReceiveProps.call(impl, element, parentInstance, tooltip, options);
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
export function tooltipParentWillUnmount(parentInstance: Instance & TooltipParentInstance): void {
|
|
156
|
+
if (impl) {
|
|
157
|
+
impl.tooltipParentWillUnmount.call(impl, parentInstance);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
export function tooltipParentDidUpdate(
|
|
162
|
+
element: Element,
|
|
163
|
+
parentInstance: Instance & TooltipParentInstance,
|
|
164
|
+
tooltip: TooltipProp | undefined,
|
|
165
|
+
): void {
|
|
166
|
+
if (impl) {
|
|
167
|
+
impl.tooltipParentDidUpdate.call(impl, element, parentInstance, tooltip);
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
export function wireTooltipOps(ops: TooltipOperations): void {
|
|
172
|
+
impl = ops;
|
|
173
|
+
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,149 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs } from "cx/jsx-runtime";
|
|
2
|
-
import { Store } from "../data/Store";
|
|
3
|
-
import assert from "assert";
|
|
4
|
-
import { createTestRenderer } from "../util/test/createTestRenderer";
|
|
5
|
-
import { bind } from "./bind";
|
|
6
|
-
import { PureContainer } from "./PureContainer";
|
|
7
|
-
describe("PureContainer", () => {
|
|
8
|
-
it("renders static text children", () => {
|
|
9
|
-
let widget = (_jsx("cx", { children: _jsx(PureContainer, { children: _jsx("div", { children: "Test" }) }) }));
|
|
10
|
-
let store = new Store();
|
|
11
|
-
const component = createTestRenderer(store, widget);
|
|
12
|
-
let tree = component.toJSON();
|
|
13
|
-
assert(tree && !Array.isArray(tree), "Expected single element");
|
|
14
|
-
assert.deepEqual(tree, {
|
|
15
|
-
type: "div",
|
|
16
|
-
props: {},
|
|
17
|
-
children: ["Test"],
|
|
18
|
-
});
|
|
19
|
-
});
|
|
20
|
-
it("renders multiple children", () => {
|
|
21
|
-
let widget = (_jsx("cx", { children: _jsxs(PureContainer, { children: [_jsx("div", { children: "First" }), _jsx("div", { children: "Second" }), _jsx("div", { children: "Third" })] }) }));
|
|
22
|
-
let store = new Store();
|
|
23
|
-
const component = createTestRenderer(store, widget);
|
|
24
|
-
let tree = component.toJSON();
|
|
25
|
-
assert(Array.isArray(tree), "Expected array of elements");
|
|
26
|
-
assert.equal(tree.length, 3);
|
|
27
|
-
assert.deepEqual(tree, [
|
|
28
|
-
{
|
|
29
|
-
type: "div",
|
|
30
|
-
props: {},
|
|
31
|
-
children: ["First"],
|
|
32
|
-
},
|
|
33
|
-
{
|
|
34
|
-
type: "div",
|
|
35
|
-
props: {},
|
|
36
|
-
children: ["Second"],
|
|
37
|
-
},
|
|
38
|
-
{
|
|
39
|
-
type: "div",
|
|
40
|
-
props: {},
|
|
41
|
-
children: ["Third"],
|
|
42
|
-
},
|
|
43
|
-
]);
|
|
44
|
-
});
|
|
45
|
-
it("renders children with data bindings", () => {
|
|
46
|
-
let widget = (_jsx("cx", { children: _jsx(PureContainer, { children: _jsx("div", { text: bind("message") }) }) }));
|
|
47
|
-
let store = new Store({
|
|
48
|
-
data: {
|
|
49
|
-
message: "Hello World",
|
|
50
|
-
},
|
|
51
|
-
});
|
|
52
|
-
const component = createTestRenderer(store, widget);
|
|
53
|
-
let tree = component.toJSON();
|
|
54
|
-
assert(tree && !Array.isArray(tree), "Expected single element");
|
|
55
|
-
assert.deepEqual(tree, {
|
|
56
|
-
type: "div",
|
|
57
|
-
props: {},
|
|
58
|
-
children: ["Hello World"],
|
|
59
|
-
});
|
|
60
|
-
});
|
|
61
|
-
it("renders nested containers", () => {
|
|
62
|
-
let widget = (_jsx("cx", { children: _jsx(PureContainer, { children: _jsx("div", { children: _jsx(PureContainer, { children: _jsx("span", { children: "Nested" }) }) }) }) }));
|
|
63
|
-
let store = new Store();
|
|
64
|
-
const component = createTestRenderer(store, widget);
|
|
65
|
-
let tree = component.toJSON();
|
|
66
|
-
assert(tree && !Array.isArray(tree), "Expected single element");
|
|
67
|
-
assert.deepEqual(tree, {
|
|
68
|
-
type: "div",
|
|
69
|
-
props: {},
|
|
70
|
-
children: [
|
|
71
|
-
{
|
|
72
|
-
type: "span",
|
|
73
|
-
props: {},
|
|
74
|
-
children: ["Nested"],
|
|
75
|
-
},
|
|
76
|
-
],
|
|
77
|
-
});
|
|
78
|
-
});
|
|
79
|
-
it("conditionally renders children based on visible binding", () => {
|
|
80
|
-
let widget = (_jsx("cx", { children: _jsxs(PureContainer, { children: [_jsx("div", { visible: bind("show"), text: "Visible" }), _jsx("div", { visible: false, text: "Hidden" })] }) }));
|
|
81
|
-
let store = new Store({
|
|
82
|
-
data: {
|
|
83
|
-
show: true,
|
|
84
|
-
},
|
|
85
|
-
});
|
|
86
|
-
const component = createTestRenderer(store, widget);
|
|
87
|
-
let tree = component.toJSON();
|
|
88
|
-
assert(tree && !Array.isArray(tree), "Expected single element");
|
|
89
|
-
assert.deepEqual(tree, {
|
|
90
|
-
type: "div",
|
|
91
|
-
props: {},
|
|
92
|
-
children: ["Visible"],
|
|
93
|
-
});
|
|
94
|
-
});
|
|
95
|
-
it("handles empty children", () => {
|
|
96
|
-
let widget = (_jsx("cx", { children: _jsx(PureContainer, { children: _jsx("div", {}) }) }));
|
|
97
|
-
let store = new Store();
|
|
98
|
-
const component = createTestRenderer(store, widget);
|
|
99
|
-
let tree = component.toJSON();
|
|
100
|
-
assert(tree && !Array.isArray(tree), "Expected single element");
|
|
101
|
-
assert.deepEqual(tree, {
|
|
102
|
-
type: "div",
|
|
103
|
-
props: {},
|
|
104
|
-
children: null,
|
|
105
|
-
});
|
|
106
|
-
});
|
|
107
|
-
it("renders children from items property", () => {
|
|
108
|
-
let widget = (_jsx("cx", { children: _jsx(PureContainer, { items: [_jsx("div", { children: "Item 1" }, "1"), _jsx("div", { children: "Item 2" }, "2")] }) }));
|
|
109
|
-
let store = new Store();
|
|
110
|
-
const component = createTestRenderer(store, widget);
|
|
111
|
-
let tree = component.toJSON();
|
|
112
|
-
assert(Array.isArray(tree), "Expected array of elements");
|
|
113
|
-
assert.equal(tree.length, 2);
|
|
114
|
-
assert.deepEqual(tree[0], {
|
|
115
|
-
type: "div",
|
|
116
|
-
props: {},
|
|
117
|
-
children: ["Item 1"],
|
|
118
|
-
});
|
|
119
|
-
assert.deepEqual(tree[1], {
|
|
120
|
-
type: "div",
|
|
121
|
-
props: {},
|
|
122
|
-
children: ["Item 2"],
|
|
123
|
-
});
|
|
124
|
-
});
|
|
125
|
-
it("updates children when store data changes", () => {
|
|
126
|
-
let widget = (_jsx("cx", { children: _jsx(PureContainer, { children: _jsx("div", { text: bind("count") }) }) }));
|
|
127
|
-
let store = new Store({
|
|
128
|
-
data: {
|
|
129
|
-
count: 0,
|
|
130
|
-
},
|
|
131
|
-
});
|
|
132
|
-
const component = createTestRenderer(store, widget);
|
|
133
|
-
let tree = component.toJSON();
|
|
134
|
-
assert.deepEqual(tree, {
|
|
135
|
-
type: "div",
|
|
136
|
-
props: {},
|
|
137
|
-
children: ["0"],
|
|
138
|
-
});
|
|
139
|
-
// Update the store
|
|
140
|
-
store.set("count", 5);
|
|
141
|
-
// Re-render
|
|
142
|
-
tree = component.toJSON();
|
|
143
|
-
assert.deepEqual(tree, {
|
|
144
|
-
type: "div",
|
|
145
|
-
props: {},
|
|
146
|
-
children: ["5"],
|
|
147
|
-
});
|
|
148
|
-
});
|
|
149
|
-
});
|