cx 25.6.3 → 25.7.0

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.
Files changed (111) hide show
  1. package/dist/charts.css +250 -250
  2. package/dist/charts.js +109 -109
  3. package/dist/data.js +19 -19
  4. package/dist/hooks.js +1 -1
  5. package/dist/manifest.js +744 -744
  6. package/dist/svg.js +25 -25
  7. package/dist/ui.js +84 -84
  8. package/dist/util.js +6 -9
  9. package/dist/widgets.css +6 -6
  10. package/dist/widgets.js +516 -511
  11. package/package.json +1 -1
  12. package/src/charts/Legend.d.ts +45 -45
  13. package/src/charts/LegendEntry.js +128 -128
  14. package/src/charts/LegendEntry.scss +27 -27
  15. package/src/charts/Marker.d.ts +1 -1
  16. package/src/charts/MarkerLine.d.ts +25 -27
  17. package/src/charts/PieChart.d.ts +92 -92
  18. package/src/charts/RangeMarker.js +159 -159
  19. package/src/charts/axis/Axis.d.ts +113 -113
  20. package/src/charts/axis/Axis.js +280 -280
  21. package/src/charts/axis/CategoryAxis.d.ts +30 -30
  22. package/src/charts/axis/CategoryAxis.js +241 -241
  23. package/src/charts/axis/NumericAxis.js +351 -351
  24. package/src/charts/axis/Stack.js +55 -55
  25. package/src/charts/axis/TimeAxis.js +611 -611
  26. package/src/charts/helpers/SnapPointFinder.js +69 -69
  27. package/src/data/Binding.spec.js +69 -69
  28. package/src/data/ExposedValueView.d.ts +19 -19
  29. package/src/data/Expression.js +229 -229
  30. package/src/data/Expression.spec.js +229 -229
  31. package/src/data/StringTemplate.js +92 -92
  32. package/src/data/StringTemplate.spec.js +132 -132
  33. package/src/data/StructuredSelector.js +132 -132
  34. package/src/data/getAccessor.spec.js +11 -11
  35. package/src/data/getSelector.js +49 -49
  36. package/src/hooks/createLocalStorageRef.d.ts +3 -3
  37. package/src/hooks/createLocalStorageRef.js +20 -20
  38. package/src/index.scss +6 -6
  39. package/src/ui/Culture.d.ts +57 -57
  40. package/src/ui/Culture.js +139 -139
  41. package/src/ui/FocusManager.js +171 -171
  42. package/src/ui/Format.js +108 -108
  43. package/src/ui/HoverSync.js +147 -147
  44. package/src/ui/Repeater.d.ts +61 -61
  45. package/src/ui/index.d.ts +42 -42
  46. package/src/ui/layout/ContentPlaceholder.d.ts +19 -19
  47. package/src/ui/layout/ContentPlaceholder.js +105 -105
  48. package/src/ui/layout/ContentPlaceholder.spec.js +579 -579
  49. package/src/ui/layout/LabelsTopLayout.js +134 -134
  50. package/src/util/Format.js +270 -270
  51. package/src/util/date/encodeDate.d.ts +1 -1
  52. package/src/util/date/encodeDate.js +8 -8
  53. package/src/util/date/encodeDateWithTimezoneOffset.d.ts +1 -1
  54. package/src/util/date/index.d.ts +11 -11
  55. package/src/util/date/index.js +11 -11
  56. package/src/util/date/parseDateInvariant.d.ts +3 -3
  57. package/src/util/date/parseDateInvariant.js +20 -20
  58. package/src/util/getSearchQueryPredicate.js +59 -59
  59. package/src/util/index.d.ts +51 -51
  60. package/src/util/index.js +54 -54
  61. package/src/util/isFunction.d.ts +1 -1
  62. package/src/util/isValidIdentifierName.d.ts +1 -1
  63. package/src/util/isValidIdentifierName.js +5 -5
  64. package/src/util/isValidIdentifierName.spec.js +33 -33
  65. package/src/util/scss/add-rules.scss +38 -38
  66. package/src/widgets/CxCredit.scss +37 -37
  67. package/src/widgets/HighlightedSearchText.js +36 -36
  68. package/src/widgets/HighlightedSearchText.scss +18 -18
  69. package/src/widgets/List.scss +91 -91
  70. package/src/widgets/Sandbox.d.ts +18 -18
  71. package/src/widgets/Sandbox.js +65 -65
  72. package/src/widgets/drag-drop/DropZone.js +214 -214
  73. package/src/widgets/form/Calendar.js +618 -618
  74. package/src/widgets/form/Calendar.scss +196 -196
  75. package/src/widgets/form/Checkbox.scss +127 -127
  76. package/src/widgets/form/ColorField.js +397 -397
  77. package/src/widgets/form/ColorField.scss +96 -96
  78. package/src/widgets/form/ColorPicker.scss +283 -283
  79. package/src/widgets/form/DateTimeField.js +576 -576
  80. package/src/widgets/form/DateTimePicker.js +392 -392
  81. package/src/widgets/form/LookupField.d.ts +179 -179
  82. package/src/widgets/form/LookupField.scss +219 -219
  83. package/src/widgets/form/NumberField.js +459 -459
  84. package/src/widgets/form/NumberField.scss +61 -61
  85. package/src/widgets/form/Radio.scss +121 -121
  86. package/src/widgets/form/Select.scss +99 -99
  87. package/src/widgets/form/Slider.scss +118 -118
  88. package/src/widgets/form/Switch.scss +140 -140
  89. package/src/widgets/form/TextArea.scss +43 -43
  90. package/src/widgets/form/TextField.js +290 -290
  91. package/src/widgets/form/TextField.scss +55 -55
  92. package/src/widgets/form/UploadButton.d.ts +34 -34
  93. package/src/widgets/form/variables.scss +353 -353
  94. package/src/widgets/grid/Grid.d.ts +442 -442
  95. package/src/widgets/grid/Grid.js +28 -23
  96. package/src/widgets/grid/GridRow.js +228 -228
  97. package/src/widgets/grid/TreeNode.d.ts +23 -23
  98. package/src/widgets/grid/TreeNode.scss +88 -88
  99. package/src/widgets/grid/variables.scss +133 -133
  100. package/src/widgets/nav/LinkButton.js +128 -128
  101. package/src/widgets/nav/Menu.scss +74 -74
  102. package/src/widgets/overlay/Dropdown.js +612 -612
  103. package/src/widgets/overlay/FlyweightTooltipTracker.js +39 -39
  104. package/src/widgets/overlay/Overlay.d.ts +73 -73
  105. package/src/widgets/overlay/Window.js +202 -202
  106. package/src/widgets/overlay/captureMouse.js +124 -124
  107. package/src/widgets/overlay/createHotPromiseWindowFactory.d.ts +18 -18
  108. package/src/widgets/overlay/createHotPromiseWindowFactory.js +56 -56
  109. package/src/widgets/overlay/index.d.ts +11 -11
  110. package/src/widgets/overlay/index.js +11 -11
  111. package/src/widgets/variables.scss +144 -144
@@ -1,128 +1,128 @@
1
- import { Widget, VDOM } from "../../ui/Widget";
2
- import { Button } from "../Button";
3
- import { History } from "../../ui/app/History";
4
- import { Url } from "../../ui/app/Url";
5
- import { routeAppend } from "../../util/routeAppend";
6
- import { parseStyle } from "../../util/parseStyle";
7
-
8
- export class LinkButton extends Button {
9
- init() {
10
- this.activeStyle = parseStyle(this.activeStyle);
11
- this.inactiveStyle = parseStyle(this.inactiveStyle);
12
- super.init();
13
- }
14
-
15
- declareData() {
16
- super.declareData(
17
- {
18
- href: undefined,
19
- url: undefined,
20
- target: undefined,
21
- active: undefined,
22
- activeClass: undefined,
23
- activeStyle: undefined,
24
- inactiveClass: undefined,
25
- inactiveStyle: undefined,
26
- },
27
- ...arguments,
28
- );
29
- }
30
-
31
- prepareData(context, instance) {
32
- let { data } = instance;
33
-
34
- data.unresolvedHref = data.href;
35
-
36
- if (typeof data.href === "string") {
37
- if (data.unresolvedHref[0] === "+")
38
- data.unresolvedHref = routeAppend(context.lastRoute.reverse(), data.href.substring(1));
39
-
40
- data.href = Url.resolve(data.unresolvedHref);
41
- }
42
-
43
- let active = this.isActive(data);
44
-
45
- data.stateMods = {
46
- disabled: data.disabled,
47
- active,
48
- };
49
-
50
- super.prepareData(context, instance);
51
-
52
- if (active) {
53
- if (data.activeClass) data.classNames += " " + data.activeClass;
54
- if (data.activeStyle)
55
- data.style = {
56
- ...data.style,
57
- ...parseStyle(data.activeStyle),
58
- };
59
- } else {
60
- if (data.inactiveClass) data.classNames += " " + data.inactiveClass;
61
- if (data.inactiveStyle)
62
- data.style = {
63
- ...data.style,
64
- ...parseStyle(data.inactiveStyle),
65
- };
66
- }
67
- }
68
-
69
- isActive(data) {
70
- if (data.active != null) return data.active;
71
-
72
- switch (this.match) {
73
- default:
74
- case "equal":
75
- return data.url === data.unresolvedHref;
76
-
77
- case "prefix":
78
- return data.url && data.unresolvedHref && data.url.indexOf(data.unresolvedHref) === 0;
79
-
80
- case "subroute":
81
- return (
82
- data.url &&
83
- data.unresolvedHref &&
84
- data.url.indexOf(data.unresolvedHref) === 0 &&
85
- (data.url === data.unresolvedHref || data.url[data.unresolvedHref.length] === "/")
86
- );
87
- }
88
- }
89
-
90
- attachProps(context, instance, props) {
91
- props.onClick = (ev) => {
92
- this.handleClick(ev, instance);
93
- };
94
- super.attachProps(context, instance, props);
95
- props.href = instance.data.href;
96
- delete props.active;
97
- delete props.activeClass;
98
- delete props.activeStyle;
99
- delete props.inactiveClass;
100
- delete props.inactiveStyle;
101
- }
102
-
103
- isValidHtmlAttribute(attr) {
104
- if (attr === "url" || attr === "match") return false;
105
- return super.isValidHtmlAttribute(attr);
106
- }
107
-
108
- handleClick(e, instance) {
109
- let { data } = instance;
110
-
111
- if (data.disabled) {
112
- e.preventDefault();
113
- return;
114
- }
115
-
116
- if (this.onClick && instance.invoke("onClick", e, instance) === false) return;
117
-
118
- if (data.href && Url.isLocal(data.href) && !e.ctrlKey && !e.shiftKey && !e.metaKey) {
119
- e.preventDefault();
120
- History.pushState({}, null, data.href);
121
- }
122
- }
123
- }
124
-
125
- LinkButton.prototype.match = "equal";
126
- LinkButton.prototype.tag = "a";
127
-
128
- Widget.alias("link-button", LinkButton);
1
+ import { Widget, VDOM } from "../../ui/Widget";
2
+ import { Button } from "../Button";
3
+ import { History } from "../../ui/app/History";
4
+ import { Url } from "../../ui/app/Url";
5
+ import { routeAppend } from "../../util/routeAppend";
6
+ import { parseStyle } from "../../util/parseStyle";
7
+
8
+ export class LinkButton extends Button {
9
+ init() {
10
+ this.activeStyle = parseStyle(this.activeStyle);
11
+ this.inactiveStyle = parseStyle(this.inactiveStyle);
12
+ super.init();
13
+ }
14
+
15
+ declareData() {
16
+ super.declareData(
17
+ {
18
+ href: undefined,
19
+ url: undefined,
20
+ target: undefined,
21
+ active: undefined,
22
+ activeClass: undefined,
23
+ activeStyle: undefined,
24
+ inactiveClass: undefined,
25
+ inactiveStyle: undefined,
26
+ },
27
+ ...arguments,
28
+ );
29
+ }
30
+
31
+ prepareData(context, instance) {
32
+ let { data } = instance;
33
+
34
+ data.unresolvedHref = data.href;
35
+
36
+ if (typeof data.href === "string") {
37
+ if (data.unresolvedHref[0] === "+")
38
+ data.unresolvedHref = routeAppend(context.lastRoute.reverse(), data.href.substring(1));
39
+
40
+ data.href = Url.resolve(data.unresolvedHref);
41
+ }
42
+
43
+ let active = this.isActive(data);
44
+
45
+ data.stateMods = {
46
+ disabled: data.disabled,
47
+ active,
48
+ };
49
+
50
+ super.prepareData(context, instance);
51
+
52
+ if (active) {
53
+ if (data.activeClass) data.classNames += " " + data.activeClass;
54
+ if (data.activeStyle)
55
+ data.style = {
56
+ ...data.style,
57
+ ...parseStyle(data.activeStyle),
58
+ };
59
+ } else {
60
+ if (data.inactiveClass) data.classNames += " " + data.inactiveClass;
61
+ if (data.inactiveStyle)
62
+ data.style = {
63
+ ...data.style,
64
+ ...parseStyle(data.inactiveStyle),
65
+ };
66
+ }
67
+ }
68
+
69
+ isActive(data) {
70
+ if (data.active != null) return data.active;
71
+
72
+ switch (this.match) {
73
+ default:
74
+ case "equal":
75
+ return data.url === data.unresolvedHref;
76
+
77
+ case "prefix":
78
+ return data.url && data.unresolvedHref && data.url.indexOf(data.unresolvedHref) === 0;
79
+
80
+ case "subroute":
81
+ return (
82
+ data.url &&
83
+ data.unresolvedHref &&
84
+ data.url.indexOf(data.unresolvedHref) === 0 &&
85
+ (data.url === data.unresolvedHref || data.url[data.unresolvedHref.length] === "/")
86
+ );
87
+ }
88
+ }
89
+
90
+ attachProps(context, instance, props) {
91
+ props.onClick = (ev) => {
92
+ this.handleClick(ev, instance);
93
+ };
94
+ super.attachProps(context, instance, props);
95
+ props.href = instance.data.href;
96
+ delete props.active;
97
+ delete props.activeClass;
98
+ delete props.activeStyle;
99
+ delete props.inactiveClass;
100
+ delete props.inactiveStyle;
101
+ }
102
+
103
+ isValidHtmlAttribute(attr) {
104
+ if (attr === "url" || attr === "match") return false;
105
+ return super.isValidHtmlAttribute(attr);
106
+ }
107
+
108
+ handleClick(e, instance) {
109
+ let { data } = instance;
110
+
111
+ if (data.disabled) {
112
+ e.preventDefault();
113
+ return;
114
+ }
115
+
116
+ if (this.onClick && instance.invoke("onClick", e, instance) === false) return;
117
+
118
+ if (data.href && Url.isLocal(data.href) && !e.ctrlKey && !e.shiftKey && !e.metaKey) {
119
+ e.preventDefault();
120
+ History.pushState({}, null, data.href);
121
+ }
122
+ }
123
+ }
124
+
125
+ LinkButton.prototype.match = "equal";
126
+ LinkButton.prototype.tag = "a";
127
+
128
+ Widget.alias("link-button", LinkButton);
@@ -1,74 +1,74 @@
1
- @mixin cx-menu($name: "menu", $state-style-map: $cx-menu-state-style-map, $besm: $cx-besm) {
2
- $block: map-get($besm, block);
3
- $element: map-get($besm, element);
4
- $state: map-get($besm, state);
5
- $mod: map-get($besm, mod);
6
-
7
- .#{$block}#{$name} {
8
- box-sizing: border-box;
9
- margin: 0;
10
- padding: 0;
11
- list-style: none;
12
-
13
- @include cx-add-state-rules($state-style-map, default);
14
-
15
- &.#{$state}horizontal {
16
- white-space: nowrap;
17
-
18
- & > .#{$element}#{$name}-item {
19
- display: inline-block;
20
- user-select: none;
21
-
22
- @each $size, $value in $cx-menu-padding-options {
23
- &.#{$state}size-#{$size} > .#{$mod}#{$name} {
24
- margin: 0 cx-right($value) 0 cx-left($value);
25
- }
26
- }
27
- }
28
- }
29
-
30
- @each $size, $value in $cx-menu-padding-options {
31
- &.#{$state}vertical.#{$state}#{$size}-item-padding .#{$mod}#{$name} {
32
- margin: $value;
33
- display: block;
34
- }
35
- }
36
-
37
- .#{$element}#{$name}-item {
38
- & > hr {
39
- border: none;
40
- border-top: 1px solid $cx-default-menu-separator-color;
41
- margin: map-get($cx-menu-padding-options, medium);
42
- }
43
-
44
- &.#{$state}hidden {
45
- visibility: hidden;
46
- position: absolute;
47
- }
48
- }
49
-
50
- &.#{$state}overflow {
51
- overflow: hidden;
52
- display: flex;
53
-
54
- & > .#{$element}#{$name}-item:last-child {
55
- visibility: hidden;
56
- position: absolute;
57
- max-height: 100%;
58
- }
59
-
60
- &.#{$state}pack > .#{$element}#{$name}-item:last-child {
61
- visibility: visible;
62
- position: relative;
63
- }
64
- }
65
- }
66
-
67
- .#{$element}#{$name}-spacer {
68
- flex: 1 1 0%;
69
- }
70
- }
71
-
72
- @if (cx-should-include("cx/widgets/Menu")) {
73
- @include cx-menu();
74
- }
1
+ @mixin cx-menu($name: "menu", $state-style-map: $cx-menu-state-style-map, $besm: $cx-besm) {
2
+ $block: map-get($besm, block);
3
+ $element: map-get($besm, element);
4
+ $state: map-get($besm, state);
5
+ $mod: map-get($besm, mod);
6
+
7
+ .#{$block}#{$name} {
8
+ box-sizing: border-box;
9
+ margin: 0;
10
+ padding: 0;
11
+ list-style: none;
12
+
13
+ @include cx-add-state-rules($state-style-map, default);
14
+
15
+ &.#{$state}horizontal {
16
+ white-space: nowrap;
17
+
18
+ & > .#{$element}#{$name}-item {
19
+ display: inline-block;
20
+ user-select: none;
21
+
22
+ @each $size, $value in $cx-menu-padding-options {
23
+ &.#{$state}size-#{$size} > .#{$mod}#{$name} {
24
+ margin: 0 cx-right($value) 0 cx-left($value);
25
+ }
26
+ }
27
+ }
28
+ }
29
+
30
+ @each $size, $value in $cx-menu-padding-options {
31
+ &.#{$state}vertical.#{$state}#{$size}-item-padding .#{$mod}#{$name} {
32
+ margin: $value;
33
+ display: block;
34
+ }
35
+ }
36
+
37
+ .#{$element}#{$name}-item {
38
+ & > hr {
39
+ border: none;
40
+ border-top: 1px solid $cx-default-menu-separator-color;
41
+ margin: map-get($cx-menu-padding-options, medium);
42
+ }
43
+
44
+ &.#{$state}hidden {
45
+ visibility: hidden;
46
+ position: absolute;
47
+ }
48
+ }
49
+
50
+ &.#{$state}overflow {
51
+ overflow: hidden;
52
+ display: flex;
53
+
54
+ & > .#{$element}#{$name}-item:last-child {
55
+ visibility: hidden;
56
+ position: absolute;
57
+ max-height: 100%;
58
+ }
59
+
60
+ &.#{$state}pack > .#{$element}#{$name}-item:last-child {
61
+ visibility: visible;
62
+ position: relative;
63
+ }
64
+ }
65
+ }
66
+
67
+ .#{$element}#{$name}-spacer {
68
+ flex: 1 1 0%;
69
+ }
70
+ }
71
+
72
+ @if (cx-should-include("cx/widgets/Menu")) {
73
+ @include cx-menu();
74
+ }