@progress/kendo-react-grid 14.2.2-develop.1 → 14.3.0-develop.10

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 (101) hide show
  1. package/GridClientContextReader.js +1 -1
  2. package/GridClientContextReader.mjs +10 -9
  3. package/GridClientWrapper.js +1 -1
  4. package/GridClientWrapper.mjs +651 -494
  5. package/GridComponent.js +1 -1
  6. package/GridComponent.mjs +418 -379
  7. package/GridState.d.ts +2 -0
  8. package/GridState.js +1 -1
  9. package/GridState.mjs +98 -90
  10. package/{toolbar-tools/smartbox/SegmentedControl.d.ts → cells/pincell/GridPinCell.d.ts} +4 -2
  11. package/cells/pincell/GridPinCell.js +9 -0
  12. package/cells/pincell/GridPinCell.mjs +19 -0
  13. package/cells/pincell/GridPinCellServer.d.ts +15 -0
  14. package/cells/pincell/GridPinCellServer.js +8 -0
  15. package/cells/pincell/GridPinCellServer.mjs +32 -0
  16. package/cells/pincell/GridPinCellServerContainer.d.ts +11 -0
  17. package/cells/pincell/GridPinCellServerContainer.js +9 -0
  18. package/cells/pincell/GridPinCellServerContainer.mjs +26 -0
  19. package/cells/pincell/GridPinDropdownButton.d.ts +21 -0
  20. package/cells/pincell/GridPinDropdownButton.js +9 -0
  21. package/cells/pincell/GridPinDropdownButton.mjs +58 -0
  22. package/cells/pincell/useGridPinCellClientTdProps.d.ts +24 -0
  23. package/cells/pincell/useGridPinCellClientTdProps.js +9 -0
  24. package/cells/pincell/useGridPinCellClientTdProps.mjs +21 -0
  25. package/cells/pincell/utils.d.ts +20 -0
  26. package/cells/pincell/utils.js +8 -0
  27. package/cells/pincell/utils.mjs +47 -0
  28. package/components/PinnedRowsTable.d.ts +48 -0
  29. package/components/PinnedRowsTable.js +9 -0
  30. package/components/PinnedRowsTable.mjs +133 -0
  31. package/components/StickyGroupTable.d.ts +42 -0
  32. package/components/StickyGroupTable.js +9 -0
  33. package/components/StickyGroupTable.mjs +82 -0
  34. package/components/colGroup/GridColGroup.js +1 -1
  35. package/components/colGroup/GridColGroup.mjs +9 -9
  36. package/contextMenu/GridContextMenu.d.ts +42 -0
  37. package/contextMenu/GridContextMenu.js +1 -1
  38. package/contextMenu/GridContextMenu.mjs +101 -51
  39. package/contextMenu/enums.d.ts +5 -1
  40. package/contextMenu/enums.js +1 -1
  41. package/contextMenu/enums.mjs +2 -2
  42. package/dist/cdn/js/kendo-react-grid.js +1 -1
  43. package/drag/ColumnResize.d.ts +17 -0
  44. package/drag/ColumnResize.js +1 -1
  45. package/drag/ColumnResize.mjs +107 -100
  46. package/getRowContents.d.ts +58 -0
  47. package/getRowContents.js +8 -0
  48. package/getRowContents.mjs +99 -0
  49. package/header/GridHeaderGroupSpacerCell.d.ts +13 -0
  50. package/header/GridHeaderGroupSpacerCell.js +9 -0
  51. package/header/GridHeaderGroupSpacerCell.mjs +23 -0
  52. package/header/client/GridHeaderPinCell.d.ts +12 -0
  53. package/header/client/GridHeaderPinCell.js +9 -0
  54. package/header/client/GridHeaderPinCell.mjs +14 -0
  55. package/hooks/useStickyGroups.d.ts +71 -0
  56. package/hooks/useStickyGroups.js +9 -0
  57. package/hooks/useStickyGroups.mjs +350 -0
  58. package/index.d.mts +5 -2
  59. package/index.d.ts +5 -2
  60. package/index.js +1 -1
  61. package/index.mjs +97 -95
  62. package/interfaces/ColumnType.d.ts +1 -1
  63. package/interfaces/GridCellsSettings.d.ts +23 -0
  64. package/interfaces/GridGroupableSettings.d.ts +23 -0
  65. package/interfaces/GridProps.d.ts +70 -1
  66. package/interfaces/GridRowProps.d.ts +4 -0
  67. package/interfaces/GridRowsSettings.d.ts +11 -0
  68. package/interfaces/events.d.ts +17 -0
  69. package/messages/index.d.ts +25 -0
  70. package/messages/index.js +2 -2
  71. package/messages/index.mjs +122 -112
  72. package/package-metadata.js +1 -1
  73. package/package-metadata.mjs +2 -2
  74. package/package.json +17 -17
  75. package/rows/GridRow.js +1 -1
  76. package/rows/GridRow.mjs +25 -24
  77. package/rows/GridRowRenderer.d.ts +1 -0
  78. package/rows/GridRowRenderer.js +1 -1
  79. package/rows/GridRowRenderer.mjs +39 -36
  80. package/stacked/GridStackedRow.d.ts +5 -0
  81. package/stacked/GridStackedRow.js +1 -1
  82. package/stacked/GridStackedRow.mjs +118 -116
  83. package/stacked/StackedModeComponents.d.ts +1 -0
  84. package/stacked/StackedModeComponents.js +1 -1
  85. package/stacked/StackedModeComponents.mjs +14 -14
  86. package/stacked/StackedModeRow.d.ts +1 -0
  87. package/stacked/StackedModeRow.js +1 -1
  88. package/stacked/StackedModeRow.mjs +13 -11
  89. package/toolbar-tools/smartbox/SmartBox.js +1 -1
  90. package/toolbar-tools/smartbox/SmartBox.mjs +102 -94
  91. package/toolbar-tools/smartbox/hooks/useSmartBoxSegmentedControl.d.ts +12 -3
  92. package/toolbar-tools/smartbox/hooks/useSmartBoxSegmentedControl.js +1 -1
  93. package/toolbar-tools/smartbox/hooks/useSmartBoxSegmentedControl.mjs +42 -41
  94. package/toolbar-tools/smartbox/index.d.ts +0 -1
  95. package/toolbar-tools/smartbox/interfaces/index.d.ts +0 -1
  96. package/utils/index.d.ts +1 -0
  97. package/utils/index.js +1 -1
  98. package/utils/index.mjs +44 -44
  99. package/toolbar-tools/smartbox/SegmentedControl.js +0 -8
  100. package/toolbar-tools/smartbox/SegmentedControl.mjs +0 -109
  101. package/toolbar-tools/smartbox/interfaces/SegmentedControlTypes.d.ts +0 -66
@@ -39,6 +39,7 @@ export interface StackedModeRowProps {
39
39
  showDetailToggle: boolean;
40
40
  isDetailExpanded: boolean;
41
41
  detailExpandField?: string;
42
+ isPinned?: boolean;
42
43
  }
43
44
  /**
44
45
  * @hidden
@@ -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 strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const P=require("react"),B=require("../cells/groupcell/GridGroupCellToggle.js"),L=require("../rows/GridRow.js"),V=require("./GridStackedRow.js");function z(e){const c=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const s in e)if(s!=="default"){const u=Object.getOwnPropertyDescriptor(e,s);Object.defineProperty(c,s,u.get?u:{enumerable:!0,get:()=>e[s]})}}return c.default=e,Object.freeze(c)}const t=z(P),H=({item:e,rowId:c,dataIndex:s,idPrefix:u,ariaRowIndex:f,absoluteRowIndex:y,isAltRow:k,isHidden:h,isRowReorderable:j,rowHeight:O,rows:R,leafColumns:p,groupLevelCount:b,stackedLayoutSettings:w,cells:F,editMode:x,isSelected:S,isHighlighted:D,isInEdit:v,preparedCells:M,showDetailToggle:_,isDetailExpanded:q,detailExpandField:A})=>{var C,G,$;if(e.rowType==="data")return t.createElement(V.GridStackedRow,{key:c,dataItem:e.dataItem,columns:p,stackedLayoutSettings:w,isAltRow:k,isSelected:S,isInEdit:v,cells:F,dataIndex:s,idPrefix:u,ariaRowIndex:f,absoluteRowIndex:y,groupLevel:b,preparedCells:M,editMode:x,showDetailToggle:_,isDetailExpanded:q,detailExpandField:A});const I=b+1,E=e.level||0,T=Math.max(1,I-E),N=Array.from({length:E},(d,r)=>t.createElement("td",{key:`group-cell-${c}-${r}`,className:"k-table-group-td k-group-cell k-table-td"}));let m;if(e.rowType==="groupHeader"){const d=(C=e.dataItem)==null?void 0:C.field,r=(G=e.dataItem)==null?void 0:G.value,g=d!==void 0?(()=>{const l=String(d),n=p.find(o=>o.field===l),i=n==null?void 0:n.title;return typeof i=="string"&&i.length?i:l})():void 0;let a="";if(d!==void 0){let l;r instanceof Date?l=r.toString():l=String(r),a=`${g}: ${l}`}else r instanceof Date?a=r.toString():r!==void 0&&(a=String(r));m=t.createElement(t.Fragment,null,N,t.createElement("td",{className:"k-table-td",colSpan:T,role:"gridcell","aria-expanded":e.expanded},t.createElement("p",{className:"k-reset"},t.createElement(B.GridGroupCellToggle,{id:"",dataItem:e.dataItem,dataIndex:e.dataIndex,field:"value",expanded:e.expanded,group:e.group,columnPosition:{},ariaColumnIndex:1,isSelected:!1}),t.createElement("span",{className:"k-value"},a))))}else{const d=p.filter(a=>{const l=!!a._type,n=a.isAccessible===!1;return!a.hidden&&!l&&!n&&(a.columnType==="data"||a.columnType===void 0)}),r=($=e.dataItem)==null?void 0:$.aggregates,g=d.map(a=>{const l=a.field;if(!l||!r)return null;const n=r[l];if(!n||typeof n!="object")return null;const i=Object.keys(n).filter(o=>n[o]!==void 0&&n[o]!==null).map(o=>`${o.length?`${o.charAt(0).toUpperCase()}${o.slice(1)}`:o}: ${String(n[o])}`);return i.length===0?null:t.createElement("div",{key:`agg-${c}-${l}`,className:"k-grid-template-column"},t.createElement("p",{className:"k-grid-template-column-header"},a.title||l),t.createElement("p",{className:"k-reset"},i.join(", ")))}).filter(Boolean);if(e.rowType==="groupFooter"&&g.length===0)return t.createElement(t.Fragment,{key:c});m=t.createElement(t.Fragment,null,N,t.createElement("td",{className:"k-table-td",colSpan:T},t.createElement("div",{className:"k-grid-column-template"},g)))}return t.createElement(L.GridRow,{key:c,dataItem:e.dataItem,isAltRow:k,isInEdit:v,rowType:e.rowType,isRowReorderable:j,isHidden:h,onClick:null,onDoubleClick:null,rowHeight:O,ariaRowIndex:f,absoluteRowIndex:y,dataIndex:s,isSelected:S,isHighlighted:D,rows:R},m)};exports.StackedModeRow=H;
8
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const B=require("react"),L=require("../cells/groupcell/GridGroupCellToggle.js"),V=require("../rows/GridRow.js"),z=require("./GridStackedRow.js");function H(e){const c=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const s in e)if(s!=="default"){const u=Object.getOwnPropertyDescriptor(e,s);Object.defineProperty(c,s,u.get?u:{enumerable:!0,get:()=>e[s]})}}return c.default=e,Object.freeze(c)}const t=H(B),U=({item:e,rowId:c,dataIndex:s,idPrefix:u,ariaRowIndex:f,absoluteRowIndex:y,isAltRow:k,isHidden:h,isRowReorderable:j,rowHeight:O,rows:R,leafColumns:p,groupLevelCount:b,stackedLayoutSettings:w,cells:F,editMode:x,isSelected:S,isHighlighted:D,isInEdit:v,preparedCells:M,showDetailToggle:_,isDetailExpanded:q,detailExpandField:A,isPinned:I})=>{var C,G,$;if(e.rowType==="data")return t.createElement(z.GridStackedRow,{key:c,dataItem:e.dataItem,columns:p,stackedLayoutSettings:w,isAltRow:k,isSelected:S,isInEdit:v,cells:F,dataIndex:s,idPrefix:u,ariaRowIndex:f,absoluteRowIndex:y,groupLevel:b,preparedCells:M,editMode:x,showDetailToggle:_,isDetailExpanded:q,detailExpandField:A,isPinned:I});const P=b+1,E=e.level||0,T=Math.max(1,P-E),N=Array.from({length:E},(d,r)=>t.createElement("td",{key:`group-cell-${c}-${r}`,className:"k-table-group-td k-group-cell k-table-td"}));let m;if(e.rowType==="groupHeader"){const d=(C=e.dataItem)==null?void 0:C.field,r=(G=e.dataItem)==null?void 0:G.value,g=d!==void 0?(()=>{const l=String(d),n=p.find(o=>o.field===l),i=n==null?void 0:n.title;return typeof i=="string"&&i.length?i:l})():void 0;let a="";if(d!==void 0){let l;r instanceof Date?l=r.toString():l=String(r),a=`${g}: ${l}`}else r instanceof Date?a=r.toString():r!==void 0&&(a=String(r));m=t.createElement(t.Fragment,null,N,t.createElement("td",{className:"k-table-td",colSpan:T,role:"gridcell","aria-expanded":e.expanded},t.createElement("p",{className:"k-reset"},t.createElement(L.GridGroupCellToggle,{id:"",dataItem:e.dataItem,dataIndex:e.dataIndex,field:"value",expanded:e.expanded,group:e.group,columnPosition:{},ariaColumnIndex:1,isSelected:!1}),t.createElement("span",{className:"k-value"},a))))}else{const d=p.filter(a=>{const l=!!a._type,n=a.isAccessible===!1;return!a.hidden&&!l&&!n&&(a.columnType==="data"||a.columnType===void 0)}),r=($=e.dataItem)==null?void 0:$.aggregates,g=d.map(a=>{const l=a.field;if(!l||!r)return null;const n=r[l];if(!n||typeof n!="object")return null;const i=Object.keys(n).filter(o=>n[o]!==void 0&&n[o]!==null).map(o=>`${o.length?`${o.charAt(0).toUpperCase()}${o.slice(1)}`:o}: ${String(n[o])}`);return i.length===0?null:t.createElement("div",{key:`agg-${c}-${l}`,className:"k-grid-template-column"},t.createElement("p",{className:"k-grid-template-column-header"},a.title||l),t.createElement("p",{className:"k-reset"},i.join(", ")))}).filter(Boolean);if(e.rowType==="groupFooter"&&g.length===0)return t.createElement(t.Fragment,{key:c});m=t.createElement(t.Fragment,null,N,t.createElement("td",{className:"k-table-td",colSpan:T},t.createElement("div",{className:"k-grid-column-template"},g)))}return t.createElement(V.GridRow,{key:c,dataItem:e.dataItem,isAltRow:k,isInEdit:v,rowType:e.rowType,isRowReorderable:j,isHidden:h,onClick:null,onDoubleClick:null,rowHeight:O,ariaRowIndex:f,absoluteRowIndex:y,dataIndex:s,isSelected:S,isHighlighted:D,rows:R},m)};exports.StackedModeRow=U;
@@ -6,10 +6,10 @@
6
6
  *-------------------------------------------------------------------------------------------
7
7
  */
8
8
  import * as e from "react";
9
- import { GridGroupCellToggle as _ } from "../cells/groupcell/GridGroupCellToggle.mjs";
10
- import { GridRow as H } from "../rows/GridRow.mjs";
11
- import { GridStackedRow as O } from "./GridStackedRow.mjs";
12
- const J = ({
9
+ import { GridGroupCellToggle as H } from "../cells/groupcell/GridGroupCellToggle.mjs";
10
+ import { GridRow as O } from "../rows/GridRow.mjs";
11
+ import { GridStackedRow as P } from "./GridStackedRow.mjs";
12
+ const K = ({
13
13
  item: t,
14
14
  rowId: d,
15
15
  dataIndex: m,
@@ -32,12 +32,13 @@ const J = ({
32
32
  preparedCells: w,
33
33
  showDetailToggle: B,
34
34
  isDetailExpanded: L,
35
- detailExpandField: M
35
+ detailExpandField: M,
36
+ isPinned: V
36
37
  }) => {
37
38
  var T, $, C;
38
39
  if (t.rowType === "data")
39
40
  return /* @__PURE__ */ e.createElement(
40
- O,
41
+ P,
41
42
  {
42
43
  key: d,
43
44
  dataItem: t.dataItem,
@@ -56,10 +57,11 @@ const J = ({
56
57
  editMode: D,
57
58
  showDetailToggle: B,
58
59
  isDetailExpanded: L,
59
- detailExpandField: M
60
+ detailExpandField: M,
61
+ isPinned: V
60
62
  }
61
63
  );
62
- const V = y + 1, S = t.level || 0, b = Math.max(1, V - S), N = Array.from({ length: S }, (c, r) => /* @__PURE__ */ e.createElement("td", { key: `group-cell-${d}-${r}`, className: "k-table-group-td k-group-cell k-table-td" }));
64
+ const _ = y + 1, S = t.level || 0, b = Math.max(1, _ - S), N = Array.from({ length: S }, (c, r) => /* @__PURE__ */ e.createElement("td", { key: `group-cell-${d}-${r}`, className: "k-table-group-td k-group-cell k-table-td" }));
63
65
  let g;
64
66
  if (t.rowType === "groupHeader") {
65
67
  const c = (T = t.dataItem) == null ? void 0 : T.field, r = ($ = t.dataItem) == null ? void 0 : $.value, i = c !== void 0 ? (() => {
@@ -72,7 +74,7 @@ const J = ({
72
74
  r instanceof Date ? l = r.toString() : l = String(r), a = `${i}: ${l}`;
73
75
  } else r instanceof Date ? a = r.toString() : r !== void 0 && (a = String(r));
74
76
  g = /* @__PURE__ */ e.createElement(e.Fragment, null, N, /* @__PURE__ */ e.createElement("td", { className: "k-table-td", colSpan: b, role: "gridcell", "aria-expanded": t.expanded }, /* @__PURE__ */ e.createElement("p", { className: "k-reset" }, /* @__PURE__ */ e.createElement(
75
- _,
77
+ H,
76
78
  {
77
79
  id: "",
78
80
  dataItem: t.dataItem,
@@ -104,7 +106,7 @@ const J = ({
104
106
  g = /* @__PURE__ */ e.createElement(e.Fragment, null, N, /* @__PURE__ */ e.createElement("td", { className: "k-table-td", colSpan: b }, /* @__PURE__ */ e.createElement("div", { className: "k-grid-column-template" }, i)));
105
107
  }
106
108
  return /* @__PURE__ */ e.createElement(
107
- H,
109
+ O,
108
110
  {
109
111
  key: d,
110
112
  dataItem: t.dataItem,
@@ -127,5 +129,5 @@ const J = ({
127
129
  );
128
130
  };
129
131
  export {
130
- J as StackedModeRow
132
+ K as StackedModeRow
131
133
  };
@@ -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 strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const Ze=require("react"),et=require("./SegmentedControl.js"),me=require("@progress/kendo-react-buttons"),K=require("@progress/kendo-svg-icons"),d=require("@progress/kendo-react-common"),tt=require("@progress/kendo-react-intl"),nt=require("../../hooks/useGridAIRequest.js"),st=require("../../utils/GridContext.js"),_=require("@progress/kendo-react-dropdowns"),rt=require("@progress/kendo-react-popup"),R=require("./listItemRenders.js"),o=require("../../messages/index.js"),at=require("./hooks/useSmartBoxModes.js"),ot=require("./hooks/useSmartBoxHistory.js"),ct=require("./hooks/useSmartBoxPopup.js"),it=require("./hooks/useSmartBoxGridState.js"),lt=require("./hooks/useSmartBoxLabels.js"),ut=require("./hooks/useSmartBoxListData.js"),pt=require("./hooks/useSmartBoxSegmentedControl.js"),dt=require("./hooks/useSmartBoxSearch.js"),mt=require("./hooks/useDebounce.js");function gt(m){const b=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(m){for(const f in m)if(f!=="default"){const I=Object.getOwnPropertyDescriptor(m,f);Object.defineProperty(b,f,I.get?I:{enumerable:!0,get:()=>m[f]})}}return b.default=m,Object.freeze(b)}const e=gt(Ze),ge=e.forwardRef((m,b)=>{var pe;const{searchConfig:f,semanticSearchConfig:I,aiAssistantConfig:he,activeMode:fe,dir:Se="ltr",size:M="medium",placeholder:ke,history:be,loading:xe=!1,promptSuggestionRender:A,historyItemRender:J,onOpen:Ce,onClose:Be,onFocus:q,onBlur:v,onSearch:Re,onSemanticSearch:Ie,onAIPromptRequest:H,onAIResponseSuccess:N,onAIResponseError:F,onAICancelRequest:w}=m,x=tt.useLocalization(),C=e.useContext(st.GridContext),qe=e.useRef(`k-${d.guid()}`),S=e.useRef(null),B=e.useRef(null),Q=e.useRef(null),[c,g]=e.useState(""),[ve,P]=e.useState(!1),[we,X]=e.useState(void 0),[Pe,Y]=e.useState(null),{searchMode:i,semanticSearchMode:u,aiAssistantMode:r,selectedView:n,setSelectedViewState:O,lastSearchMode:De,searchHistorySettings:Z,semanticSearchHistorySettings:ee,aiAssistantHistorySettings:z,speechToTextButtonSettings:te,currentSearchDelay:ye}=at.useSmartBoxModes({searchConfigProp:f,semanticSearchConfigProp:I,aiAssistantConfigProp:he,activeModeProp:fe,sharedHistory:be}),{currentHistory:D,currentHistorySettings:Ee,addToHistory:G}=ot.useSmartBoxHistory({selectedView:n,searchHistorySettings:Z,semanticSearchHistorySettings:ee,aiAssistantHistorySettings:z}),{isOpen:V,togglePopup:a}=ct.useSmartBoxPopup({onOpen:Ce,onClose:Be}),{columns:ne,gridState:Le,gridRef:Te,handleStateChange:He}=it.useSmartBoxGridState(C),W=e.useMemo(()=>(r==null?void 0:r.promptSuggestions)||[],[r==null?void 0:r.promptSuggestions]),{inputPlaceholder:Ne,prefixIcon:Fe}=lt.useSmartBoxLabels({selectedView:n,searchMode:i,semanticSearchMode:u,aiAssistantMode:r,sharedPlaceholder:ke}),{searchListData:k,aiAssistantListData:y,searchHistoryListData:E}=ut.useSmartBoxListData({selectedView:n,searchModeEnabled:i==null?void 0:i.enabled,semanticSearchModeEnabled:u==null?void 0:u.enabled,promptSuggestions:W,currentHistory:D,currentHistorySettings:Ee}),se=pt.useSmartBoxSegmentedControl({searchMode:i,semanticSearchMode:u,aiAssistantMode:r,selectedView:n,lastSearchMode:De,setSelectedViewState:O,setInputValue:g});e.useEffect(()=>{const t=S.current;if(!t)return;X(t.offsetWidth);const s=new ResizeObserver(()=>{t&&X(t.offsetWidth)});return s.observe(t),()=>{s.disconnect()}},[]);const h=xe||ve,j=!n,Oe=!(i!=null&&i.enabled)&&!(u!=null&&u.enabled)&&!(r!=null&&r.enabled),ze=d.kendoThemeMaps.sizeMap[M]||"md",{emitSearchEvent:p}=dt.useSmartBoxSearch({selectedView:n,searchMode:i,columns:ne,gridContext:C,searchHistorySettings:Z,semanticSearchHistorySettings:ee,addToHistory:G,onSearch:Re,onSemanticSearch:Ie}),{sendRequest:re,cancelRequest:ae}=nt.useGridAIRequest({requestUrl:r==null?void 0:r.requestUrl,requestOptions:r==null?void 0:r.requestOptions,columns:ne,gridState:Le,gridRef:Te,onPromptRequest:t=>{H==null||H({requestData:t})},onResponseSuccess:t=>{P(!1),N==null||N({response:t})},onResponseError:t=>{P(!1),F==null||F({error:t})},onStateChange:He,onExportPdf:()=>C==null?void 0:C.exportAsPdf()});e.useImperativeHandle(b,()=>({show:()=>a(!0),hide:()=>a(!1)}),[a]);const U=mt.useDebounce(Pe,ye),oe=e.useRef(p);oe.current=p,e.useEffect(()=>{U!==null&&oe.current(U)},[U]);const Ge=e.useCallback(t=>{const s=t.target.value;g(s),a(!s),(n==="search"||n==="semanticSearch")&&Y(s)},[a,n]),Ve=e.useCallback(()=>{q==null||q(),c||a(!0)},[q,a,c]),We=e.useCallback(t=>{var de;const s=S.current,l=(de=Q.current)==null?void 0:de.element,T=t.relatedTarget,Xe=T&&(s==null?void 0:s.contains(T)),Ye=T&&(l==null?void 0:l.contains(T));!Xe&&!Ye&&(v==null||v(),a(!1))},[v,a]),je=e.useCallback(()=>{c||a(!0)},[a,c]),ce=!!((pe=r==null?void 0:r.requestOptions)!=null&&pe.url||r!=null&&r.requestUrl),$=e.useCallback(()=>{if(h){w==null||w(),ae(),P(!1);return}c.trim()&&(ce&&P(!0),G("aiAssistant",c,z),a(!1),re(c.trim()),g(""))},[h,c,z,a,G,re,ae,ce,w]),Ue=e.useCallback(t=>{t.key==="Enter"&&(n==="aiAssistant"?$():n==="semanticSearch"&&p(c))},[n,c,p,$]),$e=e.useCallback(()=>{var t;a(!V),(t=B.current)==null||t.focus()},[V,a]),Ke=e.useCallback(t=>{var s;t.stopPropagation(),t.preventDefault(),g(""),(s=B.current)==null||s.focus(),a(!0),p("")},[a,p]),ie=e.useCallback(t=>{var s;O(t),g(""),Y(null),(s=B.current)==null||s.focus()},[O]),L=e.useCallback(t=>{var s;g(t),a(!1),(s=B.current)==null||s.focus(),n!=="aiAssistant"&&p(t)},[n,a,p]),_e=e.useCallback(t=>{if(t.isFinal&&t.alternatives.length>0){const s=t.alternatives[0].transcript;g(l=>l?`${l} ${s}`:s)}},[]),Me=e.useMemo(()=>n==="aiAssistant"?D.length===0&&W.length===0:n==="search"||n==="semanticSearch"?D.length===0&&k.length===0:!1,[n,D.length,W.length,k.length]),le=e.useCallback(t=>{const l=(n==="aiAssistant"?y:E)[t];l&&L(l.text)},[n,y,E,L]),Ae=e.useCallback(t=>{const s=k[t];s&&ie(s.mode)},[k,ie]),ue=e.useMemo(()=>R.createListItemRender({historyItemRender:J,promptSuggestionRender:A,handleListItemClick:L}),[J,A,L]),Je=V&&!Oe,Qe=()=>e.createElement(e.Fragment,null,se.length>0&&e.createElement(et.SegmentedControl,{buttons:se,size:M,stretched:!0}),(n==="search"||n==="semanticSearch")&&k.length>0&&e.createElement(_.List,{data:k,textField:"text",descriptionField:"description",onClick:Ae,itemRender:R.searchModeItemRender,show:!0,wrapperCssClass:"k-list k-list-md"}),n==="aiAssistant"&&y.length>0&&e.createElement(_.List,{data:y,textField:"text",groupField:"group",svgIconField:"groupSvgIcon",descriptionField:"description",onClick:le,itemRender:ue,groupHeaderItemRender:R.listGroupHeaderRender,showFirstGroupHeader:!0,show:!0,wrapperCssClass:"k-list k-list-md"}),(n==="search"||n==="semanticSearch")&&E.length>0&&e.createElement(_.List,{data:E,textField:"text",groupField:"group",svgIconField:"groupSvgIcon",descriptionField:"description",onClick:le,itemRender:ue,groupHeaderItemRender:R.listGroupHeaderRender,showFirstGroupHeader:!0,show:!0,wrapperCssClass:"k-list k-list-md"}),Me&&e.createElement(R.NoDataRender,{selectedView:n}));return e.createElement("div",{ref:S,className:"k-smart-box-wrapper",dir:Se,onBlur:We},e.createElement("span",{className:d.classNames("k-smart-box","k-input",`k-input-${ze}`,{"k-loading":h})},!j&&e.createElement("span",{className:"k-input-prefix k-input-prefix-horizontal"},e.createElement(d.IconWrap,{className:d.classNames("k-icon",{"k-accent-icon":n==="aiAssistant"||n==="semanticSearch"}),icon:Fe.svgIcon,onClick:$e,onMouseDown:t=>{"preventDefault"in t&&t.preventDefault()}})),e.createElement("input",{ref:B,type:"text",className:d.classNames("k-input-inner",{"k-disabled":j}),id:qe.current,placeholder:Ne,value:c,disabled:j,onChange:Ge,onFocus:Ve,onClick:je,onKeyDown:Ue}),c.length>0&&(n==="search"||n==="semanticSearch")&&e.createElement("span",{className:"k-clear-value",title:x.toLanguageString(o.smartBoxClearTitle,o.messages[o.smartBoxClearTitle]),role:"button",tabIndex:-1,onClick:Ke,onMouseDown:t=>t.preventDefault()},e.createElement(d.IconWrap,{className:"k-icon",icon:K.xIcon})),n==="aiAssistant"&&e.createElement("span",{className:"k-input-suffix k-input-suffix-horizontal"},te&&e.createElement(me.SpeechToTextButton,{...te,"aria-label":x.toLanguageString(o.smartBoxSpeechToTextButton,o.messages[o.smartBoxSpeechToTextButton]),title:x.toLanguageString(o.smartBoxSpeechToTextButton,o.messages[o.smartBoxSpeechToTextButton]),onResult:_e}),e.createElement(me.Button,{className:d.classNames("k-smart-box-send",{"k-processing":h,"k-active":h}),type:"button",rounded:"full",size:"small",title:x.toLanguageString(o.smartBoxSubmitPromptButton,o.messages[o.smartBoxSubmitPromptButton]),"aria-label":x.toLanguageString(o.smartBoxSubmitPromptButton,o.messages[o.smartBoxSubmitPromptButton]),"aria-disabled":c.length===0,svgIcon:h?K.stopSmIcon:K.arrowUpOutlineIcon,disabled:c.length===0&&!h,onClick:$}))),e.createElement(rt.Popup,{ref:Q,anchor:S.current,show:Je,popupClass:"k-smart-box-popup",style:{width:we},anchorAlign:{horizontal:"left",vertical:"bottom"},popupAlign:{horizontal:"left",vertical:"top"},margin:{horizontal:0,vertical:2},onMouseDownOutside:t=>{const s=t.event.target;S.current&&!S.current.contains(s)&&a(!1)}},Qe()))});ge.displayName="KendoReactSmartBox";exports.SmartBox=ge;
8
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const Ze=require("react"),M=require("@progress/kendo-react-buttons"),_=require("@progress/kendo-svg-icons"),d=require("@progress/kendo-react-common"),et=require("@progress/kendo-react-intl"),A=require("@progress/kendo-react-dropdowns"),tt=require("@progress/kendo-react-popup"),R=require("./listItemRenders.js"),o=require("../../messages/index.js"),nt=require("../../hooks/useGridAIRequest.js"),st=require("../../utils/GridContext.js"),rt=require("./hooks/useSmartBoxModes.js"),at=require("./hooks/useSmartBoxHistory.js"),ot=require("./hooks/useSmartBoxPopup.js"),ct=require("./hooks/useSmartBoxGridState.js"),it=require("./hooks/useSmartBoxLabels.js"),lt=require("./hooks/useSmartBoxListData.js"),ut=require("./hooks/useSmartBoxSegmentedControl.js"),pt=require("./hooks/useSmartBoxSearch.js"),dt=require("./hooks/useDebounce.js");function mt(m){const x=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(m){for(const f in m)if(f!=="default"){const I=Object.getOwnPropertyDescriptor(m,f);Object.defineProperty(x,f,I.get?I:{enumerable:!0,get:()=>m[f]})}}return x.default=m,Object.freeze(x)}const e=mt(Ze),ge=e.forwardRef((m,x)=>{var de;const{searchConfig:f,semanticSearchConfig:I,aiAssistantConfig:he,activeMode:fe,dir:Se="ltr",size:J="medium",placeholder:ke,history:xe,loading:be=!1,promptSuggestionRender:Q,historyItemRender:X,onOpen:Ce,onClose:Be,onFocus:v,onBlur:q,onSearch:Re,onSemanticSearch:Ie,onAIPromptRequest:N,onAIResponseSuccess:F,onAIResponseError:O,onAICancelRequest:w}=m,b=et.useLocalization(),C=e.useContext(st.GridContext),ve=e.useRef(`k-${d.guid()}`),S=e.useRef(null),B=e.useRef(null),Y=e.useRef(null),[c,g]=e.useState(""),[qe,D]=e.useState(!1),[we,Z]=e.useState(void 0),[De,ee]=e.useState(null),{searchMode:i,semanticSearchMode:u,aiAssistantMode:r,selectedView:n,setSelectedViewState:z,lastSearchMode:Pe,searchHistorySettings:te,semanticSearchHistorySettings:ne,aiAssistantHistorySettings:G,speechToTextButtonSettings:se,currentSearchDelay:ye}=rt.useSmartBoxModes({searchConfigProp:f,semanticSearchConfigProp:I,aiAssistantConfigProp:he,activeModeProp:fe,sharedHistory:xe}),{currentHistory:P,currentHistorySettings:Ee,addToHistory:V}=at.useSmartBoxHistory({selectedView:n,searchHistorySettings:te,semanticSearchHistorySettings:ne,aiAssistantHistorySettings:G}),{isOpen:W,togglePopup:a}=ot.useSmartBoxPopup({onOpen:Ce,onClose:Be}),{columns:re,gridState:Le,gridRef:Te,handleStateChange:He}=ct.useSmartBoxGridState(C),j=e.useMemo(()=>(r==null?void 0:r.promptSuggestions)||[],[r==null?void 0:r.promptSuggestions]),{inputPlaceholder:Ne,prefixIcon:Fe}=it.useSmartBoxLabels({selectedView:n,searchMode:i,semanticSearchMode:u,aiAssistantMode:r,sharedPlaceholder:ke}),{searchListData:k,aiAssistantListData:y,searchHistoryListData:E}=lt.useSmartBoxListData({selectedView:n,searchModeEnabled:i==null?void 0:i.enabled,semanticSearchModeEnabled:u==null?void 0:u.enabled,promptSuggestions:j,currentHistory:P,currentHistorySettings:Ee}),L=ut.useSmartBoxSegmentedControl({searchMode:i,semanticSearchMode:u,aiAssistantMode:r,selectedView:n,lastSearchMode:Pe,setSelectedViewState:z,setInputValue:g});e.useEffect(()=>{const t=S.current;if(!t)return;Z(t.offsetWidth);const s=new ResizeObserver(()=>{t&&Z(t.offsetWidth)});return s.observe(t),()=>{s.disconnect()}},[]);const h=be||qe,U=!n,Oe=!(i!=null&&i.enabled)&&!(u!=null&&u.enabled)&&!(r!=null&&r.enabled),ze=d.kendoThemeMaps.sizeMap[J]||"md",{emitSearchEvent:p}=pt.useSmartBoxSearch({selectedView:n,searchMode:i,columns:re,gridContext:C,searchHistorySettings:te,semanticSearchHistorySettings:ne,addToHistory:V,onSearch:Re,onSemanticSearch:Ie}),{sendRequest:ae,cancelRequest:oe}=nt.useGridAIRequest({requestUrl:r==null?void 0:r.requestUrl,requestOptions:r==null?void 0:r.requestOptions,columns:re,gridState:Le,gridRef:Te,onPromptRequest:t=>{N==null||N({requestData:t})},onResponseSuccess:t=>{D(!1),F==null||F({response:t})},onResponseError:t=>{D(!1),O==null||O({error:t})},onStateChange:He,onExportPdf:()=>C==null?void 0:C.exportAsPdf()});e.useImperativeHandle(x,()=>({show:()=>a(!0),hide:()=>a(!1)}),[a]);const $=dt.useDebounce(De,ye),ce=e.useRef(p);ce.current=p,e.useEffect(()=>{$!==null&&ce.current($)},[$]);const Ge=e.useCallback(t=>{const s=t.target.value;g(s),a(!s),(n==="search"||n==="semanticSearch")&&ee(s)},[a,n]),Ve=e.useCallback(()=>{v==null||v(),c||a(!0)},[v,a,c]),We=e.useCallback(t=>{var me;const s=S.current,l=(me=Y.current)==null?void 0:me.element,H=t.relatedTarget,Xe=H&&(s==null?void 0:s.contains(H)),Ye=H&&(l==null?void 0:l.contains(H));!Xe&&!Ye&&(q==null||q(),a(!1))},[q,a]),je=e.useCallback(()=>{c||a(!0)},[a,c]),ie=!!((de=r==null?void 0:r.requestOptions)!=null&&de.url||r!=null&&r.requestUrl),K=e.useCallback(()=>{if(h){w==null||w(),oe(),D(!1);return}c.trim()&&(ie&&D(!0),V("aiAssistant",c,G),a(!1),ae(c.trim()),g(""))},[h,c,G,a,V,ae,oe,ie,w]),Ue=e.useCallback(t=>{t.key==="Enter"&&(n==="aiAssistant"?K():n==="semanticSearch"&&p(c))},[n,c,p,K]),$e=e.useCallback(()=>{var t;a(!W),(t=B.current)==null||t.focus()},[W,a]),Ke=e.useCallback(t=>{var s;t.stopPropagation(),t.preventDefault(),g(""),(s=B.current)==null||s.focus(),a(!0),p("")},[a,p]),le=e.useCallback(t=>{var s;z(t),g(""),ee(null),(s=B.current)==null||s.focus()},[z]),T=e.useCallback(t=>{var s;g(t),a(!1),(s=B.current)==null||s.focus(),n!=="aiAssistant"&&p(t)},[n,a,p]),Me=e.useCallback(t=>{if(t.isFinal&&t.alternatives.length>0){const s=t.alternatives[0].transcript;g(l=>l?`${l} ${s}`:s)}},[]),_e=e.useMemo(()=>n==="aiAssistant"?P.length===0&&j.length===0:n==="search"||n==="semanticSearch"?P.length===0&&k.length===0:!1,[n,P.length,j.length,k.length]),ue=e.useCallback(t=>{const l=(n==="aiAssistant"?y:E)[t];l&&T(l.text)},[n,y,E,T]),Ae=e.useCallback(t=>{const s=k[t];s&&le(s.mode)},[k,le]),pe=e.useMemo(()=>R.createListItemRender({historyItemRender:X,promptSuggestionRender:Q,handleListItemClick:T}),[X,Q,T]),Je=W&&!Oe,Qe=()=>e.createElement(e.Fragment,null,L.items.length>0&&e.createElement(M.SegmentedControl,{items:L.items,value:L.value,onChange:L.onChange,size:J,layoutMode:"stretch"}),(n==="search"||n==="semanticSearch")&&k.length>0&&e.createElement(A.List,{data:k,textField:"text",descriptionField:"description",onClick:Ae,itemRender:R.searchModeItemRender,show:!0,wrapperCssClass:"k-list k-list-md"}),n==="aiAssistant"&&y.length>0&&e.createElement(A.List,{data:y,textField:"text",groupField:"group",svgIconField:"groupSvgIcon",descriptionField:"description",onClick:ue,itemRender:pe,groupHeaderItemRender:R.listGroupHeaderRender,showFirstGroupHeader:!0,show:!0,wrapperCssClass:"k-list k-list-md"}),(n==="search"||n==="semanticSearch")&&E.length>0&&e.createElement(A.List,{data:E,textField:"text",groupField:"group",svgIconField:"groupSvgIcon",descriptionField:"description",onClick:ue,itemRender:pe,groupHeaderItemRender:R.listGroupHeaderRender,showFirstGroupHeader:!0,show:!0,wrapperCssClass:"k-list k-list-md"}),_e&&e.createElement(R.NoDataRender,{selectedView:n}));return e.createElement("div",{ref:S,className:"k-smart-box-wrapper",dir:Se,onBlur:We},e.createElement("span",{className:d.classNames("k-smart-box","k-input",`k-input-${ze}`,{"k-loading":h})},!U&&e.createElement("span",{className:"k-input-prefix k-input-prefix-horizontal"},e.createElement(d.IconWrap,{className:d.classNames("k-icon",{"k-accent-icon":n==="aiAssistant"||n==="semanticSearch"}),icon:Fe.svgIcon,onClick:$e,onMouseDown:t=>{"preventDefault"in t&&t.preventDefault()}})),e.createElement("input",{ref:B,type:"text",className:d.classNames("k-input-inner",{"k-disabled":U}),id:ve.current,placeholder:Ne,value:c,disabled:U,onChange:Ge,onFocus:Ve,onClick:je,onKeyDown:Ue}),c.length>0&&(n==="search"||n==="semanticSearch")&&e.createElement("span",{className:"k-clear-value",title:b.toLanguageString(o.smartBoxClearTitle,o.messages[o.smartBoxClearTitle]),role:"button",tabIndex:-1,onClick:Ke,onMouseDown:t=>t.preventDefault()},e.createElement(d.IconWrap,{className:"k-icon",icon:_.xIcon})),n==="aiAssistant"&&e.createElement("span",{className:"k-input-suffix k-input-suffix-horizontal"},se&&e.createElement(M.SpeechToTextButton,{...se,"aria-label":b.toLanguageString(o.smartBoxSpeechToTextButton,o.messages[o.smartBoxSpeechToTextButton]),title:b.toLanguageString(o.smartBoxSpeechToTextButton,o.messages[o.smartBoxSpeechToTextButton]),onResult:Me}),e.createElement(M.Button,{className:d.classNames("k-smart-box-send",{"k-processing":h,"k-active":h}),type:"button",rounded:"full",size:"small",title:b.toLanguageString(o.smartBoxSubmitPromptButton,o.messages[o.smartBoxSubmitPromptButton]),"aria-label":b.toLanguageString(o.smartBoxSubmitPromptButton,o.messages[o.smartBoxSubmitPromptButton]),"aria-disabled":c.length===0,svgIcon:h?_.stopSmIcon:_.arrowUpOutlineIcon,disabled:c.length===0&&!h,onClick:K}))),e.createElement(tt.Popup,{ref:Y,anchor:S.current,show:Je,popupClass:"k-smart-box-popup",style:{width:we},anchorAlign:{horizontal:"left",vertical:"bottom"},popupAlign:{horizontal:"left",vertical:"top"},margin:{horizontal:0,vertical:2},onMouseDownOutside:t=>{const s=t.event.target;S.current&&!S.current.contains(s)&&a(!1)}},Qe()))});ge.displayName="KendoReactSmartBox";exports.SmartBox=ge;
@@ -6,17 +6,16 @@
6
6
  *-------------------------------------------------------------------------------------------
7
7
  */
8
8
  import * as e from "react";
9
- import { SegmentedControl as et } from "./SegmentedControl.mjs";
10
- import { SpeechToTextButton as tt, Button as nt } from "@progress/kendo-react-buttons";
9
+ import { SpeechToTextButton as et, Button as tt, SegmentedControl as nt } from "@progress/kendo-react-buttons";
11
10
  import { xIcon as rt, stopSmIcon as st, arrowUpOutlineIcon as at } from "@progress/kendo-svg-icons";
12
11
  import { guid as ot, kendoThemeMaps as it, classNames as B, IconWrap as ce } from "@progress/kendo-react-common";
13
12
  import { useLocalization as lt } from "@progress/kendo-react-intl";
14
- import { useGridAIRequest as ct } from "../../hooks/useGridAIRequest.mjs";
15
- import { GridContext as ut } from "../../utils/GridContext.mjs";
16
- import { List as U } from "@progress/kendo-react-dropdowns";
17
- import { Popup as pt } from "@progress/kendo-react-popup";
18
- import { createListItemRender as mt, searchModeItemRender as dt, listGroupHeaderRender as ue, NoDataRender as ft } from "./listItemRenders.mjs";
19
- import { smartBoxClearTitle as pe, messages as k, smartBoxSpeechToTextButton as y, smartBoxSubmitPromptButton as P } from "../../messages/index.mjs";
13
+ import { List as $ } from "@progress/kendo-react-dropdowns";
14
+ import { Popup as ct } from "@progress/kendo-react-popup";
15
+ import { createListItemRender as ut, searchModeItemRender as pt, listGroupHeaderRender as ue, NoDataRender as mt } from "./listItemRenders.mjs";
16
+ import { smartBoxClearTitle as pe, messages as k, smartBoxSpeechToTextButton as P, smartBoxSubmitPromptButton as L } from "../../messages/index.mjs";
17
+ import { useGridAIRequest as dt } from "../../hooks/useGridAIRequest.mjs";
18
+ import { GridContext as ft } from "../../utils/GridContext.mjs";
20
19
  import { useSmartBoxModes as ht } from "./hooks/useSmartBoxModes.mjs";
21
20
  import { useSmartBoxHistory as gt } from "./hooks/useSmartBoxHistory.mjs";
22
21
  import { useSmartBoxPopup as St } from "./hooks/useSmartBoxPopup.mjs";
@@ -25,8 +24,8 @@ import { useSmartBoxLabels as Ct } from "./hooks/useSmartBoxLabels.mjs";
25
24
  import { useSmartBoxListData as bt } from "./hooks/useSmartBoxListData.mjs";
26
25
  import { useSmartBoxSegmentedControl as xt } from "./hooks/useSmartBoxSegmentedControl.mjs";
27
26
  import { useSmartBoxSearch as Rt } from "./hooks/useSmartBoxSearch.mjs";
28
- import { useDebounce as It } from "./hooks/useDebounce.mjs";
29
- const vt = e.forwardRef((me, de) => {
27
+ import { useDebounce as vt } from "./hooks/useDebounce.mjs";
28
+ const It = e.forwardRef((me, de) => {
30
29
  var ie;
31
30
  const {
32
31
  searchConfig: fe,
@@ -34,32 +33,32 @@ const vt = e.forwardRef((me, de) => {
34
33
  aiAssistantConfig: ge,
35
34
  activeMode: Se,
36
35
  dir: ke = "ltr",
37
- size: $ = "medium",
36
+ size: K = "medium",
38
37
  placeholder: Ce,
39
38
  history: be,
40
39
  loading: xe = !1,
41
- promptSuggestionRender: K,
42
- historyItemRender: j,
40
+ promptSuggestionRender: j,
41
+ historyItemRender: J,
43
42
  onOpen: Re,
44
- onClose: Ie,
43
+ onClose: ve,
45
44
  onFocus: C,
46
45
  onBlur: b,
47
- onSearch: ve,
46
+ onSearch: Ie,
48
47
  onSemanticSearch: we,
49
- onAIPromptRequest: L,
50
- onAIResponseSuccess: F,
51
- onAIResponseError: H,
48
+ onAIPromptRequest: F,
49
+ onAIResponseSuccess: H,
50
+ onAIResponseError: z,
52
51
  onAICancelRequest: x
53
- } = me, h = lt(), g = e.useContext(ut), Ee = e.useRef(`k-${ot()}`), d = e.useRef(null), S = e.useRef(null), J = e.useRef(null), [o, p] = e.useState(""), [De, R] = e.useState(!1), [Be, Q] = e.useState(void 0), [ye, X] = e.useState(null), {
52
+ } = me, h = lt(), g = e.useContext(ft), Ee = e.useRef(`k-${ot()}`), d = e.useRef(null), S = e.useRef(null), M = e.useRef(null), [o, p] = e.useState(""), [De, R] = e.useState(!1), [ye, Q] = e.useState(void 0), [Be, X] = e.useState(null), {
54
53
  searchMode: i,
55
54
  semanticSearchMode: c,
56
55
  aiAssistantMode: s,
57
56
  selectedView: n,
58
- setSelectedViewState: z,
57
+ setSelectedViewState: N,
59
58
  lastSearchMode: Pe,
60
59
  searchHistorySettings: Y,
61
60
  semanticSearchHistorySettings: Z,
62
- aiAssistantHistorySettings: N,
61
+ aiAssistantHistorySettings: T,
63
62
  speechToTextButtonSettings: _,
64
63
  currentSearchDelay: Le
65
64
  } = ht({
@@ -68,12 +67,12 @@ const vt = e.forwardRef((me, de) => {
68
67
  aiAssistantConfigProp: ge,
69
68
  activeModeProp: Se,
70
69
  sharedHistory: be
71
- }), { currentHistory: I, currentHistorySettings: Fe, addToHistory: T } = gt({
70
+ }), { currentHistory: v, currentHistorySettings: Fe, addToHistory: q } = gt({
72
71
  selectedView: n,
73
72
  searchHistorySettings: Y,
74
73
  semanticSearchHistorySettings: Z,
75
- aiAssistantHistorySettings: N
76
- }), { isOpen: q, togglePopup: a } = St({ onOpen: Re, onClose: Ie }), { columns: A, gridState: He, gridRef: ze, handleStateChange: Ne } = kt(g), O = e.useMemo(
74
+ aiAssistantHistorySettings: T
75
+ }), { isOpen: O, togglePopup: a } = St({ onOpen: Re, onClose: ve }), { columns: A, gridState: He, gridRef: ze, handleStateChange: Ne } = kt(g), V = e.useMemo(
77
76
  () => (s == null ? void 0 : s.promptSuggestions) || [],
78
77
  [s == null ? void 0 : s.promptSuggestions]
79
78
  ), { inputPlaceholder: Te, prefixIcon: qe } = Ct({
@@ -82,20 +81,20 @@ const vt = e.forwardRef((me, de) => {
82
81
  semanticSearchMode: c,
83
82
  aiAssistantMode: s,
84
83
  sharedPlaceholder: Ce
85
- }), { searchListData: f, aiAssistantListData: v, searchHistoryListData: w } = bt({
84
+ }), { searchListData: f, aiAssistantListData: I, searchHistoryListData: w } = bt({
86
85
  selectedView: n,
87
86
  searchModeEnabled: i == null ? void 0 : i.enabled,
88
87
  semanticSearchModeEnabled: c == null ? void 0 : c.enabled,
89
- promptSuggestions: O,
90
- currentHistory: I,
88
+ promptSuggestions: V,
89
+ currentHistory: v,
91
90
  currentHistorySettings: Fe
92
- }), M = xt({
91
+ }), E = xt({
93
92
  searchMode: i,
94
93
  semanticSearchMode: c,
95
94
  aiAssistantMode: s,
96
95
  selectedView: n,
97
96
  lastSearchMode: Pe,
98
- setSelectedViewState: z,
97
+ setSelectedViewState: N,
99
98
  setInputValue: p
100
99
  });
101
100
  e.useEffect(() => {
@@ -110,30 +109,30 @@ const vt = e.forwardRef((me, de) => {
110
109
  r.disconnect();
111
110
  };
112
111
  }, []);
113
- const m = xe || De, V = !n, Oe = !(i != null && i.enabled) && !(c != null && c.enabled) && !(s != null && s.enabled), Ve = it.sizeMap[$] || "md", { emitSearchEvent: u } = Rt({
112
+ const m = xe || De, W = !n, Oe = !(i != null && i.enabled) && !(c != null && c.enabled) && !(s != null && s.enabled), Ve = it.sizeMap[K] || "md", { emitSearchEvent: u } = Rt({
114
113
  selectedView: n,
115
114
  searchMode: i,
116
115
  columns: A,
117
116
  gridContext: g,
118
117
  searchHistorySettings: Y,
119
118
  semanticSearchHistorySettings: Z,
120
- addToHistory: T,
121
- onSearch: ve,
119
+ addToHistory: q,
120
+ onSearch: Ie,
122
121
  onSemanticSearch: we
123
- }), { sendRequest: ee, cancelRequest: te } = ct({
122
+ }), { sendRequest: ee, cancelRequest: te } = dt({
124
123
  requestUrl: s == null ? void 0 : s.requestUrl,
125
124
  requestOptions: s == null ? void 0 : s.requestOptions,
126
125
  columns: A,
127
126
  gridState: He,
128
127
  gridRef: ze,
129
128
  onPromptRequest: (t) => {
130
- L == null || L({ requestData: t });
129
+ F == null || F({ requestData: t });
131
130
  },
132
131
  onResponseSuccess: (t) => {
133
- R(!1), F == null || F({ response: t });
132
+ R(!1), H == null || H({ response: t });
134
133
  },
135
134
  onResponseError: (t) => {
136
- R(!1), H == null || H({ error: t });
135
+ R(!1), z == null || z({ error: t });
137
136
  },
138
137
  onStateChange: Ne,
139
138
  onExportPdf: () => g == null ? void 0 : g.exportAsPdf()
@@ -146,10 +145,10 @@ const vt = e.forwardRef((me, de) => {
146
145
  }),
147
146
  [a]
148
147
  );
149
- const W = It(ye, Le), ne = e.useRef(u);
148
+ const G = vt(Be, Le), ne = e.useRef(u);
150
149
  ne.current = u, e.useEffect(() => {
151
- W !== null && ne.current(W);
152
- }, [W]);
150
+ G !== null && ne.current(G);
151
+ }, [G]);
153
152
  const We = e.useCallback(
154
153
  (t) => {
155
154
  const r = t.target.value;
@@ -161,37 +160,37 @@ const vt = e.forwardRef((me, de) => {
161
160
  }, [C, a, o]), Ue = e.useCallback(
162
161
  (t) => {
163
162
  var le;
164
- const r = d.current, l = (le = J.current) == null ? void 0 : le.element, D = t.relatedTarget, Ae = D && (r == null ? void 0 : r.contains(D)), Me = D && (l == null ? void 0 : l.contains(D));
165
- !Ae && !Me && (b == null || b(), a(!1));
163
+ const r = d.current, l = (le = M.current) == null ? void 0 : le.element, y = t.relatedTarget, _e = y && (r == null ? void 0 : r.contains(y)), Ae = y && (l == null ? void 0 : l.contains(y));
164
+ !_e && !Ae && (b == null || b(), a(!1));
166
165
  },
167
166
  [b, a]
168
167
  ), $e = e.useCallback(() => {
169
168
  o || a(!0);
170
- }, [a, o]), re = !!((ie = s == null ? void 0 : s.requestOptions) != null && ie.url || s != null && s.requestUrl), G = e.useCallback(() => {
169
+ }, [a, o]), re = !!((ie = s == null ? void 0 : s.requestOptions) != null && ie.url || s != null && s.requestUrl), U = e.useCallback(() => {
171
170
  if (m) {
172
171
  x == null || x(), te(), R(!1);
173
172
  return;
174
173
  }
175
- o.trim() && (re && R(!0), T("aiAssistant", o, N), a(!1), ee(o.trim()), p(""));
174
+ o.trim() && (re && R(!0), q("aiAssistant", o, T), a(!1), ee(o.trim()), p(""));
176
175
  }, [
177
176
  m,
178
177
  o,
179
- N,
180
- a,
181
178
  T,
179
+ a,
180
+ q,
182
181
  ee,
183
182
  te,
184
183
  re,
185
184
  x
186
185
  ]), Ke = e.useCallback(
187
186
  (t) => {
188
- t.key === "Enter" && (n === "aiAssistant" ? G() : n === "semanticSearch" && u(o));
187
+ t.key === "Enter" && (n === "aiAssistant" ? U() : n === "semanticSearch" && u(o));
189
188
  },
190
- [n, o, u, G]
189
+ [n, o, u, U]
191
190
  ), je = e.useCallback(() => {
192
191
  var t;
193
- a(!q), (t = S.current) == null || t.focus();
194
- }, [q, a]), Je = e.useCallback(
192
+ a(!O), (t = S.current) == null || t.focus();
193
+ }, [O, a]), Je = e.useCallback(
195
194
  (t) => {
196
195
  var r;
197
196
  t.stopPropagation(), t.preventDefault(), p(""), (r = S.current) == null || r.focus(), a(!0), u("");
@@ -200,54 +199,63 @@ const vt = e.forwardRef((me, de) => {
200
199
  ), se = e.useCallback(
201
200
  (t) => {
202
201
  var r;
203
- z(t), p(""), X(null), (r = S.current) == null || r.focus();
202
+ N(t), p(""), X(null), (r = S.current) == null || r.focus();
204
203
  },
205
- [z]
206
- ), E = e.useCallback(
204
+ [N]
205
+ ), D = e.useCallback(
207
206
  (t) => {
208
207
  var r;
209
208
  p(t), a(!1), (r = S.current) == null || r.focus(), n !== "aiAssistant" && u(t);
210
209
  },
211
210
  [n, a, u]
212
- ), Qe = e.useCallback((t) => {
211
+ ), Me = e.useCallback((t) => {
213
212
  if (t.isFinal && t.alternatives.length > 0) {
214
213
  const r = t.alternatives[0].transcript;
215
214
  p((l) => l ? `${l} ${r}` : r);
216
215
  }
217
- }, []), Xe = e.useMemo(() => n === "aiAssistant" ? I.length === 0 && O.length === 0 : n === "search" || n === "semanticSearch" ? I.length === 0 && f.length === 0 : !1, [n, I.length, O.length, f.length]), ae = e.useCallback(
216
+ }, []), Qe = e.useMemo(() => n === "aiAssistant" ? v.length === 0 && V.length === 0 : n === "search" || n === "semanticSearch" ? v.length === 0 && f.length === 0 : !1, [n, v.length, V.length, f.length]), ae = e.useCallback(
218
217
  (t) => {
219
- const l = (n === "aiAssistant" ? v : w)[t];
220
- l && E(l.text);
218
+ const l = (n === "aiAssistant" ? I : w)[t];
219
+ l && D(l.text);
221
220
  },
222
- [n, v, w, E]
223
- ), Ye = e.useCallback(
221
+ [n, I, w, D]
222
+ ), Xe = e.useCallback(
224
223
  (t) => {
225
224
  const r = f[t];
226
225
  r && se(r.mode);
227
226
  },
228
227
  [f, se]
229
228
  ), oe = e.useMemo(
230
- () => mt({
231
- historyItemRender: j,
232
- promptSuggestionRender: K,
233
- handleListItemClick: E
229
+ () => ut({
230
+ historyItemRender: J,
231
+ promptSuggestionRender: j,
232
+ handleListItemClick: D
234
233
  }),
235
- [j, K, E]
236
- ), Ze = q && !Oe, _e = () => /* @__PURE__ */ e.createElement(e.Fragment, null, M.length > 0 && /* @__PURE__ */ e.createElement(et, { buttons: M, size: $, stretched: !0 }), (n === "search" || n === "semanticSearch") && f.length > 0 && /* @__PURE__ */ e.createElement(
237
- U,
234
+ [J, j, D]
235
+ ), Ye = O && !Oe, Ze = () => /* @__PURE__ */ e.createElement(e.Fragment, null, E.items.length > 0 && /* @__PURE__ */ e.createElement(
236
+ nt,
237
+ {
238
+ items: E.items,
239
+ value: E.value,
240
+ onChange: E.onChange,
241
+ size: K,
242
+ layoutMode: "stretch"
243
+ }
244
+ ), (n === "search" || n === "semanticSearch") && f.length > 0 && /* @__PURE__ */ e.createElement(
245
+ $,
238
246
  {
239
247
  data: f,
240
248
  textField: "text",
241
249
  descriptionField: "description",
242
- onClick: Ye,
243
- itemRender: dt,
250
+ onClick: Xe,
251
+ itemRender: pt,
244
252
  show: !0,
245
253
  wrapperCssClass: "k-list k-list-md"
246
254
  }
247
- ), n === "aiAssistant" && v.length > 0 && /* @__PURE__ */ e.createElement(
248
- U,
255
+ ), n === "aiAssistant" && I.length > 0 && /* @__PURE__ */ e.createElement(
256
+ $,
249
257
  {
250
- data: v,
258
+ data: I,
251
259
  textField: "text",
252
260
  groupField: "group",
253
261
  svgIconField: "groupSvgIcon",
@@ -260,7 +268,7 @@ const vt = e.forwardRef((me, de) => {
260
268
  wrapperCssClass: "k-list k-list-md"
261
269
  }
262
270
  ), (n === "search" || n === "semanticSearch") && w.length > 0 && /* @__PURE__ */ e.createElement(
263
- U,
271
+ $,
264
272
  {
265
273
  data: w,
266
274
  textField: "text",
@@ -274,7 +282,7 @@ const vt = e.forwardRef((me, de) => {
274
282
  show: !0,
275
283
  wrapperCssClass: "k-list k-list-md"
276
284
  }
277
- ), Xe && /* @__PURE__ */ e.createElement(ft, { selectedView: n }));
285
+ ), Qe && /* @__PURE__ */ e.createElement(mt, { selectedView: n }));
278
286
  return /* @__PURE__ */ e.createElement("div", { ref: d, className: "k-smart-box-wrapper", dir: ke, onBlur: Ue }, /* @__PURE__ */ e.createElement(
279
287
  "span",
280
288
  {
@@ -282,7 +290,7 @@ const vt = e.forwardRef((me, de) => {
282
290
  "k-loading": m
283
291
  })
284
292
  },
285
- !V && /* @__PURE__ */ e.createElement("span", { className: "k-input-prefix k-input-prefix-horizontal" }, /* @__PURE__ */ e.createElement(
293
+ !W && /* @__PURE__ */ e.createElement("span", { className: "k-input-prefix k-input-prefix-horizontal" }, /* @__PURE__ */ e.createElement(
286
294
  ce,
287
295
  {
288
296
  className: B("k-icon", {
@@ -300,11 +308,11 @@ const vt = e.forwardRef((me, de) => {
300
308
  {
301
309
  ref: S,
302
310
  type: "text",
303
- className: B("k-input-inner", { "k-disabled": V }),
311
+ className: B("k-input-inner", { "k-disabled": W }),
304
312
  id: Ee.current,
305
313
  placeholder: Te,
306
314
  value: o,
307
- disabled: V,
315
+ disabled: W,
308
316
  onChange: We,
309
317
  onFocus: Ge,
310
318
  onClick: $e,
@@ -327,21 +335,21 @@ const vt = e.forwardRef((me, de) => {
327
335
  /* @__PURE__ */ e.createElement(ce, { className: "k-icon", icon: rt })
328
336
  ),
329
337
  n === "aiAssistant" && /* @__PURE__ */ e.createElement("span", { className: "k-input-suffix k-input-suffix-horizontal" }, _ && /* @__PURE__ */ e.createElement(
330
- tt,
338
+ et,
331
339
  {
332
340
  ..._,
333
341
  "aria-label": h.toLanguageString(
334
- y,
335
- k[y]
342
+ P,
343
+ k[P]
336
344
  ),
337
345
  title: h.toLanguageString(
338
- y,
339
- k[y]
346
+ P,
347
+ k[P]
340
348
  ),
341
- onResult: Qe
349
+ onResult: Me
342
350
  }
343
351
  ), /* @__PURE__ */ e.createElement(
344
- nt,
352
+ tt,
345
353
  {
346
354
  className: B("k-smart-box-send", {
347
355
  "k-processing": m,
@@ -351,27 +359,27 @@ const vt = e.forwardRef((me, de) => {
351
359
  rounded: "full",
352
360
  size: "small",
353
361
  title: h.toLanguageString(
354
- P,
355
- k[P]
362
+ L,
363
+ k[L]
356
364
  ),
357
365
  "aria-label": h.toLanguageString(
358
- P,
359
- k[P]
366
+ L,
367
+ k[L]
360
368
  ),
361
369
  "aria-disabled": o.length === 0,
362
370
  svgIcon: m ? st : at,
363
371
  disabled: o.length === 0 && !m,
364
- onClick: G
372
+ onClick: U
365
373
  }
366
374
  ))
367
375
  ), /* @__PURE__ */ e.createElement(
368
- pt,
376
+ ct,
369
377
  {
370
- ref: J,
378
+ ref: M,
371
379
  anchor: d.current,
372
- show: Ze,
380
+ show: Ye,
373
381
  popupClass: "k-smart-box-popup",
374
- style: { width: Be },
382
+ style: { width: ye },
375
383
  anchorAlign: { horizontal: "left", vertical: "bottom" },
376
384
  popupAlign: { horizontal: "left", vertical: "top" },
377
385
  margin: { horizontal: 0, vertical: 2 },
@@ -380,10 +388,10 @@ const vt = e.forwardRef((me, de) => {
380
388
  d.current && !d.current.contains(r) && a(!1);
381
389
  }
382
390
  },
383
- _e()
391
+ Ze()
384
392
  ));
385
393
  });
386
- vt.displayName = "KendoReactSmartBox";
394
+ It.displayName = "KendoReactSmartBox";
387
395
  export {
388
- vt as SmartBox
396
+ It as SmartBox
389
397
  };
@@ -5,7 +5,7 @@
5
5
  * Licensed under commercial license. See LICENSE.md in the package root for more information
6
6
  *-------------------------------------------------------------------------------------------
7
7
  */
8
- import { SmartBoxMode, SegmentedButtonProps } from '../interfaces/index.js';
8
+ import { SmartBoxMode } from '../interfaces/index.js';
9
9
  import * as React from 'react';
10
10
  /**
11
11
  * Represents a minimal mode configuration for the segmented control.
@@ -63,8 +63,17 @@ export interface UseSmartBoxSegmentedControlProps {
63
63
  * appropriate icon based on the last selected search mode.
64
64
  *
65
65
  * @param props - The hook properties.
66
- * @returns An array of segmented button props for the mode switcher.
66
+ * @returns An object containing the button array and handler function for the SegmentedControl onChange event.
67
67
  *
68
68
  * @hidden
69
69
  */
70
- export declare function useSmartBoxSegmentedControl({ searchMode, semanticSearchMode, aiAssistantMode, selectedView, lastSearchMode, setSelectedViewState, setInputValue }: UseSmartBoxSegmentedControlProps): SegmentedButtonProps[];
70
+ export declare function useSmartBoxSegmentedControl({ searchMode, semanticSearchMode, aiAssistantMode, selectedView, lastSearchMode, setSelectedViewState, setInputValue }: UseSmartBoxSegmentedControlProps): {
71
+ items: {
72
+ value: string;
73
+ text: string;
74
+ svgIcon?: any;
75
+ iconClassName?: string | undefined;
76
+ }[];
77
+ value: string | undefined;
78
+ onChange: (value: string) => void;
79
+ };
@@ -6,4 +6,4 @@
6
6
  *-------------------------------------------------------------------------------------------
7
7
  */
8
8
  "use client";
9
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const v=require("react"),I=require("@progress/kendo-svg-icons");function y(n){const t=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(n){for(const u in n)if(u!=="default"){const b=Object.getOwnPropertyDescriptor(n,u);Object.defineProperty(t,u,b.get?b:{enumerable:!0,get:()=>n[u]})}}return t.default=n,Object.freeze(t)}const x=y(v);function C({searchMode:n,semanticSearchMode:t,aiAssistantMode:u,selectedView:b,lastSearchMode:l,setSelectedViewState:f,setInputValue:r}){return x.useMemo(()=>{const g=[],p=(n==null?void 0:n.enabled)||(t==null?void 0:t.enabled),k=u==null?void 0:u.enabled;if(p&&k){const O=b==="search"||b==="semanticSearch",c=l||(n!=null&&n.enabled?"search":"semanticSearch"),o=b==="semanticSearch"||b==="aiAssistant"&&c==="semanticSearch",j=o?I.zoomSparkleIcon:I.searchIcon;g.push({buttonId:1,text:"Search",svgIcon:j,selected:O,accentIcon:o,onClick:()=>{l&&(l==="search"?n!=null&&n.enabled:t!=null&&t.enabled)?f(l):n!=null&&n.enabled?f("search"):t!=null&&t.enabled&&f("semanticSearch"),r("")}}),g.push({buttonId:2,text:"AI Assistant",svgIcon:I.sparklesIcon,selected:b==="aiAssistant",accentIcon:!0,onClick:()=>{f("aiAssistant"),r("")}})}return g},[n,t,u,b,l,f,r])}exports.useSmartBoxSegmentedControl=C;
9
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const p=require("react"),g=require("@progress/kendo-svg-icons");function O(n){const t=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(n){for(const l in n)if(l!=="default"){const u=Object.getOwnPropertyDescriptor(n,l);Object.defineProperty(t,l,u.get?u:{enumerable:!0,get:()=>n[l]})}}return t.default=n,Object.freeze(t)}const o=O(p);function a({searchMode:n,semanticSearchMode:t,aiAssistantMode:l,selectedView:u,lastSearchMode:r,setSelectedViewState:f,setInputValue:i}){const v=o.useMemo(()=>{const b=(n==null?void 0:n.enabled)||(t==null?void 0:t.enabled),k=l==null?void 0:l.enabled;if(!b||!k)return[];const s=u==="semanticSearch"||u==="aiAssistant"&&r==="semanticSearch";return[{value:"search",text:"Search",svgIcon:s?g.zoomSparkleIcon:g.searchIcon,iconClassName:s?"k-accent-icon":void 0},{value:"aiAssistant",text:"AI Assistant",svgIcon:g.sparklesIcon,iconClassName:"k-accent-icon"}]},[n,t,l,u,r]),C=o.useCallback(()=>{if(u==="search"||u==="semanticSearch")return"search";if(u==="aiAssistant")return"aiAssistant"},[u]),I=o.useCallback(b=>{b==="search"?r&&(r==="search"?n!=null&&n.enabled:t!=null&&t.enabled)?f(r):n!=null&&n.enabled?f("search"):t!=null&&t.enabled&&f("semanticSearch"):b==="aiAssistant"&&f("aiAssistant"),i("")},[n,t,r,f,i]);return{items:v,value:C(),onChange:I}}exports.useSmartBoxSegmentedControl=a;