@progress/kendo-react-grid
Version:
React Data Grid (Table) provides 100+ ready-to-use data grid features. KendoReact Grid package
10 lines (9 loc) • 19.7 kB
JavaScript
/**
* @license
*-------------------------------------------------------------------------------------------
* Copyright © 2025 Progress Software Corporation. All rights reserved.
* Licensed under commercial license. See LICENSE.md in the package root for more information
*-------------------------------------------------------------------------------------------
*/
;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;
//# 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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"}