cx 26.1.1 → 26.1.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/.mocharc.json +5 -5
- package/LICENSE-THIRD-PARTY.md +91 -91
- package/LICENSE.md +7 -7
- package/README.md +46 -46
- package/build/data/ArrayElementView.d.ts +4 -3
- package/build/ui/adapter/ArrayAdapter.js +0 -2
- package/build/ui/adapter/DataAdapter.d.ts +3 -3
- package/build.js +133 -133
- package/dist/manifest.js +826 -826
- package/dist/ui.js +0 -2
- package/package.json +100 -99
- package/src/charts/Bar.scss +28 -28
- package/src/charts/Bar.ts +114 -114
- package/src/charts/BarGraph.scss +28 -28
- package/src/charts/BarGraph.tsx +145 -145
- package/src/charts/BubbleGraph.scss +31 -31
- package/src/charts/BubbleGraph.tsx +165 -165
- package/src/charts/Chart.ts +108 -108
- package/src/charts/ColorMap.ts +150 -150
- package/src/charts/Column.scss +28 -28
- package/src/charts/Column.ts +124 -124
- package/src/charts/ColumnBarBase.tsx +284 -284
- package/src/charts/ColumnBarGraphBase.tsx +229 -229
- package/src/charts/ColumnGraph.scss +29 -29
- package/src/charts/ColumnGraph.tsx +153 -153
- package/src/charts/Grid.ts +5 -5
- package/src/charts/Gridlines.scss +24 -24
- package/src/charts/Gridlines.tsx +88 -88
- package/src/charts/Legend.scss +50 -50
- package/src/charts/Legend.tsx +270 -270
- package/src/charts/LegendEntry.scss +29 -29
- package/src/charts/LegendEntry.tsx +197 -197
- package/src/charts/LineGraph.scss +24 -24
- package/src/charts/LineGraph.tsx +455 -455
- package/src/charts/Marker.scss +43 -43
- package/src/charts/Marker.tsx +483 -483
- package/src/charts/MarkerLine.scss +19 -19
- package/src/charts/MarkerLine.tsx +214 -214
- package/src/charts/MouseTracker.tsx +112 -112
- package/src/charts/Pie.ts +8 -8
- package/src/charts/PieChart.scss +28 -28
- package/src/charts/PieChart.tsx +717 -717
- package/src/charts/PieLabel.tsx +106 -106
- package/src/charts/PieLabelsContainer.ts +68 -68
- package/src/charts/Range.scss +19 -19
- package/src/charts/Range.tsx +318 -318
- package/src/charts/RangeMarker.scss +17 -17
- package/src/charts/RangeMarker.tsx +233 -233
- package/src/charts/ScatterGraph.scss +23 -23
- package/src/charts/ScatterGraph.tsx +245 -245
- package/src/charts/Swimlane.scss +16 -16
- package/src/charts/Swimlane.tsx +195 -195
- package/src/charts/Swimlanes.scss +16 -16
- package/src/charts/Swimlanes.tsx +179 -179
- package/src/charts/axis/Axis.scss +22 -22
- package/src/charts/axis/Axis.tsx +444 -444
- package/src/charts/axis/CategoryAxis.scss +34 -34
- package/src/charts/axis/CategoryAxis.tsx +313 -313
- package/src/charts/axis/NumericAxis.scss +34 -34
- package/src/charts/axis/NumericAxis.tsx +437 -437
- package/src/charts/axis/Stack.ts +61 -61
- package/src/charts/axis/TimeAxis.scss +33 -33
- package/src/charts/axis/TimeAxis.tsx +718 -718
- package/src/charts/axis/index.scss +5 -5
- package/src/charts/axis/index.ts +3 -3
- package/src/charts/axis/variables.scss +2 -2
- package/src/charts/helpers/MinMaxFinder.ts +66 -66
- package/src/charts/helpers/PointReducer.ts +135 -135
- package/src/charts/helpers/SnapPointFinder.ts +136 -136
- package/src/charts/helpers/ValueAtFinder.ts +72 -72
- package/src/charts/helpers/index.ts +4 -4
- package/src/charts/index.scss +22 -22
- package/src/charts/index.ts +34 -34
- package/src/charts/palette.scss +97 -97
- package/src/charts/shapes.tsx +86 -86
- package/src/charts/variables.scss +22 -22
- package/src/core.d.ts +182 -182
- package/src/data/AggregateFunction.ts +171 -171
- package/src/data/ArrayElementView.spec.ts +88 -88
- package/src/data/ArrayElementView.ts +91 -90
- package/src/data/ArrayRef.ts +34 -34
- package/src/data/AugmentedViewBase.ts +88 -88
- package/src/data/Binding.spec.ts +69 -69
- 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.spec.ts +79 -79
- package/src/data/Ref.ts +104 -104
- package/src/data/Selector.ts +10 -10
- package/src/data/Store.spec.ts +22 -22
- package/src/data/Store.ts +52 -52
- package/src/data/StoreProxy.ts +19 -19
- package/src/data/StoreRef.spec.ts +24 -24
- 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/View.spec.ts +60 -60
- package/src/data/View.ts +289 -289
- package/src/data/ZoomIntoPropertyView.spec.ts +64 -64
- package/src/data/ZoomIntoPropertyView.ts +45 -45
- package/src/data/comparer.spec.ts +60 -60
- package/src/data/comparer.ts +78 -78
- package/src/data/computable.spec.ts +87 -87
- package/src/data/computable.ts +69 -69
- package/src/data/createAccessorModelProxy.spec.tsx +145 -145
- package/src/data/createAccessorModelProxy.ts +66 -66
- package/src/data/createStructuredSelector.spec.ts +45 -45
- package/src/data/createStructuredSelector.ts +62 -62
- package/src/data/defaultCompare.ts +14 -14
- package/src/data/diff/diffArrays.ts +49 -49
- package/src/data/diff/diffs.spec.ts +49 -49
- package/src/data/diff/index.ts +1 -1
- package/src/data/enableFatArrowExpansion.ts +6 -6
- 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/index.ts +30 -30
- package/src/data/isSelector.ts +26 -26
- package/src/data/ops/append.spec.ts +28 -28
- package/src/data/ops/append.ts +5 -5
- package/src/data/ops/filter.spec.ts +35 -35
- package/src/data/ops/filter.ts +9 -9
- package/src/data/ops/findTreeNode.spec.ts +23 -23
- package/src/data/ops/findTreeNode.ts +14 -14
- package/src/data/ops/findTreePath.ts +23 -23
- package/src/data/ops/index.ts +11 -11
- package/src/data/ops/insertElement.ts +3 -3
- package/src/data/ops/merge.spec.ts +27 -27
- package/src/data/ops/merge.ts +13 -13
- package/src/data/ops/moveElement.ts +21 -21
- 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.spec.ts +54 -54
- package/src/data/ops/updateTree.ts +23 -23
- package/src/data/test-types.ts +7 -7
- package/src/global.scss +13 -13
- package/src/hooks/createLocalStorageRef.ts +21 -21
- package/src/hooks/index.ts +8 -8
- package/src/hooks/invokeCallback.spec.tsx +59 -59
- package/src/hooks/invokeCallback.ts +8 -8
- package/src/hooks/resolveCallback.spec.tsx +71 -71
- package/src/hooks/resolveCallback.ts +16 -16
- package/src/hooks/store.spec.tsx +67 -67
- package/src/hooks/store.ts +46 -46
- package/src/hooks/useEffect.ts +14 -14
- package/src/hooks/useInterval.ts +8 -8
- package/src/hooks/useState.ts +20 -20
- package/src/hooks/useTrigger.spec.tsx +105 -105
- package/src/hooks/useTrigger.ts +26 -26
- package/src/index.ts +7 -7
- package/src/jsx-dev-runtime.ts +4 -4
- package/src/jsx-runtime.spec.tsx +431 -431
- package/src/jsx-runtime.ts +79 -79
- package/src/locale/de-de.ts +76 -76
- package/src/locale/en-us.ts +75 -75
- package/src/locale/es-es.ts +76 -76
- package/src/locale/fr-fr.ts +76 -76
- package/src/locale/nl-nl.ts +76 -76
- package/src/locale/pt-pt.ts +76 -76
- package/src/locale/sr-latn-ba.ts +76 -76
- package/src/svg/BoundedObject.ts +101 -101
- package/src/svg/ClipRect.tsx +29 -29
- package/src/svg/Ellipse.tsx +68 -68
- package/src/svg/Line.tsx +58 -58
- package/src/svg/NonOverlappingRect.ts +26 -26
- package/src/svg/NonOverlappingRectGroup.ts +49 -49
- package/src/svg/Rectangle.tsx +90 -90
- package/src/svg/Svg.scss +27 -27
- package/src/svg/Svg.tsx +241 -241
- package/src/svg/Text.tsx +134 -134
- package/src/svg/TextualBoundedObject.ts +35 -35
- package/src/svg/index.scss +8 -8
- package/src/svg/index.ts +17 -17
- package/src/svg/util/Rect.ts +105 -105
- package/src/ui/CSS.ts +87 -87
- package/src/ui/CSSHelper.ts +17 -17
- package/src/ui/Container.tsx +216 -216
- package/src/ui/ContentResolver.spec.tsx +585 -585
- package/src/ui/ContentResolver.ts +132 -132
- package/src/ui/Controller.spec.tsx +574 -574
- package/src/ui/Controller.ts +202 -202
- package/src/ui/Culture.ts +159 -159
- package/src/ui/Cx.spec.tsx +210 -210
- package/src/ui/Cx.tsx +386 -386
- package/src/ui/DataProxy.spec.tsx +337 -337
- package/src/ui/DataProxy.ts +55 -55
- package/src/ui/DetachedScope.tsx +159 -159
- package/src/ui/FocusManager.ts +171 -171
- package/src/ui/Format.ts +108 -108
- package/src/ui/HoverSync.tsx +189 -189
- package/src/ui/Instance.ts +866 -866
- package/src/ui/IsolatedScope.spec.tsx +62 -62
- package/src/ui/IsolatedScope.ts +50 -50
- package/src/ui/Localization.ts +70 -70
- package/src/ui/Prop.ts +140 -140
- package/src/ui/PureContainer.spec.tsx +232 -232
- package/src/ui/PureContainer.tsx +19 -19
- package/src/ui/RenderingContext.ts +99 -99
- package/src/ui/Repeater.spec.tsx +143 -143
- package/src/ui/Repeater.ts +194 -194
- package/src/ui/Rescope.spec.tsx +199 -199
- package/src/ui/Rescope.ts +49 -49
- package/src/ui/ResizeManager.ts +30 -30
- package/src/ui/Restate.spec.tsx +422 -422
- package/src/ui/Restate.tsx +217 -217
- package/src/ui/StaticText.ts +11 -11
- package/src/ui/StructuredInstanceDataAccessor.ts +32 -32
- package/src/ui/Text.ts +49 -49
- package/src/ui/VDOM.ts +1 -1
- package/src/ui/Widget.spec.tsx +53 -53
- package/src/ui/Widget.tsx +301 -301
- package/src/ui/ZIndexManager.ts +11 -11
- package/src/ui/adapter/ArrayAdapter.spec.ts +55 -55
- package/src/ui/adapter/ArrayAdapter.ts +229 -229
- package/src/ui/adapter/DataAdapter.ts +52 -52
- package/src/ui/adapter/GroupAdapter.ts +235 -235
- package/src/ui/adapter/TreeAdapter.spec.ts +76 -76
- package/src/ui/adapter/TreeAdapter.ts +185 -185
- package/src/ui/adapter/index.ts +4 -4
- package/src/ui/app/History.ts +133 -133
- package/src/ui/app/Url.spec.ts +50 -50
- package/src/ui/app/Url.ts +102 -102
- package/src/ui/app/index.ts +5 -5
- package/src/ui/app/startAppLoop.tsx +71 -71
- package/src/ui/app/startHotAppLoop.ts +41 -41
- package/src/ui/batchUpdates.ts +77 -77
- package/src/ui/bind.ts +10 -10
- package/src/ui/createFunctionalComponent.spec.tsx +454 -454
- package/src/ui/createFunctionalComponent.ts +86 -86
- package/src/ui/expr.ts +47 -47
- package/src/ui/exprHelpers.spec.ts +379 -379
- package/src/ui/exprHelpers.ts +78 -78
- package/src/ui/flattenProps.ts +21 -21
- package/src/ui/index.scss +2 -2
- package/src/ui/index.ts +47 -47
- package/src/ui/keyboardShortcuts.ts +40 -40
- package/src/ui/layout/Content.ts +30 -30
- package/src/ui/layout/ContentPlaceholder.spec.tsx +599 -599
- package/src/ui/layout/ContentPlaceholder.ts +133 -133
- package/src/ui/layout/FirstVisibleChildLayout.spec.tsx +207 -207
- package/src/ui/layout/FirstVisibleChildLayout.ts +60 -60
- package/src/ui/layout/LabelsLeftLayout.scss +46 -46
- package/src/ui/layout/LabelsLeftLayout.tsx +76 -76
- package/src/ui/layout/LabelsTopLayout.scss +64 -64
- package/src/ui/layout/LabelsTopLayout.tsx +156 -156
- package/src/ui/layout/UseParentLayout.ts +8 -8
- package/src/ui/layout/exploreChildren.ts +38 -38
- package/src/ui/layout/index.scss +3 -3
- package/src/ui/layout/index.ts +10 -10
- package/src/ui/layout/variables.scss +2 -2
- package/src/ui/selection/KeySelection.ts +153 -153
- package/src/ui/selection/PropertySelection.ts +87 -87
- package/src/ui/selection/Selection.ts +128 -128
- package/src/ui/selection/index.ts +3 -3
- package/src/ui/tpl.ts +4 -4
- package/src/ui/variables.scss +1 -1
- package/src/util/Component.spec.ts +411 -411
- package/src/util/Console.ts +13 -13
- package/src/util/DOM.ts +88 -88
- package/src/util/Debug.ts +71 -71
- package/src/util/Format.spec.ts +69 -69
- package/src/util/Format.ts +267 -267
- package/src/util/GlobalCacheIdentifier.ts +11 -11
- package/src/util/KeyCode.ts +21 -21
- package/src/util/SubscriberList.ts +86 -86
- package/src/util/Timing.ts +58 -58
- package/src/util/TraversalStack.spec.ts +53 -53
- package/src/util/TraversalStack.ts +47 -47
- package/src/util/addEventListenerWithOptions.ts +41 -41
- package/src/util/browserSupportsPassiveEventHandlers.ts +20 -20
- package/src/util/calculateNaturalElementHeight.ts +22 -22
- package/src/util/call-once.scss +6 -6
- package/src/util/capitalize.ts +4 -4
- package/src/util/coalesce.ts +6 -6
- package/src/util/color/hslToRgb.ts +34 -34
- package/src/util/color/index.ts +4 -4
- package/src/util/color/parseColor.ts +173 -173
- package/src/util/color/rgbToHex.ts +14 -14
- package/src/util/color/rgbToHsl.ts +35 -35
- package/src/util/date/dateDiff.ts +9 -9
- package/src/util/date/diff.ts +13 -13
- package/src/util/date/encodeDate.ts +8 -8
- package/src/util/date/encodeDateWithTimezoneOffset.ts +18 -18
- package/src/util/date/index.ts +11 -11
- package/src/util/date/lowerBoundCheck.ts +13 -13
- package/src/util/date/maxDate.ts +14 -14
- package/src/util/date/minDate.ts +14 -14
- package/src/util/date/monthStart.ts +8 -8
- package/src/util/date/parseDateInvariant.ts +20 -20
- package/src/util/date/sameDate.ts +11 -11
- package/src/util/date/upperBoundCheck.spec.ts +30 -30
- package/src/util/date/upperBoundCheck.ts +13 -13
- package/src/util/date/zeroTime.ts +9 -9
- package/src/util/debounce.ts +26 -26
- package/src/util/dummyCallback.ts +1 -1
- package/src/util/escapeSpecialRegexCharacters.ts +8 -8
- package/src/util/eventCallbacks.ts +12 -12
- package/src/util/expandFatArrows.ts +118 -118
- package/src/util/findScrollableParent.ts +15 -15
- package/src/util/getActiveElement.ts +4 -4
- package/src/util/getParentFrameBoundingClientRect.ts +13 -13
- package/src/util/getScrollerBoundingClientRect.ts +12 -12
- package/src/util/getSearchQueryPredicate.spec.ts +40 -40
- package/src/util/getSearchQueryPredicate.ts +58 -58
- package/src/util/getTopLevelBoundingClientRect.ts +7 -7
- package/src/util/getVendorPrefix.ts +33 -33
- package/src/util/hasKey.ts +18 -18
- package/src/util/index.scss +10 -10
- 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/isDigit.ts +8 -8
- package/src/util/isFunction.ts +3 -3
- package/src/util/isNonEmptyArray.ts +3 -3
- package/src/util/isNumber.ts +3 -3
- package/src/util/isObject.ts +3 -3
- package/src/util/isPromise.ts +6 -6
- package/src/util/isString.ts +3 -3
- package/src/util/isTextInputElement.ts +2 -2
- package/src/util/isTouchDevice.ts +7 -7
- package/src/util/isTouchEvent.ts +64 -64
- package/src/util/isUndefined.ts +3 -3
- package/src/util/isValidIdentifierName.spec.ts +33 -33
- package/src/util/isValidIdentifierName.ts +5 -5
- package/src/util/onIdleCallback.ts +10 -10
- package/src/util/parseStyle.ts +29 -29
- package/src/util/quote.ts +6 -6
- package/src/util/reverseSlice.ts +9 -9
- package/src/util/routeAppend.spec.ts +19 -19
- package/src/util/routeAppend.ts +15 -15
- package/src/util/scrollElementIntoView.ts +40 -40
- package/src/util/scss/add-rules.scss +40 -40
- package/src/util/scss/calc.scss +44 -44
- package/src/util/scss/call-once.scss +12 -12
- package/src/util/scss/clockwise.scss +49 -49
- package/src/util/scss/colors.scss +9 -9
- package/src/util/scss/deep-get.scss +11 -11
- package/src/util/scss/deep-merge.scss +21 -21
- package/src/util/scss/divide.scss +3 -3
- package/src/util/scss/include.scss +48 -48
- package/src/util/scss/index.scss +9 -9
- package/src/util/shallowEquals.ts +43 -43
- package/src/util/test/createTestRenderer.tsx +19 -19
- package/src/util/throttle.ts +21 -21
- package/src/util/validatedDebounce.ts +23 -23
- package/src/variables.scss +217 -217
- package/src/widgets/AccessorBindings.spec.tsx +90 -90
- package/src/widgets/Button.scss +119 -119
- package/src/widgets/Button.tsx +189 -189
- package/src/widgets/Button.variables.scss +117 -117
- package/src/widgets/CxCredit.scss +39 -39
- package/src/widgets/CxCredit.tsx +46 -46
- package/src/widgets/DocumentTitle.ts +95 -95
- package/src/widgets/FlexBox.scss +148 -148
- package/src/widgets/FlexBox.tsx +168 -168
- package/src/widgets/Heading.scss +40 -40
- package/src/widgets/Heading.ts +42 -42
- package/src/widgets/HighlightedSearchText.scss +20 -20
- package/src/widgets/HighlightedSearchText.tsx +54 -54
- package/src/widgets/HtmlElement.spec.helpers.tsx +108 -108
- package/src/widgets/HtmlElement.spec.tsx +89 -89
- package/src/widgets/HtmlElement.tsx +407 -407
- package/src/widgets/Icon.scss +22 -22
- package/src/widgets/Icon.ts +64 -64
- package/src/widgets/List.scss +93 -93
- package/src/widgets/List.tsx +793 -793
- package/src/widgets/ProgressBar.scss +50 -50
- package/src/widgets/ProgressBar.tsx +66 -66
- package/src/widgets/ReactElementWrapper.spec.tsx +452 -452
- package/src/widgets/ReactElementWrapper.tsx +108 -108
- package/src/widgets/Resizer.scss +43 -43
- package/src/widgets/Resizer.tsx +200 -200
- package/src/widgets/Sandbox.ts +103 -103
- package/src/widgets/Section.scss +55 -55
- package/src/widgets/Section.tsx +187 -187
- package/src/widgets/animations.scss +10 -10
- package/src/widgets/autoFocus.ts +9 -9
- package/src/widgets/cx.ts +63 -63
- package/src/widgets/drag-drop/DragClone.scss +35 -35
- package/src/widgets/drag-drop/DragHandle.scss +18 -18
- package/src/widgets/drag-drop/DragHandle.tsx +47 -47
- package/src/widgets/drag-drop/DragSource.scss +26 -26
- package/src/widgets/drag-drop/DragSource.tsx +237 -237
- package/src/widgets/drag-drop/DropZone.scss +76 -76
- package/src/widgets/drag-drop/DropZone.tsx +353 -353
- package/src/widgets/drag-drop/index.scss +3 -3
- package/src/widgets/drag-drop/index.ts +4 -4
- package/src/widgets/drag-drop/ops.tsx +422 -422
- package/src/widgets/drag-drop/variables.scss +14 -14
- package/src/widgets/enableAllInternalDependencies.ts +11 -11
- package/src/widgets/form/Calendar.scss +199 -199
- package/src/widgets/form/Calendar.tsx +760 -760
- package/src/widgets/form/Calendar.variables.scss +63 -63
- package/src/widgets/form/Checkbox.scss +129 -129
- package/src/widgets/form/Checkbox.tsx +287 -287
- package/src/widgets/form/Checkbox.variables.scss +39 -39
- package/src/widgets/form/ColorField.scss +98 -98
- package/src/widgets/form/ColorField.tsx +497 -497
- package/src/widgets/form/ColorPicker.scss +285 -285
- package/src/widgets/form/ColorPicker.tsx +544 -544
- package/src/widgets/form/ColorPicker.variables.scss +22 -22
- package/src/widgets/form/DateField.ts +21 -21
- package/src/widgets/form/DateTimeField.scss +92 -92
- package/src/widgets/form/DateTimeField.tsx +726 -726
- package/src/widgets/form/DateTimePicker.scss +46 -46
- package/src/widgets/form/DateTimePicker.tsx +429 -429
- package/src/widgets/form/Field.scss +164 -164
- package/src/widgets/form/Field.tsx +608 -608
- package/src/widgets/form/FieldGroup.ts +10 -10
- package/src/widgets/form/FieldIcon.ts +61 -61
- package/src/widgets/form/HelpText.scss +24 -24
- package/src/widgets/form/HelpText.ts +15 -15
- package/src/widgets/form/Label.scss +37 -37
- package/src/widgets/form/Label.tsx +117 -117
- package/src/widgets/form/LabeledContainer.ts +77 -77
- package/src/widgets/form/LookupField.scss +221 -221
- package/src/widgets/form/LookupField.spec.tsx +93 -93
- package/src/widgets/form/LookupField.tsx +1421 -1421
- package/src/widgets/form/MonthField.scss +100 -100
- package/src/widgets/form/MonthField.tsx +670 -670
- package/src/widgets/form/MonthPicker.scss +125 -125
- package/src/widgets/form/MonthPicker.tsx +822 -822
- package/src/widgets/form/NumberField.scss +63 -63
- package/src/widgets/form/NumberField.tsx +543 -543
- package/src/widgets/form/Radio.scss +123 -123
- package/src/widgets/form/Radio.tsx +249 -249
- package/src/widgets/form/Radio.variables.scss +45 -45
- package/src/widgets/form/Select.scss +101 -101
- package/src/widgets/form/Select.tsx +327 -327
- package/src/widgets/form/Slider.scss +121 -121
- package/src/widgets/form/Slider.tsx +473 -473
- package/src/widgets/form/Switch.scss +142 -142
- package/src/widgets/form/Switch.tsx +176 -176
- package/src/widgets/form/TextArea.scss +45 -45
- package/src/widgets/form/TextArea.tsx +229 -229
- package/src/widgets/form/TextField.scss +57 -57
- package/src/widgets/form/TextField.tsx +407 -407
- package/src/widgets/form/TimeField.ts +10 -10
- package/src/widgets/form/TimeList.tsx +105 -105
- package/src/widgets/form/UploadButton.scss +49 -49
- package/src/widgets/form/UploadButton.tsx +307 -307
- package/src/widgets/form/ValidationError.scss +22 -22
- package/src/widgets/form/ValidationError.tsx +72 -72
- package/src/widgets/form/ValidationGroup.spec.tsx +147 -147
- package/src/widgets/form/ValidationGroup.ts +141 -141
- package/src/widgets/form/Validator.ts +60 -60
- package/src/widgets/form/Wheel.scss +152 -152
- package/src/widgets/form/Wheel.tsx +314 -314
- package/src/widgets/form/index.scss +24 -24
- package/src/widgets/form/index.ts +28 -28
- package/src/widgets/form/variables.scss +355 -355
- package/src/widgets/grid/Grid.scss +640 -640
- package/src/widgets/grid/Grid.tsx +4243 -4243
- package/src/widgets/grid/GridCell.ts +143 -143
- package/src/widgets/grid/GridCellEditor.tsx +58 -58
- package/src/widgets/grid/GridRow.ts +302 -302
- package/src/widgets/grid/GridRowLine.ts +49 -49
- package/src/widgets/grid/Pagination.scss +115 -115
- package/src/widgets/grid/Pagination.tsx +126 -126
- package/src/widgets/grid/TreeNode.scss +90 -90
- package/src/widgets/grid/TreeNode.tsx +154 -154
- package/src/widgets/grid/createGridCellEditor.tsx +18 -18
- package/src/widgets/grid/index.scss +3 -3
- package/src/widgets/grid/index.ts +16 -16
- package/src/widgets/grid/variables.scss +137 -137
- package/src/widgets/icons/arrow-down.svg +3 -3
- package/src/widgets/icons/arrow-right.svg +2 -2
- package/src/widgets/icons/base.svg +104 -104
- package/src/widgets/icons/calendar-old.svg +169 -169
- package/src/widgets/icons/calendar.svg +187 -187
- package/src/widgets/icons/calendar.tsx +22 -22
- package/src/widgets/icons/check.tsx +14 -14
- package/src/widgets/icons/clear.svg +74 -74
- package/src/widgets/icons/clear.tsx +16 -16
- package/src/widgets/icons/close.svg +74 -74
- package/src/widgets/icons/close.tsx +20 -20
- package/src/widgets/icons/cx.tsx +39 -39
- package/src/widgets/icons/drop-down.tsx +16 -16
- package/src/widgets/icons/dropdown-arrow.svg +61 -61
- package/src/widgets/icons/file.svg +4 -4
- package/src/widgets/icons/file.tsx +14 -14
- package/src/widgets/icons/folder-open.svg +5 -5
- package/src/widgets/icons/folder-open.tsx +16 -16
- package/src/widgets/icons/folder.svg +58 -58
- package/src/widgets/icons/folder.tsx +14 -14
- package/src/widgets/icons/forward.svg +67 -67
- package/src/widgets/icons/forward.tsx +23 -23
- package/src/widgets/icons/index.ts +14 -14
- package/src/widgets/icons/loading.svg +4 -4
- package/src/widgets/icons/loading.tsx +25 -25
- package/src/widgets/icons/menu.tsx +18 -18
- package/src/widgets/icons/pixel-picker.tsx +18 -18
- package/src/widgets/icons/registry.ts +56 -56
- package/src/widgets/icons/search.svg +107 -107
- package/src/widgets/icons/search.tsx +14 -14
- package/src/widgets/icons/sort-asc.svg +3 -3
- package/src/widgets/icons/sort-asc.tsx +15 -15
- package/src/widgets/icons/square.tsx +19 -19
- package/src/widgets/index.d.ts +55 -55
- package/src/widgets/index.scss +16 -16
- package/src/widgets/index.ts +58 -58
- package/src/widgets/nav/Link.scss +20 -20
- package/src/widgets/nav/Link.ts +11 -11
- package/src/widgets/nav/LinkButton.ts +176 -176
- package/src/widgets/nav/Menu.scss +76 -76
- package/src/widgets/nav/Menu.tsx +489 -489
- package/src/widgets/nav/Menu.variables.scss +25 -25
- package/src/widgets/nav/MenuItem.scss +130 -130
- package/src/widgets/nav/MenuItem.tsx +525 -525
- package/src/widgets/nav/MenuSpacer.ts +18 -18
- package/src/widgets/nav/RedirectRoute.ts +49 -49
- package/src/widgets/nav/Route.spec.tsx +24 -24
- package/src/widgets/nav/Route.ts +142 -142
- package/src/widgets/nav/Scroller.scss +148 -148
- package/src/widgets/nav/Scroller.tsx +252 -252
- package/src/widgets/nav/Submenu.ts +6 -6
- package/src/widgets/nav/Tab.scss +82 -82
- package/src/widgets/nav/Tab.ts +120 -120
- package/src/widgets/nav/Tab.variables.scss +84 -84
- package/src/widgets/nav/cover.scss +22 -22
- package/src/widgets/nav/index.scss +5 -5
- package/src/widgets/nav/index.ts +10 -10
- package/src/widgets/nav/variables.scss +27 -27
- package/src/widgets/overlay/ContextMenu.ts +42 -42
- package/src/widgets/overlay/Dropdown.scss +186 -186
- package/src/widgets/overlay/Dropdown.tsx +762 -762
- package/src/widgets/overlay/FlyweightTooltipTracker.ts +57 -57
- package/src/widgets/overlay/MsgBox.tsx +141 -141
- package/src/widgets/overlay/Overlay.scss +68 -68
- package/src/widgets/overlay/Overlay.tsx +947 -947
- package/src/widgets/overlay/Toast.scss +163 -163
- package/src/widgets/overlay/Toast.ts +111 -111
- package/src/widgets/overlay/Tooltip.scss +177 -177
- package/src/widgets/overlay/Tooltip.tsx +393 -393
- package/src/widgets/overlay/Window.scss +129 -129
- package/src/widgets/overlay/Window.tsx +299 -299
- package/src/widgets/overlay/Window.variables.scss +62 -62
- package/src/widgets/overlay/alerts.ts +46 -46
- package/src/widgets/overlay/captureMouse.scss +13 -13
- package/src/widgets/overlay/captureMouse.ts +195 -195
- package/src/widgets/overlay/createHotPromiseWindowFactory.ts +71 -71
- package/src/widgets/overlay/index.scss +15 -15
- package/src/widgets/overlay/index.ts +11 -11
- package/src/widgets/overlay/tooltip-ops.ts +173 -173
- package/src/widgets/overlay/variables.scss +85 -85
- package/src/widgets/variables.scss +146 -146
- package/tsconfig.compile.json +4 -4
- package/tsconfig.json +34 -34
- package/tsconfig.mocha.json +14 -14
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import {dateDiff} from './dateDiff';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Checks `date` against the lower bound `minDate`. Set `exclusive` to true to disallow the border value.
|
|
5
|
-
* @param date
|
|
6
|
-
* @param minDate
|
|
7
|
-
* @param [exclusive=false]
|
|
8
|
-
* @returns {boolean}
|
|
9
|
-
*/
|
|
10
|
-
export function lowerBoundCheck(date: Date, minDate: Date, exclusive: boolean = false): boolean {
|
|
11
|
-
var d = dateDiff(date, minDate);
|
|
12
|
-
return d > 0 || (d == 0 && !exclusive);
|
|
13
|
-
}
|
|
1
|
+
import {dateDiff} from './dateDiff';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Checks `date` against the lower bound `minDate`. Set `exclusive` to true to disallow the border value.
|
|
5
|
+
* @param date
|
|
6
|
+
* @param minDate
|
|
7
|
+
* @param [exclusive=false]
|
|
8
|
+
* @returns {boolean}
|
|
9
|
+
*/
|
|
10
|
+
export function lowerBoundCheck(date: Date, minDate: Date, exclusive: boolean = false): boolean {
|
|
11
|
+
var d = dateDiff(date, minDate);
|
|
12
|
+
return d > 0 || (d == 0 && !exclusive);
|
|
13
|
+
}
|
package/src/util/date/maxDate.ts
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import {dateDiff} from './dateDiff';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Returns the maximum Date value from the provided values.
|
|
5
|
-
* @param args
|
|
6
|
-
* @returns {Date}
|
|
7
|
-
*/
|
|
8
|
-
export function maxDate(...args: Date[]): Date {
|
|
9
|
-
var max = args[0];
|
|
10
|
-
for (var i = 1; i < args.length; i++)
|
|
11
|
-
if (dateDiff(max, args[i]) < 0)
|
|
12
|
-
max = args[i];
|
|
13
|
-
return max;
|
|
14
|
-
}
|
|
1
|
+
import {dateDiff} from './dateDiff';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Returns the maximum Date value from the provided values.
|
|
5
|
+
* @param args
|
|
6
|
+
* @returns {Date}
|
|
7
|
+
*/
|
|
8
|
+
export function maxDate(...args: Date[]): Date {
|
|
9
|
+
var max = args[0];
|
|
10
|
+
for (var i = 1; i < args.length; i++)
|
|
11
|
+
if (dateDiff(max, args[i]) < 0)
|
|
12
|
+
max = args[i];
|
|
13
|
+
return max;
|
|
14
|
+
}
|
package/src/util/date/minDate.ts
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import {dateDiff} from './dateDiff';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Returns the minimum Date value from the provided values.
|
|
5
|
-
* @param args
|
|
6
|
-
* @returns {Date}
|
|
7
|
-
*/
|
|
8
|
-
export function minDate(...args: Date[]): Date {
|
|
9
|
-
var min = args[0];
|
|
10
|
-
for (var i = 1; i<args.length; i++)
|
|
11
|
-
if (dateDiff(min, args[i]) > 0)
|
|
12
|
-
min = args[i];
|
|
13
|
-
return min;
|
|
14
|
-
}
|
|
1
|
+
import {dateDiff} from './dateDiff';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Returns the minimum Date value from the provided values.
|
|
5
|
+
* @param args
|
|
6
|
+
* @returns {Date}
|
|
7
|
+
*/
|
|
8
|
+
export function minDate(...args: Date[]): Date {
|
|
9
|
+
var min = args[0];
|
|
10
|
+
for (var i = 1; i<args.length; i++)
|
|
11
|
+
if (dateDiff(min, args[i]) > 0)
|
|
12
|
+
min = args[i];
|
|
13
|
+
return min;
|
|
14
|
+
}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Returns the date representing the beginning of the month in respect to the date provided.
|
|
3
|
-
* @param d
|
|
4
|
-
* @returns {Date}
|
|
5
|
-
*/
|
|
6
|
-
export function monthStart(d: Date): Date {
|
|
7
|
-
return new Date(d.getFullYear(), d.getMonth(), 1);
|
|
8
|
-
}
|
|
1
|
+
/**
|
|
2
|
+
* Returns the date representing the beginning of the month in respect to the date provided.
|
|
3
|
+
* @param d
|
|
4
|
+
* @returns {Date}
|
|
5
|
+
*/
|
|
6
|
+
export function monthStart(d: Date): Date {
|
|
7
|
+
return new Date(d.getFullYear(), d.getMonth(), 1);
|
|
8
|
+
}
|
|
@@ -1,20 +1,20 @@
|
|
|
1
|
-
// This module addresses a common issue when handling date strings in the format "yyyy-MM-dd" usually returned by backends.
|
|
2
|
-
// In time zones earlier than UTC, creating a Date object from such a string can result in the date being shifted one day earlier.
|
|
3
|
-
// This happens because "yyyy-MM-dd" is interpreted as a UTC date at 00:00, and when the browser displays it in local time, it adjusts backward.
|
|
4
|
-
// To resolve this, the default implementation (`defaultInvariantParseDate`) appends " 00:00" to the date string,
|
|
5
|
-
// explicitly indicating local time. Custom parsing logic can also be registered dynamically using `registerInvariantParseDateImpl`
|
|
6
|
-
// to accommodate other formats or requirements.
|
|
7
|
-
function defaultParseDateInvariant(input: string | number | Date): Date {
|
|
8
|
-
if (typeof input == "string" && input.length == 10 && input[4] == "-" && input[7] == "-")
|
|
9
|
-
return new Date(`${input} 00:00`);
|
|
10
|
-
return new Date(input);
|
|
11
|
-
}
|
|
12
|
-
let impl: (input: string | number | Date) => Date = defaultParseDateInvariant;
|
|
13
|
-
|
|
14
|
-
export function parseDateInvariant(input: string | number | Date): Date {
|
|
15
|
-
return impl(input);
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export function overrideParseDateInvariant(newImpl: (input: string | number | Date) => Date): void {
|
|
19
|
-
impl = newImpl;
|
|
20
|
-
}
|
|
1
|
+
// This module addresses a common issue when handling date strings in the format "yyyy-MM-dd" usually returned by backends.
|
|
2
|
+
// In time zones earlier than UTC, creating a Date object from such a string can result in the date being shifted one day earlier.
|
|
3
|
+
// This happens because "yyyy-MM-dd" is interpreted as a UTC date at 00:00, and when the browser displays it in local time, it adjusts backward.
|
|
4
|
+
// To resolve this, the default implementation (`defaultInvariantParseDate`) appends " 00:00" to the date string,
|
|
5
|
+
// explicitly indicating local time. Custom parsing logic can also be registered dynamically using `registerInvariantParseDateImpl`
|
|
6
|
+
// to accommodate other formats or requirements.
|
|
7
|
+
function defaultParseDateInvariant(input: string | number | Date): Date {
|
|
8
|
+
if (typeof input == "string" && input.length == 10 && input[4] == "-" && input[7] == "-")
|
|
9
|
+
return new Date(`${input} 00:00`);
|
|
10
|
+
return new Date(input);
|
|
11
|
+
}
|
|
12
|
+
let impl: (input: string | number | Date) => Date = defaultParseDateInvariant;
|
|
13
|
+
|
|
14
|
+
export function parseDateInvariant(input: string | number | Date): Date {
|
|
15
|
+
return impl(input);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export function overrideParseDateInvariant(newImpl: (input: string | number | Date) => Date): void {
|
|
19
|
+
impl = newImpl;
|
|
20
|
+
}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Returns `true` if the dates provided represent the same day.
|
|
3
|
-
* @param d1
|
|
4
|
-
* @param d2
|
|
5
|
-
* @returns {boolean}
|
|
6
|
-
*/
|
|
7
|
-
export function sameDate(d1: Date, d2: Date): boolean {
|
|
8
|
-
return d1.getDate() == d2.getDate()
|
|
9
|
-
&& d1.getMonth() == d2.getMonth()
|
|
10
|
-
&& d1.getFullYear() == d2.getFullYear();
|
|
11
|
-
}
|
|
1
|
+
/**
|
|
2
|
+
* Returns `true` if the dates provided represent the same day.
|
|
3
|
+
* @param d1
|
|
4
|
+
* @param d2
|
|
5
|
+
* @returns {boolean}
|
|
6
|
+
*/
|
|
7
|
+
export function sameDate(d1: Date, d2: Date): boolean {
|
|
8
|
+
return d1.getDate() == d2.getDate()
|
|
9
|
+
&& d1.getMonth() == d2.getMonth()
|
|
10
|
+
&& d1.getFullYear() == d2.getFullYear();
|
|
11
|
+
}
|
|
@@ -1,30 +1,30 @@
|
|
|
1
|
-
import assert from 'assert';
|
|
2
|
-
import {upperBoundCheck} from './upperBoundCheck';
|
|
3
|
-
|
|
4
|
-
describe('upperBoundCheck', () => {
|
|
5
|
-
|
|
6
|
-
let may18th = new Date('2017-05-18'); // May 18th
|
|
7
|
-
let may19th = new Date('2017-05-19'); // May 19th
|
|
8
|
-
let exclusive = true; // strictly less than...
|
|
9
|
-
|
|
10
|
-
it('returns true for May 18th <= May 19th', ()=> {
|
|
11
|
-
assert.equal(upperBoundCheck(may18th, may19th), true);
|
|
12
|
-
});
|
|
13
|
-
|
|
14
|
-
it('returns true for May 19th <= May 19th', ()=> {
|
|
15
|
-
assert.equal(upperBoundCheck(may19th, may19th), true);
|
|
16
|
-
});
|
|
17
|
-
|
|
18
|
-
it('returns true for May 19th <= May 19th with exclusive=`false`', ()=> {
|
|
19
|
-
assert.equal(upperBoundCheck(may19th, may19th, false), true);
|
|
20
|
-
});
|
|
21
|
-
|
|
22
|
-
it('returns false for May 19th < May 19th', ()=> {
|
|
23
|
-
assert.equal(upperBoundCheck(may19th, may19th, exclusive), false);
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
it('returns false for May 19th <= May 18th', ()=> {
|
|
27
|
-
assert.equal(upperBoundCheck(may19th, may18th), false);
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
});
|
|
1
|
+
import assert from 'assert';
|
|
2
|
+
import {upperBoundCheck} from './upperBoundCheck';
|
|
3
|
+
|
|
4
|
+
describe('upperBoundCheck', () => {
|
|
5
|
+
|
|
6
|
+
let may18th = new Date('2017-05-18'); // May 18th
|
|
7
|
+
let may19th = new Date('2017-05-19'); // May 19th
|
|
8
|
+
let exclusive = true; // strictly less than...
|
|
9
|
+
|
|
10
|
+
it('returns true for May 18th <= May 19th', ()=> {
|
|
11
|
+
assert.equal(upperBoundCheck(may18th, may19th), true);
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
it('returns true for May 19th <= May 19th', ()=> {
|
|
15
|
+
assert.equal(upperBoundCheck(may19th, may19th), true);
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
it('returns true for May 19th <= May 19th with exclusive=`false`', ()=> {
|
|
19
|
+
assert.equal(upperBoundCheck(may19th, may19th, false), true);
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
it('returns false for May 19th < May 19th', ()=> {
|
|
23
|
+
assert.equal(upperBoundCheck(may19th, may19th, exclusive), false);
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
it('returns false for May 19th <= May 18th', ()=> {
|
|
27
|
+
assert.equal(upperBoundCheck(may19th, may18th), false);
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
});
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import {dateDiff} from './dateDiff';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Checks `date` against the upper bound `maxDate`. Set `exclusive` to true to disallow the border value.
|
|
5
|
-
* @param date
|
|
6
|
-
* @param maxDate
|
|
7
|
-
* @param exclusive
|
|
8
|
-
* @returns {boolean}
|
|
9
|
-
*/
|
|
10
|
-
export function upperBoundCheck(date: Date, maxDate: Date, exclusive: boolean = false): boolean {
|
|
11
|
-
var d = dateDiff(date, maxDate);
|
|
12
|
-
return d < 0 || (d == 0 && !exclusive);
|
|
13
|
-
}
|
|
1
|
+
import {dateDiff} from './dateDiff';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Checks `date` against the upper bound `maxDate`. Set `exclusive` to true to disallow the border value.
|
|
5
|
+
* @param date
|
|
6
|
+
* @param maxDate
|
|
7
|
+
* @param exclusive
|
|
8
|
+
* @returns {boolean}
|
|
9
|
+
*/
|
|
10
|
+
export function upperBoundCheck(date: Date, maxDate: Date, exclusive: boolean = false): boolean {
|
|
11
|
+
var d = dateDiff(date, maxDate);
|
|
12
|
+
return d < 0 || (d == 0 && !exclusive);
|
|
13
|
+
}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Zeros out time for the given Date object. E.g. for date object representing Wed Apr 19 2017 14:31:51 GMT+0200
|
|
3
|
-
* returns Wed Apr 19 2017 00:00:00 GMT+0200.
|
|
4
|
-
* @param d
|
|
5
|
-
* @returns {Date}
|
|
6
|
-
*/
|
|
7
|
-
export function zeroTime(d: Date): Date {
|
|
8
|
-
return new Date(d.getFullYear(), d.getMonth(), d.getDate());
|
|
9
|
-
}
|
|
1
|
+
/**
|
|
2
|
+
* Zeros out time for the given Date object. E.g. for date object representing Wed Apr 19 2017 14:31:51 GMT+0200
|
|
3
|
+
* returns Wed Apr 19 2017 00:00:00 GMT+0200.
|
|
4
|
+
* @param d
|
|
5
|
+
* @returns {Date}
|
|
6
|
+
*/
|
|
7
|
+
export function zeroTime(d: Date): Date {
|
|
8
|
+
return new Date(d.getFullYear(), d.getMonth(), d.getDate());
|
|
9
|
+
}
|
package/src/util/debounce.ts
CHANGED
|
@@ -1,26 +1,26 @@
|
|
|
1
|
-
export interface DebouncedFunction<T extends (...args: any[]) => any> {
|
|
2
|
-
(...args: Parameters<T>): void;
|
|
3
|
-
reset(...args: Parameters<T>): void;
|
|
4
|
-
}
|
|
5
|
-
|
|
6
|
-
export function debounce<T extends (...args: any[]) => any>(
|
|
7
|
-
callback: T,
|
|
8
|
-
delay: number
|
|
9
|
-
): DebouncedFunction<T> {
|
|
10
|
-
let timer: ReturnType<typeof setTimeout> | undefined;
|
|
11
|
-
|
|
12
|
-
const result = function (this: any, ...args: Parameters<T>): void {
|
|
13
|
-
const context = this;
|
|
14
|
-
clearTimeout(timer);
|
|
15
|
-
timer = setTimeout(() => {
|
|
16
|
-
callback.apply(context, args);
|
|
17
|
-
}, delay);
|
|
18
|
-
} as DebouncedFunction<T>;
|
|
19
|
-
|
|
20
|
-
result.reset = function (this: any, ...args: Parameters<T>): void {
|
|
21
|
-
clearTimeout(timer);
|
|
22
|
-
callback.apply(this, args);
|
|
23
|
-
};
|
|
24
|
-
|
|
25
|
-
return result;
|
|
26
|
-
}
|
|
1
|
+
export interface DebouncedFunction<T extends (...args: any[]) => any> {
|
|
2
|
+
(...args: Parameters<T>): void;
|
|
3
|
+
reset(...args: Parameters<T>): void;
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
export function debounce<T extends (...args: any[]) => any>(
|
|
7
|
+
callback: T,
|
|
8
|
+
delay: number
|
|
9
|
+
): DebouncedFunction<T> {
|
|
10
|
+
let timer: ReturnType<typeof setTimeout> | undefined;
|
|
11
|
+
|
|
12
|
+
const result = function (this: any, ...args: Parameters<T>): void {
|
|
13
|
+
const context = this;
|
|
14
|
+
clearTimeout(timer);
|
|
15
|
+
timer = setTimeout(() => {
|
|
16
|
+
callback.apply(context, args);
|
|
17
|
+
}, delay);
|
|
18
|
+
} as DebouncedFunction<T>;
|
|
19
|
+
|
|
20
|
+
result.reset = function (this: any, ...args: Parameters<T>): void {
|
|
21
|
+
clearTimeout(timer);
|
|
22
|
+
callback.apply(this, args);
|
|
23
|
+
};
|
|
24
|
+
|
|
25
|
+
return result;
|
|
26
|
+
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export function dummyCallback(): void {}
|
|
1
|
+
export function dummyCallback(): void {}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
/**
|
|
2
|
-
*
|
|
3
|
-
* @param s
|
|
4
|
-
* @return {string}
|
|
5
|
-
*/
|
|
6
|
-
export function escapeSpecialRegexCharacters(s: string): string {
|
|
7
|
-
return s.replace(/[\\^$*+?.()|[\]{}]/g, '\\$&');
|
|
8
|
-
}
|
|
1
|
+
/**
|
|
2
|
+
*
|
|
3
|
+
* @param s
|
|
4
|
+
* @return {string}
|
|
5
|
+
*/
|
|
6
|
+
export function escapeSpecialRegexCharacters(s: string): string {
|
|
7
|
+
return s.replace(/[\\^$*+?.()|[\]{}]/g, '\\$&');
|
|
8
|
+
}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
interface SyntheticEvent<T> {
|
|
2
|
-
stopPropagation(): void;
|
|
3
|
-
preventDefault(): void;
|
|
4
|
-
}
|
|
5
|
-
|
|
6
|
-
export function stopPropagation(e: SyntheticEvent<any>): void {
|
|
7
|
-
e.stopPropagation();
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
export function preventDefault(e: SyntheticEvent<any>): void {
|
|
11
|
-
e.preventDefault();
|
|
12
|
-
}
|
|
1
|
+
interface SyntheticEvent<T> {
|
|
2
|
+
stopPropagation(): void;
|
|
3
|
+
preventDefault(): void;
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
export function stopPropagation(e: SyntheticEvent<any>): void {
|
|
7
|
+
e.stopPropagation();
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export function preventDefault(e: SyntheticEvent<any>): void {
|
|
11
|
+
e.preventDefault();
|
|
12
|
+
}
|
|
@@ -1,118 +1,118 @@
|
|
|
1
|
-
//http://stackoverflow.com/questions/36428283/arrow-function-eval-preprocessor
|
|
2
|
-
|
|
3
|
-
export function expandFatArrows(code: string): string {
|
|
4
|
-
var arrowHeadRegex = RegExp(/(\((?:\w+,)*\w+\)|\(\)|\w+)[\r\t ]*=>\s*/);
|
|
5
|
-
var arrowHeadMatch = arrowHeadRegex.exec(code);
|
|
6
|
-
|
|
7
|
-
if (arrowHeadMatch) {//if no match return as it is
|
|
8
|
-
var params = arrowHeadMatch[1];
|
|
9
|
-
if (params.charAt(0) !== "(") {
|
|
10
|
-
params = "(" + params + ")";
|
|
11
|
-
}
|
|
12
|
-
var index = arrowHeadMatch.index;
|
|
13
|
-
var startCode = code.substring(0, index);
|
|
14
|
-
|
|
15
|
-
var bodyAndNext = code.substring(index + arrowHeadMatch[0].length);
|
|
16
|
-
|
|
17
|
-
var curlyCount = 0;
|
|
18
|
-
var curlyPresent = false;
|
|
19
|
-
var singleLineBodyEnd = 0;
|
|
20
|
-
var bodyEnd = 0;
|
|
21
|
-
|
|
22
|
-
for (var i = 0; i < bodyAndNext.length; i++) {
|
|
23
|
-
var ch = bodyAndNext[i];
|
|
24
|
-
if (ch === '{') {
|
|
25
|
-
curlyPresent = true;
|
|
26
|
-
curlyCount++;
|
|
27
|
-
} else if (ch === '}') {
|
|
28
|
-
curlyCount--;
|
|
29
|
-
} else if (!curlyPresent) {
|
|
30
|
-
//any character other than { or }
|
|
31
|
-
singleLineBodyEnd = getSingeLineBodyEnd(bodyAndNext, i);
|
|
32
|
-
break;
|
|
33
|
-
}
|
|
34
|
-
if (curlyPresent && curlyCount === 0) {
|
|
35
|
-
bodyEnd = i;
|
|
36
|
-
break;
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
var body;
|
|
41
|
-
|
|
42
|
-
if (curlyPresent) {
|
|
43
|
-
if (curlyCount !== 0) {
|
|
44
|
-
throw Error("Could not match curly braces for function at : " + index);
|
|
45
|
-
}
|
|
46
|
-
body = bodyAndNext.substring(0, bodyEnd + 1);
|
|
47
|
-
|
|
48
|
-
var restCode = bodyAndNext.substring(bodyEnd + 1);
|
|
49
|
-
var expandedFun = "(function " + params + body + ").bind(this)";
|
|
50
|
-
code = startCode + expandedFun + restCode;
|
|
51
|
-
} else {
|
|
52
|
-
if (singleLineBodyEnd <= 0) {
|
|
53
|
-
throw Error("could not get function body at : " + index);
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
body = bodyAndNext.substring(0, singleLineBodyEnd + 1);
|
|
57
|
-
|
|
58
|
-
restCode = bodyAndNext.substring(singleLineBodyEnd + 1);
|
|
59
|
-
expandedFun = "(function " + params + "{return " + body + "}).bind(this)";
|
|
60
|
-
code = startCode + expandedFun + restCode;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
return expandFatArrows(code);//recursive call
|
|
64
|
-
}
|
|
65
|
-
return code;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
function getSingeLineBodyEnd(bodyCode: string, startI: number): number {
|
|
69
|
-
var braceCount = 0;
|
|
70
|
-
var openingQuote = null;
|
|
71
|
-
|
|
72
|
-
for (var i = startI; i < bodyCode.length; i++) {
|
|
73
|
-
var ch = bodyCode[i];
|
|
74
|
-
var lastCh = null;
|
|
75
|
-
if (ch === '"' || ch === "'") {
|
|
76
|
-
openingQuote = ch;
|
|
77
|
-
i = skipQuotedString(bodyCode, openingQuote, i);
|
|
78
|
-
ch = bodyCode[i];
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
if (i !== 0 && !bodyCode[i - 1].match(/[\t\r ]/)) {
|
|
82
|
-
lastCh = bodyCode[i - 1];
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
if (ch === '{' || ch === '(') {
|
|
86
|
-
braceCount++;
|
|
87
|
-
} else if (ch === '}' || ch === ')') {
|
|
88
|
-
braceCount--;
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
if (braceCount < 0 || (lastCh !== '.' && ch === '\n')) {
|
|
92
|
-
return i - 1;
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
return bodyCode.length;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
function skipQuotedString(bodyAndNext: string, openingQuote: string, i: number): number {
|
|
100
|
-
var matchFound = false;//matching quote
|
|
101
|
-
var openingQuoteI = i;
|
|
102
|
-
i++;
|
|
103
|
-
for (; i < bodyAndNext.length; i++) {
|
|
104
|
-
var ch = bodyAndNext[i];
|
|
105
|
-
var lastCh = (i !== 0) ? bodyAndNext[i - 1] : null;
|
|
106
|
-
|
|
107
|
-
if (ch !== openingQuote || (ch === openingQuote && lastCh === '\\' )) {
|
|
108
|
-
continue;//skip quoted string
|
|
109
|
-
} else if (ch === openingQuote) {//matched closing quote
|
|
110
|
-
matchFound = false;
|
|
111
|
-
break;
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
if (matchFound) {
|
|
115
|
-
throw new Error("Could not find closing quote for quote at : " + openingQuoteI);
|
|
116
|
-
}
|
|
117
|
-
return i;
|
|
118
|
-
}
|
|
1
|
+
//http://stackoverflow.com/questions/36428283/arrow-function-eval-preprocessor
|
|
2
|
+
|
|
3
|
+
export function expandFatArrows(code: string): string {
|
|
4
|
+
var arrowHeadRegex = RegExp(/(\((?:\w+,)*\w+\)|\(\)|\w+)[\r\t ]*=>\s*/);
|
|
5
|
+
var arrowHeadMatch = arrowHeadRegex.exec(code);
|
|
6
|
+
|
|
7
|
+
if (arrowHeadMatch) {//if no match return as it is
|
|
8
|
+
var params = arrowHeadMatch[1];
|
|
9
|
+
if (params.charAt(0) !== "(") {
|
|
10
|
+
params = "(" + params + ")";
|
|
11
|
+
}
|
|
12
|
+
var index = arrowHeadMatch.index;
|
|
13
|
+
var startCode = code.substring(0, index);
|
|
14
|
+
|
|
15
|
+
var bodyAndNext = code.substring(index + arrowHeadMatch[0].length);
|
|
16
|
+
|
|
17
|
+
var curlyCount = 0;
|
|
18
|
+
var curlyPresent = false;
|
|
19
|
+
var singleLineBodyEnd = 0;
|
|
20
|
+
var bodyEnd = 0;
|
|
21
|
+
|
|
22
|
+
for (var i = 0; i < bodyAndNext.length; i++) {
|
|
23
|
+
var ch = bodyAndNext[i];
|
|
24
|
+
if (ch === '{') {
|
|
25
|
+
curlyPresent = true;
|
|
26
|
+
curlyCount++;
|
|
27
|
+
} else if (ch === '}') {
|
|
28
|
+
curlyCount--;
|
|
29
|
+
} else if (!curlyPresent) {
|
|
30
|
+
//any character other than { or }
|
|
31
|
+
singleLineBodyEnd = getSingeLineBodyEnd(bodyAndNext, i);
|
|
32
|
+
break;
|
|
33
|
+
}
|
|
34
|
+
if (curlyPresent && curlyCount === 0) {
|
|
35
|
+
bodyEnd = i;
|
|
36
|
+
break;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
var body;
|
|
41
|
+
|
|
42
|
+
if (curlyPresent) {
|
|
43
|
+
if (curlyCount !== 0) {
|
|
44
|
+
throw Error("Could not match curly braces for function at : " + index);
|
|
45
|
+
}
|
|
46
|
+
body = bodyAndNext.substring(0, bodyEnd + 1);
|
|
47
|
+
|
|
48
|
+
var restCode = bodyAndNext.substring(bodyEnd + 1);
|
|
49
|
+
var expandedFun = "(function " + params + body + ").bind(this)";
|
|
50
|
+
code = startCode + expandedFun + restCode;
|
|
51
|
+
} else {
|
|
52
|
+
if (singleLineBodyEnd <= 0) {
|
|
53
|
+
throw Error("could not get function body at : " + index);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
body = bodyAndNext.substring(0, singleLineBodyEnd + 1);
|
|
57
|
+
|
|
58
|
+
restCode = bodyAndNext.substring(singleLineBodyEnd + 1);
|
|
59
|
+
expandedFun = "(function " + params + "{return " + body + "}).bind(this)";
|
|
60
|
+
code = startCode + expandedFun + restCode;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
return expandFatArrows(code);//recursive call
|
|
64
|
+
}
|
|
65
|
+
return code;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
function getSingeLineBodyEnd(bodyCode: string, startI: number): number {
|
|
69
|
+
var braceCount = 0;
|
|
70
|
+
var openingQuote = null;
|
|
71
|
+
|
|
72
|
+
for (var i = startI; i < bodyCode.length; i++) {
|
|
73
|
+
var ch = bodyCode[i];
|
|
74
|
+
var lastCh = null;
|
|
75
|
+
if (ch === '"' || ch === "'") {
|
|
76
|
+
openingQuote = ch;
|
|
77
|
+
i = skipQuotedString(bodyCode, openingQuote, i);
|
|
78
|
+
ch = bodyCode[i];
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
if (i !== 0 && !bodyCode[i - 1].match(/[\t\r ]/)) {
|
|
82
|
+
lastCh = bodyCode[i - 1];
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
if (ch === '{' || ch === '(') {
|
|
86
|
+
braceCount++;
|
|
87
|
+
} else if (ch === '}' || ch === ')') {
|
|
88
|
+
braceCount--;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
if (braceCount < 0 || (lastCh !== '.' && ch === '\n')) {
|
|
92
|
+
return i - 1;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
return bodyCode.length;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
function skipQuotedString(bodyAndNext: string, openingQuote: string, i: number): number {
|
|
100
|
+
var matchFound = false;//matching quote
|
|
101
|
+
var openingQuoteI = i;
|
|
102
|
+
i++;
|
|
103
|
+
for (; i < bodyAndNext.length; i++) {
|
|
104
|
+
var ch = bodyAndNext[i];
|
|
105
|
+
var lastCh = (i !== 0) ? bodyAndNext[i - 1] : null;
|
|
106
|
+
|
|
107
|
+
if (ch !== openingQuote || (ch === openingQuote && lastCh === '\\' )) {
|
|
108
|
+
continue;//skip quoted string
|
|
109
|
+
} else if (ch === openingQuote) {//matched closing quote
|
|
110
|
+
matchFound = false;
|
|
111
|
+
break;
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
if (matchFound) {
|
|
115
|
+
throw new Error("Could not find closing quote for quote at : " + openingQuoteI);
|
|
116
|
+
}
|
|
117
|
+
return i;
|
|
118
|
+
}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { closest } from "./DOM";
|
|
2
|
-
|
|
3
|
-
export function findScrollableParent(sourceEl: Element, horizontal: boolean = false): HTMLElement | null {
|
|
4
|
-
if (!sourceEl) return null;
|
|
5
|
-
let scrollParent = closest(sourceEl, (el) => {
|
|
6
|
-
if (el.nodeType != Node.ELEMENT_NODE) return false;
|
|
7
|
-
if (!horizontal && el.clientHeight >= el.scrollHeight) return false;
|
|
8
|
-
if (horizontal && el.clientWidth >= el.scrollWidth) return false;
|
|
9
|
-
let overflow = getComputedStyle(el).getPropertyValue(horizontal ? "overflow-x" : "overflow-y");
|
|
10
|
-
return overflow == "auto" || overflow == "scroll";
|
|
11
|
-
}) as HTMLElement;
|
|
12
|
-
return (
|
|
13
|
-
scrollParent || (sourceEl.ownerDocument.scrollingElement as HTMLElement) || sourceEl.ownerDocument.documentElement
|
|
14
|
-
);
|
|
15
|
-
}
|
|
1
|
+
import { closest } from "./DOM";
|
|
2
|
+
|
|
3
|
+
export function findScrollableParent(sourceEl: Element, horizontal: boolean = false): HTMLElement | null {
|
|
4
|
+
if (!sourceEl) return null;
|
|
5
|
+
let scrollParent = closest(sourceEl, (el) => {
|
|
6
|
+
if (el.nodeType != Node.ELEMENT_NODE) return false;
|
|
7
|
+
if (!horizontal && el.clientHeight >= el.scrollHeight) return false;
|
|
8
|
+
if (horizontal && el.clientWidth >= el.scrollWidth) return false;
|
|
9
|
+
let overflow = getComputedStyle(el).getPropertyValue(horizontal ? "overflow-x" : "overflow-y");
|
|
10
|
+
return overflow == "auto" || overflow == "scroll";
|
|
11
|
+
}) as HTMLElement;
|
|
12
|
+
return (
|
|
13
|
+
scrollParent || (sourceEl.ownerDocument.scrollingElement as HTMLElement) || sourceEl.ownerDocument.documentElement
|
|
14
|
+
);
|
|
15
|
+
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
//IE sometimes returns null while other browsers always return document.body.
|
|
2
|
-
export function getActiveElement(): Element {
|
|
3
|
-
return document.activeElement ?? document.body;
|
|
4
|
-
}
|
|
1
|
+
//IE sometimes returns null while other browsers always return document.body.
|
|
2
|
+
export function getActiveElement(): Element {
|
|
3
|
+
return document.activeElement ?? document.body;
|
|
4
|
+
}
|