mirror of
https://github.com/danielsogl/awesome-cordova-plugins.git
synced 2026-05-02 00:07:23 +08:00
4f8f99fa44
BREAKING CHANGE: Minimum Angular version requirement updated to 19.2.14 - Angular Core: 19.0.5 → 19.2.14 (latest Angular 19 LTS) - Zone.js: 0.15.0 → 0.15.1 (latest compatibility) - TypeScript: 5.6.3 (latest supported by Angular 19) Testing Infrastructure Modernization: - Jest: 27.5.1 → 29.7.0 (major upgrade for better performance) - ts-jest: 27.1.5 → 29.3.4 (TypeScript 5.6+ compatibility) - @types/jest: 27.5.2 → 29.5.14 (latest type definitions) - jest-environment-jsdom: Added 29.7.0 (required for Jest 29) - RxJS: 7.8.1 → 7.8.2 (latest patch version) Package Generator Improvements: - Fixed package.json generator to use correct author from main package.json - Updated RxJS peer dependency to ^7.8.0 (modern version range) - Updated core version dependency to use current package version dynamically - Ensured consistency across all generated plugin package.json files This update brings the project to the latest Angular 19 LTS with enhanced testing capabilities, improved build performance, and modernized dependency management. All builds and tests passing successfully.
35 lines
1.1 KiB
TypeScript
35 lines
1.1 KiB
TypeScript
import { ClassDeclaration, factory, SyntaxKind } from 'typescript';
|
|
|
|
import { transformMethod } from './methods';
|
|
import { transformProperty } from './properties';
|
|
|
|
export function transformMembers(cls: ClassDeclaration) {
|
|
const propertyIndices: number[] = [];
|
|
|
|
const members = cls.members.map((member: any, index: number) => {
|
|
// only process decorated members
|
|
if (!member.decorators || !member.decorators.length) return member;
|
|
|
|
switch (member.kind) {
|
|
case SyntaxKind.MethodDeclaration:
|
|
return transformMethod(member);
|
|
case SyntaxKind.PropertyDeclaration:
|
|
propertyIndices.push(index);
|
|
return member;
|
|
case SyntaxKind.Constructor:
|
|
return factory.createConstructorDeclaration(undefined, member.parameters, member.body);
|
|
default:
|
|
return member; // in case anything gets here by accident...
|
|
}
|
|
});
|
|
|
|
propertyIndices.forEach((i: number) => {
|
|
const [getter, setter] = transformProperty(members, i) as any;
|
|
members.push(getter, setter);
|
|
});
|
|
|
|
propertyIndices.reverse().forEach((i) => members.splice(i, 1));
|
|
|
|
return members;
|
|
}
|