feat: configure sentry; add hasToken extension to context.

dev
DebuggerX 3 years ago
parent f760e7239c
commit 49ec2a641e

1
app/.gitignore vendored

@ -47,3 +47,4 @@ app.*.map.json
/android/app/release
/deb_builder/
*.deb

@ -1,7 +1,13 @@
import 'package:dde_gesture_manager/models/configs.provider.dart';
import 'package:flutter/material.dart';
import 'package:dde_gesture_manager/extensions.dart';
extension ContextExtension on BuildContext {
ThemeData get t => Theme.of(this);
NavigatorState get n => Navigator.of(this);
bool get hasToken => this.read<ConfigsProvider>().accessToken.notNull;
bool get watchHasToken => this.watch<ConfigsProvider>().accessToken.notNull;
}

@ -12,6 +12,7 @@ import 'package:dde_gesture_manager/themes/light.dart';
import 'package:dde_gesture_manager/utils/helper.dart';
import 'package:dde_gesture_manager/utils/init.dart';
import 'package:dde_gesture_manager/utils/simple_throttle.dart';
import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart';
import 'package:sentry_flutter/sentry_flutter.dart';
@ -27,7 +28,9 @@ Future<void> main() async {
options.dsn = 'https://febbfdeac6874a01b5fee56b2ba9515c@o644838.ingest.sentry.io/6216990';
// Set tracesSampleRate to 1.0 to capture 100% of transactions for performance monitoring.
// We recommend adjusting this value in production.
options.tracesSampleRate = 1.0;
options.tracesSampleRate = kReleaseMode ? 0.1 : 1.0;
options.reportPackages = false;
options.maxDeduplicationItems = 3;
},
appRunner: () => runApp(EasyLocalization(
supportedLocales: supportedLocales,
@ -82,6 +85,10 @@ class MyApp extends StatelessWidget {
Future.microtask(() {
initEvents(context);
SimpleThrottle.throttledFunc(_checkAuthStatus, timeout: const Duration(minutes: 5))?.call(context);
SimpleThrottle.throttledFunc(
Sentry.captureMessage,
timeout: const Duration(days: 1),
)?.call('App launched');
});
return Container();
}),
@ -97,7 +104,7 @@ class MyApp extends StatelessWidget {
void _checkAuthStatus(BuildContext context) {
if (H().lastCheckAuthStatusTime != null &&
H().lastCheckAuthStatusTime!.difference(DateTime.now()) < Duration(minutes: 10)) return;
if (context.read<ConfigsProvider>().accessToken.notNull) {
if (context.hasToken) {
Api.checkAuthStatus().then((value) {
if (!value) context.read<ConfigsProvider>().setProps(email: '', accessToken: '');
});

@ -2,6 +2,7 @@ import 'package:dde_gesture_manager/builder/provider_annotation.dart';
import 'package:dde_gesture_manager/constants/sp_keys.dart';
import 'package:dde_gesture_manager/extensions.dart';
import 'package:dde_gesture_manager/utils/helper.dart';
import 'package:sentry_flutter/sentry_flutter.dart';
enum BrightnessMode {
system,
@ -45,9 +46,12 @@ class Configs {
set email(String? emailAddress) {
_email = emailAddress;
if (emailAddress.notNull)
if (emailAddress.notNull) {
H().sp.updateString(SPKeys.loginEmail, emailAddress!);
else
Sentry.configureScope(
(scope) => scope.user = SentryUser(email: emailAddress),
);
} else
H().sp.remove(SPKeys.loginEmail);
}

@ -2,7 +2,6 @@ import 'package:adaptive_scrollbar/adaptive_scrollbar.dart';
import 'package:dde_gesture_manager/constants/constants.dart';
import 'package:dde_gesture_manager/extensions.dart';
import 'package:dde_gesture_manager/http/api.dart';
import 'package:dde_gesture_manager/models/configs.provider.dart';
import 'package:dde_gesture_manager/models/content_layout.provider.dart';
import 'package:dde_gesture_manager/models/local_schemes_provider.dart';
import 'package:dde_gesture_manager/models/scheme.dart';
@ -305,7 +304,7 @@ class GestureEditor extends StatelessWidget {
Notificator.error(context, title: LocaleKeys.info_upload_pls_add_description.tr());
return;
}
if (context.read<ConfigsProvider>().accessToken.isNull) {
if (!context.hasToken) {
return Notificator.showAlert(
title: LocaleKeys.info_login_for_upload_title.tr(),
description: LocaleKeys.info_login_for_upload_description.tr(),

@ -13,6 +13,7 @@ import 'package:dde_gesture_manager/widgets/dde_button.dart';
import 'package:dde_gesture_manager_api/models.dart' show SchemeForDownload;
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:sentry_flutter/sentry_flutter.dart';
import 'package:uuid/uuid.dart';
class LocalManager extends StatefulWidget {
@ -262,6 +263,7 @@ class LocalManagerState extends State<LocalManager> {
localSchemes.firstWhere((ele) => ele.path == _selectedItemPath).scheme;
context.read<ConfigsProvider>().setProps(appliedSchemeId: appliedScheme.id);
SchemeApplyUtil().apply(context, appliedScheme);
Sentry.captureMessage('Scheme applied: [${appliedScheme.name}](${appliedScheme.id})');
},
),
]

@ -1,6 +1,5 @@
import 'package:dde_gesture_manager/constants/constants.dart';
import 'package:dde_gesture_manager/extensions.dart';
import 'package:dde_gesture_manager/models/configs.provider.dart';
import 'package:dde_gesture_manager/models/content_layout.provider.dart';
import 'package:dde_gesture_manager/widgets/dde_button.dart';
import 'package:dde_gesture_manager/widgets/login.dart';
@ -79,11 +78,11 @@ class MarketOrMe extends StatelessWidget {
);
}
Widget buildMeContent(BuildContext context) {
var accessToken = context.watch<ConfigsProvider>().accessToken;
if (accessToken.isNull) return LoginWidget();
return Expanded(child: MeWidget());
}
Widget buildMeContent(BuildContext context) => context.watchHasToken
? Expanded(
child: MeWidget(),
)
: LoginWidget();
Widget buildMarketContent(BuildContext context) => Expanded(child: MarketWidget());
}

@ -2,7 +2,6 @@ import 'package:auto_size_text/auto_size_text.dart';
import 'package:cached_network_image/cached_network_image.dart';
import 'package:dde_gesture_manager/constants/constants.dart';
import 'package:dde_gesture_manager/http/api.dart';
import 'package:dde_gesture_manager/models/configs.provider.dart';
import 'package:dde_gesture_manager/models/local_schemes_provider.dart';
import 'package:dde_gesture_manager/models/settings.provider.dart';
import 'package:dde_gesture_manager/utils/helper.dart';
@ -40,7 +39,7 @@ class _MarketWidgetState extends State<MarketWidget> {
@override
void initState() {
super.initState();
if (context.read<ConfigsProvider>().accessToken.notNull)
if (context.hasToken)
Api.userLikes().then((value) {
if (mounted && value != null)
setState(() {
@ -265,7 +264,7 @@ class _MarketWidgetState extends State<MarketWidget> {
mainAxisAlignment: MainAxisAlignment.end,
children: [
DButton.like(
enabled: context.watch<ConfigsProvider>().accessToken.notNull,
enabled: context.watchHasToken,
onTap: () {
bool liked = _likedSchemes.contains(currentSelectedScheme!.id!);
Api.likeScheme(schemeId: currentSelectedScheme.uuid!, isLike: !liked).then((value) {

Loading…
Cancel
Save