@progress/kendo-react-grid 11.0.0-develop.13 → 11.0.0-develop.15
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/BasePDFExport.js +1 -1
- package/BasePDFExport.mjs +21 -21
- package/GridClientWrapper.js +1 -1
- package/GridClientWrapper.mjs +1 -1
- package/GridComponent.js +1 -1
- package/GridComponent.mjs +136 -136
- package/codemods/v11/cell-render.js +9 -0
- package/codemods/v11/column-cell.js +9 -0
- package/codemods/v11/column-filter-cell.js +9 -0
- package/codemods/v11/column-footer-cell.js +9 -0
- package/codemods/v11/column-header-cell.js +9 -0
- package/codemods/v11/detail-expand-state.js +9 -0
- package/codemods/v11/edit-state.js +9 -0
- package/codemods/v11/filter-cell-render.js +9 -0
- package/codemods/v11/group-expand-state.js +9 -0
- package/codemods/v11/header-cell-render.js +9 -0
- package/codemods/v11/index.js +9 -0
- package/codemods/v11/row-render.js +9 -0
- package/codemods/v11/selection-state.js +9 -0
- package/codemods/v11/utils.js +9 -0
- package/dist/cdn/js/kendo-react-grid.js +1 -1
- package/package-metadata.js +1 -1
- package/package-metadata.mjs +2 -2
- package/package.json +77 -21
- package/codemods/index.js +0 -8
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
*-------------------------------------------------------------------------------------------
|
|
4
|
+
* Copyright © 2025 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 strict";const t=require("./utils.js");function v(d,C){const e=C.jscodeshift,n=e(d.source),a=d.path.endsWith(".ts")||d.path.endsWith(".tsx");let c=!1;const u=new Set;n.find(e.Identifier).forEach(r=>{u.add(r.node.name)});const f="CustomColumnCell",g=t.findImportedName(e,n,"Grid","@progress/kendo-react-grid")||"Grid",E=t.findImportedName(e,n,"GridColumn","@progress/kendo-react-grid")||"GridColumn";return n.find(e.JSXElement,{openingElement:{name:{name:g}}}).forEach(r=>{const{isClassComponent:i,parentNode:h}=t.findParentComponent(e,r);e(r).find(e.JSXElement,{openingElement:{name:{name:E}}}).forEach((N,G)=>{const m=N.node.openingElement.attributes;if(!m)return;const o=m.find(p=>p.type==="JSXAttribute"&&p.name.name==="cell");if(!o)return;const l=t.generateUniqueName(`${f}$${G+1}`,u),S=o!=null&&o.value?e(o.value).toSource():"No value provided";t.removeAttribute(m,"cell"),t.ensureAttributeExists(e,m,"cells","data",i?`this.${l}`:l),c=!0;let s;i?s=t.createMethodForClassComponent(e,l,a,"GridCustomCellProps"):s=t.createArrowFunctionForFunctionalComponent(e,l,a,"GridCustomCellProps"),t.addMethodToComponent(e,h,s,i),s&&t.addCommentToMethod(e,e(s),`Original cell value: ${S}`,i?"class":"function")})}),c&&a&&t.ensureImportExists(e,n,"GridCustomCellProps","@progress/kendo-react-grid"),n.toSource()}module.exports=v;
|
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"column-cell.js","sources":["../../../../../packages/grid/codemods/v11/column-cell.ts"],"sourcesContent":["import { API, FileInfo, JSCodeshift, JSXAttribute, JSXSpreadAttribute } from 'jscodeshift';\nimport {\n    addCommentToMethod,\n    ensureAttributeExists,\n    findParentComponent,\n    generateUniqueName,\n    ensureImportExists,\n    createMethodForClassComponent,\n    createArrowFunctionForFunctionalComponent,\n    addMethodToComponent,\n    removeAttribute,\n    findImportedName\n} from './utils';\n\nexport default function (fileInfo: FileInfo, api: API) {\n    const j: JSCodeshift = api.jscodeshift;\n    const root = j(fileInfo.source);\n\n    // Check if the file is TypeScript or TSX\n    const isTypeScript = fileInfo.path.endsWith('.ts') || fileInfo.path.endsWith('.tsx');\n\n    let addImports = false;\n    const existingNames = new Set<string>();\n    root.find(j.Identifier).forEach((path) => {\n        existingNames.add(path.node.name);\n    });\n\n    const baseName = 'CustomColumnCell';\n\n    // Ensures we find the correct Grid and GridColumn imports\n    const gridName = findImportedName(j, root, 'Grid', '@progress/kendo-react-grid') || 'Grid';\n    const columnName = findImportedName(j, root, 'GridColumn', '@progress/kendo-react-grid') || 'GridColumn';\n\n    // Find all JSXElements with the name of the Grid component\n    const gridElements = root.find(j.JSXElement, { openingElement: { name: { name: gridName } } });\n\n    gridElements.forEach((gridPath) => {\n        const { isClassComponent, parentNode } = findParentComponent(j, gridPath);\n\n        // Separate counters for functional and class components\n\n        // Find all columns inside the current Grid\n        const columnElements = j(gridPath).find(j.JSXElement, { openingElement: { name: { name: columnName } } });\n\n        columnElements.forEach((columnPath, index) => {\n            const columnAttributes = columnPath.node.openingElement.attributes;\n\n            if (!columnAttributes) {\n                return;\n            }\n\n            // Find the 'cell' attribute\n            const cellAttribute = columnAttributes.find(\n                (attr) => attr.type === 'JSXAttribute' && attr.name.name === 'cell'\n            ) as JSXAttribute;\n\n            if (!cellAttribute) {\n                return; // Skip if no 'cell' attribute is found\n            }\n\n            // Generate a unique name for the CustomColumnCell function\n            const uniqueName = generateUniqueName(`${baseName}$${index + 1}`, existingNames);\n\n            // Copy the value of the 'cell' attribute as a comment\n            const cellValue = cellAttribute?.value ? j(cellAttribute.value).toSource() : 'No value provided';\n\n            // Remove the 'cell' attribute\n            removeAttribute(columnAttributes as (JSXAttribute | JSXSpreadAttribute)[], 'cell');\n\n            // Ensure the 'cells' attribute exists and assign the new method\n            ensureAttributeExists(\n                j,\n                columnAttributes,\n                'cells',\n                'data',\n                isClassComponent ? `this.${uniqueName}` : uniqueName\n            );\n\n            addImports = true; // Mark that imports need to be added\n\n            // Add the `cell` value as a comment in the CustomColumnCell method\n            let customMethod;\n\n            if (isClassComponent) {\n                // Create a proper class method for class components\n                customMethod = createMethodForClassComponent(j, uniqueName, isTypeScript, 'GridCustomCellProps');\n            } else {\n                // Create an arrow function for functional components\n                customMethod = createArrowFunctionForFunctionalComponent(\n                    j,\n                    uniqueName,\n                    isTypeScript,\n                    'GridCustomCellProps'\n                );\n            }\n\n            // Add the CustomColumnCell method to the component\n            addMethodToComponent(j, parentNode, customMethod, isClassComponent);\n\n            // Add the `cell` value as a comment in the method\n            if (customMethod) {\n                addCommentToMethod(\n                    j,\n                    j(customMethod),\n                    `Original cell value: ${cellValue}`,\n                    isClassComponent ? 'class' : 'function'\n                );\n            }\n        });\n    });\n\n    if (addImports) {\n        // Ensure the import for GridCustomCellProps exists\n        if (isTypeScript) {\n            ensureImportExists(j, root, 'GridCustomCellProps', '@progress/kendo-react-grid');\n        }\n    }\n\n    return root.toSource();\n}\n"],"names":["columnCell","fileInfo","api","j","root","isTypeScript","addImports","existingNames","path","baseName","gridName","findImportedName","columnName","gridPath","isClassComponent","parentNode","findParentComponent","columnPath","index","columnAttributes","cellAttribute","attr","uniqueName","generateUniqueName","cellValue","removeAttribute","ensureAttributeExists","customMethod","createMethodForClassComponent","createArrowFunctionForFunctionalComponent","addMethodToComponent","addCommentToMethod","ensureImportExists"],"mappings":"2CAcA,SAAAA,EAAyBC,EAAoBC,EAAU,CACnD,MAAMC,EAAiBD,EAAI,YACrBE,EAAOD,EAAEF,EAAS,MAAM,EAGxBI,EAAeJ,EAAS,KAAK,SAAS,KAAK,GAAKA,EAAS,KAAK,SAAS,MAAM,EAEnF,IAAIK,EAAa,GACX,MAAAC,MAAoB,IAC1BH,EAAK,KAAKD,EAAE,UAAU,EAAE,QAASK,GAAS,CACxBD,EAAA,IAAIC,EAAK,KAAK,IAAI,CAAA,CACnC,EAED,MAAMC,EAAW,mBAGXC,EAAWC,EAAAA,iBAAiBR,EAAGC,EAAM,OAAQ,4BAA4B,GAAK,OAC9EQ,EAAaD,EAAAA,iBAAiBR,EAAGC,EAAM,aAAc,4BAA4B,GAAK,aAK/E,OAFQA,EAAK,KAAKD,EAAE,WAAY,CAAE,eAAgB,CAAE,KAAM,CAAE,KAAMO,CAAS,CAAA,CAAK,CAAA,EAEhF,QAASG,GAAa,CAC/B,KAAM,CAAE,iBAAAC,EAAkB,WAAAC,CAAA,EAAeC,EAAAA,oBAAoBb,EAAGU,CAAQ,EAKjDV,EAAEU,CAAQ,EAAE,KAAKV,EAAE,WAAY,CAAE,eAAgB,CAAE,KAAM,CAAE,KAAMS,CAAW,CAAA,CAAK,CAAA,EAEzF,QAAQ,CAACK,EAAYC,IAAU,CACpC,MAAAC,EAAmBF,EAAW,KAAK,eAAe,WAExD,GAAI,CAACE,EACD,OAIJ,MAAMC,EAAgBD,EAAiB,KAClCE,GAASA,EAAK,OAAS,gBAAkBA,EAAK,KAAK,OAAS,MAAA,EAGjE,GAAI,CAACD,EACD,OAIE,MAAAE,EAAaC,qBAAmB,GAAGd,CAAQ,IAAIS,EAAQ,CAAC,GAAIX,CAAa,EAGzEiB,EAAYJ,GAAA,MAAAA,EAAe,MAAQjB,EAAEiB,EAAc,KAAK,EAAE,SAAa,EAAA,oBAG7EK,kBAAgBN,EAA2D,MAAM,EAGjFO,EAAA,sBACIvB,EACAgB,EACA,QACA,OACAL,EAAmB,QAAQQ,CAAU,GAAKA,CAAA,EAGjChB,EAAA,GAGT,IAAAqB,EAEAb,EAEAa,EAAeC,EAA8B,8BAAAzB,EAAGmB,EAAYjB,EAAc,qBAAqB,EAGhFsB,EAAAE,EAAA,0CACX1B,EACAmB,EACAjB,EACA,qBAAA,EAKayB,EAAAA,qBAAA3B,EAAGY,EAAYY,EAAcb,CAAgB,EAG9Da,GACAI,EAAA,mBACI5B,EACAA,EAAEwB,CAAY,EACd,wBAAwBH,CAAS,GACjCV,EAAmB,QAAU,UAAA,CAErC,CACH,CAAA,CACJ,EAEGR,GAEID,GACmB2B,EAAAA,mBAAA7B,EAAGC,EAAM,sBAAuB,4BAA4B,EAIhFA,EAAK,UAChB"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
*-------------------------------------------------------------------------------------------
|
|
4
|
+
* Copyright © 2025 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 strict";const t=require("./utils.js");function S(d,C){const e=C.jscodeshift,n=e(d.source),a=d.path.endsWith(".ts")||d.path.endsWith(".tsx");let c=!1;const u=new Set;n.find(e.Identifier).forEach(s=>{u.add(s.node.name)});const f="CustomColumnFilterCell",g=t.findImportedName(e,n,"Grid","@progress/kendo-react-grid")||"Grid",E=t.findImportedName(e,n,"GridColumn","@progress/kendo-react-grid")||"GridColumn";return n.find(e.JSXElement,{openingElement:{name:{name:g}}}).forEach(s=>{const{isClassComponent:i,parentNode:h}=t.findParentComponent(e,s);e(s).find(e.JSXElement,{openingElement:{name:{name:E}}}).forEach((N,F)=>{const l=N.node.openingElement.attributes;if(!l)return;const o=l.find(p=>p.type==="JSXAttribute"&&p.name.name==="filterCell");if(!o)return;const m=t.generateUniqueName(`${f}$${F+1}`,u),G=o!=null&&o.value?e(o.value).toSource():"No value provided";t.removeAttribute(l,"filterCell"),t.ensureAttributeExists(e,l,"cells","filterCell",i?`this.${m}`:m),c=!0;let r;i?r=t.createMethodForClassComponent(e,m,a,"GridCustomFilterCellProps"):r=t.createArrowFunctionForFunctionalComponent(e,m,a,"GridCustomFilterCellProps"),t.addMethodToComponent(e,h,r,i),r&&t.addCommentToMethod(e,e(r),`Original filterCell value: ${G}`,i?"class":"function")})}),c&&a&&t.ensureImportExists(e,n,"GridCustomFilterCellProps","@progress/kendo-react-grid"),n.toSource()}module.exports=S;
|
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"column-filter-cell.js","sources":["../../../../../packages/grid/codemods/v11/column-filter-cell.ts"],"sourcesContent":["import { API, FileInfo, JSCodeshift, JSXAttribute, JSXSpreadAttribute } from 'jscodeshift';\nimport {\n    addCommentToMethod,\n    ensureAttributeExists,\n    findParentComponent,\n    generateUniqueName,\n    ensureImportExists,\n    createMethodForClassComponent,\n    createArrowFunctionForFunctionalComponent,\n    addMethodToComponent,\n    removeAttribute,\n    findImportedName\n} from './utils';\n\nexport default function (fileInfo: FileInfo, api: API) {\n    const j: JSCodeshift = api.jscodeshift;\n    const root = j(fileInfo.source);\n\n    // Check if the file is TypeScript or TSX\n    const isTypeScript = fileInfo.path.endsWith('.ts') || fileInfo.path.endsWith('.tsx');\n\n    let addImports = false;\n    const existingNames = new Set<string>();\n    root.find(j.Identifier).forEach((path) => {\n        existingNames.add(path.node.name);\n    });\n\n    const baseName = 'CustomColumnFilterCell';\n\n    // Ensures we find the correct Grid and GridColumn imports\n    const gridName = findImportedName(j, root, 'Grid', '@progress/kendo-react-grid') || 'Grid';\n    const columnName = findImportedName(j, root, 'GridColumn', '@progress/kendo-react-grid') || 'GridColumn';\n\n    // Find all JSXElements with the name of the Grid component\n    const gridElements = root.find(j.JSXElement, { openingElement: { name: { name: gridName } } });\n\n    gridElements.forEach((gridPath) => {\n        const { isClassComponent, parentNode } = findParentComponent(j, gridPath);\n\n        // Separate counters for functional and class components\n\n        // Find all columns inside the current Grid\n        const columnElements = j(gridPath).find(j.JSXElement, { openingElement: { name: { name: columnName } } });\n\n        columnElements.forEach((columnPath, index) => {\n            const columnAttributes = columnPath.node.openingElement.attributes;\n\n            if (!columnAttributes) {\n                return;\n            }\n\n            // Find the 'filterCell' attribute\n            const filterCellAttribute = columnAttributes.find(\n                (attr) => attr.type === 'JSXAttribute' && attr.name.name === 'filterCell'\n            ) as JSXAttribute;\n\n            if (!filterCellAttribute) {\n                return; // Skip if no 'filterCell' attribute is found\n            }\n\n            // Generate a unique name for the CustomColumnFilterCell function\n            const uniqueName = generateUniqueName(`${baseName}$${index + 1}`, existingNames);\n\n            // Copy the value of the 'filterCell' attribute as a comment\n            const filterCellValue = filterCellAttribute?.value\n                ? j(filterCellAttribute.value).toSource()\n                : 'No value provided';\n\n            // Remove the 'filterCell' attribute\n            removeAttribute(columnAttributes as (JSXAttribute | JSXSpreadAttribute)[], 'filterCell');\n\n            // Ensure the 'cells' attribute exists and assign the new method\n            ensureAttributeExists(\n                j,\n                columnAttributes,\n                'cells',\n                'filterCell',\n                isClassComponent ? `this.${uniqueName}` : uniqueName\n            );\n\n            addImports = true; // Mark that imports need to be added\n\n            // Add the `filterCell` value as a comment in the CustomColumnFilterCell method\n            let customMethod;\n\n            if (isClassComponent) {\n                // Create a proper class method for class components\n                customMethod = createMethodForClassComponent(j, uniqueName, isTypeScript, 'GridCustomFilterCellProps');\n            } else {\n                // Create an arrow function for functional components\n                customMethod = createArrowFunctionForFunctionalComponent(\n                    j,\n                    uniqueName,\n                    isTypeScript,\n                    'GridCustomFilterCellProps'\n                );\n            }\n\n            // Add the CustomColumnFilterCell method to the component\n            addMethodToComponent(j, parentNode, customMethod, isClassComponent);\n\n            // Add the `filterCell` value as a comment in the method\n            if (customMethod) {\n                addCommentToMethod(\n                    j,\n                    j(customMethod),\n                    `Original filterCell value: ${filterCellValue}`,\n                    isClassComponent ? 'class' : 'function'\n                );\n            }\n        });\n    });\n\n    if (addImports) {\n        // Ensure the import for GridCustomFilterCellProps exists\n        if (isTypeScript) {\n            ensureImportExists(j, root, 'GridCustomFilterCellProps', '@progress/kendo-react-grid');\n        }\n    }\n\n    return root.toSource();\n}\n"],"names":["columnFilterCell","fileInfo","api","j","root","isTypeScript","addImports","existingNames","path","baseName","gridName","findImportedName","columnName","gridPath","isClassComponent","parentNode","findParentComponent","columnPath","index","columnAttributes","filterCellAttribute","attr","uniqueName","generateUniqueName","filterCellValue","removeAttribute","ensureAttributeExists","customMethod","createMethodForClassComponent","createArrowFunctionForFunctionalComponent","addMethodToComponent","addCommentToMethod","ensureImportExists"],"mappings":"2CAcA,SAAAA,EAAyBC,EAAoBC,EAAU,CACnD,MAAMC,EAAiBD,EAAI,YACrBE,EAAOD,EAAEF,EAAS,MAAM,EAGxBI,EAAeJ,EAAS,KAAK,SAAS,KAAK,GAAKA,EAAS,KAAK,SAAS,MAAM,EAEnF,IAAIK,EAAa,GACX,MAAAC,MAAoB,IAC1BH,EAAK,KAAKD,EAAE,UAAU,EAAE,QAASK,GAAS,CACxBD,EAAA,IAAIC,EAAK,KAAK,IAAI,CAAA,CACnC,EAED,MAAMC,EAAW,yBAGXC,EAAWC,EAAAA,iBAAiBR,EAAGC,EAAM,OAAQ,4BAA4B,GAAK,OAC9EQ,EAAaD,EAAAA,iBAAiBR,EAAGC,EAAM,aAAc,4BAA4B,GAAK,aAK/E,OAFQA,EAAK,KAAKD,EAAE,WAAY,CAAE,eAAgB,CAAE,KAAM,CAAE,KAAMO,CAAS,CAAA,CAAK,CAAA,EAEhF,QAASG,GAAa,CAC/B,KAAM,CAAE,iBAAAC,EAAkB,WAAAC,CAAA,EAAeC,EAAAA,oBAAoBb,EAAGU,CAAQ,EAKjDV,EAAEU,CAAQ,EAAE,KAAKV,EAAE,WAAY,CAAE,eAAgB,CAAE,KAAM,CAAE,KAAMS,CAAW,CAAA,CAAK,CAAA,EAEzF,QAAQ,CAACK,EAAYC,IAAU,CACpC,MAAAC,EAAmBF,EAAW,KAAK,eAAe,WAExD,GAAI,CAACE,EACD,OAIJ,MAAMC,EAAsBD,EAAiB,KACxCE,GAASA,EAAK,OAAS,gBAAkBA,EAAK,KAAK,OAAS,YAAA,EAGjE,GAAI,CAACD,EACD,OAIE,MAAAE,EAAaC,qBAAmB,GAAGd,CAAQ,IAAIS,EAAQ,CAAC,GAAIX,CAAa,EAGzEiB,EAAkBJ,GAAA,MAAAA,EAAqB,MACvCjB,EAAEiB,EAAoB,KAAK,EAAE,SAC7B,EAAA,oBAGNK,kBAAgBN,EAA2D,YAAY,EAGvFO,EAAA,sBACIvB,EACAgB,EACA,QACA,aACAL,EAAmB,QAAQQ,CAAU,GAAKA,CAAA,EAGjChB,EAAA,GAGT,IAAAqB,EAEAb,EAEAa,EAAeC,EAA8B,8BAAAzB,EAAGmB,EAAYjB,EAAc,2BAA2B,EAGtFsB,EAAAE,EAAA,0CACX1B,EACAmB,EACAjB,EACA,2BAAA,EAKayB,EAAAA,qBAAA3B,EAAGY,EAAYY,EAAcb,CAAgB,EAG9Da,GACAI,EAAA,mBACI5B,EACAA,EAAEwB,CAAY,EACd,8BAA8BH,CAAe,GAC7CV,EAAmB,QAAU,UAAA,CAErC,CACH,CAAA,CACJ,EAEGR,GAEID,GACmB2B,EAAAA,mBAAA7B,EAAGC,EAAM,4BAA6B,4BAA4B,EAItFA,EAAK,UAChB"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
*-------------------------------------------------------------------------------------------
|
|
4
|
+
* Copyright © 2025 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 strict";const o=require("./utils.js");function S(d,C){const e=C.jscodeshift,t=e(d.source),a=d.path.endsWith(".ts")||d.path.endsWith(".tsx");let c=!1;const u=new Set;t.find(e.Identifier).forEach(s=>{u.add(s.node.name)});const f="CustomColumnFooterCell",g=o.findImportedName(e,t,"Grid","@progress/kendo-react-grid")||"Grid",E=o.findImportedName(e,t,"GridColumn","@progress/kendo-react-grid")||"GridColumn";return t.find(e.JSXElement,{openingElement:{name:{name:g}}}).forEach(s=>{const{isClassComponent:i,parentNode:h}=o.findParentComponent(e,s);e(s).find(e.JSXElement,{openingElement:{name:{name:E}}}).forEach((N,F)=>{const l=N.node.openingElement.attributes;if(!l)return;const n=l.find(p=>p.type==="JSXAttribute"&&p.name.name==="footerCell");if(!n)return;const m=o.generateUniqueName(`${f}$${F+1}`,u),G=n!=null&&n.value?e(n.value).toSource():"No value provided";o.removeAttribute(l,"footerCell"),o.ensureAttributeExists(e,l,"cells","footerCell",i?`this.${m}`:m),c=!0;let r;i?r=o.createMethodForClassComponent(e,m,a,"GridCustomFooterCellProps"):r=o.createArrowFunctionForFunctionalComponent(e,m,a,"GridCustomFooterCellProps"),o.addMethodToComponent(e,h,r,i),r&&o.addCommentToMethod(e,e(r),`Original footerCell value: ${G}`,i?"class":"function")})}),c&&a&&o.ensureImportExists(e,t,"GridCustomFooterCellProps","@progress/kendo-react-grid"),t.toSource()}module.exports=S;
|
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"column-footer-cell.js","sources":["../../../../../packages/grid/codemods/v11/column-footer-cell.ts"],"sourcesContent":["import { API, FileInfo, JSCodeshift, JSXAttribute, JSXSpreadAttribute } from 'jscodeshift';\nimport {\n    addCommentToMethod,\n    ensureAttributeExists,\n    findParentComponent,\n    generateUniqueName,\n    ensureImportExists,\n    createMethodForClassComponent,\n    createArrowFunctionForFunctionalComponent,\n    addMethodToComponent,\n    removeAttribute,\n    findImportedName\n} from './utils';\n\nexport default function (fileInfo: FileInfo, api: API) {\n    const j: JSCodeshift = api.jscodeshift;\n    const root = j(fileInfo.source);\n\n    // Check if the file is TypeScript or TSX\n    const isTypeScript = fileInfo.path.endsWith('.ts') || fileInfo.path.endsWith('.tsx');\n\n    let addImports = false;\n    const existingNames = new Set<string>();\n    root.find(j.Identifier).forEach((path) => {\n        existingNames.add(path.node.name);\n    });\n\n    const baseName = 'CustomColumnFooterCell';\n\n    // Ensures we find the correct Grid and GridColumn imports\n    const gridName = findImportedName(j, root, 'Grid', '@progress/kendo-react-grid') || 'Grid';\n    const columnName = findImportedName(j, root, 'GridColumn', '@progress/kendo-react-grid') || 'GridColumn';\n\n    // Find all JSXElements with the name of the Grid component\n    const gridElements = root.find(j.JSXElement, { openingElement: { name: { name: gridName } } });\n\n    gridElements.forEach((gridPath) => {\n        const { isClassComponent, parentNode } = findParentComponent(j, gridPath);\n\n        // Separate counters for functional and class components\n\n        // Find all columns inside the current Grid\n        const columnElements = j(gridPath).find(j.JSXElement, { openingElement: { name: { name: columnName } } });\n\n        columnElements.forEach((columnPath, index) => {\n            const columnAttributes = columnPath.node.openingElement.attributes;\n\n            if (!columnAttributes) {\n                return;\n            }\n\n            // Find the 'footerCell' attribute\n            const footerCellAttribute = columnAttributes.find(\n                (attr) => attr.type === 'JSXAttribute' && attr.name.name === 'footerCell'\n            ) as JSXAttribute;\n\n            if (!footerCellAttribute) {\n                return; // Skip if no 'footerCell' attribute is found\n            }\n\n            // Generate a unique name for the CustomColumnFooterCell function\n            const uniqueName = generateUniqueName(`${baseName}$${index + 1}`, existingNames);\n\n            // Copy the value of the 'footerCell' attribute as a comment\n            const footerCellValue = footerCellAttribute?.value\n                ? j(footerCellAttribute.value).toSource()\n                : 'No value provided';\n\n            // Remove the 'footerCell' attribute\n            removeAttribute(columnAttributes as (JSXAttribute | JSXSpreadAttribute)[], 'footerCell');\n\n            // Ensure the 'cells' attribute exists and assign the new method\n            ensureAttributeExists(\n                j,\n                columnAttributes,\n                'cells',\n                'footerCell',\n                isClassComponent ? `this.${uniqueName}` : uniqueName\n            );\n\n            addImports = true; // Mark that imports need to be added\n\n            // Add the `footerCell` value as a comment in the CustomColumnFooterCell method\n            let customMethod;\n\n            if (isClassComponent) {\n                // Create a proper class method for class components\n                customMethod = createMethodForClassComponent(j, uniqueName, isTypeScript, 'GridCustomFooterCellProps');\n            } else {\n                // Create an arrow function for functional components\n                customMethod = createArrowFunctionForFunctionalComponent(\n                    j,\n                    uniqueName,\n                    isTypeScript,\n                    'GridCustomFooterCellProps'\n                );\n            }\n\n            // Add the CustomColumnFooterCell method to the component\n            addMethodToComponent(j, parentNode, customMethod, isClassComponent);\n\n            // Add the `footerCell` value as a comment in the method\n            if (customMethod) {\n                addCommentToMethod(\n                    j,\n                    j(customMethod),\n                    `Original footerCell value: ${footerCellValue}`,\n                    isClassComponent ? 'class' : 'function'\n                );\n            }\n        });\n    });\n\n    if (addImports) {\n        // Ensure the import for GridCustomFooterCellProps exists\n        if (isTypeScript) {\n            ensureImportExists(j, root, 'GridCustomFooterCellProps', '@progress/kendo-react-grid');\n        }\n    }\n\n    return root.toSource();\n}\n"],"names":["columnFooterCell","fileInfo","api","j","root","isTypeScript","addImports","existingNames","path","baseName","gridName","findImportedName","columnName","gridPath","isClassComponent","parentNode","findParentComponent","columnPath","index","columnAttributes","footerCellAttribute","attr","uniqueName","generateUniqueName","footerCellValue","removeAttribute","ensureAttributeExists","customMethod","createMethodForClassComponent","createArrowFunctionForFunctionalComponent","addMethodToComponent","addCommentToMethod","ensureImportExists"],"mappings":"2CAcA,SAAAA,EAAyBC,EAAoBC,EAAU,CACnD,MAAMC,EAAiBD,EAAI,YACrBE,EAAOD,EAAEF,EAAS,MAAM,EAGxBI,EAAeJ,EAAS,KAAK,SAAS,KAAK,GAAKA,EAAS,KAAK,SAAS,MAAM,EAEnF,IAAIK,EAAa,GACX,MAAAC,MAAoB,IAC1BH,EAAK,KAAKD,EAAE,UAAU,EAAE,QAASK,GAAS,CACxBD,EAAA,IAAIC,EAAK,KAAK,IAAI,CAAA,CACnC,EAED,MAAMC,EAAW,yBAGXC,EAAWC,EAAAA,iBAAiBR,EAAGC,EAAM,OAAQ,4BAA4B,GAAK,OAC9EQ,EAAaD,EAAAA,iBAAiBR,EAAGC,EAAM,aAAc,4BAA4B,GAAK,aAK/E,OAFQA,EAAK,KAAKD,EAAE,WAAY,CAAE,eAAgB,CAAE,KAAM,CAAE,KAAMO,CAAS,CAAA,CAAK,CAAA,EAEhF,QAASG,GAAa,CAC/B,KAAM,CAAE,iBAAAC,EAAkB,WAAAC,CAAA,EAAeC,EAAAA,oBAAoBb,EAAGU,CAAQ,EAKjDV,EAAEU,CAAQ,EAAE,KAAKV,EAAE,WAAY,CAAE,eAAgB,CAAE,KAAM,CAAE,KAAMS,CAAW,CAAA,CAAK,CAAA,EAEzF,QAAQ,CAACK,EAAYC,IAAU,CACpC,MAAAC,EAAmBF,EAAW,KAAK,eAAe,WAExD,GAAI,CAACE,EACD,OAIJ,MAAMC,EAAsBD,EAAiB,KACxCE,GAASA,EAAK,OAAS,gBAAkBA,EAAK,KAAK,OAAS,YAAA,EAGjE,GAAI,CAACD,EACD,OAIE,MAAAE,EAAaC,qBAAmB,GAAGd,CAAQ,IAAIS,EAAQ,CAAC,GAAIX,CAAa,EAGzEiB,EAAkBJ,GAAA,MAAAA,EAAqB,MACvCjB,EAAEiB,EAAoB,KAAK,EAAE,SAC7B,EAAA,oBAGNK,kBAAgBN,EAA2D,YAAY,EAGvFO,EAAA,sBACIvB,EACAgB,EACA,QACA,aACAL,EAAmB,QAAQQ,CAAU,GAAKA,CAAA,EAGjChB,EAAA,GAGT,IAAAqB,EAEAb,EAEAa,EAAeC,EAA8B,8BAAAzB,EAAGmB,EAAYjB,EAAc,2BAA2B,EAGtFsB,EAAAE,EAAA,0CACX1B,EACAmB,EACAjB,EACA,2BAAA,EAKayB,EAAAA,qBAAA3B,EAAGY,EAAYY,EAAcb,CAAgB,EAG9Da,GACAI,EAAA,mBACI5B,EACAA,EAAEwB,CAAY,EACd,8BAA8BH,CAAe,GAC7CV,EAAmB,QAAU,UAAA,CAErC,CACH,CAAA,CACJ,EAEGR,GAEID,GACmB2B,EAAAA,mBAAA7B,EAAGC,EAAM,4BAA6B,4BAA4B,EAItFA,EAAK,UAChB"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
*-------------------------------------------------------------------------------------------
|
|
4
|
+
* Copyright © 2025 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 strict";const t=require("./utils.js");function v(l,C){const e=C.jscodeshift,n=e(l.source),m=l.path.endsWith(".ts")||l.path.endsWith(".tsx");let c=!1;const u=new Set;n.find(e.Identifier).forEach(s=>{u.add(s.node.name)});const f="CustomColumnHeaderCell",h=t.findImportedName(e,n,"Grid","@progress/kendo-react-grid")||"Grid",g=t.findImportedName(e,n,"GridColumn","@progress/kendo-react-grid")||"GridColumn";return n.find(e.JSXElement,{openingElement:{name:{name:h}}}).forEach(s=>{const{isClassComponent:i,parentNode:E}=t.findParentComponent(e,s);e(s).find(e.JSXElement,{openingElement:{name:{name:g}}}).forEach((N,G)=>{const d=N.node.openingElement.attributes;if(!d)return;const o=d.find(p=>p.type==="JSXAttribute"&&p.name.name==="headerCell");if(!o)return;const a=t.generateUniqueName(`${f}$${G+1}`,u),S=o!=null&&o.value?e(o.value).toSource():"No value provided";t.removeAttribute(d,"headerCell"),t.ensureAttributeExists(e,d,"cells","headerCell",i?`this.${a}`:a),c=!0;let r;i?r=t.createMethodForClassComponent(e,a,m,"GridCustomHeaderCellProps"):r=t.createArrowFunctionForFunctionalComponent(e,a,m,"GridCustomHeaderCellProps"),t.addMethodToComponent(e,E,r,i),r&&t.addCommentToMethod(e,e(r),`Original headerCell value: ${S}`,i?"class":"function")})}),c&&m&&t.ensureImportExists(e,n,"GridCustomHeaderCellProps","@progress/kendo-react-grid"),n.toSource()}module.exports=v;
|
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"column-header-cell.js","sources":["../../../../../packages/grid/codemods/v11/column-header-cell.ts"],"sourcesContent":["import { API, FileInfo, JSCodeshift, JSXAttribute, JSXSpreadAttribute } from 'jscodeshift';\nimport {\n    addCommentToMethod,\n    ensureAttributeExists,\n    findParentComponent,\n    generateUniqueName,\n    ensureImportExists,\n    createMethodForClassComponent,\n    createArrowFunctionForFunctionalComponent,\n    addMethodToComponent,\n    removeAttribute,\n    findImportedName\n} from './utils';\n\nexport default function (fileInfo: FileInfo, api: API) {\n    const j: JSCodeshift = api.jscodeshift;\n    const root = j(fileInfo.source);\n\n    // Check if the file is TypeScript or TSX\n    const isTypeScript = fileInfo.path.endsWith('.ts') || fileInfo.path.endsWith('.tsx');\n\n    let addImports = false;\n    const existingNames = new Set<string>();\n    root.find(j.Identifier).forEach((path) => {\n        existingNames.add(path.node.name);\n    });\n\n    const baseName = 'CustomColumnHeaderCell';\n\n    // Ensures we find the correct Grid and GridColumn imports\n    const gridName = findImportedName(j, root, 'Grid', '@progress/kendo-react-grid') || 'Grid';\n    const columnName = findImportedName(j, root, 'GridColumn', '@progress/kendo-react-grid') || 'GridColumn';\n\n    // Find all JSXElements with the name of the Grid component\n    const gridElements = root.find(j.JSXElement, { openingElement: { name: { name: gridName } } });\n\n    gridElements.forEach((gridPath) => {\n        const { isClassComponent, parentNode } = findParentComponent(j, gridPath);\n\n        // Separate counters for functional and class components\n\n        // Find all columns inside the current Grid\n        const columnElements = j(gridPath).find(j.JSXElement, { openingElement: { name: { name: columnName } } });\n\n        columnElements.forEach((columnPath, index) => {\n            const columnAttributes = columnPath.node.openingElement.attributes;\n\n            if (!columnAttributes) {\n                return;\n            }\n\n            // Find the 'headerCell' attribute\n            const headerCellAttribute = columnAttributes.find(\n                (attr) => attr.type === 'JSXAttribute' && attr.name.name === 'headerCell'\n            ) as JSXAttribute;\n\n            if (!headerCellAttribute) {\n                return; // Skip if no 'headerCell' attribute is found\n            }\n\n            // Generate a unique name for the CustomColumnHeaderCell function\n            const uniqueName = generateUniqueName(`${baseName}$${index + 1}`, existingNames);\n\n            // Copy the value of the 'headerCell' attribute as a comment\n            const headerCellValue = headerCellAttribute?.value\n                ? j(headerCellAttribute.value).toSource()\n                : 'No value provided';\n\n            // Remove the 'headerCell' attribute\n            removeAttribute(columnAttributes as (JSXAttribute | JSXSpreadAttribute)[], 'headerCell');\n\n            // Ensure the 'cells' attribute exists and assign the new method\n            ensureAttributeExists(\n                j,\n                columnAttributes,\n                'cells',\n                'headerCell',\n                isClassComponent ? `this.${uniqueName}` : uniqueName\n            );\n\n            addImports = true; // Mark that imports need to be added\n\n            // Add the `headerCell` value as a comment in the CustomColumnHeaderCell method\n            let customMethod;\n\n            if (isClassComponent) {\n                // Create a proper class method for class components\n                customMethod = createMethodForClassComponent(j, uniqueName, isTypeScript, 'GridCustomHeaderCellProps');\n            } else {\n                // Create an arrow function for functional components\n                customMethod = createArrowFunctionForFunctionalComponent(\n                    j,\n                    uniqueName,\n                    isTypeScript,\n                    'GridCustomHeaderCellProps'\n                );\n            }\n\n            // Add the CustomColumnHeaderCell method to the component\n            addMethodToComponent(j, parentNode, customMethod, isClassComponent);\n\n            // Add the `headerCell` value as a comment in the method\n            if (customMethod) {\n                addCommentToMethod(\n                    j,\n                    j(customMethod),\n                    `Original headerCell value: ${headerCellValue}`,\n                    isClassComponent ? 'class' : 'function'\n                );\n            }\n        });\n    });\n\n    if (addImports) {\n        // Ensure the import for GridCustomHeaderCellProps exists\n        if (isTypeScript) {\n            ensureImportExists(j, root, 'GridCustomHeaderCellProps', '@progress/kendo-react-grid');\n        }\n    }\n\n    return root.toSource();\n}\n"],"names":["columnHeaderCell","fileInfo","api","j","root","isTypeScript","addImports","existingNames","path","baseName","gridName","findImportedName","columnName","gridPath","isClassComponent","parentNode","findParentComponent","columnPath","index","columnAttributes","headerCellAttribute","attr","uniqueName","generateUniqueName","headerCellValue","removeAttribute","ensureAttributeExists","customMethod","createMethodForClassComponent","createArrowFunctionForFunctionalComponent","addMethodToComponent","addCommentToMethod","ensureImportExists"],"mappings":"2CAcA,SAAAA,EAAyBC,EAAoBC,EAAU,CACnD,MAAMC,EAAiBD,EAAI,YACrBE,EAAOD,EAAEF,EAAS,MAAM,EAGxBI,EAAeJ,EAAS,KAAK,SAAS,KAAK,GAAKA,EAAS,KAAK,SAAS,MAAM,EAEnF,IAAIK,EAAa,GACX,MAAAC,MAAoB,IAC1BH,EAAK,KAAKD,EAAE,UAAU,EAAE,QAASK,GAAS,CACxBD,EAAA,IAAIC,EAAK,KAAK,IAAI,CAAA,CACnC,EAED,MAAMC,EAAW,yBAGXC,EAAWC,EAAAA,iBAAiBR,EAAGC,EAAM,OAAQ,4BAA4B,GAAK,OAC9EQ,EAAaD,EAAAA,iBAAiBR,EAAGC,EAAM,aAAc,4BAA4B,GAAK,aAK/E,OAFQA,EAAK,KAAKD,EAAE,WAAY,CAAE,eAAgB,CAAE,KAAM,CAAE,KAAMO,CAAS,CAAA,CAAK,CAAA,EAEhF,QAASG,GAAa,CAC/B,KAAM,CAAE,iBAAAC,EAAkB,WAAAC,CAAA,EAAeC,EAAAA,oBAAoBb,EAAGU,CAAQ,EAKjDV,EAAEU,CAAQ,EAAE,KAAKV,EAAE,WAAY,CAAE,eAAgB,CAAE,KAAM,CAAE,KAAMS,CAAW,CAAA,CAAK,CAAA,EAEzF,QAAQ,CAACK,EAAYC,IAAU,CACpC,MAAAC,EAAmBF,EAAW,KAAK,eAAe,WAExD,GAAI,CAACE,EACD,OAIJ,MAAMC,EAAsBD,EAAiB,KACxCE,GAASA,EAAK,OAAS,gBAAkBA,EAAK,KAAK,OAAS,YAAA,EAGjE,GAAI,CAACD,EACD,OAIE,MAAAE,EAAaC,qBAAmB,GAAGd,CAAQ,IAAIS,EAAQ,CAAC,GAAIX,CAAa,EAGzEiB,EAAkBJ,GAAA,MAAAA,EAAqB,MACvCjB,EAAEiB,EAAoB,KAAK,EAAE,SAC7B,EAAA,oBAGNK,kBAAgBN,EAA2D,YAAY,EAGvFO,EAAA,sBACIvB,EACAgB,EACA,QACA,aACAL,EAAmB,QAAQQ,CAAU,GAAKA,CAAA,EAGjChB,EAAA,GAGT,IAAAqB,EAEAb,EAEAa,EAAeC,EAA8B,8BAAAzB,EAAGmB,EAAYjB,EAAc,2BAA2B,EAGtFsB,EAAAE,EAAA,0CACX1B,EACAmB,EACAjB,EACA,2BAAA,EAKayB,EAAAA,qBAAA3B,EAAGY,EAAYY,EAAcb,CAAgB,EAG9Da,GACAI,EAAA,mBACI5B,EACAA,EAAEwB,CAAY,EACd,8BAA8BH,CAAe,GAC7CV,EAAmB,QAAU,UAAA,CAErC,CACH,CAAA,CACJ,EAEGR,GAEID,GACmB2B,EAAAA,mBAAA7B,EAAGC,EAAM,4BAA6B,4BAA4B,EAItFA,EAAK,UAChB"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
*-------------------------------------------------------------------------------------------
|
|
4
|
+
* Copyright © 2025 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 strict";const t=require("./utils.js");function f(l,m){const e=m.jscodeshift,i=e(l.source),d=l.path.endsWith(".ts")||l.path.endsWith(".tsx");let E=!1;const x=new Set;i.find(e.Identifier).forEach(s=>{x.add(s.node.name)});const o=t.generateUniqueName("handleDetailExpandChange",x),u=t.findImportedName(e,i,"Grid","@progress/kendo-react-grid")||"Grid";return i.find(e.JSXElement,{openingElement:{name:{name:u}}}).forEach(s=>{const n=s.node.openingElement.attributes;if(!t.hasJSXAttribute(n,"detail"))return;const r=n==null?void 0:n.find(a=>a.type==="JSXAttribute"&&a.name.name==="onExpandChange"),c=r!=null&&r.value?e(r.value).toSource():"No value provided";t.removeAttribute(n,"onExpandChange"),E=!0;const{isClassComponent:h,isFunctionalComponent:g,parentNode:p}=t.findParentComponent(e,s);if(h){if(t.addStateDeclaration(e,p,"detailExpand",e.objectExpression([])),t.hasJSXAttribute(n,"detailExpand")||t.addStateAttribute(e,n,"detailExpand","this.state.detailExpand"),!t.hasJSXAttribute(n,"onDetailExpandChange")){t.addEventAttribute(e,n,"onDetailExpandChange",`this.${o}`);const a=t.createClassMethod(e,o,[`event${d?": GridDetailExpandChangeEvent":""}`],[e.expressionStatement(e.callExpression(e.memberExpression(e.thisExpression(),e.identifier("setState")),[e.objectExpression([e.property("init",e.identifier("detailExpand"),e.memberExpression(e.identifier("event"),e.identifier("detailExpand")))])]))]);t.addCommentToMethod(e,e(a),`Original onExpandChange value: ${c}`,"class"),t.addMethodToComponent(e,p,a,!0)}}else if(g&&(t.addUseStateDeclaration(e,p,"detailExpand","setDetailExpand",e.objectExpression([]),d,"DetailExpandDescriptor"),t.hasJSXAttribute(n,"detailExpand")||t.addStateAttribute(e,n,"detailExpand","detailExpand"),!t.hasJSXAttribute(n,"onDetailExpandChange"))){t.addEventAttribute(e,n,"onDetailExpandChange",`${o}`);const a=t.createArrowFunction(e,`${o}`,[`(event${d?": GridDetailExpandChangeEvent":""})`],[e.expressionStatement(e.callExpression(e.identifier("setDetailExpand"),[e.memberExpression(e.identifier("event"),e.identifier("detailExpand"))]))]);t.addCommentToMethod(e,e(a),`Original onExpandChange value: ${c}`,"function"),t.addMethodToComponent(e,p,a,!1)}}),E&&d&&(t.ensureImportExists(e,i,"GridDetailExpandChangeEvent","@progress/kendo-react-grid"),t.ensureImportExists(e,i,"DetailExpandDescriptor","@progress/kendo-react-data-tools")),i.toSource()}module.exports=f;
|
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"detail-expand-state.js","sources":["../../../../../packages/grid/codemods/v11/detail-expand-state.ts"],"sourcesContent":["import { API, FileInfo, JSCodeshift, JSXAttribute, JSXSpreadAttribute } from 'jscodeshift';\nimport {\n    addMethodToComponent,\n    removeAttribute,\n    findParentComponent,\n    generateUniqueName,\n    ensureImportExists,\n    addEventAttribute,\n    addStateAttribute,\n    addStateDeclaration,\n    addUseStateDeclaration,\n    findImportedName,\n    createClassMethod,\n    createArrowFunction,\n    hasJSXAttribute,\n    addCommentToMethod\n} from './utils';\n\nexport default function (fileInfo: FileInfo, api: API) {\n    const j: JSCodeshift = api.jscodeshift;\n    const root = j(fileInfo.source);\n\n    // Check if the file is TypeScript or TSX\n    const isTypeScript = fileInfo.path.endsWith('.ts') || fileInfo.path.endsWith('.tsx');\n\n    let addImports = false;\n    const existingNames = new Set<string>();\n    root.find(j.Identifier).forEach((path) => {\n        existingNames.add(path.node.name);\n    });\n\n    const baseName = 'handleDetailExpandChange';\n    const uniqueName = generateUniqueName(baseName, existingNames);\n\n    // Dynamically resolve the imported name for `Grid`\n    const gridName = findImportedName(j, root, 'Grid', '@progress/kendo-react-grid') || 'Grid';\n\n    // Find all JSXElements with the name of the resolved `Grid` component\n    const gridElements = root.find(j.JSXElement, { openingElement: { name: { name: gridName } } });\n\n    gridElements.forEach((gridPath) => {\n        const attributes = gridPath.node.openingElement.attributes;\n\n        // Check if the `detail` attribute exists\n        if (!hasJSXAttribute(attributes, 'detail')) {\n            return; // Skip this Grid if `detail` is not present\n        }\n\n        // Find the `onExpandChange` attribute\n        const onExpandChangeAttribute = attributes?.find(\n            (attr) => attr.type === 'JSXAttribute' && attr.name.name === 'onExpandChange'\n        ) as JSXAttribute;\n\n        // Copy the value of `onExpandChange` as a comment\n        const onExpandChangeValue = onExpandChangeAttribute?.value\n            ? j(onExpandChangeAttribute.value).toSource()\n            : 'No value provided';\n\n        // Remove the `onExpandChange` attribute\n        removeAttribute(attributes as (JSXAttribute | JSXSpreadAttribute)[], 'onExpandChange');\n        addImports = true;\n\n        // Determine if the parent component is a class or functional component\n        const { isClassComponent, isFunctionalComponent, parentNode } = findParentComponent(j, gridPath);\n\n        if (isClassComponent) {\n            // Add `detailExpand` to the class component's state\n            addStateDeclaration(j, parentNode, 'detailExpand', j.objectExpression([]));\n\n            // Add `detailExpand` and `onDetailExpandChange` attributes\n            if (!hasJSXAttribute(attributes, 'detailExpand')) {\n                addStateAttribute(\n                    j,\n                    attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                    'detailExpand',\n                    'this.state.detailExpand'\n                );\n            }\n\n            if (!hasJSXAttribute(attributes, 'onDetailExpandChange')) {\n                addEventAttribute(\n                    j,\n                    attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                    'onDetailExpandChange',\n                    `this.${uniqueName}`\n                );\n\n                // Create and add `handleDetailExpandChange` method\n                const handleDetailExpandMethod = createClassMethod(\n                    j,\n                    uniqueName,\n                    [`event${isTypeScript ? ': GridDetailExpandChangeEvent' : ''}`],\n                    [\n                        j.expressionStatement(\n                            j.callExpression(j.memberExpression(j.thisExpression(), j.identifier('setState')), [\n                                j.objectExpression([\n                                    j.property(\n                                        'init',\n                                        j.identifier('detailExpand'),\n                                        j.memberExpression(j.identifier('event'), j.identifier('detailExpand'))\n                                    )\n                                ])\n                            ])\n                        )\n                    ]\n                );\n\n                // Add the `onExpandChange` value as a comment in the method\n                addCommentToMethod(\n                    j,\n                    j(handleDetailExpandMethod),\n                    `Original onExpandChange value: ${onExpandChangeValue}`,\n                    'class'\n                );\n\n                addMethodToComponent(j, parentNode, handleDetailExpandMethod, true);\n            }\n        } else if (isFunctionalComponent) {\n            // Add `React.useState` for `detailExpand`\n            addUseStateDeclaration(\n                j,\n                parentNode,\n                'detailExpand',\n                'setDetailExpand',\n                j.objectExpression([]),\n                isTypeScript,\n                'DetailExpandDescriptor'\n            );\n\n            // Add `detailExpand` and `onDetailExpandChange` attributes\n            if (!hasJSXAttribute(attributes, 'detailExpand')) {\n                addStateAttribute(\n                    j,\n                    attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                    'detailExpand',\n                    'detailExpand'\n                );\n            }\n\n            if (!hasJSXAttribute(attributes, 'onDetailExpandChange')) {\n                addEventAttribute(\n                    j,\n                    attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                    'onDetailExpandChange',\n                    `${uniqueName}`\n                );\n\n                // Create and add `handleDetailExpandChange` function\n                const handleDetailExpandFunction = createArrowFunction(\n                    j,\n                    `${uniqueName}`,\n                    [`(event${isTypeScript ? ': GridDetailExpandChangeEvent' : ''})`],\n                    [\n                        j.expressionStatement(\n                            j.callExpression(j.identifier('setDetailExpand'), [\n                                j.memberExpression(j.identifier('event'), j.identifier('detailExpand'))\n                            ])\n                        )\n                    ]\n                );\n\n                // Add the `onExpandChange` value as a comment in the function\n                addCommentToMethod(\n                    j,\n                    j(handleDetailExpandFunction),\n                    `Original onExpandChange value: ${onExpandChangeValue}`,\n                    'function'\n                );\n\n                addMethodToComponent(j, parentNode, handleDetailExpandFunction, false);\n            }\n        }\n    });\n\n    if (addImports && isTypeScript) {\n        // Ensure TypeScript imports\n        ensureImportExists(j, root, 'GridDetailExpandChangeEvent', '@progress/kendo-react-grid');\n        ensureImportExists(j, root, 'DetailExpandDescriptor', '@progress/kendo-react-data-tools');\n    }\n\n    return root.toSource();\n}\n"],"names":["detailExpandState","fileInfo","api","j","root","isTypeScript","addImports","existingNames","path","uniqueName","generateUniqueName","gridName","findImportedName","gridPath","attributes","hasJSXAttribute","onExpandChangeAttribute","attr","onExpandChangeValue","removeAttribute","isClassComponent","isFunctionalComponent","parentNode","findParentComponent","addStateDeclaration","addStateAttribute","addEventAttribute","handleDetailExpandMethod","createClassMethod","addCommentToMethod","addMethodToComponent","addUseStateDeclaration","handleDetailExpandFunction","createArrowFunction","ensureImportExists"],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
*-------------------------------------------------------------------------------------------
|
|
4
|
+
* Copyright © 2025 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 strict";const t=require("./utils.js");function b(h,E){const e=E.jscodeshift,d=e(h.source),a=h.path.endsWith(".ts")||h.path.endsWith(".tsx");let c=!1;const u=new Set;d.find(e.Identifier).forEach(s=>{u.add(s.node.name)});const r=t.generateUniqueName("handleEditChange",u),p=t.findImportedName(e,d,"Grid","@progress/kendo-react-grid")||"Grid";return d.find(e.JSXElement,{openingElement:{name:{name:p}}}).forEach(s=>{const n=s.node.openingElement.attributes,m=n==null?void 0:n.find(i=>i.type==="JSXAttribute"&&i.name.name==="editField");if(!m)return;const l=m.value?e(m.value).toSource():"No value provided";t.removeAttribute(n,"editField"),c=!0,t.hasJSXAttribute(n,"editable")||t.addStateAttribute(e,n,"editable","true"),t.hasJSXAttribute(n,"dataItemKey")||t.addStateAttribute(e,n,"dataItemKey",'"insert dataItemKey here"');const{isClassComponent:g,isFunctionalComponent:C,parentNode:o}=t.findParentComponent(e,s);if(g){if(t.addStateDeclaration(e,o,"edit",e.objectExpression([])),t.hasJSXAttribute(n,"edit")||t.addStateAttribute(e,n,"edit","this.state.edit"),!t.hasJSXAttribute(n,"onItemChange")){t.addEventAttribute(e,n,"onItemChange","this.handleItemChange");const i=t.createClassMethod(e,"handleItemChange",[`event${a?": GridItemChangeEvent":""}`],[]);t.addMethodToComponent(e,o,i,!0)}if(!t.hasJSXAttribute(n,"onEditChange")){t.addEventAttribute(e,n,"onEditChange",`this.${r}`);const i=t.createClassMethod(e,r,[`event${a?": GridEditChangeEvent":""}`],[e.expressionStatement(e.callExpression(e.memberExpression(e.thisExpression(),e.identifier("setState")),[e.objectExpression([e.property("init",e.identifier("edit"),e.memberExpression(e.identifier("event"),e.identifier("edit")))])]))]);t.addCommentToMethod(e,e(i),`Original editField value: ${l}`,"class"),t.addMethodToComponent(e,o,i,!0)}}else if(C){if(t.addUseStateDeclaration(e,o,"edit","setEdit",e.objectExpression([]),a,"EditDescriptor"),t.hasJSXAttribute(n,"edit")||t.addStateAttribute(e,n,"edit","edit"),!t.hasJSXAttribute(n,"onItemChange")){t.addEventAttribute(e,n,"onItemChange","handleItemChange");const i=t.createArrowFunction(e,"handleItemChange",[`(event${a?": GridItemChangeEvent":""})`],[]);t.addMethodToComponent(e,o,i,!1)}if(!t.hasJSXAttribute(n,"onEditChange")){t.addEventAttribute(e,n,"onEditChange",`${r}`);const i=t.createArrowFunction(e,`${r}`,[`(event${a?": GridEditChangeEvent":""})`],[e.expressionStatement(e.callExpression(e.identifier("setEdit"),[e.memberExpression(e.identifier("event"),e.identifier("edit"))]))]);t.addCommentToMethod(e,e(i),`Original editField value: ${l}`,"function"),t.addMethodToComponent(e,o,i,!1)}}}),c&&a&&(t.ensureImportExists(e,d,"GridItemChangeEvent","@progress/kendo-react-grid"),t.ensureImportExists(e,d,"GridEditChangeEvent","@progress/kendo-react-grid"),t.ensureImportExists(e,d,"EditDescriptor","@progress/kendo-react-data-tools")),d.toSource()}module.exports=b;
|
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"edit-state.js","sources":["../../../../../packages/grid/codemods/v11/edit-state.ts"],"sourcesContent":["import { API, FileInfo, JSCodeshift, JSXAttribute, JSXSpreadAttribute } from 'jscodeshift';\nimport {\n    addMethodToComponent,\n    removeAttribute,\n    findParentComponent,\n    generateUniqueName,\n    ensureImportExists,\n    addEventAttribute,\n    addStateAttribute,\n    addStateDeclaration,\n    addUseStateDeclaration,\n    findImportedName,\n    createClassMethod,\n    createArrowFunction,\n    hasJSXAttribute,\n    addCommentToMethod\n} from './utils';\n\nexport default function (fileInfo: FileInfo, api: API) {\n    const j: JSCodeshift = api.jscodeshift;\n    const root = j(fileInfo.source);\n\n    // Check if the file is TypeScript or TSX\n    const isTypeScript = fileInfo.path.endsWith('.ts') || fileInfo.path.endsWith('.tsx');\n\n    let addImports = false;\n    const existingNames = new Set<string>();\n    root.find(j.Identifier).forEach((path) => {\n        existingNames.add(path.node.name);\n    });\n\n    const baseName = 'handleEditChange';\n    const uniqueName = generateUniqueName(baseName, existingNames);\n\n    // Dynamically resolve the imported name for `Grid`\n    const gridName = findImportedName(j, root, 'Grid', '@progress/kendo-react-grid') || 'Grid';\n\n    // Find all JSXElements with the name of the resolved `Grid` component\n    const gridElements = root.find(j.JSXElement, { openingElement: { name: { name: gridName } } });\n\n    gridElements.forEach((gridPath) => {\n        const attributes = gridPath.node.openingElement.attributes;\n\n        // Check if the `editField` attribute exists\n        const editFieldAttribute = attributes?.find(\n            (attr) => attr.type === 'JSXAttribute' && attr.name.name === 'editField'\n        ) as JSXAttribute;\n\n        if (!editFieldAttribute) {\n            return; // Skip this Grid if `editField` is not present\n        }\n\n        // Copy the value of `editField` as a comment\n        const editFieldValue = editFieldAttribute.value ? j(editFieldAttribute.value).toSource() : 'No value provided';\n\n        // Remove the `editField` attribute\n        removeAttribute(attributes as (JSXAttribute | JSXSpreadAttribute)[], 'editField');\n        addImports = true;\n\n        // Ensure `editable` attribute is present and set to true\n        if (!hasJSXAttribute(attributes, 'editable')) {\n            addStateAttribute(j, attributes as (JSXAttribute | JSXSpreadAttribute)[], 'editable', 'true');\n        }\n\n        // Ensure `dataItemKey` attribute is present\n        if (!hasJSXAttribute(attributes, 'dataItemKey')) {\n            addStateAttribute(\n                j,\n                attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                'dataItemKey',\n                '\"insert dataItemKey here\"'\n            );\n        }\n\n        // Determine if the parent component is a class or functional component\n        const { isClassComponent, isFunctionalComponent, parentNode } = findParentComponent(j, gridPath);\n\n        if (isClassComponent) {\n            // Add `edit` to the class component's state\n            addStateDeclaration(j, parentNode, 'edit', j.objectExpression([]));\n\n            // Add `edit`, `onItemChange`, and `onEditChange` attributes\n            if (!hasJSXAttribute(attributes, 'edit')) {\n                addStateAttribute(j, attributes as (JSXAttribute | JSXSpreadAttribute)[], 'edit', 'this.state.edit');\n            }\n\n            if (!hasJSXAttribute(attributes, 'onItemChange')) {\n                addEventAttribute(\n                    j,\n                    attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                    'onItemChange',\n                    'this.handleItemChange'\n                );\n\n                const handleItemChangeMethod = createClassMethod(\n                    j,\n                    'handleItemChange',\n                    [`event${isTypeScript ? ': GridItemChangeEvent' : ''}`],\n                    [] // Empty block for now\n                );\n\n                addMethodToComponent(j, parentNode, handleItemChangeMethod, true);\n            }\n\n            if (!hasJSXAttribute(attributes, 'onEditChange')) {\n                addEventAttribute(\n                    j,\n                    attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                    'onEditChange',\n                    `this.${uniqueName}`\n                );\n\n                const handleEditChangeMethod = createClassMethod(\n                    j,\n                    uniqueName,\n                    [`event${isTypeScript ? ': GridEditChangeEvent' : ''}`],\n                    [\n                        j.expressionStatement(\n                            j.callExpression(j.memberExpression(j.thisExpression(), j.identifier('setState')), [\n                                j.objectExpression([\n                                    j.property(\n                                        'init',\n                                        j.identifier('edit'),\n                                        j.memberExpression(j.identifier('event'), j.identifier('edit'))\n                                    )\n                                ])\n                            ])\n                        )\n                    ]\n                );\n\n                // Add the `editField` value as a comment in the method\n                addCommentToMethod(\n                    j,\n                    j(handleEditChangeMethod),\n                    `Original editField value: ${editFieldValue}`,\n                    'class'\n                );\n\n                addMethodToComponent(j, parentNode, handleEditChangeMethod, true);\n            }\n        } else if (isFunctionalComponent) {\n            // Add `React.useState` for `edit`\n            addUseStateDeclaration(\n                j,\n                parentNode,\n                'edit',\n                'setEdit',\n                j.objectExpression([]),\n                isTypeScript,\n                'EditDescriptor'\n            );\n\n            // Add `edit`, `onItemChange`, and `onEditChange` attributes\n            if (!hasJSXAttribute(attributes, 'edit')) {\n                addStateAttribute(j, attributes as (JSXAttribute | JSXSpreadAttribute)[], 'edit', 'edit');\n            }\n\n            if (!hasJSXAttribute(attributes, 'onItemChange')) {\n                addEventAttribute(\n                    j,\n                    attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                    'onItemChange',\n                    'handleItemChange'\n                );\n\n                const handleItemChangeFunction = createArrowFunction(\n                    j,\n                    'handleItemChange',\n                    [`(event${isTypeScript ? ': GridItemChangeEvent' : ''})`],\n                    [] // Empty block for now\n                );\n                addMethodToComponent(j, parentNode, handleItemChangeFunction, false);\n            }\n\n            if (!hasJSXAttribute(attributes, 'onEditChange')) {\n                addEventAttribute(\n                    j,\n                    attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                    'onEditChange',\n                    `${uniqueName}`\n                );\n\n                const handleEditChangeFunction = createArrowFunction(\n                    j,\n                    `${uniqueName}`,\n                    [`(event${isTypeScript ? ': GridEditChangeEvent' : ''})`],\n                    [\n                        j.expressionStatement(\n                            j.callExpression(j.identifier('setEdit'), [\n                                j.memberExpression(j.identifier('event'), j.identifier('edit'))\n                            ])\n                        )\n                    ]\n                );\n\n                // Add the `editField` value as a comment in the function\n                addCommentToMethod(\n                    j,\n                    j(handleEditChangeFunction),\n                    `Original editField value: ${editFieldValue}`,\n                    'function'\n                );\n\n                addMethodToComponent(j, parentNode, handleEditChangeFunction, false);\n            }\n        }\n    });\n\n    if (addImports && isTypeScript) {\n        // Ensure TypeScript imports\n        ensureImportExists(j, root, 'GridItemChangeEvent', '@progress/kendo-react-grid');\n        ensureImportExists(j, root, 'GridEditChangeEvent', '@progress/kendo-react-grid');\n        ensureImportExists(j, root, 'EditDescriptor', '@progress/kendo-react-data-tools');\n    }\n\n    return root.toSource();\n}\n"],"names":["editState","fileInfo","api","j","root","isTypeScript","addImports","existingNames","path","uniqueName","generateUniqueName","gridName","findImportedName","gridPath","attributes","editFieldAttribute","attr","editFieldValue","removeAttribute","hasJSXAttribute","addStateAttribute","isClassComponent","isFunctionalComponent","parentNode","findParentComponent","addStateDeclaration","addEventAttribute","handleItemChangeMethod","createClassMethod","addMethodToComponent","handleEditChangeMethod","addCommentToMethod","addUseStateDeclaration","handleItemChangeFunction","createArrowFunction","handleEditChangeFunction","ensureImportExists"],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
*-------------------------------------------------------------------------------------------
|
|
4
|
+
* Copyright © 2025 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 strict";const t=require("./utils.js");function F(m,C){const e=C.jscodeshift,o=e(m.source),c=m.path.endsWith(".ts")||m.path.endsWith(".tsx");let u=!1;const p=new Set;o.find(e.Identifier).forEach(s=>{p.add(s.node.name)});const i=t.generateUniqueName("CustomFilterCell",p),f=t.findImportedName(e,o,"Grid","@progress/kendo-react-grid")||"Grid";return o.find(e.JSXElement,{openingElement:{name:{name:f}}}).forEach(s=>{const n=s.node.openingElement.attributes,l=n==null?void 0:n.find(d=>d.type==="JSXAttribute"&&d.name.name==="filterCellRender");if(l&&l.type==="JSXAttribute"){const d=l.value?e(l.value).toSource():"No value provided",{isClassComponent:a,isFunctionalComponent:h,parentNode:g}=t.findParentComponent(e,s);n&&t.ensureAttributeExists(e,n,"cells","filterCell",a?`this.${i}`:i);let r;a?r=t.createMethodForClassComponent(e,i,c,"GridCustomFilterCellProps"):h&&(r=t.createArrowFunctionForFunctionalComponent(e,i,c,"GridCustomFilterCellProps")),t.addMethodToComponent(e,g,r,a),r&&t.addCommentToMethod(e,e(r),`Original filterCellRender value: ${d}`,a?"class":"function"),t.removeAttribute(n,"filterCellRender")&&(u=!0)}}),u&&c&&t.ensureImportExists(e,o,"GridCustomFilterCellProps","@progress/kendo-react-grid"),o.toSource()}module.exports=F;
|
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"filter-cell-render.js","sources":["../../../../../packages/grid/codemods/v11/filter-cell-render.ts"],"sourcesContent":["import { API, FileInfo, JSCodeshift, JSXAttribute, JSXSpreadAttribute } from 'jscodeshift';\nimport {\n    addCommentToMethod,\n    ensureAttributeExists,\n    findParentComponent,\n    generateUniqueName,\n    ensureImportExists,\n    createMethodForClassComponent,\n    createArrowFunctionForFunctionalComponent,\n    addMethodToComponent,\n    removeAttribute,\n    findImportedName\n} from './utils';\n\nexport default function (fileInfo: FileInfo, api: API) {\n    const j: JSCodeshift = api.jscodeshift;\n    const root = j(fileInfo.source);\n\n    // Check if the file is TypeScript or TSX\n    const isTypeScript = fileInfo.path.endsWith('.ts') || fileInfo.path.endsWith('.tsx');\n\n    let addImports = false;\n    // Collect all existing method names\n    const existingNames = new Set<string>();\n    root.find(j.Identifier).forEach((path) => {\n        existingNames.add(path.node.name);\n    });\n\n    const baseName = 'CustomFilterCell';\n    const uniqueName = generateUniqueName(baseName, existingNames);\n\n    // Ensures we find the correct Grid import\n    // if the user has imported it with a different name\n    // e.g. import { Grid as KendoGrid } from '@progress/kendo-react-grid';\n    const gridName = findImportedName(j, root, 'Grid', '@progress/kendo-react-grid') || 'Grid';\n\n    // Find all JSXElements with the name 'Grid'\n    root.find(j.JSXElement, { openingElement: { name: { name: gridName } } }).forEach((path) => {\n        const attributes = path.node.openingElement.attributes;\n\n        // Find the 'filterCellRender' attribute\n        const filterCellRenderAttribute = attributes?.find(\n            (attr) => attr.type === 'JSXAttribute' && attr.name.name === 'filterCellRender'\n        ) as JSXAttribute;\n\n        // If the 'filterCellRender' attribute exists, copy its value as a comment\n        if (filterCellRenderAttribute && filterCellRenderAttribute.type === 'JSXAttribute') {\n            const filterCellRenderValue = filterCellRenderAttribute.value\n                ? j(filterCellRenderAttribute.value).toSource()\n                : 'No value provided';\n\n            // Find the parent component\n            const { isClassComponent, isFunctionalComponent, parentNode } = findParentComponent(j, path);\n\n            if (attributes) {\n                // Ensure the 'cells' attribute exists\n                ensureAttributeExists(\n                    j,\n                    attributes,\n                    'cells',\n                    'filterCell',\n                    isClassComponent ? `this.${uniqueName}` : uniqueName\n                );\n            }\n\n            // Create the CustomFilterCell method\n            let customMethod;\n            if (isClassComponent) {\n                customMethod = createMethodForClassComponent(j, uniqueName, isTypeScript, 'GridCustomFilterCellProps');\n            } else if (isFunctionalComponent) {\n                customMethod = createArrowFunctionForFunctionalComponent(\n                    j,\n                    uniqueName,\n                    isTypeScript,\n                    'GridCustomFilterCellProps'\n                );\n            }\n\n            // Add the CustomFilterCell method to the component\n            addMethodToComponent(j, parentNode, customMethod, isClassComponent);\n\n            // Add the filterCellRender value as a comment in the CustomFilterCell method\n            if (customMethod) {\n                addCommentToMethod(\n                    j,\n                    j(customMethod),\n                    `Original filterCellRender value: ${filterCellRenderValue}`,\n                    isClassComponent ? 'class' : 'function'\n                );\n            }\n\n            // Remove the 'filterCellRender' attribute\n            const wasRemoved = removeAttribute(attributes as (JSXAttribute | JSXSpreadAttribute)[], 'filterCellRender');\n            if (wasRemoved) {\n                addImports = true;\n            }\n        }\n    });\n\n    if (addImports && isTypeScript) {\n        // Ensure the import for GridCustomFilterCellProps exists\n        ensureImportExists(j, root, 'GridCustomFilterCellProps', '@progress/kendo-react-grid');\n    }\n\n    return root.toSource();\n}\n"],"names":["filterCellRender","fileInfo","api","j","root","isTypeScript","addImports","existingNames","path","uniqueName","generateUniqueName","gridName","findImportedName","attributes","filterCellRenderAttribute","attr","filterCellRenderValue","isClassComponent","isFunctionalComponent","parentNode","findParentComponent","ensureAttributeExists","customMethod","createMethodForClassComponent","createArrowFunctionForFunctionalComponent","addMethodToComponent","addCommentToMethod","removeAttribute","ensureImportExists"],"mappings":"2CAcA,SAAAA,EAAyBC,EAAoBC,EAAU,CACnD,MAAMC,EAAiBD,EAAI,YACrBE,EAAOD,EAAEF,EAAS,MAAM,EAGxBI,EAAeJ,EAAS,KAAK,SAAS,KAAK,GAAKA,EAAS,KAAK,SAAS,MAAM,EAEnF,IAAIK,EAAa,GAEX,MAAAC,MAAoB,IAC1BH,EAAK,KAAKD,EAAE,UAAU,EAAE,QAASK,GAAS,CACxBD,EAAA,IAAIC,EAAK,KAAK,IAAI,CAAA,CACnC,EAGK,MAAAC,EAAaC,EAAAA,mBADF,mBAC+BH,CAAa,EAKvDI,EAAWC,EAAAA,iBAAiBT,EAAGC,EAAM,OAAQ,4BAA4B,GAAK,OAGpF,OAAAA,EAAK,KAAKD,EAAE,WAAY,CAAE,eAAgB,CAAE,KAAM,CAAE,KAAMQ,CAAA,CAAa,CAAA,CAAC,EAAE,QAASH,GAAS,CAClF,MAAAK,EAAaL,EAAK,KAAK,eAAe,WAGtCM,EAA4BD,GAAA,YAAAA,EAAY,KACzCE,GAASA,EAAK,OAAS,gBAAkBA,EAAK,KAAK,OAAS,oBAI7D,GAAAD,GAA6BA,EAA0B,OAAS,eAAgB,CAC1E,MAAAE,EAAwBF,EAA0B,MAClDX,EAAEW,EAA0B,KAAK,EAAE,SACnC,EAAA,oBAGA,CAAE,iBAAAG,EAAkB,sBAAAC,EAAuB,WAAAC,CAAe,EAAAC,sBAAoBjB,EAAGK,CAAI,EAEvFK,GAEAQ,EAAA,sBACIlB,EACAU,EACA,QACA,aACAI,EAAmB,QAAQR,CAAU,GAAKA,CAAA,EAK9C,IAAAa,EACAL,EACAK,EAAeC,EAA8B,8BAAApB,EAAGM,EAAYJ,EAAc,2BAA2B,EAC9Fa,IACQI,EAAAE,EAAA,0CACXrB,EACAM,EACAJ,EACA,2BAAA,GAKaoB,EAAAA,qBAAAtB,EAAGgB,EAAYG,EAAcL,CAAgB,EAG9DK,GACAI,EAAA,mBACIvB,EACAA,EAAEmB,CAAY,EACd,oCAAoCN,CAAqB,GACzDC,EAAmB,QAAU,UAAA,EAKlBU,EAAAA,gBAAgBd,EAAqD,kBAAkB,IAEzFP,EAAA,GAErB,CAAA,CACH,EAEGA,GAAcD,GAEKuB,EAAAA,mBAAAzB,EAAGC,EAAM,4BAA6B,4BAA4B,EAGlFA,EAAK,UAChB"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
*-------------------------------------------------------------------------------------------
|
|
4
|
+
* Copyright © 2025 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 strict";const n=require("./utils.js");function f(u,m){const e=m.jscodeshift,r=e(u.source),a=u.path.endsWith(".ts")||u.path.endsWith(".tsx");let E=!1;const x=new Set;r.find(e.Identifier).forEach(d=>{x.add(d.node.name)});const i=n.generateUniqueName("handleGroupExpand",x),g=n.findImportedName(e,r,"Grid","@progress/kendo-react-grid")||"Grid";return r.find(e.JSXElement,{openingElement:{name:{name:g}}}).forEach(d=>{const t=d.node.openingElement.attributes;if(!n.hasJSXAttribute(t,"groupable"))return;const s=t==null?void 0:t.find(o=>o.type==="JSXAttribute"&&o.name.name==="onExpandChange"),c=s!=null&&s.value?e(s.value).toSource():"No value provided";n.removeAttribute(t,"onExpandChange"),E=!0;const{isClassComponent:h,isFunctionalComponent:l,parentNode:p}=n.findParentComponent(e,d);if(h){if(n.addStateDeclaration(e,p,"groupExpand",e.arrayExpression([])),n.hasJSXAttribute(t,"groupExpand")||n.addStateAttribute(e,t,"groupExpand","this.state.groupExpand"),!n.hasJSXAttribute(t,"onGroupExpandChange")){n.addEventAttribute(e,t,"onGroupExpandChange",`this.${i}`);const o=n.createClassMethod(e,i,[`event${a?": GridGroupExpandChangeEvent":""}`],[e.expressionStatement(e.callExpression(e.memberExpression(e.thisExpression(),e.identifier("setState")),[e.objectExpression([e.property("init",e.identifier("groupExpand"),e.memberExpression(e.identifier("event"),e.identifier("groupExpand")))])]))]);n.addCommentToMethod(e,e(o),`Original onExpandChange value: ${c}`,"class"),n.addMethodToComponent(e,p,o,!0)}}else if(l&&(n.addUseStateDeclaration(e,p,"groupExpand","setGroupExpand",e.arrayExpression([]),a,"GroupExpandDescriptor[]"),n.hasJSXAttribute(t,"groupExpand")||n.addStateAttribute(e,t,"groupExpand","groupExpand"),!n.hasJSXAttribute(t,"onGroupExpandChange"))){n.addEventAttribute(e,t,"onGroupExpandChange",`${i}`);const o=n.createArrowFunction(e,`${i}`,[`(event${a?": GridGroupExpandChangeEvent":""})`],[e.expressionStatement(e.callExpression(e.identifier("setGroupExpand"),[e.memberExpression(e.identifier("event"),e.identifier("groupExpand"))]))]);n.addCommentToMethod(e,e(o),`Original onExpandChange value: ${c}`,"function"),n.addMethodToComponent(e,p,o,!1)}}),E&&a&&(n.ensureImportExists(e,r,"GroupExpandDescriptor","@progress/kendo-react-data-tools"),n.ensureImportExists(e,r,"GridGroupExpandChangeEvent","@progress/kendo-react-grid")),r.toSource()}module.exports=f;
|
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"group-expand-state.js","sources":["../../../../../packages/grid/codemods/v11/group-expand-state.ts"],"sourcesContent":["import { API, FileInfo, JSCodeshift, JSXAttribute, JSXSpreadAttribute } from 'jscodeshift';\nimport {\n    addMethodToComponent,\n    removeAttribute,\n    findParentComponent,\n    generateUniqueName,\n    ensureImportExists,\n    addEventAttribute,\n    addStateAttribute,\n    addStateDeclaration,\n    addUseStateDeclaration,\n    findImportedName,\n    createClassMethod,\n    createArrowFunction,\n    hasJSXAttribute,\n    addCommentToMethod\n} from './utils';\n\nexport default function (fileInfo: FileInfo, api: API) {\n    const j: JSCodeshift = api.jscodeshift;\n    const root = j(fileInfo.source);\n\n    // Check if the file is TypeScript or TSX\n    const isTypeScript = fileInfo.path.endsWith('.ts') || fileInfo.path.endsWith('.tsx');\n\n    let addImports = false;\n    const existingNames = new Set<string>();\n    root.find(j.Identifier).forEach((path) => {\n        existingNames.add(path.node.name);\n    });\n\n    const baseName = 'handleGroupExpand';\n    const uniqueName = generateUniqueName(baseName, existingNames);\n\n    // Dynamically resolve the imported name for `Grid`\n    const gridName = findImportedName(j, root, 'Grid', '@progress/kendo-react-grid') || 'Grid';\n\n    // Find all JSXElements with the name of the resolved `Grid` component\n    const gridElements = root.find(j.JSXElement, { openingElement: { name: { name: gridName } } });\n\n    gridElements.forEach((gridPath) => {\n        const attributes = gridPath.node.openingElement.attributes;\n\n        // Check if the `groupable` attribute exists\n        if (!hasJSXAttribute(attributes, 'groupable')) {\n            return; // Skip this Grid if `groupable` is not present\n        }\n\n        // Find the `onExpandChange` attribute\n        const onExpandChangeAttribute = attributes?.find(\n            (attr) => attr.type === 'JSXAttribute' && attr.name.name === 'onExpandChange'\n        ) as JSXAttribute;\n\n        // Copy the value of `onExpandChange` as a comment\n        const onExpandChangeValue = onExpandChangeAttribute?.value\n            ? j(onExpandChangeAttribute.value).toSource()\n            : 'No value provided';\n\n        // Remove the `onExpandChange` attribute\n        removeAttribute(attributes as (JSXAttribute | JSXSpreadAttribute)[], 'onExpandChange');\n        addImports = true;\n\n        // Determine if the parent component is a class or functional component\n        const { isClassComponent, isFunctionalComponent, parentNode } = findParentComponent(j, gridPath);\n\n        if (isClassComponent) {\n            // Add `groupExpand` to the class component's state\n            addStateDeclaration(j, parentNode, 'groupExpand', j.arrayExpression([]));\n\n            // Add `groupExpand` and `onGroupExpandChange` attributes\n            if (!hasJSXAttribute(attributes, 'groupExpand')) {\n                addStateAttribute(\n                    j,\n                    attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                    'groupExpand',\n                    'this.state.groupExpand'\n                );\n            }\n\n            if (!hasJSXAttribute(attributes, 'onGroupExpandChange')) {\n                addEventAttribute(\n                    j,\n                    attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                    'onGroupExpandChange',\n                    `this.${uniqueName}`\n                );\n\n                // Create and add `handleGroupExpand` method\n                const handleGroupExpandMethod = createClassMethod(\n                    j,\n                    uniqueName,\n                    [`event${isTypeScript ? ': GridGroupExpandChangeEvent' : ''}`],\n                    [\n                        j.expressionStatement(\n                            j.callExpression(j.memberExpression(j.thisExpression(), j.identifier('setState')), [\n                                j.objectExpression([\n                                    j.property(\n                                        'init',\n                                        j.identifier('groupExpand'),\n                                        j.memberExpression(j.identifier('event'), j.identifier('groupExpand'))\n                                    )\n                                ])\n                            ])\n                        )\n                    ]\n                );\n\n                // Add the `onExpandChange` value as a comment in the method\n                addCommentToMethod(\n                    j,\n                    j(handleGroupExpandMethod),\n                    `Original onExpandChange value: ${onExpandChangeValue}`,\n                    'class'\n                );\n\n                addMethodToComponent(j, parentNode, handleGroupExpandMethod, true);\n            }\n        } else if (isFunctionalComponent) {\n            // Add `React.useState` for `groupExpand`\n            addUseStateDeclaration(\n                j,\n                parentNode,\n                'groupExpand',\n                'setGroupExpand',\n                j.arrayExpression([]),\n                isTypeScript,\n                'GroupExpandDescriptor[]'\n            );\n\n            // Add `groupExpand` and `onGroupExpandChange` attributes\n            if (!hasJSXAttribute(attributes, 'groupExpand')) {\n                addStateAttribute(j, attributes as (JSXAttribute | JSXSpreadAttribute)[], 'groupExpand', 'groupExpand');\n            }\n\n            if (!hasJSXAttribute(attributes, 'onGroupExpandChange')) {\n                addEventAttribute(\n                    j,\n                    attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                    'onGroupExpandChange',\n                    `${uniqueName}`\n                );\n\n                // Create and add `handleGroupExpand` function\n                const handleGroupExpandFunction = createArrowFunction(\n                    j,\n                    `${uniqueName}`,\n                    [`(event${isTypeScript ? ': GridGroupExpandChangeEvent' : ''})`],\n                    [\n                        j.expressionStatement(\n                            j.callExpression(j.identifier('setGroupExpand'), [\n                                j.memberExpression(j.identifier('event'), j.identifier('groupExpand'))\n                            ])\n                        )\n                    ]\n                );\n\n                // Add the `onExpandChange` value as a comment in the function\n                addCommentToMethod(\n                    j,\n                    j(handleGroupExpandFunction),\n                    `Original onExpandChange value: ${onExpandChangeValue}`,\n                    'function'\n                );\n\n                addMethodToComponent(j, parentNode, handleGroupExpandFunction, false);\n            }\n        }\n    });\n\n    if (addImports && isTypeScript) {\n        // Ensure TypeScript imports\n        ensureImportExists(j, root, 'GroupExpandDescriptor', '@progress/kendo-react-data-tools');\n        ensureImportExists(j, root, 'GridGroupExpandChangeEvent', '@progress/kendo-react-grid');\n    }\n\n    return root.toSource();\n}\n"],"names":["groupExpandState","fileInfo","api","j","root","isTypeScript","addImports","existingNames","path","uniqueName","generateUniqueName","gridName","findImportedName","gridPath","attributes","hasJSXAttribute","onExpandChangeAttribute","attr","onExpandChangeValue","removeAttribute","isClassComponent","isFunctionalComponent","parentNode","findParentComponent","addStateDeclaration","addStateAttribute","addEventAttribute","handleGroupExpandMethod","createClassMethod","addCommentToMethod","addMethodToComponent","addUseStateDeclaration","handleGroupExpandFunction","createArrowFunction","ensureImportExists"],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
*-------------------------------------------------------------------------------------------
|
|
4
|
+
* Copyright © 2025 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 strict";const t=require("./utils.js");function N(m,C){const e=C.jscodeshift,o=e(m.source),c=m.path.endsWith(".ts")||m.path.endsWith(".tsx");let u=!1;const p=new Set;o.find(e.Identifier).forEach(d=>{p.add(d.node.name)});const s=t.generateUniqueName("CustomHeaderCell",p),h=t.findImportedName(e,o,"Grid","@progress/kendo-react-grid")||"Grid";return o.find(e.JSXElement,{openingElement:{name:{name:h}}}).forEach(d=>{const n=d.node.openingElement.attributes,a=n==null?void 0:n.find(i=>i.type==="JSXAttribute"&&i.name.name==="headerCellRender");if(a&&a.type==="JSXAttribute"){const i=a.value?e(a.value).toSource():"No value provided",{isClassComponent:l,isFunctionalComponent:f,parentNode:g}=t.findParentComponent(e,d);n&&t.ensureAttributeExists(e,n,"cells","headerCell",l?`this.${s}`:s);let r;l?r=t.createMethodForClassComponent(e,s,c,"GridCustomHeaderCellProps"):f&&(r=t.createArrowFunctionForFunctionalComponent(e,s,c,"GridCustomHeaderCellProps")),t.addMethodToComponent(e,g,r,l),r&&t.addCommentToMethod(e,e(r),`Original headerCellRender value: ${i}`,l?"class":"function"),t.removeAttribute(n,"headerCellRender")&&(u=!0)}}),u&&c&&t.ensureImportExists(e,o,"GridCustomHeaderCellProps","@progress/kendo-react-grid"),o.toSource()}module.exports=N;
|
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"header-cell-render.js","sources":["../../../../../packages/grid/codemods/v11/header-cell-render.ts"],"sourcesContent":["import { API, FileInfo, JSCodeshift, JSXAttribute, JSXSpreadAttribute } from 'jscodeshift';\nimport {\n    addCommentToMethod,\n    ensureAttributeExists,\n    findParentComponent,\n    generateUniqueName,\n    ensureImportExists,\n    createMethodForClassComponent,\n    createArrowFunctionForFunctionalComponent,\n    addMethodToComponent,\n    removeAttribute,\n    findImportedName\n} from './utils';\n\nexport default function (fileInfo: FileInfo, api: API) {\n    const j: JSCodeshift = api.jscodeshift;\n    const root = j(fileInfo.source);\n\n    // Check if the file is TypeScript or TSX\n    const isTypeScript = fileInfo.path.endsWith('.ts') || fileInfo.path.endsWith('.tsx');\n\n    let addImports = false;\n    // Collect all existing method names\n    const existingNames = new Set<string>();\n    root.find(j.Identifier).forEach((path) => {\n        existingNames.add(path.node.name);\n    });\n\n    const baseName = 'CustomHeaderCell';\n    const uniqueName = generateUniqueName(baseName, existingNames);\n\n    // Ensures we find the correct Grid import\n    // if the user has imported it with a different name\n    // e.g. import { Grid as KendoGrid } from '@progress/kendo-react-grid';\n    const gridName = findImportedName(j, root, 'Grid', '@progress/kendo-react-grid') || 'Grid';\n\n    // Find all JSXElements with the name 'Grid'\n    root.find(j.JSXElement, { openingElement: { name: { name: gridName } } }).forEach((path) => {\n        const attributes = path.node.openingElement.attributes;\n\n        // Find the 'headerCellRender' attribute\n        const headerCellRenderAttribute = attributes?.find(\n            (attr) => attr.type === 'JSXAttribute' && attr.name.name === 'headerCellRender'\n        ) as JSXAttribute;\n\n        // If the 'headerCellRender' attribute exists, copy its value as a comment\n        if (headerCellRenderAttribute && headerCellRenderAttribute.type === 'JSXAttribute') {\n            const headerCellRenderValue = headerCellRenderAttribute.value\n                ? j(headerCellRenderAttribute.value).toSource()\n                : 'No value provided';\n\n            // Find the parent component\n            const { isClassComponent, isFunctionalComponent, parentNode } = findParentComponent(j, path);\n\n            if (attributes) {\n                // Ensure the 'cells' attribute exists\n                ensureAttributeExists(\n                    j,\n                    attributes,\n                    'cells',\n                    'headerCell',\n                    isClassComponent ? `this.${uniqueName}` : uniqueName\n                );\n            }\n\n            // Create the CustomHeaderCell method\n            let customMethod;\n            if (isClassComponent) {\n                customMethod = createMethodForClassComponent(j, uniqueName, isTypeScript, 'GridCustomHeaderCellProps');\n            } else if (isFunctionalComponent) {\n                customMethod = createArrowFunctionForFunctionalComponent(\n                    j,\n                    uniqueName,\n                    isTypeScript,\n                    'GridCustomHeaderCellProps'\n                );\n            }\n\n            // Add the CustomHeaderCell method to the component\n            addMethodToComponent(j, parentNode, customMethod, isClassComponent);\n\n            // Add the headerCellRender value as a comment in the CustomHeaderCell method\n            if (customMethod) {\n                addCommentToMethod(\n                    j,\n                    j(customMethod),\n                    `Original headerCellRender value: ${headerCellRenderValue}`,\n                    isClassComponent ? 'class' : 'function'\n                );\n            }\n\n            // Remove the 'headerCellRender' attribute\n            const wasRemoved = removeAttribute(attributes as (JSXAttribute | JSXSpreadAttribute)[], 'headerCellRender');\n            if (wasRemoved) {\n                addImports = true;\n            }\n        }\n    });\n\n    if (addImports && isTypeScript) {\n        // Ensure the import for GridCustomHeaderCellProps exists\n        ensureImportExists(j, root, 'GridCustomHeaderCellProps', '@progress/kendo-react-grid');\n    }\n\n    return root.toSource();\n}\n"],"names":["headerCellRender","fileInfo","api","j","root","isTypeScript","addImports","existingNames","path","uniqueName","generateUniqueName","gridName","findImportedName","attributes","headerCellRenderAttribute","attr","headerCellRenderValue","isClassComponent","isFunctionalComponent","parentNode","findParentComponent","ensureAttributeExists","customMethod","createMethodForClassComponent","createArrowFunctionForFunctionalComponent","addMethodToComponent","addCommentToMethod","removeAttribute","ensureImportExists"],"mappings":"2CAcA,SAAAA,EAAyBC,EAAoBC,EAAU,CACnD,MAAMC,EAAiBD,EAAI,YACrBE,EAAOD,EAAEF,EAAS,MAAM,EAGxBI,EAAeJ,EAAS,KAAK,SAAS,KAAK,GAAKA,EAAS,KAAK,SAAS,MAAM,EAEnF,IAAIK,EAAa,GAEX,MAAAC,MAAoB,IAC1BH,EAAK,KAAKD,EAAE,UAAU,EAAE,QAASK,GAAS,CACxBD,EAAA,IAAIC,EAAK,KAAK,IAAI,CAAA,CACnC,EAGK,MAAAC,EAAaC,EAAAA,mBADF,mBAC+BH,CAAa,EAKvDI,EAAWC,EAAAA,iBAAiBT,EAAGC,EAAM,OAAQ,4BAA4B,GAAK,OAGpF,OAAAA,EAAK,KAAKD,EAAE,WAAY,CAAE,eAAgB,CAAE,KAAM,CAAE,KAAMQ,CAAA,CAAa,CAAA,CAAC,EAAE,QAASH,GAAS,CAClF,MAAAK,EAAaL,EAAK,KAAK,eAAe,WAGtCM,EAA4BD,GAAA,YAAAA,EAAY,KACzCE,GAASA,EAAK,OAAS,gBAAkBA,EAAK,KAAK,OAAS,oBAI7D,GAAAD,GAA6BA,EAA0B,OAAS,eAAgB,CAC1E,MAAAE,EAAwBF,EAA0B,MAClDX,EAAEW,EAA0B,KAAK,EAAE,SACnC,EAAA,oBAGA,CAAE,iBAAAG,EAAkB,sBAAAC,EAAuB,WAAAC,CAAe,EAAAC,sBAAoBjB,EAAGK,CAAI,EAEvFK,GAEAQ,EAAA,sBACIlB,EACAU,EACA,QACA,aACAI,EAAmB,QAAQR,CAAU,GAAKA,CAAA,EAK9C,IAAAa,EACAL,EACAK,EAAeC,EAA8B,8BAAApB,EAAGM,EAAYJ,EAAc,2BAA2B,EAC9Fa,IACQI,EAAAE,EAAA,0CACXrB,EACAM,EACAJ,EACA,2BAAA,GAKaoB,EAAAA,qBAAAtB,EAAGgB,EAAYG,EAAcL,CAAgB,EAG9DK,GACAI,EAAA,mBACIvB,EACAA,EAAEmB,CAAY,EACd,oCAAoCN,CAAqB,GACzDC,EAAmB,QAAU,UAAA,EAKlBU,EAAAA,gBAAgBd,EAAqD,kBAAkB,IAEzFP,EAAA,GAErB,CAAA,CACH,EAEGA,GAAcD,GAEKuB,EAAAA,mBAAAzB,EAAGC,EAAM,4BAA6B,4BAA4B,EAGlFA,EAAK,UAChB"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
*-------------------------------------------------------------------------------------------
|
|
4
|
+
* Copyright © 2025 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 strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./cell-render.js"),r=require("./column-cell.js"),l=require("./column-filter-cell.js"),t=require("./column-footer-cell.js"),n=require("./column-header-cell.js"),o=require("./detail-expand-state.js"),i=require("./edit-state.js"),u=require("./filter-cell-render.js"),c=require("./group-expand-state.js"),d=require("./header-cell-render.js"),a=require("./row-render.js"),C=require("./selection-state.js");exports.CellRender=e;exports.ColumnCell=r;exports.ColumnFilterCell=l;exports.ColumnFooterCell=t;exports.ColumnHeaderCell=n;exports.DetailExpand=o;exports.EditState=i;exports.FilterCellRender=u;exports.GroupExpandState=c;exports.HeaderCellRender=d;exports.RowRender=a;exports.SelectionState=C;
|
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIn0=
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
*-------------------------------------------------------------------------------------------
|
|
4
|
+
* Copyright © 2025 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 strict";const t=require("./utils.js");function h(u,f){const e=f.jscodeshift,n=e(u.source),c=u.path.endsWith(".ts")||u.path.endsWith(".tsx");let p=!1;const l=new Set;n.find(e.Identifier).forEach(i=>{l.add(i.node.name)});const s=t.generateUniqueName("CustomRow",l),w=t.findImportedName(e,n,"Grid","@progress/kendo-react-grid")||"Grid";return n.find(e.JSXElement,{openingElement:{name:{name:w}}}).forEach(i=>{const o=i.node.openingElement.attributes,d=o==null?void 0:o.find(a=>a.type==="JSXAttribute"&&a.name.name==="rowRender");if(d&&d.type==="JSXAttribute"){const a=d.value?e(d.value).toSource():"No value provided",{isClassComponent:m,isFunctionalComponent:C,parentNode:R}=t.findParentComponent(e,i);o&&t.ensureAttributeExists(e,o,"rows","data",m?`this.${s}`:s);let r;m?r=t.createMethodForClassComponent(e,s,c,"GridCustomRowProps"):C&&(r=t.createArrowFunctionForFunctionalComponent(e,s,c,"GridCustomRowProps")),t.addMethodToComponent(e,R,r,m),r&&t.addCommentToMethod(e,e(r),`Original rowRender value: ${a}`,m?"class":"function"),t.removeAttribute(o,"rowRender")&&(p=!0)}}),p&&c&&t.ensureImportExists(e,n,"GridCustomRowProps","@progress/kendo-react-grid"),n.toSource()}module.exports=h;
|
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm93LXJlbmRlci5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ3JpZC9jb2RlbW9kcy92MTEvcm93LXJlbmRlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBUEksIEZpbGVJbmZvLCBKU0NvZGVzaGlmdCwgSlNYQXR0cmlidXRlLCBKU1hTcHJlYWRBdHRyaWJ1dGUgfSBmcm9tICdqc2NvZGVzaGlmdCc7XG5pbXBvcnQge1xuICAgIGFkZENvbW1lbnRUb01ldGhvZCxcbiAgICBlbnN1cmVBdHRyaWJ1dGVFeGlzdHMsXG4gICAgZmluZFBhcmVudENvbXBvbmVudCxcbiAgICBnZW5lcmF0ZVVuaXF1ZU5hbWUsXG4gICAgZW5zdXJlSW1wb3J0RXhpc3RzLFxuICAgIGNyZWF0ZU1ldGhvZEZvckNsYXNzQ29tcG9uZW50LFxuICAgIGNyZWF0ZUFycm93RnVuY3Rpb25Gb3JGdW5jdGlvbmFsQ29tcG9uZW50LFxuICAgIGFkZE1ldGhvZFRvQ29tcG9uZW50LFxuICAgIHJlbW92ZUF0dHJpYnV0ZSxcbiAgICBmaW5kSW1wb3J0ZWROYW1lXG59IGZyb20gJy4vdXRpbHMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiAoZmlsZUluZm86IEZpbGVJbmZvLCBhcGk6IEFQSSkge1xuICAgIGNvbnN0IGo6IEpTQ29kZXNoaWZ0ID0gYXBpLmpzY29kZXNoaWZ0O1xuICAgIGNvbnN0IHJvb3QgPSBqKGZpbGVJbmZvLnNvdXJjZSk7XG5cbiAgICAvLyBDaGVjayBpZiB0aGUgZmlsZSBpcyBUeXBlU2NyaXB0IG9yIFRTWFxuICAgIGNvbnN0IGlzVHlwZVNjcmlwdCA9IGZpbGVJbmZvLnBhdGguZW5kc1dpdGgoJy50cycpIHx8IGZpbGVJbmZvLnBhdGguZW5kc1dpdGgoJy50c3gnKTtcblxuICAgIGxldCBhZGRJbXBvcnRzID0gZmFsc2U7XG4gICAgLy8gQ29sbGVjdCBhbGwgZXhpc3RpbmcgbWV0aG9kIG5hbWVzXG4gICAgY29uc3QgZXhpc3RpbmdOYW1lcyA9IG5ldyBTZXQ8c3RyaW5nPigpO1xuICAgIHJvb3QuZmluZChqLklkZW50aWZpZXIpLmZvckVhY2goKHBhdGgpID0+IHtcbiAgICAgICAgZXhpc3RpbmdOYW1lcy5hZGQocGF0aC5ub2RlLm5hbWUpO1xuICAgIH0pO1xuXG4gICAgY29uc3QgYmFzZU5hbWUgPSAnQ3VzdG9tUm93JztcbiAgICBjb25zdCB1bmlxdWVOYW1lID0gZ2VuZXJhdGVVbmlxdWVOYW1lKGJhc2VOYW1lLCBleGlzdGluZ05hbWVzKTtcblxuICAgIC8vIEVuc3VyZXMgd2UgZmluZCB0aGUgY29ycmVjdCBHcmlkIGltcG9ydFxuICAgIC8vIGlmIHRoZSB1c2VyIGhhcyBpbXBvcnRlZCBpdCB3aXRoIGEgZGlmZmVyZW50IG5hbWVcbiAgICAvLyBlLmcuIGltcG9ydCB7IEdyaWQgYXMgS2VuZG9HcmlkIH0gZnJvbSAnQHByb2dyZXNzL2tlbmRvLXJlYWN0LWdyaWQnO1xuICAgIGNvbnN0IGdyaWROYW1lID0gZmluZEltcG9ydGVkTmFtZShqLCByb290LCAnR3JpZCcsICdAcHJvZ3Jlc3Mva2VuZG8tcmVhY3QtZ3JpZCcpIHx8ICdHcmlkJztcblxuICAgIC8vIEZpbmQgYWxsIEpTWEVsZW1lbnRzIHdpdGggdGhlIG5hbWUgJ0dyaWQnXG4gICAgcm9vdC5maW5kKGouSlNYRWxlbWVudCwgeyBvcGVuaW5nRWxlbWVudDogeyBuYW1lOiB7IG5hbWU6IGdyaWROYW1lIH0gfSB9KS5mb3JFYWNoKChwYXRoKSA9PiB7XG4gICAgICAgIGNvbnN0IGF0dHJpYnV0ZXMgPSBwYXRoLm5vZGUub3BlbmluZ0VsZW1lbnQuYXR0cmlidXRlcztcblxuICAgICAgICAvLyBGaW5kIHRoZSAncm93UmVuZGVyJyBhdHRyaWJ1dGVcbiAgICAgICAgY29uc3Qgcm93UmVuZGVyQXR0cmlidXRlID0gYXR0cmlidXRlcz8uZmluZChcbiAgICAgICAgICAgIChhdHRyKSA9PiBhdHRyLnR5cGUgPT09ICdKU1hBdHRyaWJ1dGUnICYmIGF0dHIubmFtZS5uYW1lID09PSAncm93UmVuZGVyJ1xuICAgICAgICApIGFzIEpTWEF0dHJpYnV0ZTtcblxuICAgICAgICAvLyBJZiB0aGUgJ3Jvd1JlbmRlcicgYXR0cmlidXRlIGV4aXN0cywgY29weSBpdHMgdmFsdWUgYXMgYSBjb21tZW50XG4gICAgICAgIGlmIChyb3dSZW5kZXJBdHRyaWJ1dGUgJiYgcm93UmVuZGVyQXR0cmlidXRlLnR5cGUgPT09ICdKU1hBdHRyaWJ1dGUnKSB7XG4gICAgICAgICAgICBjb25zdCByb3dSZW5kZXJWYWx1ZSA9IHJvd1JlbmRlckF0dHJpYnV0ZS52YWx1ZVxuICAgICAgICAgICAgICAgID8gaihyb3dSZW5kZXJBdHRyaWJ1dGUudmFsdWUpLnRvU291cmNlKClcbiAgICAgICAgICAgICAgICA6ICdObyB2YWx1ZSBwcm92aWRlZCc7XG5cbiAgICAgICAgICAgIC8vIEZpbmQgdGhlIHBhcmVudCBjb21wb25lbnRcbiAgICAgICAgICAgIGNvbnN0IHsgaXNDbGFzc0NvbXBvbmVudCwgaXNGdW5jdGlvbmFsQ29tcG9uZW50LCBwYXJlbnROb2RlIH0gPSBmaW5kUGFyZW50Q29tcG9uZW50KGosIHBhdGgpO1xuXG4gICAgICAgICAgICBpZiAoYXR0cmlidXRlcykge1xuICAgICAgICAgICAgICAgIC8vIEVuc3VyZSB0aGUgJ3Jvd3MnIGF0dHJpYnV0ZSBleGlzdHNcbiAgICAgICAgICAgICAgICBlbnN1cmVBdHRyaWJ1dGVFeGlzdHMoXG4gICAgICAgICAgICAgICAgICAgIGosXG4gICAgICAgICAgICAgICAgICAgIGF0dHJpYnV0ZXMsXG4gICAgICAgICAgICAgICAgICAgICdyb3dzJyxcbiAgICAgICAgICAgICAgICAgICAgJ2RhdGEnLFxuICAgICAgICAgICAgICAgICAgICBpc0NsYXNzQ29tcG9uZW50ID8gYHRoaXMuJHt1bmlxdWVOYW1lfWAgOiB1bmlxdWVOYW1lXG4gICAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIC8vIENyZWF0ZSB0aGUgQ3VzdG9tUm93IG1ldGhvZFxuICAgICAgICAgICAgbGV0IGN1c3RvbU1ldGhvZDtcbiAgICAgICAgICAgIGlmIChpc0NsYXNzQ29tcG9uZW50KSB7XG4gICAgICAgICAgICAgICAgY3VzdG9tTWV0aG9kID0gY3JlYXRlTWV0aG9kRm9yQ2xhc3NDb21wb25lbnQoaiwgdW5pcXVlTmFtZSwgaXNUeXBlU2NyaXB0LCAnR3JpZEN1c3RvbVJvd1Byb3BzJyk7XG4gICAgICAgICAgICB9IGVsc2UgaWYgKGlzRnVuY3Rpb25hbENvbXBvbmVudCkge1xuICAgICAgICAgICAgICAgIGN1c3RvbU1ldGhvZCA9IGNyZWF0ZUFycm93RnVuY3Rpb25Gb3JGdW5jdGlvbmFsQ29tcG9uZW50KFxuICAgICAgICAgICAgICAgICAgICBqLFxuICAgICAgICAgICAgICAgICAgICB1bmlxdWVOYW1lLFxuICAgICAgICAgICAgICAgICAgICBpc1R5cGVTY3JpcHQsXG4gICAgICAgICAgICAgICAgICAgICdHcmlkQ3VzdG9tUm93UHJvcHMnXG4gICAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgLy8gQWRkIHRoZSBDdXN0b21Sb3cgbWV0aG9kIHRvIHRoZSBjb21wb25lbnRcbiAgICAgICAgICAgIGFkZE1ldGhvZFRvQ29tcG9uZW50KGosIHBhcmVudE5vZGUsIGN1c3RvbU1ldGhvZCwgaXNDbGFzc0NvbXBvbmVudCk7XG5cbiAgICAgICAgICAgIC8vIEFkZCB0aGUgcm93UmVuZGVyIHZhbHVlIGFzIGEgY29tbWVudCBpbiB0aGUgQ3VzdG9tUm93IG1ldGhvZFxuICAgICAgICAgICAgaWYgKGN1c3RvbU1ldGhvZCkge1xuICAgICAgICAgICAgICAgIGFkZENvbW1lbnRUb01ldGhvZChcbiAgICAgICAgICAgICAgICAgICAgaixcbiAgICAgICAgICAgICAgICAgICAgaihjdXN0b21NZXRob2QpLFxuICAgICAgICAgICAgICAgICAgICBgT3JpZ2luYWwgcm93UmVuZGVyIHZhbHVlOiAke3Jvd1JlbmRlclZhbHVlfWAsXG4gICAgICAgICAgICAgICAgICAgIGlzQ2xhc3NDb21wb25lbnQgPyAnY2xhc3MnIDogJ2Z1bmN0aW9uJ1xuICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIC8vIFJlbW92ZSB0aGUgJ3Jvd1JlbmRlcicgYXR0cmlidXRlXG4gICAgICAgICAgICBjb25zdCB3YXNSZW1vdmVkID0gcmVtb3ZlQXR0cmlidXRlKGF0dHJpYnV0ZXMgYXMgKEpTWEF0dHJpYnV0ZSB8IEpTWFNwcmVhZEF0dHJpYnV0ZSlbXSwgJ3Jvd1JlbmRlcicpO1xuICAgICAgICAgICAgaWYgKHdhc1JlbW92ZWQpIHtcbiAgICAgICAgICAgICAgICBhZGRJbXBvcnRzID0gdHJ1ZTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH0pO1xuXG4gICAgaWYgKGFkZEltcG9ydHMgJiYgaXNUeXBlU2NyaXB0KSB7XG4gICAgICAgIC8vIEVuc3VyZSB0aGUgaW1wb3J0IGZvciBHcmlkQ3VzdG9tUm93UHJvcHMgZXhpc3RzXG4gICAgICAgIGVuc3VyZUltcG9ydEV4aXN0cyhqLCByb290LCAnR3JpZEN1c3RvbVJvd1Byb3BzJywgJ0Bwcm9ncmVzcy9rZW5kby1yZWFjdC1ncmlkJyk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHJvb3QudG9Tb3VyY2UoKTtcbn1cbiJdLCJuYW1lcyI6WyJyb3dSZW5kZXIiLCJmaWxlSW5mbyIsImFwaSIsImoiLCJyb290IiwiaXNUeXBlU2NyaXB0IiwiYWRkSW1wb3J0cyIsImV4aXN0aW5nTmFtZXMiLCJwYXRoIiwidW5pcXVlTmFtZSIsImdlbmVyYXRlVW5pcXVlTmFtZSIsImdyaWROYW1lIiwiZmluZEltcG9ydGVkTmFtZSIsImF0dHJpYnV0ZXMiLCJyb3dSZW5kZXJBdHRyaWJ1dGUiLCJhdHRyIiwicm93UmVuZGVyVmFsdWUiLCJpc0NsYXNzQ29tcG9uZW50IiwiaXNGdW5jdGlvbmFsQ29tcG9uZW50IiwicGFyZW50Tm9kZSIsImZpbmRQYXJlbnRDb21wb25lbnQiLCJlbnN1cmVBdHRyaWJ1dGVFeGlzdHMiLCJjdXN0b21NZXRob2QiLCJjcmVhdGVNZXRob2RGb3JDbGFzc0NvbXBvbmVudCIsImNyZWF0ZUFycm93RnVuY3Rpb25Gb3JGdW5jdGlvbmFsQ29tcG9uZW50IiwiYWRkTWV0aG9kVG9Db21wb25lbnQiLCJhZGRDb21tZW50VG9NZXRob2QiLCJyZW1vdmVBdHRyaWJ1dGUiLCJlbnN1cmVJbXBvcnRFeGlzdHMiXSwibWFwcGluZ3MiOiIyQ0FjQSxTQUFBQSxFQUF5QkMsRUFBb0JDLEVBQVUsQ0FDbkQsTUFBTUMsRUFBaUJELEVBQUksWUFDckJFLEVBQU9ELEVBQUVGLEVBQVMsTUFBTSxFQUd4QkksRUFBZUosRUFBUyxLQUFLLFNBQVMsS0FBSyxHQUFLQSxFQUFTLEtBQUssU0FBUyxNQUFNLEVBRW5GLElBQUlLLEVBQWEsR0FFWCxNQUFBQyxNQUFvQixJQUMxQkgsRUFBSyxLQUFLRCxFQUFFLFVBQVUsRUFBRSxRQUFTSyxHQUFTLENBQ3hCRCxFQUFBLElBQUlDLEVBQUssS0FBSyxJQUFJLENBQUEsQ0FDbkMsRUFHSyxNQUFBQyxFQUFhQyxFQUFBQSxtQkFERixZQUMrQkgsQ0FBYSxFQUt2REksRUFBV0MsRUFBQUEsaUJBQWlCVCxFQUFHQyxFQUFNLE9BQVEsNEJBQTRCLEdBQUssT0FHcEYsT0FBQUEsRUFBSyxLQUFLRCxFQUFFLFdBQVksQ0FBRSxlQUFnQixDQUFFLEtBQU0sQ0FBRSxLQUFNUSxDQUFBLENBQWEsQ0FBQSxDQUFDLEVBQUUsUUFBU0gsR0FBUyxDQUNsRixNQUFBSyxFQUFhTCxFQUFLLEtBQUssZUFBZSxXQUd0Q00sRUFBcUJELEdBQUEsWUFBQUEsRUFBWSxLQUNsQ0UsR0FBU0EsRUFBSyxPQUFTLGdCQUFrQkEsRUFBSyxLQUFLLE9BQVMsYUFJN0QsR0FBQUQsR0FBc0JBLEVBQW1CLE9BQVMsZUFBZ0IsQ0FDNUQsTUFBQUUsRUFBaUJGLEVBQW1CLE1BQ3BDWCxFQUFFVyxFQUFtQixLQUFLLEVBQUUsU0FDNUIsRUFBQSxvQkFHQSxDQUFFLGlCQUFBRyxFQUFrQixzQkFBQUMsRUFBdUIsV0FBQUMsQ0FBZSxFQUFBQyxzQkFBb0JqQixFQUFHSyxDQUFJLEVBRXZGSyxHQUVBUSxFQUFBLHNCQUNJbEIsRUFDQVUsRUFDQSxPQUNBLE9BQ0FJLEVBQW1CLFFBQVFSLENBQVUsR0FBS0EsQ0FBQSxFQUk5QyxJQUFBYSxFQUNBTCxFQUNBSyxFQUFlQyxFQUE4Qiw4QkFBQXBCLEVBQUdNLEVBQVlKLEVBQWMsb0JBQW9CLEVBQ3ZGYSxJQUNRSSxFQUFBRSxFQUFBLDBDQUNYckIsRUFDQU0sRUFDQUosRUFDQSxvQkFBQSxHQUthb0IsRUFBQUEscUJBQUF0QixFQUFHZ0IsRUFBWUcsRUFBY0wsQ0FBZ0IsRUFHOURLLEdBQ0FJLEVBQUEsbUJBQ0l2QixFQUNBQSxFQUFFbUIsQ0FBWSxFQUNkLDZCQUE2Qk4sQ0FBYyxHQUMzQ0MsRUFBbUIsUUFBVSxVQUFBLEVBS2xCVSxFQUFBQSxnQkFBZ0JkLEVBQXFELFdBQVcsSUFFbEZQLEVBQUEsR0FFckIsQ0FBQSxDQUNILEVBRUdBLEdBQWNELEdBRUt1QixFQUFBQSxtQkFBQXpCLEVBQUdDLEVBQU0scUJBQXNCLDRCQUE0QixFQUczRUEsRUFBSyxVQUNoQiJ9
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
*-------------------------------------------------------------------------------------------
|
|
4
|
+
* Copyright © 2025 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 strict";const t=require("./utils.js");function g(c,S){const e=S.jscodeshift,s=e(c.source),o=c.path.endsWith(".ts")||c.path.endsWith(".tsx");let u=!1;const m=new Set;s.find(e.Identifier).forEach(a=>{m.add(a.node.name)});const r=t.generateUniqueName("handleSelectionChange",m),h=t.findImportedName(e,s,"Grid","@progress/kendo-react-grid")||"Grid";return s.find(e.JSXElement,{openingElement:{name:{name:h}}}).forEach(a=>{const n=a.node.openingElement.attributes,l=n==null?void 0:n.find(i=>i.type==="JSXAttribute"&&i.name.name==="selectedField");if(!l)return;const p=l.value?e(l.value).toSource():"No value provided";t.removeAttribute(n,"selectedField"),u=!0,t.hasJSXAttribute(n,"selectable")||t.addStateAttribute(e,n,"selectable","true"),t.hasJSXAttribute(n,"dataItemKey")||t.addStateAttribute(e,n,"dataItemKey",'"place your key here"');const{isClassComponent:f,isFunctionalComponent:b,parentNode:d}=t.findParentComponent(e,a);if(f){if(t.addStateDeclaration(e,d,"select",e.objectExpression([])),t.hasJSXAttribute(n,"select")||t.addStateAttribute(e,n,"select","this.state.select"),!t.hasJSXAttribute(n,"onSelectionChange")){t.addEventAttribute(e,n,"onSelectionChange",`this.${r}`);const i=t.createClassMethod(e,r,[`event${o?": GridSelectionChangeEvent":""}`],[e.expressionStatement(e.callExpression(e.memberExpression(e.thisExpression(),e.identifier("setState")),[e.objectExpression([e.property("init",e.identifier("select"),e.memberExpression(e.identifier("event"),e.identifier("select")))])]))]);t.addCommentToMethod(e,e(i),`Original selectedField value: ${p}`,"class"),t.addMethodToComponent(e,d,i,!0)}}else if(b&&(t.addUseStateDeclaration(e,d,"select","setSelect",e.objectExpression([]),o,"SelectDescriptor"),t.hasJSXAttribute(n,"select")||t.addStateAttribute(e,n,"select","select"),!t.hasJSXAttribute(n,"onSelectionChange"))){t.addEventAttribute(e,n,"onSelectionChange",`${r}`);const i=t.createArrowFunction(e,`${r}`,[`(event${o?": GridSelectionChangeEvent":""})`],[e.expressionStatement(e.callExpression(e.identifier("setSelect"),[e.memberExpression(e.identifier("event"),e.identifier("select"))]))]);t.addCommentToMethod(e,e(i),`Original selectedField value: ${p}`,"function"),t.addMethodToComponent(e,d,i,!1)}}),u&&o&&(t.ensureImportExists(e,s,"SelectDescriptor","@progress/kendo-react-data-tools"),t.ensureImportExists(e,s,"GridSelectionChangeEvent","@progress/kendo-react-grid")),s.toSource()}module.exports=g;
|
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"selection-state.js","sources":["../../../../../packages/grid/codemods/v11/selection-state.ts"],"sourcesContent":["import { API, FileInfo, JSCodeshift, JSXAttribute, JSXSpreadAttribute } from 'jscodeshift';\nimport {\n    addMethodToComponent,\n    removeAttribute,\n    findParentComponent,\n    generateUniqueName,\n    ensureImportExists,\n    addEventAttribute,\n    addStateAttribute,\n    addStateDeclaration,\n    addUseStateDeclaration,\n    findImportedName,\n    createClassMethod,\n    createArrowFunction,\n    hasJSXAttribute,\n    addCommentToMethod\n} from './utils';\n\nexport default function (fileInfo: FileInfo, api: API) {\n    const j: JSCodeshift = api.jscodeshift;\n    const root = j(fileInfo.source);\n\n    // Check if the file is TypeScript or TSX\n    const isTypeScript = fileInfo.path.endsWith('.ts') || fileInfo.path.endsWith('.tsx');\n\n    let addImports = false;\n    const existingNames = new Set<string>();\n    root.find(j.Identifier).forEach((path) => {\n        existingNames.add(path.node.name);\n    });\n\n    const baseName = 'handleSelectionChange';\n    const uniqueName = generateUniqueName(baseName, existingNames);\n\n    // Dynamically resolve the imported name for `Grid`\n    const gridName = findImportedName(j, root, 'Grid', '@progress/kendo-react-grid') || 'Grid';\n\n    // Find all JSXElements with the name of the resolved `Grid` component\n    const gridElements = root.find(j.JSXElement, { openingElement: { name: { name: gridName } } });\n\n    gridElements.forEach((gridPath) => {\n        const attributes = gridPath.node.openingElement.attributes;\n\n        // Check if the `selectedField` attribute exists\n        const selectedFieldAttribute = attributes?.find(\n            (attr) => attr.type === 'JSXAttribute' && attr.name.name === 'selectedField'\n        ) as JSXAttribute;\n\n        if (!selectedFieldAttribute) {\n            return; // Skip this Grid if `selectedField` is not present\n        }\n\n        // Copy the value of `selectedField` as a comment\n        const selectedFieldValue = selectedFieldAttribute.value\n            ? j(selectedFieldAttribute.value).toSource()\n            : 'No value provided';\n\n        // Remove the `selectedField` attribute\n        removeAttribute(attributes as (JSXAttribute | JSXSpreadAttribute)[], 'selectedField');\n        addImports = true;\n\n        // Ensure `selectable` attribute is present and set to true\n        if (!hasJSXAttribute(attributes, 'selectable')) {\n            addStateAttribute(j, attributes as (JSXAttribute | JSXSpreadAttribute)[], 'selectable', 'true');\n        }\n\n        // Ensure `dataItemKey` attribute is present\n        if (!hasJSXAttribute(attributes, 'dataItemKey')) {\n            addStateAttribute(\n                j,\n                attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                'dataItemKey',\n                '\"place your key here\"'\n            );\n        }\n\n        // Determine if the parent component is a class or functional component\n        const { isClassComponent, isFunctionalComponent, parentNode } = findParentComponent(j, gridPath);\n\n        if (isClassComponent) {\n            // Add `select` to the class component's state\n            addStateDeclaration(j, parentNode, 'select', j.objectExpression([]));\n\n            // Add `select` and `onSelectionChange` attributes\n            if (!hasJSXAttribute(attributes, 'select')) {\n                addStateAttribute(\n                    j,\n                    attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                    'select',\n                    'this.state.select'\n                );\n            }\n\n            if (!hasJSXAttribute(attributes, 'onSelectionChange')) {\n                addEventAttribute(\n                    j,\n                    attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                    'onSelectionChange',\n                    `this.${uniqueName}`\n                );\n\n                // Create and add `handleSelectionChange` method\n                const handleSelectionChangeMethod = createClassMethod(\n                    j,\n                    uniqueName,\n                    [`event${isTypeScript ? ': GridSelectionChangeEvent' : ''}`],\n                    [\n                        j.expressionStatement(\n                            j.callExpression(j.memberExpression(j.thisExpression(), j.identifier('setState')), [\n                                j.objectExpression([\n                                    j.property(\n                                        'init',\n                                        j.identifier('select'),\n                                        j.memberExpression(j.identifier('event'), j.identifier('select'))\n                                    )\n                                ])\n                            ])\n                        )\n                    ]\n                );\n\n                // Add the `selectedField` value as a comment in the method\n                addCommentToMethod(\n                    j,\n                    j(handleSelectionChangeMethod),\n                    `Original selectedField value: ${selectedFieldValue}`,\n                    'class'\n                );\n\n                addMethodToComponent(j, parentNode, handleSelectionChangeMethod, true);\n            }\n        } else if (isFunctionalComponent) {\n            // Add `React.useState` for `select`\n            addUseStateDeclaration(\n                j,\n                parentNode,\n                'select',\n                'setSelect',\n                j.objectExpression([]),\n                isTypeScript,\n                'SelectDescriptor'\n            );\n\n            // Add `select` and `onSelectionChange` attributes\n            if (!hasJSXAttribute(attributes, 'select')) {\n                addStateAttribute(j, attributes as (JSXAttribute | JSXSpreadAttribute)[], 'select', 'select');\n            }\n\n            if (!hasJSXAttribute(attributes, 'onSelectionChange')) {\n                addEventAttribute(\n                    j,\n                    attributes as (JSXAttribute | JSXSpreadAttribute)[],\n                    'onSelectionChange',\n                    `${uniqueName}`\n                );\n\n                // Create and add `handleSelectionChange` function\n                const handleSelectionChangeFunction = createArrowFunction(\n                    j,\n                    `${uniqueName}`,\n                    [`(event${isTypeScript ? ': GridSelectionChangeEvent' : ''})`],\n                    [\n                        j.expressionStatement(\n                            j.callExpression(j.identifier('setSelect'), [\n                                j.memberExpression(j.identifier('event'), j.identifier('select'))\n                            ])\n                        )\n                    ]\n                );\n\n                // Add the `selectedField` value as a comment in the function\n                addCommentToMethod(\n                    j,\n                    j(handleSelectionChangeFunction),\n                    `Original selectedField value: ${selectedFieldValue}`,\n                    'function'\n                );\n\n                addMethodToComponent(j, parentNode, handleSelectionChangeFunction, false);\n            }\n        }\n    });\n\n    if (addImports && isTypeScript) {\n        // Ensure TypeScript imports\n        ensureImportExists(j, root, 'SelectDescriptor', '@progress/kendo-react-data-tools');\n        ensureImportExists(j, root, 'GridSelectionChangeEvent', '@progress/kendo-react-grid');\n    }\n\n    return root.toSource();\n}\n"],"names":["selectionState","fileInfo","api","j","root","isTypeScript","addImports","existingNames","path","uniqueName","generateUniqueName","gridName","findImportedName","gridPath","attributes","selectedFieldAttribute","attr","selectedFieldValue","removeAttribute","hasJSXAttribute","addStateAttribute","isClassComponent","isFunctionalComponent","parentNode","findParentComponent","addStateDeclaration","addEventAttribute","handleSelectionChangeMethod","createClassMethod","addCommentToMethod","addMethodToComponent","addUseStateDeclaration","handleSelectionChangeFunction","createArrowFunction","ensureImportExists"],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
*-------------------------------------------------------------------------------------------
|
|
4
|
+
* Copyright © 2025 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 strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const l=(e,n,t,i)=>{if(i==="class"){if(n.size()>0&&n.get(0).node.value.body){const o=n.get(0).node.value.body.body;if(o){const r=e.emptyStatement();r.comments=[e.commentBlock(` ${t} `)],o.unshift(r)}}}else{let o;if(n.get(0).node.declarations&&n.get(0).node.declarations[0].init?o=n.get(0).node.declarations[0].init.body.body:n.get(0).node.body&&(o=n.get(0).node.body.body),o){const r=e.emptyStatement();r.comments=[e.commentBlock(` ${t} `)],o.unshift(r)}}},u=(e,n,t,i)=>{const o=n.find(e.ImportDeclaration,{source:{value:i}});if(o.size()>0){const r=o.get(0).node.specifiers;r.some(a=>a.type==="ImportSpecifier"&&a.imported.name===t)||r.push(e.importSpecifier(e.identifier(t)))}else{const r=e.importDeclaration([e.importSpecifier(e.identifier(t))],e.literal(i));n.get().node.program.body.unshift(r)}},f=(e,n)=>{let t=n.parentPath,i=!1,o=!1;for(;t;){if(e.ClassDeclaration.check(t.node)){i=!0;break}else if(e.FunctionDeclaration.check(t.node)||e.FunctionExpression.check(t.node)||e.ArrowFunctionExpression.check(t.node)){o=!0;break}t=t.parentPath}return{isClassComponent:i,isFunctionalComponent:o,parentNode:t}},m=(e,n)=>{let t=e,i=1;for(;n.has(t);)t=`${e}$${i}`,i++;return t},d=(e,n)=>e.find(t=>t.type==="JSXAttribute"&&t.name.name===n),b=(e,n)=>e.some(t=>t.type==="JSXAttribute"&&t.name.name===n),c=(e,n,t,i)=>{if(n.value&&n.value.type==="JSXExpressionContainer"){const o=n.value.expression;o.type==="ObjectExpression"&&o.properties.push(e.property("init",e.identifier(t),e.identifier(i)))}},p=(e,n,t,i,o)=>{const r=e.jsxAttribute(e.jsxIdentifier(t),e.jsxExpressionContainer(e.objectExpression([e.property("init",e.identifier(i),e.identifier(o))])));n.push(r)},y=(e,n)=>{const t=e==null?void 0:e.findIndex(i=>i.type==="JSXAttribute"&&i.name.name===n);return t!==-1?(e.splice(t,1),!0):!1},x=(e,n,t,i,o)=>{const r=d(n,t);r?c(e,r,i,o):p(e,n,t,i,o)},h=(e,n,t,i)=>e.jsxAttribute(e.jsxIdentifier(n),e.jsxExpressionContainer(e.objectExpression([e.property("init",e.identifier(t),e.identifier(i))]))),A=(e,n,t,i)=>{n.type==="ObjectExpression"&&n.properties.push(e.property("init",e.identifier(t),e.identifier(i)))},S=(e,n,t,i)=>e.methodDefinition("method",e.identifier(n),e.functionExpression(null,[e.identifier(t?`event: ${i}`:"event")],e.blockStatement([e.returnStatement(e.jsxFragment(e.jsxOpeningFragment(),e.jsxClosingFragment(),[]))]))),E=(e,n,t,i)=>e.variableDeclaration("const",[e.variableDeclarator(e.identifier(n),e.arrowFunctionExpression([e.identifier(`(event${t?`: ${i}`:""})`)],e.blockStatement([e.returnStatement(e.jsxFragment(e.jsxOpeningFragment(),e.jsxClosingFragment(),[]))])))]),g=(e,n,t,i)=>{i?n.node.body.body.push(t):(n.node.body.body||n.node.body).unshift(t)},C=(e,n,t,i)=>{const o=n.find(e.ImportDeclaration,{source:{value:i}});if(o.size()>0){const r=o.find(e.ImportSpecifier,{imported:{name:t}});if(r.size()>0)return r.get(0).node.local.name}return null},v=(e,n,t,i)=>{const o=n.node.body.body.find(r=>r.type==="ClassProperty"&&r.key.name==="state");o&&o.value.type==="ObjectExpression"?o.value.properties.some(s=>s.key.name===t)||o.value.properties.push(e.property("init",e.identifier(t),i)):n.node.body.body.unshift(e.classProperty(e.identifier("state"),e.objectExpression([e.property("init",e.identifier(t),i)])))},F=(e,n)=>(e==null?void 0:e.some(t=>t.type==="JSXAttribute"&&t.name.name===n))||!1,D=(e,n,t,i,o,r,s)=>{const a=e.variableDeclaration("const",[e.variableDeclarator(e.arrayPattern([e.identifier(t),e.identifier(i)]),e.callExpression(e.identifier(`React.useState${r?`<${s}>`:""}`),[o]))]);n.node.body.body.unshift(a)},I=(e,n,t,i)=>{n.push(e.jsxAttribute(e.jsxIdentifier(t),e.jsxExpressionContainer(e.identifier(i))))},k=(e,n,t,i)=>{n.push(e.jsxAttribute(e.jsxIdentifier(t),e.jsxExpressionContainer(e.identifier(i))))},w=(e,n,t,i)=>e.methodDefinition("method",e.identifier(n),e.functionExpression(null,t.map(o=>e.identifier(o)),e.blockStatement(i))),P=(e,n,t,i)=>e.variableDeclaration("const",[e.variableDeclarator(e.identifier(n),e.arrowFunctionExpression(t.map(o=>e.identifier(o)),e.blockStatement(i)))]);exports.addCommentToMethod=l;exports.addEventAttribute=I;exports.addMethodToComponent=g;exports.addNewAttribute=p;exports.addPropertyToObjectExpression=A;exports.addStateAttribute=k;exports.addStateDeclaration=v;exports.addUseStateDeclaration=D;exports.createArrowFunction=P;exports.createArrowFunctionForFunctionalComponent=E;exports.createAttribute=h;exports.createClassMethod=w;exports.createMethodForClassComponent=S;exports.doesAttributeExist=b;exports.ensureAttributeExists=x;exports.ensureImportExists=u;exports.findAttribute=d;exports.findImportedName=C;exports.findParentComponent=f;exports.generateUniqueName=m;exports.hasJSXAttribute=F;exports.modifyExistingAttribute=c;exports.removeAttribute=y;
|
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"utils.js","sources":["../../../../../packages/grid/codemods/v11/utils.ts"],"sourcesContent":["import {\n    Collection,\n    FunctionDeclaration,\n    JSCodeshift,\n    JSXAttribute,\n    JSXSpreadAttribute,\n    VariableDeclaration\n} from 'jscodeshift';\n\nexport const addCommentToMethod = (\n    j: JSCodeshift,\n    method: Collection<VariableDeclaration> | Collection<FunctionDeclaration>,\n    commentText: string,\n    parentType: 'class' | 'function'\n) => {\n    if (parentType === 'class') {\n        if (method.size() > 0 && method.get(0).node.value.body) {\n            const methodBody = method.get(0).node.value.body.body;\n\n            if (methodBody) {\n                // Create a comment and attach it to an empty statement\n                const placeholderStatement = j.emptyStatement();\n                placeholderStatement.comments = [j.commentBlock(` ${commentText} `)];\n\n                // Add the placeholder statement with the comment to the method body\n                methodBody.unshift(placeholderStatement);\n            }\n        }\n    } else {\n        let methodBody;\n\n        if (method.get(0).node.declarations && method.get(0).node.declarations[0].init) {\n            methodBody = method.get(0).node.declarations[0].init.body.body;\n        } else if (method.get(0).node.body) {\n            methodBody = method.get(0).node.body.body;\n        }\n\n        if (methodBody) {\n            const placeholderStatement = j.emptyStatement();\n            placeholderStatement.comments = [j.commentBlock(` ${commentText} `)];\n\n            methodBody.unshift(placeholderStatement);\n        }\n    }\n};\n\nexport const ensureImportExists = (j: JSCodeshift, root: Collection, importName: string, source: string) => {\n    const importDeclaration = root.find(j.ImportDeclaration, {\n        source: { value: source }\n    });\n\n    if (importDeclaration.size() > 0) {\n        // If the import statement exists, add the new import name if not already present\n        const specifiers = importDeclaration.get(0).node.specifiers;\n        const alreadyImported = specifiers.some(\n            (specifier: any) => specifier.type === 'ImportSpecifier' && specifier.imported.name === importName\n        );\n\n        if (!alreadyImported) {\n            specifiers.push(j.importSpecifier(j.identifier(importName)));\n        }\n    } else {\n        // If the import statement doesn't exist, create a new one\n        const newImport = j.importDeclaration([j.importSpecifier(j.identifier(importName))], j.literal(source));\n        root.get().node.program.body.unshift(newImport);\n    }\n};\n\nexport const findParentComponent = (j: JSCodeshift, path: any) => {\n    let parentNode = path.parentPath;\n    let isClassComponent = false;\n    let isFunctionalComponent = false;\n\n    while (parentNode) {\n        if (j.ClassDeclaration.check(parentNode.node)) {\n            isClassComponent = true;\n            break;\n        } else if (\n            j.FunctionDeclaration.check(parentNode.node) ||\n            j.FunctionExpression.check(parentNode.node) ||\n            j.ArrowFunctionExpression.check(parentNode.node)\n        ) {\n            isFunctionalComponent = true;\n            break;\n        }\n        parentNode = parentNode.parentPath;\n    }\n\n    return { isClassComponent, isFunctionalComponent, parentNode };\n};\n\nexport const generateUniqueName = (baseName: string, existingNames: Set<string>): string => {\n    let name = baseName;\n    let counter = 1;\n    while (existingNames.has(name)) {\n        name = `${baseName}$${counter}`;\n        counter++;\n    }\n    return name;\n};\n\nexport const findAttribute = (attributes: any[], attributeName: string) => {\n    return attributes.find((attr) => attr.type === 'JSXAttribute' && attr.name.name === attributeName);\n};\n\nexport const doesAttributeExist = (attributes: any[], attributeName: string): boolean => {\n    return attributes.some((attr) => attr.type === 'JSXAttribute' && attr.name.name === attributeName);\n};\n\nexport const modifyExistingAttribute = (\n    j: JSCodeshift,\n    existingAttribute: any,\n    propertyName: string,\n    propertyValue: string\n) => {\n    if (existingAttribute.value && existingAttribute.value.type === 'JSXExpressionContainer') {\n        const expression = existingAttribute.value.expression;\n        if (expression.type === 'ObjectExpression') {\n            expression.properties.push(j.property('init', j.identifier(propertyName), j.identifier(propertyValue)));\n        }\n    }\n};\n\nexport const addNewAttribute = (\n    j: JSCodeshift,\n    attributes: any[],\n    attributeName: string,\n    propertyName: string,\n    propertyValue: string\n) => {\n    const newAttribute = j.jsxAttribute(\n        j.jsxIdentifier(attributeName),\n        j.jsxExpressionContainer(\n            j.objectExpression([j.property('init', j.identifier(propertyName), j.identifier(propertyValue))])\n        )\n    );\n    attributes.push(newAttribute);\n};\n\nexport const removeAttribute = (attributes: any[], attributeName: string): boolean => {\n    const attributeIndex = attributes?.findIndex(\n        (attr) => attr.type === 'JSXAttribute' && attr.name.name === attributeName\n    );\n\n    if (attributeIndex !== -1) {\n        attributes.splice(attributeIndex, 1);\n        return true; // Indicates the attribute was found and removed\n    }\n\n    return false; // Indicates the attribute was not found\n};\n\nexport const ensureAttributeExists = (\n    j: JSCodeshift,\n    attributes: any[],\n    attributeName: string,\n    propertyName: string,\n    propertyValue: string\n) => {\n    const existingAttribute = findAttribute(attributes, attributeName);\n\n    if (existingAttribute) {\n        modifyExistingAttribute(j, existingAttribute, propertyName, propertyValue);\n    } else {\n        addNewAttribute(j, attributes, attributeName, propertyName, propertyValue);\n    }\n};\n\nexport const createAttribute = (j: JSCodeshift, attributeName: string, propertyName: string, propertyValue: string) => {\n    return j.jsxAttribute(\n        j.jsxIdentifier(attributeName),\n        j.jsxExpressionContainer(\n            j.objectExpression([j.property('init', j.identifier(propertyName), j.identifier(propertyValue))])\n        )\n    );\n};\n\nexport const addPropertyToObjectExpression = (\n    j: JSCodeshift,\n    expression: any,\n    propertyName: string,\n    propertyValue: string\n) => {\n    if (expression.type === 'ObjectExpression') {\n        expression.properties.push(j.property('init', j.identifier(propertyName), j.identifier(propertyValue)));\n    }\n};\n\nexport const createMethodForClassComponent = (\n    j: JSCodeshift,\n    methodName: string,\n    isTypeScript: boolean,\n    typeName: string\n) => {\n    return j.methodDefinition(\n        'method',\n        j.identifier(methodName),\n        j.functionExpression(\n            null,\n            [j.identifier(isTypeScript ? `event: ${typeName}` : 'event')],\n            j.blockStatement([j.returnStatement(j.jsxFragment(j.jsxOpeningFragment(), j.jsxClosingFragment(), []))])\n        )\n    );\n};\n\nexport const createArrowFunctionForFunctionalComponent = (\n    j: JSCodeshift,\n    functionName: string,\n    isTypeScript: boolean,\n    typeName: string\n) => {\n    return j.variableDeclaration('const', [\n        j.variableDeclarator(\n            j.identifier(functionName),\n            j.arrowFunctionExpression(\n                [j.identifier(`(event${isTypeScript ? `: ${typeName}` : ''})`)],\n                j.blockStatement([j.returnStatement(j.jsxFragment(j.jsxOpeningFragment(), j.jsxClosingFragment(), []))])\n            )\n        )\n    ]);\n};\n\nexport const addMethodToComponent = (j: JSCodeshift, parentNode: any, method: any, isClassComponent: boolean) => {\n    if (isClassComponent) {\n        const classBody = parentNode.node.body.body;\n        classBody.push(method);\n    } else {\n        const parentBody = parentNode.node.body.body || parentNode.node.body;\n        parentBody.unshift(method);\n    }\n};\n\nexport const findImportedName = (j: JSCodeshift, root: any, originalName: string, source: string): string | null => {\n    const importDeclaration = root.find(j.ImportDeclaration, {\n        source: { value: source }\n    });\n\n    if (importDeclaration.size() > 0) {\n        const specifier = importDeclaration.find(j.ImportSpecifier, {\n            imported: { name: originalName }\n        });\n\n        if (specifier.size() > 0) {\n            const localName = specifier.get(0).node.local.name;\n            return localName; // Return the shadow name or the original name\n        }\n    }\n\n    return null; // Return null if the import is not found\n};\n\nexport const addStateDeclaration = (j: JSCodeshift, parentNode: any, stateName: string, initialValue: any) => {\n    const stateProperty = parentNode.node.body.body.find(\n        (node: any) => node.type === 'ClassProperty' && node.key.name === 'state'\n    );\n\n    if (stateProperty && stateProperty.value.type === 'ObjectExpression') {\n        const hasState = stateProperty.value.properties.some((prop: any) => prop.key.name === stateName);\n        if (!hasState) {\n            stateProperty.value.properties.push(j.property('init', j.identifier(stateName), initialValue));\n        }\n    } else {\n        parentNode.node.body.body.unshift(\n            j.classProperty(\n                j.identifier('state'),\n                j.objectExpression([j.property('init', j.identifier(stateName), initialValue)])\n            )\n        );\n    }\n};\n\nexport const hasJSXAttribute = (\n    attributes: (JSXAttribute | JSXSpreadAttribute)[] | undefined,\n    attributeName: string\n): boolean => {\n    return attributes?.some((attr) => attr.type === 'JSXAttribute' && attr.name.name === attributeName) || false;\n};\n\nexport const addUseStateDeclaration = (\n    j: JSCodeshift,\n    parentNode: any,\n    stateName: string,\n    setStateName: string,\n    initialValue: any,\n    isTypeScript: boolean,\n    typeName: string\n) => {\n    const useStateDeclaration = j.variableDeclaration('const', [\n        j.variableDeclarator(\n            j.arrayPattern([j.identifier(stateName), j.identifier(setStateName)]),\n            j.callExpression(j.identifier(`React.useState${isTypeScript ? `<${typeName}>` : ''}`), [initialValue])\n        )\n    ]);\n    parentNode.node.body.body.unshift(useStateDeclaration);\n};\n\nexport const addEventAttribute = (j: JSCodeshift, attributes: any[], attributeName: string, handlerName: string) => {\n    attributes.push(\n        j.jsxAttribute(j.jsxIdentifier(attributeName), j.jsxExpressionContainer(j.identifier(handlerName)))\n    );\n};\n\nexport const addStateAttribute = (j: JSCodeshift, attributes: any[], attributeName: string, stateName: string) => {\n    attributes.push(j.jsxAttribute(j.jsxIdentifier(attributeName), j.jsxExpressionContainer(j.identifier(stateName))));\n};\n\nexport const createClassMethod = (j: JSCodeshift, methodName: string, params: string[], bodyStatements: any[]) => {\n    return j.methodDefinition(\n        'method',\n        j.identifier(methodName),\n        j.functionExpression(\n            null,\n            params.map((param) => j.identifier(param)),\n            j.blockStatement(bodyStatements)\n        )\n    );\n};\n\nexport const createArrowFunction = (j: JSCodeshift, functionName: string, params: string[], bodyStatements: any[]) => {\n    return j.variableDeclaration('const', [\n        j.variableDeclarator(\n            j.identifier(functionName),\n            j.arrowFunctionExpression(\n                params.map((param) => j.identifier(param)),\n                j.blockStatement(bodyStatements)\n            )\n        )\n    ]);\n};\n"],"names":["addCommentToMethod","j","method","commentText","parentType","methodBody","placeholderStatement","ensureImportExists","root","importName","source","importDeclaration","specifiers","specifier","newImport","findParentComponent","path","parentNode","isClassComponent","isFunctionalComponent","generateUniqueName","baseName","existingNames","name","counter","findAttribute","attributes","attributeName","attr","doesAttributeExist","modifyExistingAttribute","existingAttribute","propertyName","propertyValue","expression","addNewAttribute","newAttribute","removeAttribute","attributeIndex","ensureAttributeExists","createAttribute","addPropertyToObjectExpression","createMethodForClassComponent","methodName","isTypeScript","typeName","createArrowFunctionForFunctionalComponent","functionName","addMethodToComponent","findImportedName","originalName","addStateDeclaration","stateName","initialValue","stateProperty","node","prop","hasJSXAttribute","addUseStateDeclaration","setStateName","useStateDeclaration","addEventAttribute","handlerName","addStateAttribute","createClassMethod","params","bodyStatements","param","createArrowFunction"],"mappings":"gFASO,MAAMA,EAAqB,CAC9BC,EACAC,EACAC,EACAC,IACC,CACD,GAAIA,IAAe,SACX,GAAAF,EAAO,OAAS,GAAKA,EAAO,IAAI,CAAC,EAAE,KAAK,MAAM,KAAM,CACpD,MAAMG,EAAaH,EAAO,IAAI,CAAC,EAAE,KAAK,MAAM,KAAK,KAEjD,GAAIG,EAAY,CAEN,MAAAC,EAAuBL,EAAE,iBAC/BK,EAAqB,SAAW,CAACL,EAAE,aAAa,IAAIE,CAAW,GAAG,CAAC,EAGnEE,EAAW,QAAQC,CAAoB,CAC3C,CACJ,MACG,CACC,IAAAD,EAQJ,GANIH,EAAO,IAAI,CAAC,EAAE,KAAK,cAAgBA,EAAO,IAAI,CAAC,EAAE,KAAK,aAAa,CAAC,EAAE,KACzDG,EAAAH,EAAO,IAAI,CAAC,EAAE,KAAK,aAAa,CAAC,EAAE,KAAK,KAAK,KACnDA,EAAO,IAAI,CAAC,EAAE,KAAK,OAC1BG,EAAaH,EAAO,IAAI,CAAC,EAAE,KAAK,KAAK,MAGrCG,EAAY,CACN,MAAAC,EAAuBL,EAAE,iBAC/BK,EAAqB,SAAW,CAACL,EAAE,aAAa,IAAIE,CAAW,GAAG,CAAC,EAEnEE,EAAW,QAAQC,CAAoB,CAC3C,CACJ,CACJ,EAEaC,EAAqB,CAACN,EAAgBO,EAAkBC,EAAoBC,IAAmB,CACxG,MAAMC,EAAoBH,EAAK,KAAKP,EAAE,kBAAmB,CACrD,OAAQ,CAAE,MAAOS,CAAO,CAAA,CAC3B,EAEG,GAAAC,EAAkB,KAAK,EAAI,EAAG,CAE9B,MAAMC,EAAaD,EAAkB,IAAI,CAAC,EAAE,KAAK,WACzBC,EAAW,KAC9BC,GAAmBA,EAAU,OAAS,mBAAqBA,EAAU,SAAS,OAASJ,CAAA,GAIxFG,EAAW,KAAKX,EAAE,gBAAgBA,EAAE,WAAWQ,CAAU,CAAC,CAAC,CAC/D,KACG,CAEH,MAAMK,EAAYb,EAAE,kBAAkB,CAACA,EAAE,gBAAgBA,EAAE,WAAWQ,CAAU,CAAC,CAAC,EAAGR,EAAE,QAAQS,CAAM,CAAC,EACtGF,EAAK,MAAM,KAAK,QAAQ,KAAK,QAAQM,CAAS,CAClD,CACJ,EAEaC,EAAsB,CAACd,EAAgBe,IAAc,CAC9D,IAAIC,EAAaD,EAAK,WAClBE,EAAmB,GACnBC,EAAwB,GAE5B,KAAOF,GAAY,CACf,GAAIhB,EAAE,iBAAiB,MAAMgB,EAAW,IAAI,EAAG,CACxBC,EAAA,GACnB,KAAA,SAEAjB,EAAE,oBAAoB,MAAMgB,EAAW,IAAI,GAC3ChB,EAAE,mBAAmB,MAAMgB,EAAW,IAAI,GAC1ChB,EAAE,wBAAwB,MAAMgB,EAAW,IAAI,EACjD,CAC0BE,EAAA,GACxB,KACJ,CACAF,EAAaA,EAAW,UAC5B,CAEO,MAAA,CAAE,iBAAAC,EAAkB,sBAAAC,EAAuB,WAAAF,EACtD,EAEaG,EAAqB,CAACC,EAAkBC,IAAuC,CACxF,IAAIC,EAAOF,EACPG,EAAU,EACP,KAAAF,EAAc,IAAIC,CAAI,GAClBA,EAAA,GAAGF,CAAQ,IAAIG,CAAO,GAC7BA,IAEG,OAAAD,CACX,EAEaE,EAAgB,CAACC,EAAmBC,IACtCD,EAAW,KAAME,GAASA,EAAK,OAAS,gBAAkBA,EAAK,KAAK,OAASD,CAAa,EAGxFE,EAAqB,CAACH,EAAmBC,IAC3CD,EAAW,KAAME,GAASA,EAAK,OAAS,gBAAkBA,EAAK,KAAK,OAASD,CAAa,EAGxFG,EAA0B,CACnC7B,EACA8B,EACAC,EACAC,IACC,CACD,GAAIF,EAAkB,OAASA,EAAkB,MAAM,OAAS,yBAA0B,CAChF,MAAAG,EAAaH,EAAkB,MAAM,WACvCG,EAAW,OAAS,oBACpBA,EAAW,WAAW,KAAKjC,EAAE,SAAS,OAAQA,EAAE,WAAW+B,CAAY,EAAG/B,EAAE,WAAWgC,CAAa,CAAC,CAAC,CAE9G,CACJ,EAEaE,EAAkB,CAC3BlC,EACAyB,EACAC,EACAK,EACAC,IACC,CACD,MAAMG,EAAenC,EAAE,aACnBA,EAAE,cAAc0B,CAAa,EAC7B1B,EAAE,uBACEA,EAAE,iBAAiB,CAACA,EAAE,SAAS,OAAQA,EAAE,WAAW+B,CAAY,EAAG/B,EAAE,WAAWgC,CAAa,CAAC,CAAC,CAAC,CACpG,CAAA,EAEJP,EAAW,KAAKU,CAAY,CAChC,EAEaC,EAAkB,CAACX,EAAmBC,IAAmC,CAClF,MAAMW,EAAiBZ,GAAA,YAAAA,EAAY,UAC9BE,GAASA,EAAK,OAAS,gBAAkBA,EAAK,KAAK,OAASD,GAGjE,OAAIW,IAAmB,IACRZ,EAAA,OAAOY,EAAgB,CAAC,EAC5B,IAGJ,EACX,EAEaC,EAAwB,CACjCtC,EACAyB,EACAC,EACAK,EACAC,IACC,CACK,MAAAF,EAAoBN,EAAcC,EAAYC,CAAa,EAE7DI,EACwBD,EAAA7B,EAAG8B,EAAmBC,EAAcC,CAAa,EAEzEE,EAAgBlC,EAAGyB,EAAYC,EAAeK,EAAcC,CAAa,CAEjF,EAEaO,EAAkB,CAACvC,EAAgB0B,EAAuBK,EAAsBC,IAClFhC,EAAE,aACLA,EAAE,cAAc0B,CAAa,EAC7B1B,EAAE,uBACEA,EAAE,iBAAiB,CAACA,EAAE,SAAS,OAAQA,EAAE,WAAW+B,CAAY,EAAG/B,EAAE,WAAWgC,CAAa,CAAC,CAAC,CAAC,CACpG,CAAA,EAIKQ,EAAgC,CACzCxC,EACAiC,EACAF,EACAC,IACC,CACGC,EAAW,OAAS,oBACpBA,EAAW,WAAW,KAAKjC,EAAE,SAAS,OAAQA,EAAE,WAAW+B,CAAY,EAAG/B,EAAE,WAAWgC,CAAa,CAAC,CAAC,CAE9G,EAEaS,EAAgC,CACzCzC,EACA0C,EACAC,EACAC,IAEO5C,EAAE,iBACL,SACAA,EAAE,WAAW0C,CAAU,EACvB1C,EAAE,mBACE,KACA,CAACA,EAAE,WAAW2C,EAAe,UAAUC,CAAQ,GAAK,OAAO,CAAC,EAC5D5C,EAAE,eAAe,CAACA,EAAE,gBAAgBA,EAAE,YAAYA,EAAE,mBAAmB,EAAGA,EAAE,mBAAmB,EAAG,CAAE,CAAA,CAAC,CAAC,CAAC,CAC3G,CAAA,EAIK6C,EAA4C,CACrD7C,EACA8C,EACAH,EACAC,IAEO5C,EAAE,oBAAoB,QAAS,CAClCA,EAAE,mBACEA,EAAE,WAAW8C,CAAY,EACzB9C,EAAE,wBACE,CAACA,EAAE,WAAW,SAAS2C,EAAe,KAAKC,CAAQ,GAAK,EAAE,GAAG,CAAC,EAC9D5C,EAAE,eAAe,CAACA,EAAE,gBAAgBA,EAAE,YAAYA,EAAE,mBAAmB,EAAGA,EAAE,mBAAmB,EAAG,CAAE,CAAA,CAAC,CAAC,CAAC,CAC3G,CACJ,CAAA,CACH,EAGQ+C,EAAuB,CAAC/C,EAAgBgB,EAAiBf,EAAagB,IAA8B,CACzGA,EACkBD,EAAW,KAAK,KAAK,KAC7B,KAAKf,CAAM,GAEFe,EAAW,KAAK,KAAK,MAAQA,EAAW,KAAK,MACrD,QAAQf,CAAM,CAEjC,EAEa+C,EAAmB,CAAChD,EAAgBO,EAAW0C,EAAsBxC,IAAkC,CAChH,MAAMC,EAAoBH,EAAK,KAAKP,EAAE,kBAAmB,CACrD,OAAQ,CAAE,MAAOS,CAAO,CAAA,CAC3B,EAEG,GAAAC,EAAkB,KAAK,EAAI,EAAG,CAC9B,MAAME,EAAYF,EAAkB,KAAKV,EAAE,gBAAiB,CACxD,SAAU,CAAE,KAAMiD,CAAa,CAAA,CAClC,EAEG,GAAArC,EAAU,KAAK,EAAI,EAEZ,OADWA,EAAU,IAAI,CAAC,EAAE,KAAK,MAAM,IAGtD,CAEO,OAAA,IACX,EAEasC,EAAsB,CAAClD,EAAgBgB,EAAiBmC,EAAmBC,IAAsB,CAC1G,MAAMC,EAAgBrC,EAAW,KAAK,KAAK,KAAK,KAC3CsC,GAAcA,EAAK,OAAS,iBAAmBA,EAAK,IAAI,OAAS,OAAA,EAGlED,GAAiBA,EAAc,MAAM,OAAS,mBAC7BA,EAAc,MAAM,WAAW,KAAME,GAAcA,EAAK,IAAI,OAASJ,CAAS,GAE7EE,EAAA,MAAM,WAAW,KAAKrD,EAAE,SAAS,OAAQA,EAAE,WAAWmD,CAAS,EAAGC,CAAY,CAAC,EAGtFpC,EAAA,KAAK,KAAK,KAAK,QACtBhB,EAAE,cACEA,EAAE,WAAW,OAAO,EACpBA,EAAE,iBAAiB,CAACA,EAAE,SAAS,OAAQA,EAAE,WAAWmD,CAAS,EAAGC,CAAY,CAAC,CAAC,CAClF,CAAA,CAGZ,EAEaI,EAAkB,CAC3B/B,EACAC,KAEOD,GAAA,YAAAA,EAAY,KAAME,GAASA,EAAK,OAAS,gBAAkBA,EAAK,KAAK,OAASD,KAAkB,GAG9F+B,EAAyB,CAClCzD,EACAgB,EACAmC,EACAO,EACAN,EACAT,EACAC,IACC,CACK,MAAAe,EAAsB3D,EAAE,oBAAoB,QAAS,CACvDA,EAAE,mBACEA,EAAE,aAAa,CAACA,EAAE,WAAWmD,CAAS,EAAGnD,EAAE,WAAW0D,CAAY,CAAC,CAAC,EACpE1D,EAAE,eAAeA,EAAE,WAAW,iBAAiB2C,EAAe,IAAIC,CAAQ,IAAM,EAAE,EAAE,EAAG,CAACQ,CAAY,CAAC,CACzG,CAAA,CACH,EACDpC,EAAW,KAAK,KAAK,KAAK,QAAQ2C,CAAmB,CACzD,EAEaC,EAAoB,CAAC5D,EAAgByB,EAAmBC,EAAuBmC,IAAwB,CACrGpC,EAAA,KACPzB,EAAE,aAAaA,EAAE,cAAc0B,CAAa,EAAG1B,EAAE,uBAAuBA,EAAE,WAAW6D,CAAW,CAAC,CAAC,CAAA,CAE1G,EAEaC,EAAoB,CAAC9D,EAAgByB,EAAmBC,EAAuByB,IAAsB,CAC9G1B,EAAW,KAAKzB,EAAE,aAAaA,EAAE,cAAc0B,CAAa,EAAG1B,EAAE,uBAAuBA,EAAE,WAAWmD,CAAS,CAAC,CAAC,CAAC,CACrH,EAEaY,EAAoB,CAAC/D,EAAgB0C,EAAoBsB,EAAkBC,IAC7EjE,EAAE,iBACL,SACAA,EAAE,WAAW0C,CAAU,EACvB1C,EAAE,mBACE,KACAgE,EAAO,IAAKE,GAAUlE,EAAE,WAAWkE,CAAK,CAAC,EACzClE,EAAE,eAAeiE,CAAc,CACnC,CAAA,EAIKE,EAAsB,CAACnE,EAAgB8C,EAAsBkB,EAAkBC,IACjFjE,EAAE,oBAAoB,QAAS,CAClCA,EAAE,mBACEA,EAAE,WAAW8C,CAAY,EACzB9C,EAAE,wBACEgE,EAAO,IAAKE,GAAUlE,EAAE,WAAWkE,CAAK,CAAC,EACzClE,EAAE,eAAeiE,CAAc,CACnC,CACJ,CAAA,CACH"}
|