# Introduction Added a no-explicit-any rule to the twenty-server, not applicable to tests and integration tests folder Related to https://github.com/twentyhq/core-team-issues/issues/975 Discussed with Charles ## In case of conflicts Until this is approved I won't rebased and handle conflict, just need to drop two latest commits and re run the scripts etc ## Legacy We decided not to handle the existing lint error occurrences and programmatically ignored them through a disable next line rule comment ## Open question We might wanna activate the [no-explicit-any](https://typescript-eslint.io/rules/no-explicit-any/) `ignoreRestArgs` for our use case ? ``` ignoreRestArgs?: boolean; ``` --------- Co-authored-by: etiennejouan <jouan.etienne@gmail.com>
29 lines
901 B
TypeScript
29 lines
901 B
TypeScript
import isObject from 'lodash.isobject';
|
|
import lodashCamelCase from 'lodash.camelcase';
|
|
import upperFirst from 'lodash.upperfirst';
|
|
import { PascalCase, PascalCasedPropertiesDeep } from 'type-fest';
|
|
|
|
export const pascalCase = <T>(text: T) =>
|
|
upperFirst(lodashCamelCase(text as unknown as string)) as PascalCase<T>;
|
|
|
|
export const pascalCaseDeep = <T>(value: T): PascalCasedPropertiesDeep<T> => {
|
|
// Check if it's an array
|
|
if (Array.isArray(value)) {
|
|
return value.map(pascalCaseDeep) as PascalCasedPropertiesDeep<T>;
|
|
}
|
|
|
|
// Check if it's an object
|
|
if (isObject(value)) {
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
const result: Record<string, any> = {};
|
|
|
|
for (const key in value) {
|
|
result[pascalCase(key)] = pascalCaseDeep(value[key]);
|
|
}
|
|
|
|
return result as PascalCasedPropertiesDeep<T>;
|
|
}
|
|
|
|
return value as PascalCasedPropertiesDeep<T>;
|
|
};
|