Skip to content

Commit

Permalink
Refactor
Browse files Browse the repository at this point in the history
  • Loading branch information
natsuk4ze committed Jan 23, 2024
1 parent 17e149f commit 162cbb2
Show file tree
Hide file tree
Showing 6 changed files with 17 additions and 15 deletions.
11 changes: 6 additions & 5 deletions lib/features/package_details/package_details.dart
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import 'package:freezed_annotation/freezed_annotation.dart';
import 'package:npm/util/dio.dart';
import 'package:npm/util/typedefs.dart';
import 'package:riverpod_annotation/riverpod_annotation.dart';

part 'package_details.g.dart';
Expand All @@ -8,9 +9,10 @@ part 'package_details.freezed.dart';
@riverpod
Future<PackageDetails> packageDetails(PackageDetailsRef ref,
{required String id}) async {
final response =
await ref.watch(dioProvider).get('https://registry.npmjs.org/$id');
return PackageDetails.fromJson(response.data);
final response = await ref.watch(dioProvider).getUri<Json>(
Uri.parse('https://registry.npmjs.org/$id'),
);
return PackageDetails.fromJson(response.data!);
}

@freezed
Expand All @@ -26,8 +28,7 @@ class PackageDetails with _$PackageDetails {
final String? homepage,
@JsonKey(readValue: _toRepository) required final String? repository,
}) = _PackageDetails;
factory PackageDetails.fromJson(Map<String, dynamic> json) =>
_$PackageDetailsFromJson(json);
factory PackageDetails.fromJson(Json json) => _$PackageDetailsFromJson(json);
}

String? _toRepository(Map json, String _) {
Expand Down
2 changes: 1 addition & 1 deletion lib/features/package_details/package_details.g.dart

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

13 changes: 6 additions & 7 deletions lib/features/packages/packages.dart
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import 'package:freezed_annotation/freezed_annotation.dart';
import 'package:npm/util/dio.dart';
import 'package:npm/util/extensions.dart';
import 'package:npm/features/score/score.dart';
import 'package:npm/util/typedefs.dart';
import 'package:riverpod_annotation/riverpod_annotation.dart';

part 'packages.g.dart';
Expand All @@ -20,14 +21,12 @@ Future<List<Package>> packages(
await Future.delayed(const Duration(milliseconds: 500));
if (cancelToken.isCancelled) throw Exception('Cancelled');
}
final response = await ref.watch(dioProvider).get(
'https://registry.npmjs.org/-/v1/search?text=$search',
final response = await ref.watch(dioProvider).getUri<Json>(
Uri.parse('https://registry.npmjs.org/-/v1/search?text=$search'),
cancelToken: cancelToken,
);
final List packages = response.data['objects'];
return packages
.map((package) => Package.fromJson(package as Map<String, dynamic>))
.toList();
final packages = response.data!['objects'] as List;
return packages.map((package) => Package.fromJson(package)).toList();
}

@freezed
Expand All @@ -41,7 +40,7 @@ class Package with _$Package {
final List<String>? keywords,
}) = _Package;

factory Package.fromJson(Map<String, dynamic> json) {
factory Package.fromJson(Json json) {
final package = json['package'];
final score = json['score']['detail'];

Expand Down
2 changes: 1 addition & 1 deletion lib/features/packages/packages.g.dart

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 2 additions & 1 deletion lib/features/score/score.dart
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import 'package:flutter/material.dart';
import 'package:freezed_annotation/freezed_annotation.dart';
import 'package:npm/l10n/strings.g.dart';
import 'package:npm/util/typedefs.dart';

part 'score.freezed.dart';
part 'score.g.dart';
Expand All @@ -12,7 +13,7 @@ class Score with _$Score {
required final double quality,
required final double maintenance,
}) = _Score;
factory Score.fromJson(Map<String, dynamic> json) => _$ScoreFromJson(json);
factory Score.fromJson(Json json) => _$ScoreFromJson(json);
}

enum ScoreType {
Expand Down
1 change: 1 addition & 0 deletions lib/util/typedefs.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
typedef Json = Map<String, dynamic>;

0 comments on commit 162cbb2

Please sign in to comment.