UNPKG

@progress/kendo-react-grid

Version:

React Data Grid (Table) provides 100+ ready-to-use data grid features. KendoReact Grid package

10 lines (9 loc) 9.88 kB
/** * @license *------------------------------------------------------------------------------------------- * Copyright © 2025 Progress Software Corporation. All rights reserved. * Licensed under commercial license. See LICENSE.md in the package root for more information *------------------------------------------------------------------------------------------- */ "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; //# 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"}