@progress/kendo-react-grid 7.4.0-develop.9 → 7.4.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.
- package/Grid.js +1 -1
- package/Grid.mjs +186 -182
- package/columnMenu/GridColumnMenuFilter.js +1 -1
- package/columnMenu/GridColumnMenuFilter.mjs +34 -35
- package/columnMenu/GridColumnMenuItem.js +1 -1
- package/columnMenu/GridColumnMenuItem.mjs +7 -12
- package/columnMenu/GridColumnMenuWrapper.js +1 -1
- package/columnMenu/GridColumnMenuWrapper.mjs +98 -75
- package/dist/cdn/js/kendo-react-grid.js +1 -1
- package/header/HeaderRow.js +1 -1
- package/header/HeaderRow.mjs +140 -139
- package/index.d.mts +4 -38
- package/index.d.ts +4 -38
- package/package-metadata.mjs +1 -1
- package/package.json +10 -10
|
@@ -5,4 +5,4 @@
|
|
|
5
5
|
* Licensed under commercial license. See LICENSE.md in the package root for more information
|
|
6
6
|
*-------------------------------------------------------------------------------------------
|
|
7
7
|
*/
|
|
8
|
-
"use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const
|
|
8
|
+
"use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const B=require("react"),y=require("@progress/kendo-data-query"),L=require("./GridColumnMenuItem.js"),P=require("./GridColumnMenuItemGroup.js"),U=require("./GridColumnMenuItemContent.js"),b=require("@progress/kendo-react-intl"),a=require("../filterCommon.js"),f=require("../messages/index.js"),T=require("./GridColumnMenuFilterUI.js"),E=require("@progress/kendo-react-buttons"),j=require("@progress/kendo-svg-icons");function R(c){const i=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(c){for(const l in c)if(l!=="default"){const e=Object.getOwnPropertyDescriptor(c,l);Object.defineProperty(i,l,e.get?e:{enumerable:!0,get:()=>c[l]})}}return i.default=c,Object.freeze(i)}const u=R(B),g=c=>c||{filters:[],logic:"and"},h=(c,i)=>g(i).filters.filter(t=>y.isCompositeFilterDescriptor(t)?t.filters&&t.filters.length&&t.filters.length<=2&&!t.filters.find(r=>y.isCompositeFilterDescriptor(r)||r.field!==c):!1)[0]||null,F=class F extends u.Component{constructor(i){super(i),this.removeGroup=(e,t)=>{const r=[...t.filters],n=r.findIndex(o=>o===e);return n>-1&&r.splice(n,1),{...t,filters:r}},this.insertGroup=(e,t)=>({...t,filters:[e,...t.filters]}),this.isControlled=()=>this.props.expanded!==void 0,this.onFilterExpand=()=>{const e=this.isControlled(),t=!(e?this.props.expanded:this.state.expanded);this.props.onExpandChange&&this.props.onExpandChange(t),e||this.setState({expanded:t})},this.firstFilterChange=e=>{this.filterChange(0,e)},this.secondFilterChange=e=>{this.filterChange(1,e)},this.filterChange=(e,t)=>{const r=this.state.filterGroup.filters.map((n,o)=>o===e?{...n,value:t.value,operator:t.operator}:n);this.setState({filterGroup:{...this.state.filterGroup,filters:r}})},this.logicChange=e=>{this.setState({filterGroup:{...this.state.filterGroup,logic:e.target.value.operator}})},this.clear=e=>{if(e.preventDefault(),!this.props.onFilterChange)return;const t=this.props.column.field,r=g(this.props.filter),n=h(t,this.props.filter),o=r.filters.filter(s=>s!==n);o.length?this.props.onFilterChange({...r,filters:o},e):this.props.onFilterChange(null,e),this.props.onCloseMenu&&this.props.onCloseMenu()},this.currentFilterGroup=()=>({...this.state.filterGroup,filters:this.state.filterGroup.filters.filter(e=>e.value!==void 0&&e.value!==null&&e.value!==""||e.value===null&&e.operator)}),this.submit=e=>{if(e.preventDefault(),!this.props.onFilterChange)return;const t=this.props.column.field,r=g(this.props.filter),n=h(t,this.props.filter),o=this.currentFilterGroup();let s=null;if(n&&o.filters.length>0){const p=r.filters.map(d=>d===n?o:d);s={...r,filters:p}}else if(o.filters.length===0){const p=r.filters.filter(d=>d!==n);p.length&&(s={...r,filters:p})}else s={...r,filters:[...r.filters,o]};this.props.onFilterChange(s,e),this.props.onCloseMenu&&this.props.onCloseMenu()};let l;if(i.column&&i.column.field){const e=a.getFilterType(i.column.filter),t=a.getDefaultOperator(i.filterOperators,e);l=h(i.column.field,i.filter),l=l?{...l,filters:l.filters.map(r=>({...r}))}:{logic:"and",filters:[{field:i.column.field,operator:t,value:a.IsUnaryFilter(t)?null:void 0},{field:i.column.field,operator:t,value:a.IsUnaryFilter(t)?null:void 0}]},l.filters.filter(r=>r.field===i.column.field).length===1&&l.filters.splice(1,0,{field:i.column.field,operator:t})}this.state={expanded:i.expanded||!1,filterGroup:l}}render(){const{column:i,filterUI:l,hideSecondFilter:e,filterOperators:t}=this.props;if(!i||!i.field)return u.createElement("div",null);const r=a.getFilterType(i.filter),n=e!==void 0?e:a.defaultHideSecondFilter[r],o=b.provideLocalizationService(this),s=this.state.filterGroup.filters,p=a.operatorMap(t[r],o),d=a.operatorMap(a.booleanFilterValues,o),M={field:i.field,value:s[0].value,operator:s[0].operator,operators:p,booleanValues:d,onChange:this.firstFilterChange,filterType:r},O={field:i.field,value:s[1].value,operator:s[1].operator,operators:p,booleanValues:d,onChange:this.secondFilterChange,filterType:r},v=this.state.filterGroup.logic,G=a.operatorMap(a.filterLogicList,o),C={value:G.find(q=>q.operator===(v===null?"":v)),onChange:this.logicChange,data:G},I=l,S={firstFilterProps:M,secondFilterProps:O,logicData:C.data,logicValue:C.value,onLogicChange:C.onChange,hideSecondFilter:n},D=this.currentFilterGroup().filters.length!==0||a.IsUnaryFilter(s[0].operator)||a.IsUnaryFilter(s[1].operator),k=this.isControlled()?this.props.expanded:this.state.expanded,x=this.props.alwaysExpand;return u.createElement(P.GridColumnMenuItemGroup,null,!x&&u.createElement(L.GridColumnMenuItem,{title:o.toLanguageString(f.filterTitle,f.messages[f.filterTitle]),iconClass:"k-i-filter",svgIcon:j.filterIcon,onClick:this.onFilterExpand}),u.createElement(U.GridColumnMenuItemContent,{show:x||!!k},u.createElement("form",{className:"k-filter-menu",onSubmit:this.submit,onReset:this.clear},u.createElement("div",{className:"k-filter-menu-container"},I?u.createElement(I,{...S}):u.createElement(T.GridColumnMenuFilterUI,{...S}),u.createElement("div",{className:"k-actions k-actions-stretched"},u.createElement(E.Button,{themeColor:"primary",disabled:!D},o.toLanguageString(f.filterSubmitButton,f.messages[f.filterSubmitButton])),u.createElement(E.Button,{type:"reset"},o.toLanguageString(f.filterClearButton,f.messages[f.filterClearButton])))))))}};F.active=(i,l)=>!!h(i,l);let m=F;b.registerForLocalization(m);exports.GridColumnMenuFilter=m;exports.filterGroupByField=h;exports.rootFilterOrDefault=g;
|
|
@@ -7,17 +7,17 @@
|
|
|
7
7
|
*/
|
|
8
8
|
"use client";
|
|
9
9
|
import * as a from "react";
|
|
10
|
-
import { isCompositeFilterDescriptor as
|
|
11
|
-
import { GridColumnMenuItem as
|
|
12
|
-
import { GridColumnMenuItemGroup as
|
|
10
|
+
import { isCompositeFilterDescriptor as y } from "@progress/kendo-data-query";
|
|
11
|
+
import { GridColumnMenuItem as T } from "./GridColumnMenuItem.mjs";
|
|
12
|
+
import { GridColumnMenuItemGroup as w } from "./GridColumnMenuItemGroup.mjs";
|
|
13
13
|
import { GridColumnMenuItemContent as z } from "./GridColumnMenuItemContent.mjs";
|
|
14
14
|
import { provideLocalizationService as N, registerForLocalization as H } from "@progress/kendo-react-intl";
|
|
15
|
-
import { getFilterType as
|
|
16
|
-
import { filterTitle as b, messages as
|
|
17
|
-
import { GridColumnMenuFilterUI as
|
|
15
|
+
import { getFilterType as L, getDefaultOperator as R, IsUnaryFilter as c, operatorMap as m, booleanFilterValues as j, filterLogicList as q, defaultHideSecondFilter as A } from "../filterCommon.mjs";
|
|
16
|
+
import { filterTitle as b, messages as g, filterSubmitButton as D, filterClearButton as M } from "../messages/index.mjs";
|
|
17
|
+
import { GridColumnMenuFilterUI as J } from "./GridColumnMenuFilterUI.mjs";
|
|
18
18
|
import { Button as k } from "@progress/kendo-react-buttons";
|
|
19
|
-
import { filterIcon as
|
|
20
|
-
const
|
|
19
|
+
import { filterIcon as K } from "@progress/kendo-svg-icons";
|
|
20
|
+
const C = (h) => h || { filters: [], logic: "and" }, u = (h, i) => C(i).filters.filter((t) => y(t) ? t.filters && t.filters.length && t.filters.length <= 2 && !t.filters.find((r) => y(r) || r.field !== h) : !1)[0] || null, v = class v extends a.Component {
|
|
21
21
|
constructor(i) {
|
|
22
22
|
super(i), this.removeGroup = (e, t) => {
|
|
23
23
|
const r = [...t.filters], s = r.findIndex((l) => l === e);
|
|
@@ -62,7 +62,7 @@ const F = (h) => h || { filters: [], logic: "and" }, u = (h, i) => F(i).filters.
|
|
|
62
62
|
}, this.clear = (e) => {
|
|
63
63
|
if (e.preventDefault(), !this.props.onFilterChange)
|
|
64
64
|
return;
|
|
65
|
-
const t = this.props.column.field, r =
|
|
65
|
+
const t = this.props.column.field, r = C(this.props.filter), s = u(t, this.props.filter), l = r.filters.filter((n) => n !== s);
|
|
66
66
|
l.length ? this.props.onFilterChange({ ...r, filters: l }, e) : this.props.onFilterChange(null, e), this.props.onCloseMenu && this.props.onCloseMenu();
|
|
67
67
|
}, this.currentFilterGroup = () => ({
|
|
68
68
|
...this.state.filterGroup,
|
|
@@ -70,7 +70,7 @@ const F = (h) => h || { filters: [], logic: "and" }, u = (h, i) => F(i).filters.
|
|
|
70
70
|
}), this.submit = (e) => {
|
|
71
71
|
if (e.preventDefault(), !this.props.onFilterChange)
|
|
72
72
|
return;
|
|
73
|
-
const t = this.props.column.field, r =
|
|
73
|
+
const t = this.props.column.field, r = C(this.props.filter), s = u(t, this.props.filter), l = this.currentFilterGroup();
|
|
74
74
|
let n = null;
|
|
75
75
|
if (s && l.filters.length > 0) {
|
|
76
76
|
const f = r.filters.map((p) => p === s ? l : p);
|
|
@@ -93,7 +93,7 @@ const F = (h) => h || { filters: [], logic: "and" }, u = (h, i) => F(i).filters.
|
|
|
93
93
|
};
|
|
94
94
|
let o;
|
|
95
95
|
if (i.column && i.column.field) {
|
|
96
|
-
const e =
|
|
96
|
+
const e = L(i.column.filter), t = R(i.filterOperators, e);
|
|
97
97
|
o = u(i.column.field, i.filter), o = o ? {
|
|
98
98
|
...o,
|
|
99
99
|
filters: o.filters.map((r) => ({ ...r }))
|
|
@@ -117,7 +117,7 @@ const F = (h) => h || { filters: [], logic: "and" }, u = (h, i) => F(i).filters.
|
|
|
117
117
|
const { column: i, filterUI: o, hideSecondFilter: e, filterOperators: t } = this.props;
|
|
118
118
|
if (!i || !i.field)
|
|
119
119
|
return /* @__PURE__ */ a.createElement("div", null);
|
|
120
|
-
const r =
|
|
120
|
+
const r = L(i.filter), s = e !== void 0 ? e : A[r], l = N(this), n = this.state.filterGroup.filters, f = m(t[r], l), p = m(j, l), O = {
|
|
121
121
|
field: i.field,
|
|
122
122
|
value: n[0].value,
|
|
123
123
|
operator: n[0].operator,
|
|
@@ -125,7 +125,7 @@ const F = (h) => h || { filters: [], logic: "and" }, u = (h, i) => F(i).filters.
|
|
|
125
125
|
booleanValues: p,
|
|
126
126
|
onChange: this.firstFilterChange,
|
|
127
127
|
filterType: r
|
|
128
|
-
},
|
|
128
|
+
}, P = {
|
|
129
129
|
field: i.field,
|
|
130
130
|
value: n[1].value,
|
|
131
131
|
operator: n[1].operator,
|
|
@@ -133,56 +133,55 @@ const F = (h) => h || { filters: [], logic: "and" }, u = (h, i) => F(i).filters.
|
|
|
133
133
|
booleanValues: p,
|
|
134
134
|
onChange: this.secondFilterChange,
|
|
135
135
|
filterType: r
|
|
136
|
-
},
|
|
137
|
-
value:
|
|
136
|
+
}, G = this.state.filterGroup.logic, x = m(q, l), d = {
|
|
137
|
+
value: x.find((B) => B.operator === (G === null ? "" : G)),
|
|
138
138
|
onChange: this.logicChange,
|
|
139
|
-
data:
|
|
140
|
-
},
|
|
139
|
+
data: x
|
|
140
|
+
}, E = o, S = {
|
|
141
141
|
firstFilterProps: O,
|
|
142
|
-
secondFilterProps:
|
|
142
|
+
secondFilterProps: P,
|
|
143
143
|
logicData: d.data,
|
|
144
144
|
logicValue: d.value,
|
|
145
145
|
onLogicChange: d.onChange,
|
|
146
146
|
hideSecondFilter: s
|
|
147
|
-
},
|
|
148
|
-
return /* @__PURE__ */ a.createElement(
|
|
149
|
-
|
|
147
|
+
}, U = this.currentFilterGroup().filters.length !== 0 || c(n[0].operator) || c(n[1].operator), V = this.isControlled() ? this.props.expanded : this.state.expanded, I = this.props.alwaysExpand;
|
|
148
|
+
return /* @__PURE__ */ a.createElement(w, null, !I && /* @__PURE__ */ a.createElement(
|
|
149
|
+
T,
|
|
150
150
|
{
|
|
151
|
-
title: l.toLanguageString(b,
|
|
151
|
+
title: l.toLanguageString(b, g[b]),
|
|
152
152
|
iconClass: "k-i-filter",
|
|
153
|
-
svgIcon:
|
|
153
|
+
svgIcon: K,
|
|
154
154
|
onClick: this.onFilterExpand
|
|
155
155
|
}
|
|
156
|
-
), /* @__PURE__ */ a.createElement(z, { show:
|
|
156
|
+
), /* @__PURE__ */ a.createElement(z, { show: I || !!V }, /* @__PURE__ */ a.createElement(
|
|
157
157
|
"form",
|
|
158
158
|
{
|
|
159
159
|
className: "k-filter-menu",
|
|
160
160
|
onSubmit: this.submit,
|
|
161
|
-
onReset: this.clear
|
|
162
|
-
onKeyDown: (m) => m.stopPropagation()
|
|
161
|
+
onReset: this.clear
|
|
163
162
|
},
|
|
164
|
-
/* @__PURE__ */ a.createElement("div", { className: "k-filter-menu-container" },
|
|
163
|
+
/* @__PURE__ */ a.createElement("div", { className: "k-filter-menu-container" }, E ? /* @__PURE__ */ a.createElement(E, { ...S }) : /* @__PURE__ */ a.createElement(J, { ...S }), /* @__PURE__ */ a.createElement("div", { className: "k-actions k-actions-stretched" }, /* @__PURE__ */ a.createElement(
|
|
165
164
|
k,
|
|
166
165
|
{
|
|
167
166
|
themeColor: "primary",
|
|
168
|
-
disabled: !
|
|
167
|
+
disabled: !U
|
|
169
168
|
},
|
|
170
|
-
l.toLanguageString(
|
|
169
|
+
l.toLanguageString(D, g[D])
|
|
171
170
|
), /* @__PURE__ */ a.createElement(
|
|
172
171
|
k,
|
|
173
172
|
{
|
|
174
173
|
type: "reset"
|
|
175
174
|
},
|
|
176
|
-
l.toLanguageString(
|
|
175
|
+
l.toLanguageString(M, g[M])
|
|
177
176
|
)))
|
|
178
177
|
)));
|
|
179
178
|
}
|
|
180
179
|
};
|
|
181
|
-
|
|
182
|
-
let
|
|
183
|
-
H(
|
|
180
|
+
v.active = (i, o) => !!u(i, o);
|
|
181
|
+
let F = v;
|
|
182
|
+
H(F);
|
|
184
183
|
export {
|
|
185
|
-
|
|
184
|
+
F as GridColumnMenuFilter,
|
|
186
185
|
u as filterGroupByField,
|
|
187
|
-
|
|
186
|
+
C as rootFilterOrDefault
|
|
188
187
|
};
|
|
@@ -5,4 +5,4 @@
|
|
|
5
5
|
* Licensed under commercial license. See LICENSE.md in the package root for more information
|
|
6
6
|
*-------------------------------------------------------------------------------------------
|
|
7
7
|
*/
|
|
8
|
-
"use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const
|
|
8
|
+
"use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("react"),o=require("@progress/kendo-react-common");function i(t){const n=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(t){for(const e in t)if(e!=="default"){const c=Object.getOwnPropertyDescriptor(t,e);Object.defineProperty(n,e,c.get?c:{enumerable:!0,get:()=>t[e]})}}return n.default=t,Object.freeze(n)}const r=i(a),u=t=>{const{title:n,iconClass:e,svgIcon:c,selected:l}=t;return r.createElement("div",{onClick:t.onClick,className:`k-columnmenu-item ${l?"k-selected":""}`},(e||c)&&r.createElement(o.IconWrap,{name:e&&o.toIconName(e),icon:c}),n)};exports.GridColumnMenuItem=u;
|
|
@@ -6,17 +6,12 @@
|
|
|
6
6
|
*-------------------------------------------------------------------------------------------
|
|
7
7
|
*/
|
|
8
8
|
"use client";
|
|
9
|
-
import * as
|
|
10
|
-
import { IconWrap as
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
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
|
-
}
|
|
9
|
+
import * as c from "react";
|
|
10
|
+
import { IconWrap as l, toIconName as i } from "@progress/kendo-react-common";
|
|
11
|
+
const r = (t) => {
|
|
12
|
+
const { title: o, iconClass: e, svgIcon: n, selected: m } = t;
|
|
13
|
+
return /* @__PURE__ */ c.createElement("div", { onClick: t.onClick, className: `k-columnmenu-item ${m ? "k-selected" : ""}` }, (e || n) && /* @__PURE__ */ c.createElement(l, { name: e && i(e), icon: n }), o);
|
|
14
|
+
};
|
|
20
15
|
export {
|
|
21
|
-
|
|
16
|
+
r as GridColumnMenuItem
|
|
22
17
|
};
|
|
@@ -5,4 +5,4 @@
|
|
|
5
5
|
* Licensed under commercial license. See LICENSE.md in the package root for more information
|
|
6
6
|
*-------------------------------------------------------------------------------------------
|
|
7
7
|
*/
|
|
8
|
-
"use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const
|
|
8
|
+
"use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const N=require("react"),O=require("@progress/kendo-react-popup"),i=require("@progress/kendo-react-common"),P=require("@progress/kendo-svg-icons"),E=require("../messages/index.js"),_=require("@progress/kendo-react-intl");function j(e){const r=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const l in e)if(l!=="default"){const u=Object.getOwnPropertyDescriptor(e,l);Object.defineProperty(r,l,u.get?u:{enumerable:!0,get:()=>e[l]})}}return r.default=e,Object.freeze(r)}const o=j(N),z=[".k-columnmenu-item-content",".k-filter-menu-container"].map(e=>i.TABBABLE_ELEMENTS.map(r=>`${e} ${r}`)),W=[[".k-tabstrip-items"],[".k-columnmenu-item"],...z],$=e=>{const[r,l]=o.useState(!1),u=o.useRef(null),a=o.useRef(null),s=o.useRef(null),m=o.useRef(0),{columnMenu:h,...v}=e,{column:b}=e,w=_.useLocalization(),k=b.title||b.field,M=k?`${k} `:"",y="#",p=n=>{const t=i.getActiveElement(document);clearTimeout(m.current),m.current=window.setTimeout(()=>{t&&n.relatedTarget!==u.current&&a.current&&!a.current.contains(t)&&f()})},C=()=>{clearTimeout(m.current)},D=n=>{n.preventDefault(),r&&e.onCloseMenu&&e.onCloseMenu(),l(!r)},f=()=>{e.onCloseMenu&&e.onCloseMenu(),l(!1),!e.navigatable&&u.current&&u.current.focus()},S=n=>{var t;if(n.keyCode===i.Keys.tab){const c=n.target,g=c&&((t=c.closest(".k-grid"))==null?void 0:t.getElementsByClassName("k-grid-content")[0]);g&&g.scrollWidth>g.clientWidth&&c.scrollIntoView({inline:"center"})}},d=o.useMemo(()=>e.show!==void 0?e.show:r,[e.show,r]),T=n=>{var t;(t=s.current)==null||t.triggerKeyboardEvent(n)},R=n=>{var t;(t=s.current)==null||t.triggerMouseEvent(n)},I=(n,t,c)=>{c.preventDefault(),c.shiftKey?t.focusPrevious(n):t.focusNext(n)},K=(n,t,c)=>{n&&n.click()},q=(n,t,c)=>{c.preventDefault(),f()},B=(n,t,c)=>{c.preventDefault(),t.focusElement(n)};return o.useEffect(()=>(d&&a.current&&(s.current=new i.Navigation({tabIndex:0,root:a,selectors:W,keyboardEvents:{keydown:{Tab:I,Enter:K,Escape:q}},mouseEvents:{mousedown:B}}),s.current.focusElement(s.current.first,null)),()=>{s.current&&(s.current=null)}),[d]),o.createElement(o.Fragment,null,o.createElement("a",{className:"k-grid-header-menu k-grid-column-menu",ref:u,onClick:D,onKeyDown:S,href:y,tabIndex:e.navigatable?-1:void 0,"aria-label":`${M}${w.toLanguageString(E.columnMenu,E.messages[E.columnMenu])}`},o.createElement(i.IconWrap,{name:"filter",icon:P.filterIcon})),o.createElement(O.Popup,{anchor:u.current,show:d,popupClass:"k-column-menu k-column-menu-popup k-grid-columnmenu-popup"},o.createElement("div",{ref:a,onBlur:p,onFocus:C,onMouseDown:R,onKeyDown:T,style:{outline:"none"}},h&&o.createElement(h,{...v,onCloseMenu:f}))))};exports.GridColumnMenuWrapper=$;
|
|
@@ -7,85 +7,108 @@
|
|
|
7
7
|
*/
|
|
8
8
|
"use client";
|
|
9
9
|
import * as t from "react";
|
|
10
|
-
import { Popup as
|
|
11
|
-
import {
|
|
12
|
-
import { filterIcon as
|
|
13
|
-
import { columnMenu as
|
|
14
|
-
import {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
10
|
+
import { Popup as R } from "@progress/kendo-react-popup";
|
|
11
|
+
import { TABBABLE_ELEMENTS as $, Navigation as x, IconWrap as z, getActiveElement as A, Keys as F } from "@progress/kendo-react-common";
|
|
12
|
+
import { filterIcon as L } from "@progress/kendo-svg-icons";
|
|
13
|
+
import { columnMenu as w, messages as W } from "../messages/index.mjs";
|
|
14
|
+
import { useLocalization as _ } from "@progress/kendo-react-intl";
|
|
15
|
+
const H = [
|
|
16
|
+
".k-columnmenu-item-content",
|
|
17
|
+
".k-filter-menu-container"
|
|
18
|
+
].map((o) => $.map(
|
|
19
|
+
(u) => `${o} ${u}`
|
|
20
|
+
)), P = [
|
|
21
|
+
[".k-tabstrip-items"],
|
|
22
|
+
[".k-columnmenu-item"],
|
|
23
|
+
...H
|
|
24
|
+
], Q = (o) => {
|
|
25
|
+
const [u, d] = t.useState(!1), l = t.useRef(null), s = t.useRef(null), c = t.useRef(null), a = t.useRef(0), { columnMenu: E, ...v } = o, { column: h } = o, k = _(), g = h.title || h.field, M = g ? `${g} ` : "", b = "#", p = (e) => {
|
|
26
|
+
const n = A(document);
|
|
27
|
+
clearTimeout(a.current), a.current = window.setTimeout(() => {
|
|
28
|
+
n && e.relatedTarget !== l.current && s.current && !s.current.contains(n) && i();
|
|
29
|
+
});
|
|
30
|
+
}, y = () => {
|
|
31
|
+
clearTimeout(a.current);
|
|
32
|
+
}, C = (e) => {
|
|
33
|
+
e.preventDefault(), u && o.onCloseMenu && o.onCloseMenu(), d(!u);
|
|
34
|
+
}, i = () => {
|
|
35
|
+
o.onCloseMenu && o.onCloseMenu(), d(!1), !o.navigatable && l.current && l.current.focus();
|
|
36
|
+
}, D = (e) => {
|
|
37
|
+
var n;
|
|
38
|
+
if (e.keyCode === F.tab) {
|
|
39
|
+
const r = e.target, f = r && ((n = r.closest(".k-grid")) == null ? void 0 : n.getElementsByClassName("k-grid-content")[0]);
|
|
40
|
+
f && f.scrollWidth > f.clientWidth && r.scrollIntoView({ inline: "center" });
|
|
41
|
+
}
|
|
42
|
+
}, m = t.useMemo(() => o.show !== void 0 ? o.show : u, [o.show, u]), T = (e) => {
|
|
43
|
+
var n;
|
|
44
|
+
(n = c.current) == null || n.triggerKeyboardEvent(e);
|
|
45
|
+
}, S = (e) => {
|
|
46
|
+
var n;
|
|
47
|
+
(n = c.current) == null || n.triggerMouseEvent(e);
|
|
48
|
+
}, K = (e, n, r) => {
|
|
49
|
+
r.preventDefault(), r.shiftKey ? n.focusPrevious(e) : n.focusNext(e);
|
|
50
|
+
}, B = (e, n, r) => {
|
|
51
|
+
e && e.click();
|
|
52
|
+
}, I = (e, n, r) => {
|
|
53
|
+
r.preventDefault(), i();
|
|
54
|
+
}, N = (e, n, r) => {
|
|
55
|
+
r.preventDefault(), n.focusElement(e);
|
|
56
|
+
};
|
|
57
|
+
return t.useEffect(() => (m && s.current && (c.current = new x({
|
|
58
|
+
tabIndex: 0,
|
|
59
|
+
root: s,
|
|
60
|
+
selectors: P,
|
|
61
|
+
keyboardEvents: {
|
|
62
|
+
keydown: {
|
|
63
|
+
Tab: K,
|
|
64
|
+
Enter: B,
|
|
65
|
+
Escape: I
|
|
23
66
|
}
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
},
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
"a",
|
|
67
|
+
},
|
|
68
|
+
mouseEvents: {
|
|
69
|
+
mousedown: N
|
|
70
|
+
}
|
|
71
|
+
}), c.current.focusElement(c.current.first, null)), () => {
|
|
72
|
+
c.current && (c.current = null);
|
|
73
|
+
}), [m]), /* @__PURE__ */ t.createElement(t.Fragment, null, /* @__PURE__ */ t.createElement(
|
|
74
|
+
"a",
|
|
75
|
+
{
|
|
76
|
+
className: "k-grid-header-menu k-grid-column-menu",
|
|
77
|
+
ref: l,
|
|
78
|
+
onClick: C,
|
|
79
|
+
onKeyDown: D,
|
|
80
|
+
href: b,
|
|
81
|
+
tabIndex: o.navigatable ? -1 : void 0,
|
|
82
|
+
"aria-label": `${M}${k.toLanguageString(w, W[w])}`
|
|
83
|
+
},
|
|
84
|
+
/* @__PURE__ */ t.createElement(z, { name: "filter", icon: L })
|
|
85
|
+
), /* @__PURE__ */ t.createElement(
|
|
86
|
+
R,
|
|
87
|
+
{
|
|
88
|
+
anchor: l.current,
|
|
89
|
+
show: m,
|
|
90
|
+
popupClass: "k-column-menu k-column-menu-popup k-grid-columnmenu-popup"
|
|
91
|
+
},
|
|
92
|
+
/* @__PURE__ */ t.createElement(
|
|
93
|
+
"div",
|
|
52
94
|
{
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
onMouseDown:
|
|
57
|
-
onKeyDown:
|
|
58
|
-
|
|
59
|
-
"aria-label": `${c}${s.toLanguageString(l, p[l])}`
|
|
95
|
+
ref: s,
|
|
96
|
+
onBlur: p,
|
|
97
|
+
onFocus: y,
|
|
98
|
+
onMouseDown: S,
|
|
99
|
+
onKeyDown: T,
|
|
100
|
+
style: { outline: "none" }
|
|
60
101
|
},
|
|
61
|
-
/* @__PURE__ */ t.createElement(
|
|
62
|
-
|
|
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",
|
|
102
|
+
E && /* @__PURE__ */ t.createElement(
|
|
103
|
+
E,
|
|
71
104
|
{
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
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
|
-
)
|
|
105
|
+
...v,
|
|
106
|
+
onCloseMenu: i
|
|
107
|
+
}
|
|
85
108
|
)
|
|
86
|
-
)
|
|
87
|
-
|
|
88
|
-
}
|
|
109
|
+
)
|
|
110
|
+
));
|
|
111
|
+
};
|
|
89
112
|
export {
|
|
90
|
-
|
|
113
|
+
Q as GridColumnMenuWrapper
|
|
91
114
|
};
|