@progress/kendo-react-grid 7.2.4-develop.3 → 7.3.0-develop.1

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 (174) hide show
  1. package/Grid.js +8 -0
  2. package/Grid.mjs +1111 -0
  3. package/GridColumn.js +8 -0
  4. package/GridColumn.mjs +53 -0
  5. package/GridNoRecords.js +8 -0
  6. package/GridNoRecords.mjs +25 -0
  7. package/GridToolbar.js +8 -0
  8. package/GridToolbar.mjs +39 -0
  9. package/StatusBar.js +8 -0
  10. package/StatusBar.mjs +53 -0
  11. package/VirtualScroll.js +8 -0
  12. package/VirtualScroll.mjs +128 -0
  13. package/VirtualScrollFixed.js +8 -0
  14. package/VirtualScrollFixed.mjs +86 -0
  15. package/cells/GridCell.js +8 -0
  16. package/cells/GridCell.mjs +57 -0
  17. package/cells/GridDetailCell.js +8 -0
  18. package/cells/GridDetailCell.mjs +30 -0
  19. package/cells/GridDetailHierarchyCell.js +8 -0
  20. package/cells/GridDetailHierarchyCell.mjs +17 -0
  21. package/cells/GridEditCell.js +8 -0
  22. package/cells/GridEditCell.mjs +172 -0
  23. package/cells/GridFilterCell.js +8 -0
  24. package/cells/GridFilterCell.mjs +145 -0
  25. package/cells/GridGroupCell.js +8 -0
  26. package/cells/GridGroupCell.mjs +115 -0
  27. package/cells/GridHierarchyCell.js +8 -0
  28. package/cells/GridHierarchyCell.mjs +84 -0
  29. package/cells/GridSelectionCell.js +8 -0
  30. package/cells/GridSelectionCell.mjs +54 -0
  31. package/columnMenu/GridColumnMenuCheckboxFilter.js +8 -0
  32. package/columnMenu/GridColumnMenuCheckboxFilter.mjs +199 -0
  33. package/columnMenu/GridColumnMenuColumnsList.js +8 -0
  34. package/columnMenu/GridColumnMenuColumnsList.mjs +60 -0
  35. package/columnMenu/GridColumnMenuFilter.js +8 -0
  36. package/columnMenu/GridColumnMenuFilter.mjs +188 -0
  37. package/columnMenu/GridColumnMenuFilterCell.js +8 -0
  38. package/columnMenu/GridColumnMenuFilterCell.mjs +96 -0
  39. package/columnMenu/GridColumnMenuFilterUI.js +8 -0
  40. package/columnMenu/GridColumnMenuFilterUI.mjs +36 -0
  41. package/columnMenu/GridColumnMenuGroup.js +8 -0
  42. package/columnMenu/GridColumnMenuGroup.mjs +50 -0
  43. package/columnMenu/GridColumnMenuItem.js +8 -0
  44. package/columnMenu/GridColumnMenuItem.mjs +22 -0
  45. package/columnMenu/GridColumnMenuItemContent.js +8 -0
  46. package/columnMenu/GridColumnMenuItemContent.mjs +30 -0
  47. package/columnMenu/GridColumnMenuItemGroup.js +8 -0
  48. package/columnMenu/GridColumnMenuItemGroup.mjs +30 -0
  49. package/columnMenu/GridColumnMenuSort.js +8 -0
  50. package/columnMenu/GridColumnMenuSort.mjs +75 -0
  51. package/columnMenu/GridColumnMenuWrapper.js +8 -0
  52. package/columnMenu/GridColumnMenuWrapper.mjs +91 -0
  53. package/constants/index.js +8 -0
  54. package/constants/index.mjs +15 -0
  55. package/dist/cdn/js/kendo-react-grid.js +8 -5
  56. package/drag/ColumnDraggable.js +8 -0
  57. package/drag/ColumnDraggable.mjs +43 -0
  58. package/drag/ColumnResize.js +8 -0
  59. package/drag/ColumnResize.mjs +128 -0
  60. package/drag/CommonDragLogic.js +8 -0
  61. package/drag/CommonDragLogic.mjs +104 -0
  62. package/drag/GroupingIndicator.js +8 -0
  63. package/drag/GroupingIndicator.mjs +91 -0
  64. package/filterCommon.js +8 -0
  65. package/filterCommon.mjs +103 -0
  66. package/footer/Footer.js +8 -0
  67. package/footer/Footer.mjs +76 -0
  68. package/footer/FooterRow.js +8 -0
  69. package/footer/FooterRow.mjs +46 -0
  70. package/header/FilterRow.js +8 -0
  71. package/header/FilterRow.mjs +96 -0
  72. package/header/GridHeaderCell.js +8 -0
  73. package/header/GridHeaderCell.mjs +38 -0
  74. package/header/GridHeaderSelectionCell.js +8 -0
  75. package/header/GridHeaderSelectionCell.mjs +44 -0
  76. package/header/GroupPanel.js +8 -0
  77. package/header/GroupPanel.mjs +60 -0
  78. package/header/Header.js +8 -0
  79. package/header/Header.mjs +107 -0
  80. package/header/HeaderRow.js +8 -0
  81. package/header/HeaderRow.mjs +155 -0
  82. package/index.d.mts +2777 -5
  83. package/index.d.ts +2777 -57
  84. package/index.js +8 -5
  85. package/index.mjs +89 -3845
  86. package/interfaces/GridSortSettings.js +8 -0
  87. package/interfaces/GridSortSettings.mjs +12 -0
  88. package/messages/index.js +8 -0
  89. package/messages/index.mjs +107 -0
  90. package/package-metadata.js +8 -0
  91. package/package-metadata.mjs +19 -0
  92. package/package.json +10 -10
  93. package/paging/GridPagerSettings.js +8 -0
  94. package/paging/GridPagerSettings.mjs +28 -0
  95. package/rows/GridDetailRow.js +8 -0
  96. package/rows/GridDetailRow.mjs +20 -0
  97. package/rows/GridRow.js +8 -0
  98. package/rows/GridRow.mjs +51 -0
  99. package/utils/index.js +8 -0
  100. package/utils/index.mjs +180 -0
  101. package/Grid.d.ts +0 -267
  102. package/GridColumn.d.ts +0 -28
  103. package/GridNoRecords.d.ts +0 -40
  104. package/GridToolbar.d.ts +0 -54
  105. package/ScrollMode.d.ts +0 -5
  106. package/StatusBar.d.ts +0 -51
  107. package/VirtualScroll.d.ts +0 -51
  108. package/VirtualScrollFixed.d.ts +0 -53
  109. package/cells/GridCell.d.ts +0 -6
  110. package/cells/GridDetailCell.d.ts +0 -18
  111. package/cells/GridDetailHierarchyCell.d.ts +0 -10
  112. package/cells/GridEditCell.d.ts +0 -9
  113. package/cells/GridFilterCell.d.ts +0 -20
  114. package/cells/GridGroupCell.d.ts +0 -9
  115. package/cells/GridHierarchyCell.d.ts +0 -9
  116. package/cells/GridSelectionCell.d.ts +0 -9
  117. package/columnMenu/GridColumnMenuCheckboxFilter.d.ts +0 -122
  118. package/columnMenu/GridColumnMenuColumnsList.d.ts +0 -31
  119. package/columnMenu/GridColumnMenuFilter.d.ts +0 -165
  120. package/columnMenu/GridColumnMenuFilterCell.d.ts +0 -37
  121. package/columnMenu/GridColumnMenuFilterUI.d.ts +0 -12
  122. package/columnMenu/GridColumnMenuGroup.d.ts +0 -77
  123. package/columnMenu/GridColumnMenuItem.d.ts +0 -40
  124. package/columnMenu/GridColumnMenuItemContent.d.ts +0 -24
  125. package/columnMenu/GridColumnMenuItemGroup.d.ts +0 -20
  126. package/columnMenu/GridColumnMenuSort.d.ts +0 -89
  127. package/columnMenu/GridColumnMenuWrapper.d.ts +0 -49
  128. package/constants/index.d.ts +0 -10
  129. package/drag/ColumnDraggable.d.ts +0 -38
  130. package/drag/ColumnResize.d.ts +0 -37
  131. package/drag/CommonDragLogic.d.ts +0 -44
  132. package/drag/GroupingIndicator.d.ts +0 -41
  133. package/filterCommon.d.ts +0 -73
  134. package/footer/Footer.d.ts +0 -38
  135. package/footer/FooterRow.d.ts +0 -25
  136. package/header/FilterRow.d.ts +0 -38
  137. package/header/GridHeaderCell.d.ts +0 -56
  138. package/header/GridHeaderSelectionCell.d.ts +0 -10
  139. package/header/GroupPanel.d.ts +0 -26
  140. package/header/Header.d.ts +0 -46
  141. package/header/HeaderRow.d.ts +0 -51
  142. package/interfaces/GridCellProps.d.ts +0 -73
  143. package/interfaces/GridCellsSettings.d.ts +0 -115
  144. package/interfaces/GridColumnMenuBaseProps.d.ts +0 -18
  145. package/interfaces/GridColumnMenuColumnProps.d.ts +0 -29
  146. package/interfaces/GridColumnMenuFilterBaseProps.d.ts +0 -28
  147. package/interfaces/GridColumnMenuFilterUIProps.d.ts +0 -35
  148. package/interfaces/GridColumnMenuGroupBaseProps.d.ts +0 -23
  149. package/interfaces/GridColumnMenuProps.d.ts +0 -12
  150. package/interfaces/GridColumnMenuSortBaseProps.d.ts +0 -24
  151. package/interfaces/GridColumnProps.d.ts +0 -92
  152. package/interfaces/GridDetailRowProps.d.ts +0 -17
  153. package/interfaces/GridFilterCellProps.d.ts +0 -68
  154. package/interfaces/GridFilterOperator.d.ts +0 -10
  155. package/interfaces/GridFilterOperators.d.ts +0 -53
  156. package/interfaces/GridFooterCellProps.d.ts +0 -26
  157. package/interfaces/GridGroupableSettings.d.ts +0 -17
  158. package/interfaces/GridHeaderCellProps.d.ts +0 -24
  159. package/interfaces/GridNoRecordsProps.d.ts +0 -13
  160. package/interfaces/GridProps.d.ts +0 -333
  161. package/interfaces/GridRowProps.d.ts +0 -67
  162. package/interfaces/GridRowType.d.ts +0 -13
  163. package/interfaces/GridSelectableSettings.d.ts +0 -22
  164. package/interfaces/GridSortSettings.d.ts +0 -17
  165. package/interfaces/GridToolbarProps.d.ts +0 -37
  166. package/interfaces/VirtualScrollInterface.d.ts +0 -31
  167. package/interfaces/events.d.ts +0 -232
  168. package/messages/index.d.ts +0 -199
  169. package/package-metadata.d.ts +0 -9
  170. package/paging/GridPagerSettings.d.ts +0 -71
  171. package/paging/Page.d.ts +0 -17
  172. package/rows/GridDetailRow.d.ts +0 -55
  173. package/rows/GridRow.d.ts +0 -15
  174. package/utils/index.d.ts +0 -73
@@ -0,0 +1,50 @@
1
+ /**
2
+ * @license
3
+ *-------------------------------------------------------------------------------------------
4
+ * Copyright © 2024 Progress Software Corporation. All rights reserved.
5
+ * Licensed under commercial license. See LICENSE.md in the package root for more information
6
+ *-------------------------------------------------------------------------------------------
7
+ */
8
+ "use client";
9
+ import * as t from "react";
10
+ import { provideLocalizationService as u, registerForIntl as l, registerForLocalization as c } from "@progress/kendo-react-intl";
11
+ import { GridColumnMenuItemGroup as m } from "./GridColumnMenuItemGroup.mjs";
12
+ import { GridColumnMenuItem as a } from "./GridColumnMenuItem.mjs";
13
+ import { messages as f, groupColumn as g, ungroupColumn as d } from "../messages/index.mjs";
14
+ import { groupIcon as C, ungroupIcon as h } from "@progress/kendo-svg-icons";
15
+ class s extends t.Component {
16
+ constructor() {
17
+ super(...arguments), this.onGroupClick = (n) => {
18
+ if (n.preventDefault(), this.props.onGroupChange) {
19
+ const { column: o } = this.props;
20
+ if (!o.field)
21
+ return;
22
+ const e = (this.props.group || []).slice(), r = e.findIndex((i) => i.field === o.field);
23
+ r > -1 ? e.splice(r, 1) : e.push({
24
+ field: o.field
25
+ }), this.props.onGroupChange(e, n);
26
+ }
27
+ this.props.onCloseMenu && this.props.onCloseMenu();
28
+ };
29
+ }
30
+ /**
31
+ * @hidden
32
+ */
33
+ render() {
34
+ const { group: n, column: o } = this.props, e = u(this), r = !!(n && o.field && n.find((p) => p.field === o.field)), i = r ? d : g;
35
+ return /* @__PURE__ */ t.createElement(m, null, /* @__PURE__ */ t.createElement(
36
+ a,
37
+ {
38
+ title: e.toLanguageString(i, f[i]),
39
+ iconClass: r ? "k-i-ungroup" : "k-i-group",
40
+ svgIcon: r ? h : C,
41
+ onClick: this.onGroupClick
42
+ }
43
+ ));
44
+ }
45
+ }
46
+ l(s);
47
+ c(s);
48
+ export {
49
+ s as GridColumnMenuGroup
50
+ };
@@ -0,0 +1,8 @@
1
+ /**
2
+ * @license
3
+ *-------------------------------------------------------------------------------------------
4
+ * Copyright © 2024 Progress Software Corporation. All rights reserved.
5
+ * Licensed under commercial license. See LICENSE.md in the package root for more information
6
+ *-------------------------------------------------------------------------------------------
7
+ */
8
+ "use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const l=require("react"),r=require("@progress/kendo-react-common");function a(t){const n=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(t){for(const e in t)if(e!=="default"){const o=Object.getOwnPropertyDescriptor(t,e);Object.defineProperty(n,e,o.get?o:{enumerable:!0,get:()=>t[e]})}}return n.default=t,Object.freeze(n)}const c=a(l);class i extends c.Component{render(){const{title:n,iconClass:e,svgIcon:o,selected:s}=this.props;return c.createElement("div",{onClick:this.props.onClick,className:`k-columnmenu-item ${s?"k-selected":""}`},(e||o)&&c.createElement(r.IconWrap,{name:e&&r.toIconName(e),icon:o}),n)}}exports.GridColumnMenuItem=i;
@@ -0,0 +1,22 @@
1
+ /**
2
+ * @license
3
+ *-------------------------------------------------------------------------------------------
4
+ * Copyright © 2024 Progress Software Corporation. All rights reserved.
5
+ * Licensed under commercial license. See LICENSE.md in the package root for more information
6
+ *-------------------------------------------------------------------------------------------
7
+ */
8
+ "use client";
9
+ import * as t from "react";
10
+ import { IconWrap as s, toIconName as m } from "@progress/kendo-react-common";
11
+ class l extends t.Component {
12
+ /**
13
+ * @hidden
14
+ */
15
+ render() {
16
+ const { title: o, iconClass: e, svgIcon: n, selected: c } = this.props;
17
+ return /* @__PURE__ */ t.createElement("div", { onClick: this.props.onClick, className: `k-columnmenu-item ${c ? "k-selected" : ""}` }, (e || n) && /* @__PURE__ */ t.createElement(s, { name: e && m(e), icon: n }), o);
18
+ }
19
+ }
20
+ export {
21
+ l as GridColumnMenuItem
22
+ };
@@ -0,0 +1,8 @@
1
+ /**
2
+ * @license
3
+ *-------------------------------------------------------------------------------------------
4
+ * Copyright © 2024 Progress Software Corporation. All rights reserved.
5
+ * Licensed under commercial license. See LICENSE.md in the package root for more information
6
+ *-------------------------------------------------------------------------------------------
7
+ */
8
+ "use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("react"),c=require("@progress/kendo-react-animation"),i=require("@progress/kendo-react-common");function l(e){const n=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const t in e)if(t!=="default"){const r=Object.getOwnPropertyDescriptor(e,t);Object.defineProperty(n,t,r.get?r:{enumerable:!0,get:()=>e[t]})}}return n.default=e,Object.freeze(n)}const o=l(s);class a extends o.Component{render(){return o.createElement("div",{id:this.props.id,className:i.classNames("k-columnmenu-item-content",this.props.className),style:this.props.style},o.createElement(c.Reveal,{style:{position:"relative",display:"block"}},this.props.show?this.props.children:null))}}exports.GridColumnMenuItemContent=a;
@@ -0,0 +1,30 @@
1
+ /**
2
+ * @license
3
+ *-------------------------------------------------------------------------------------------
4
+ * Copyright © 2024 Progress Software Corporation. All rights reserved.
5
+ * Licensed under commercial license. See LICENSE.md in the package root for more information
6
+ *-------------------------------------------------------------------------------------------
7
+ */
8
+ "use client";
9
+ import * as e from "react";
10
+ import { Reveal as t } from "@progress/kendo-react-animation";
11
+ import { classNames as s } from "@progress/kendo-react-common";
12
+ class l extends e.Component {
13
+ /**
14
+ * @hidden
15
+ */
16
+ render() {
17
+ return /* @__PURE__ */ e.createElement(
18
+ "div",
19
+ {
20
+ id: this.props.id,
21
+ className: s("k-columnmenu-item-content", this.props.className),
22
+ style: this.props.style
23
+ },
24
+ /* @__PURE__ */ e.createElement(t, { style: { position: "relative", display: "block" } }, this.props.show ? this.props.children : null)
25
+ );
26
+ }
27
+ }
28
+ export {
29
+ l as GridColumnMenuItemContent
30
+ };
@@ -0,0 +1,8 @@
1
+ /**
2
+ * @license
3
+ *-------------------------------------------------------------------------------------------
4
+ * Copyright © 2024 Progress Software Corporation. All rights reserved.
5
+ * Licensed under commercial license. See LICENSE.md in the package root for more information
6
+ *-------------------------------------------------------------------------------------------
7
+ */
8
+ "use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("@progress/kendo-react-common"),c=require("react");function a(e){const t=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const r in e)if(r!=="default"){const n=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,n.get?n:{enumerable:!0,get:()=>e[r]})}}return t.default=e,Object.freeze(t)}const o=a(c);class i extends o.Component{render(){const{children:t}=this.props;return o.createElement("div",{id:this.props.id,className:s.classNames("k-columnmenu-item-wrapper",this.props.className),style:this.props.style},t)}}exports.GridColumnMenuItemGroup=i;
@@ -0,0 +1,30 @@
1
+ /**
2
+ * @license
3
+ *-------------------------------------------------------------------------------------------
4
+ * Copyright © 2024 Progress Software Corporation. All rights reserved.
5
+ * Licensed under commercial license. See LICENSE.md in the package root for more information
6
+ *-------------------------------------------------------------------------------------------
7
+ */
8
+ "use client";
9
+ import { classNames as r } from "@progress/kendo-react-common";
10
+ import * as e from "react";
11
+ class p extends e.Component {
12
+ /**
13
+ * @hidden
14
+ */
15
+ render() {
16
+ const { children: s } = this.props;
17
+ return /* @__PURE__ */ e.createElement(
18
+ "div",
19
+ {
20
+ id: this.props.id,
21
+ className: r("k-columnmenu-item-wrapper", this.props.className),
22
+ style: this.props.style
23
+ },
24
+ s
25
+ );
26
+ }
27
+ }
28
+ export {
29
+ p as GridColumnMenuItemGroup
30
+ };
@@ -0,0 +1,8 @@
1
+ /**
2
+ * @license
3
+ *-------------------------------------------------------------------------------------------
4
+ * Copyright © 2024 Progress Software Corporation. All rights reserved.
5
+ * Licensed under commercial license. See LICENSE.md in the package root for more information
6
+ *-------------------------------------------------------------------------------------------
7
+ */
8
+ "use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const v=require("react"),g=require("./GridColumnMenuItem.js"),q=require("./GridColumnMenuItemGroup.js"),A=require("../interfaces/GridSortSettings.js"),a=require("@progress/kendo-react-intl"),o=require("../messages/index.js"),m=require("@progress/kendo-svg-icons");function G(t){const e=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(t){for(const s in t)if(s!=="default"){const n=Object.getOwnPropertyDescriptor(t,s);Object.defineProperty(e,s,n.get?n:{enumerable:!0,get:()=>t[s]})}}return e.default=t,Object.freeze(e)}const i=G(v),I="asc",D="desc",O={true:{asc:{asc:"",desc:"desc"},desc:{asc:"asc",desc:""},"":{asc:"asc",desc:"desc"}},false:{asc:{asc:"asc",desc:"desc"},desc:{asc:"asc",desc:"desc"},"":{asc:"asc",desc:"desc"}}},S=(t,e)=>e?e.findIndex(s=>s.field===t):-1,h=(t,e)=>!!(e&&t>-1&&e[t].dir===I),C=(t,e)=>!!(e&&t>-1&&e[t].dir===D),d=class d extends i.Component{constructor(){super(...arguments),this.onAscClick=e=>{this.onSort(e,I),this.props.onCloseMenu&&this.props.onCloseMenu()},this.onDescClick=e=>{this.onSort(e,D),this.props.onCloseMenu&&this.props.onCloseMenu()},this.onSort=(e,s)=>{if(e.preventDefault(),!this.props.onSortChange)return;const{column:n,sortable:r,sort:k}=this.props,{allowUnsort:M,mode:b}=A.normalize(r||!1,!1),u=(k||[]).filter(l=>l.field===n.field)[0],p=O[M][u&&u.dir||""][s],f=b==="single"?[]:(this.props.sort||[]).filter(l=>l.field!==n.field);p!==""&&n.field&&f.push({field:n.field,dir:p}),this.props.onSortChange(f,e)}}render(){const{sort:e,column:s}=this.props,n=S(s.field,e),r=a.provideLocalizationService(this);return i.createElement(q.GridColumnMenuItemGroup,null,i.createElement(g.GridColumnMenuItem,{title:r.toLanguageString(o.sortAscending,o.messages[o.sortAscending]),iconClass:"k-i-sort-asc-sm",svgIcon:m.sortAscSmallIcon,selected:h(n,e),onClick:this.onAscClick}),i.createElement(g.GridColumnMenuItem,{title:r.toLanguageString(o.sortDescending,o.messages[o.sortDescending]),iconClass:"k-i-sort-desc-sm",svgIcon:m.sortDescSmallIcon,selected:C(n,e),onClick:this.onDescClick}))}};d.active=(e,s)=>{const n=S(e,s);return C(n,s)||h(n,s)};let c=d;a.registerForIntl(c);a.registerForLocalization(c);exports.GridColumnMenuSort=c;
@@ -0,0 +1,75 @@
1
+ /**
2
+ * @license
3
+ *-------------------------------------------------------------------------------------------
4
+ * Copyright © 2024 Progress Software Corporation. All rights reserved.
5
+ * Licensed under commercial license. See LICENSE.md in the package root for more information
6
+ *-------------------------------------------------------------------------------------------
7
+ */
8
+ "use client";
9
+ import * as r from "react";
10
+ import { GridColumnMenuItem as m } from "./GridColumnMenuItem.mjs";
11
+ import { GridColumnMenuItemGroup as M } from "./GridColumnMenuItemGroup.mjs";
12
+ import { normalize as x } from "../interfaces/GridSortSettings.mjs";
13
+ import { provideLocalizationService as z, registerForIntl as E, registerForLocalization as L } from "@progress/kendo-react-intl";
14
+ import { sortAscending as f, messages as u, sortDescending as h } from "../messages/index.mjs";
15
+ import { sortAscSmallIcon as R, sortDescSmallIcon as w } from "@progress/kendo-svg-icons";
16
+ const D = "asc", I = "desc", F = {
17
+ true: {
18
+ asc: { asc: "", desc: "desc" },
19
+ desc: { asc: "asc", desc: "" },
20
+ "": { asc: "asc", desc: "desc" }
21
+ },
22
+ false: {
23
+ asc: { asc: "asc", desc: "desc" },
24
+ desc: { asc: "asc", desc: "desc" },
25
+ "": { asc: "asc", desc: "desc" }
26
+ }
27
+ }, g = (o, s) => s ? s.findIndex((t) => t.field === o) : -1, C = (o, s) => !!(s && o > -1 && s[o].dir === D), S = (o, s) => !!(s && o > -1 && s[o].dir === I), l = class l extends r.Component {
28
+ constructor() {
29
+ super(...arguments), this.onAscClick = (s) => {
30
+ this.onSort(s, D), this.props.onCloseMenu && this.props.onCloseMenu();
31
+ }, this.onDescClick = (s) => {
32
+ this.onSort(s, I), this.props.onCloseMenu && this.props.onCloseMenu();
33
+ }, this.onSort = (s, t) => {
34
+ if (s.preventDefault(), !this.props.onSortChange)
35
+ return;
36
+ const { column: e, sortable: c, sort: k } = this.props, { allowUnsort: v, mode: A } = x(c || !1, !1), a = (k || []).filter((i) => i.field === e.field)[0], d = F[v][a && a.dir || ""][t], p = A === "single" ? [] : (this.props.sort || []).filter((i) => i.field !== e.field);
37
+ d !== "" && e.field && p.push({ field: e.field, dir: d }), this.props.onSortChange(p, s);
38
+ };
39
+ }
40
+ /**
41
+ * @hidden
42
+ */
43
+ render() {
44
+ const { sort: s, column: t } = this.props, e = g(t.field, s), c = z(this);
45
+ return /* @__PURE__ */ r.createElement(M, null, /* @__PURE__ */ r.createElement(
46
+ m,
47
+ {
48
+ title: c.toLanguageString(f, u[f]),
49
+ iconClass: "k-i-sort-asc-sm",
50
+ svgIcon: R,
51
+ selected: C(e, s),
52
+ onClick: this.onAscClick
53
+ }
54
+ ), /* @__PURE__ */ r.createElement(
55
+ m,
56
+ {
57
+ title: c.toLanguageString(h, u[h]),
58
+ iconClass: "k-i-sort-desc-sm",
59
+ svgIcon: w,
60
+ selected: S(e, s),
61
+ onClick: this.onDescClick
62
+ }
63
+ ));
64
+ }
65
+ };
66
+ l.active = (s, t) => {
67
+ const e = g(s, t);
68
+ return S(e, t) || C(e, t);
69
+ };
70
+ let n = l;
71
+ E(n);
72
+ L(n);
73
+ export {
74
+ n as GridColumnMenuSort
75
+ };
@@ -0,0 +1,8 @@
1
+ /**
2
+ * @license
3
+ *-------------------------------------------------------------------------------------------
4
+ * Copyright © 2024 Progress Software Corporation. All rights reserved.
5
+ * Licensed under commercial license. See LICENSE.md in the package root for more information
6
+ *-------------------------------------------------------------------------------------------
7
+ */
8
+ "use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const h=require("react"),m=require("@progress/kendo-react-popup"),u=require("@progress/kendo-react-common"),p=require("@progress/kendo-svg-icons"),c=require("../messages/index.js"),d=require("@progress/kendo-react-intl");function f(s){const e=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(s){for(const t in s)if(t!=="default"){const o=Object.getOwnPropertyDescriptor(s,t);Object.defineProperty(e,t,o.get?o:{enumerable:!0,get:()=>s[t]})}}return e.default=s,Object.freeze(e)}const n=f(h);class g extends n.Component{constructor(){super(...arguments),this.state={show:!1},this._anchor=null,this._content=null,this.blurTimeout=void 0,this.willBlur=!1,this.blur=()=>{if(this.willBlur){this.willBlur=!1;return}clearTimeout(this.blurTimeout),this.blurTimeout=window.setTimeout(()=>{this.closeMenu()})},this.focus=()=>{clearTimeout(this.blurTimeout)},this.anchorClick=e=>{e.preventDefault(),this.state.show&&this.props.onCloseMenu&&this.props.onCloseMenu(),this.setState({show:!this.state.show},()=>this.state.show&&this._content&&this._content.focus())},this.closeMenu=()=>{this.props.onCloseMenu&&this.props.onCloseMenu(),this.setState({show:!1})},this.onAnchorMouseDown=e=>{this.willBlur=this.state.show&&e.currentTarget===this._anchor},this.onAnchorKeyDown=e=>{var t;if(e.keyCode===u.Keys.tab){const o=e.target,r=o&&((t=o.closest(".k-grid"))==null?void 0:t.getElementsByClassName("k-grid-content")[0]);r&&r.scrollWidth>r.clientWidth&&o.scrollIntoView({inline:"center"})}}}render(){const{columnMenu:e,...t}=this.props,{column:o}=this.props,r=d.provideLocalizationService(this),i=o.title||o.field,a=i?`${i} `:"";return n.createElement(n.Fragment,null,n.createElement("a",{className:"k-grid-header-menu k-grid-column-menu",ref:l=>this._anchor=l,onClick:this.anchorClick,onMouseDown:this.onAnchorMouseDown,onKeyDown:this.onAnchorKeyDown,href:"#","aria-label":`${a}${r.toLanguageString(c.columnMenu,c.messages[c.columnMenu])}`},n.createElement(u.IconWrap,{name:"filter",icon:p.filterIcon})),n.createElement(m.Popup,{anchor:this._anchor,show:this.state.show,popupClass:"k-column-menu k-column-menu-popup k-grid-columnmenu-popup"},n.createElement("div",{ref:l=>this._content=l,tabIndex:0,onBlur:this.blur,onFocus:this.focus,style:{outline:"none"}},e&&n.createElement(e,{...t,onCloseMenu:this.closeMenu}))))}}exports.GridColumnMenuWrapper=g;
@@ -0,0 +1,91 @@
1
+ /**
2
+ * @license
3
+ *-------------------------------------------------------------------------------------------
4
+ * Copyright © 2024 Progress Software Corporation. All rights reserved.
5
+ * Licensed under commercial license. See LICENSE.md in the package root for more information
6
+ *-------------------------------------------------------------------------------------------
7
+ */
8
+ "use client";
9
+ import * as t from "react";
10
+ import { Popup as h } from "@progress/kendo-react-popup";
11
+ import { Keys as u, IconWrap as a } from "@progress/kendo-react-common";
12
+ import { filterIcon as m } from "@progress/kendo-svg-icons";
13
+ import { columnMenu as l, messages as p } from "../messages/index.mjs";
14
+ import { provideLocalizationService as f } from "@progress/kendo-react-intl";
15
+ class k extends t.Component {
16
+ constructor() {
17
+ super(...arguments), this.state = {
18
+ show: !1
19
+ }, this._anchor = null, this._content = null, this.blurTimeout = void 0, this.willBlur = !1, this.blur = () => {
20
+ if (this.willBlur) {
21
+ this.willBlur = !1;
22
+ return;
23
+ }
24
+ clearTimeout(this.blurTimeout), this.blurTimeout = window.setTimeout(() => {
25
+ this.closeMenu();
26
+ });
27
+ }, this.focus = () => {
28
+ clearTimeout(this.blurTimeout);
29
+ }, this.anchorClick = (e) => {
30
+ e.preventDefault(), this.state.show && this.props.onCloseMenu && this.props.onCloseMenu(), this.setState(
31
+ {
32
+ show: !this.state.show
33
+ },
34
+ () => this.state.show && this._content && this._content.focus()
35
+ );
36
+ }, this.closeMenu = () => {
37
+ this.props.onCloseMenu && this.props.onCloseMenu(), this.setState({ show: !1 });
38
+ }, this.onAnchorMouseDown = (e) => {
39
+ this.willBlur = this.state.show && e.currentTarget === this._anchor;
40
+ }, this.onAnchorKeyDown = (e) => {
41
+ var n;
42
+ if (e.keyCode === u.tab) {
43
+ const o = e.target, s = o && ((n = o.closest(".k-grid")) == null ? void 0 : n.getElementsByClassName("k-grid-content")[0]);
44
+ s && s.scrollWidth > s.clientWidth && o.scrollIntoView({ inline: "center" });
45
+ }
46
+ };
47
+ }
48
+ render() {
49
+ const { columnMenu: e, ...n } = this.props, { column: o } = this.props, s = f(this), i = o.title || o.field, c = i ? `${i} ` : "";
50
+ return /* @__PURE__ */ t.createElement(t.Fragment, null, /* @__PURE__ */ t.createElement(
51
+ "a",
52
+ {
53
+ className: "k-grid-header-menu k-grid-column-menu",
54
+ ref: (r) => this._anchor = r,
55
+ onClick: this.anchorClick,
56
+ onMouseDown: this.onAnchorMouseDown,
57
+ onKeyDown: this.onAnchorKeyDown,
58
+ href: "#",
59
+ "aria-label": `${c}${s.toLanguageString(l, p[l])}`
60
+ },
61
+ /* @__PURE__ */ t.createElement(a, { name: "filter", icon: m })
62
+ ), /* @__PURE__ */ t.createElement(
63
+ h,
64
+ {
65
+ anchor: this._anchor,
66
+ show: this.state.show,
67
+ popupClass: "k-column-menu k-column-menu-popup k-grid-columnmenu-popup"
68
+ },
69
+ /* @__PURE__ */ t.createElement(
70
+ "div",
71
+ {
72
+ ref: (r) => this._content = r,
73
+ tabIndex: 0,
74
+ onBlur: this.blur,
75
+ onFocus: this.focus,
76
+ style: { outline: "none" }
77
+ },
78
+ e && /* @__PURE__ */ t.createElement(
79
+ e,
80
+ {
81
+ ...n,
82
+ onCloseMenu: this.closeMenu
83
+ }
84
+ )
85
+ )
86
+ ));
87
+ }
88
+ }
89
+ export {
90
+ k as GridColumnMenuWrapper
91
+ };
@@ -0,0 +1,8 @@
1
+ /**
2
+ * @license
3
+ *-------------------------------------------------------------------------------------------
4
+ * Copyright © 2024 Progress Software Corporation. All rights reserved.
5
+ * Licensed under commercial license. See LICENSE.md in the package root for more information
6
+ *-------------------------------------------------------------------------------------------
7
+ */
8
+ "use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const E=require("@progress/kendo-react-data-tools"),T=E.TABLE_ROW_INDEX_ATTRIBUTE,_=E.TABLE_COL_INDEX_ATTRIBUTE,I=E.TABLE_PREVENT_SELECTION_ELEMENT;exports.GRID_COL_INDEX_ATTRIBUTE=_;exports.GRID_PREVENT_SELECTION_ELEMENT=I;exports.GRID_ROW_INDEX_ATTRIBUTE=T;
@@ -0,0 +1,15 @@
1
+ /**
2
+ * @license
3
+ *-------------------------------------------------------------------------------------------
4
+ * Copyright © 2024 Progress Software Corporation. All rights reserved.
5
+ * Licensed under commercial license. See LICENSE.md in the package root for more information
6
+ *-------------------------------------------------------------------------------------------
7
+ */
8
+ "use client";
9
+ import { TABLE_ROW_INDEX_ATTRIBUTE as E, TABLE_COL_INDEX_ATTRIBUTE as T, TABLE_PREVENT_SELECTION_ELEMENT as _ } from "@progress/kendo-react-data-tools";
10
+ const R = E, N = T, L = _;
11
+ export {
12
+ N as GRID_COL_INDEX_ATTRIBUTE,
13
+ L as GRID_PREVENT_SELECTION_ELEMENT,
14
+ R as GRID_ROW_INDEX_ATTRIBUTE
15
+ };