feat: update provider generator to support named constructor.

pull/2/head
DebuggerX 4 years ago
parent fbbbffe7af
commit fbc1a4ba72

@ -34,14 +34,44 @@ class ProviderGenerator extends GeneratorForAnnotation<ProviderModel> {
);
});
return [
if (needImports)
'''
_genImports(className, needImports),
_genClassDefine(element.displayName),
_genNamedConstructors(element.constructors, element.displayName),
_genSetPropsFunc(fields),
].whereNotNull();
}
}
String? _genImports(String className, bool needImports) => needImports
? '''
import 'package:flutter/foundation.dart';
import 'package:dde_gesture_manager/extensions/compare_extension.dart';
import '$className';
''',
'''
class ${element.displayName}Provider extends ${element.displayName} with ChangeNotifier {
'''
: null;
String _genClassDefine(String displayName) => '''
class ${displayName}Provider extends $displayName with ChangeNotifier {
''';
String? _genNamedConstructors(List<ConstructorElement> constructors, String displayName) {
String _genCallSuperParamStr(ParameterElement param) => param.isNamed ? '${param.name}: ${param.name}' : param.name;
List<String> _constructors = [];
if (constructors.length > 0) {
constructors.forEach((constructor) {
if (constructor.name.length > 0) {
var params = constructor.getDisplayString(withNullability: true).split('$displayName.${constructor.name}').last;
_constructors.add('''
${displayName}Provider.${constructor.name}${params.replaceAll('dynamic ', '')}
: super.${constructor.name}(${constructor.parameters.map(_genCallSuperParamStr).join(',')});
''');
}
});
}
return _constructors.length > 0 ? _constructors.join('\n') : null;
}
String _genSetPropsFunc(List<AnnotationField> fields) => '''
void setProps({
${fields.map((f) => '${f.type.endsWith('?') ? '' : 'required '}${f.type} ${f.name},').join('\n')}
}) {
@ -50,7 +80,4 @@ class ${element.displayName}Provider extends ${element.displayName} with ChangeN
if (changed) notifyListeners();
}
}
'''
];
}
}
''';

Loading…
Cancel
Save