Merge pull request #333 from calcitem/license_page

use showLicensePage fixes #324
This commit is contained in:
Nikolas Rimikis 2021-10-18 15:22:33 +02:00 committed by GitHub
commit 965e66e43b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 6 additions and 207 deletions

View File

@ -14,9 +14,6 @@ flutter pub get
flutter gen-l10n
flutter pub run flutter_oss_licenses:generate.dart
mv lib/oss_licenses.dart lib/generated
mkdir -p "$GEN_FILE_PATH" || true
echo "const Map<String, String> flutterVersion =" >"$FLUTTER_VERSION_FILE"

View File

@ -25,7 +25,6 @@ import 'package:package_info_plus/package_info_plus.dart';
import 'package:sanmill/generated/flutter_version.dart';
import 'package:sanmill/generated/intl/l10n.dart';
import 'package:sanmill/screens/license_page.dart';
import 'package:sanmill/screens/oss_license_page.dart';
import 'package:sanmill/shared/constants.dart';
import 'package:sanmill/shared/list_item_divider.dart';
import 'package:sanmill/shared/settings/settings_list_tile.dart';
@ -101,7 +100,10 @@ class AboutPage extends StatelessWidget {
),
SettingsListTile(
titleString: S.of(context).ossLicenses,
onTap: () => _launchThirdPartyNotices(context),
onTap: () => showLicensePage(
context: context,
applicationName: S.of(context).appName,
),
),
SettingsListTile(
titleString: S.of(context).helpImproveTranslate,
@ -176,29 +178,6 @@ class AboutPage extends StatelessWidget {
}
}
Future<void> _launchThirdPartyNotices(BuildContext context) async {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => OssLicensesPage(),
),
);
/*
String? locale = "en_US";
if (!Platform.isWindows) {
locale = await Devicelocale.currentLocale;
}
debugPrint("$tag local = $locale");
if (locale != null && locale.startsWith("zh_")) {
_launchURL(Constants.giteeThirdPartyNoticesURL);
} else {
_launchURL(Constants.githubThirdPartyNoticesURL);
}
*/
}
Future<void> _launchPrivacyPolicy() async {
String? locale = "en_US";

View File

@ -1,176 +0,0 @@
/*
This file is part of Sanmill.
Copyright (C) 2019-2021 The Sanmill developers (see AUTHORS file)
Sanmill is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Sanmill is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
import 'package:fluentui_system_icons/fluentui_system_icons.dart';
import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart';
import 'package:sanmill/generated/intl/l10n.dart';
import 'package:sanmill/generated/oss_licenses.dart';
import 'package:url_launcher/url_launcher.dart';
// TODO: use flutters build in viewLicense function
class FlutterLicense extends LicenseEntry {
@override
final List<String> packages;
@override
final List<LicenseParagraph> paragraphs;
FlutterLicense(this.packages, this.paragraphs);
}
/// display all used packages and their license
class OssLicensesPage extends StatelessWidget {
static Future<List<String>> loadLicenses() async {
Stream<LicenseEntry> licenses() async* {
yield FlutterLicense(
['Sound Effects'],
[
const LicenseParagraph(
'CC-0\nhttps://freesound.org/people/unfa/sounds/243749/',
0,
),
],
);
}
LicenseRegistry.addLicense(licenses);
// merging non-dart based dependency list using LicenseRegistry.
final ossKeys = ossLicenses.keys.toList();
final lm = <String, List<String>>{};
await for (final l in LicenseRegistry.licenses) {
for (final p in l.packages) {
if (!ossKeys.contains(p)) {
final lp = lm.putIfAbsent(p, () => []);
lp.addAll(l.paragraphs.map((p) => p.text));
ossKeys.add(p);
}
}
}
for (final key in lm.keys) {
ossLicenses[key] = {'license': lm[key]!.join('\n')};
}
return ossKeys..sort();
}
@override
Widget build(BuildContext context) => Scaffold(
appBar: AppBar(
title: Text(S.of(context).ossLicenses),
),
body: FutureBuilder<List<String>>(
future: loadLicenses(),
builder: (context, snapshot) => ListView.separated(
itemCount: snapshot.data?.length ?? 0,
itemBuilder: (context, index) {
final key = snapshot.data![index];
final ossl = ossLicenses[key] as Map<String, dynamic>;
final version = ossl['version'];
final desc = ossl['description'] as String?;
return ListTile(
title: Text('$key $version'),
subtitle: desc != null ? Text(desc) : null,
trailing: const Icon(FluentIcons.chevron_right_24_regular),
onTap: () => Navigator.push(
context,
MaterialPageRoute(
builder: (_) => MiscOssLicenseSingle(name: key, json: ossl),
),
),
);
},
separatorBuilder: (context, index) => const Divider(),
),
),
);
}
class MiscOssLicenseSingle extends StatelessWidget {
final String name;
final Map<String, dynamic> json;
const MiscOssLicenseSingle({
required this.name,
required this.json,
});
String get version => json['version'] as String? ?? "";
String? get description => json['description'] as String?;
String get licenseText => json['license'] as String;
String? get homepage => json['homepage'] as String?;
String get _bodyText => licenseText.split('\n').map((line) {
if (line.startsWith('//')) line = line.substring(2);
return line.trim();
}).join('\n');
@override
Widget build(BuildContext context) => Scaffold(
appBar: AppBar(title: Text('$name $version')),
backgroundColor: Theme.of(context).canvasColor,
body: ListView(
children: <Widget>[
if (description != null)
Padding(
padding: const EdgeInsets.only(
top: 12.0,
left: 12.0,
right: 12.0,
),
child: Text(
description!,
style: Theme.of(context)
.textTheme
.bodyText2!
.copyWith(fontWeight: FontWeight.bold),
),
),
if (homepage != null)
Padding(
padding: const EdgeInsets.only(
top: 12.0,
left: 12.0,
right: 12.0,
),
child: InkWell(
child: Text(
homepage!,
style: const TextStyle(
color: Colors.blue,
decoration: TextDecoration.underline,
),
),
onTap: () => launch(homepage!),
),
),
if (description != null || homepage != null) const Divider(),
Padding(
padding: const EdgeInsets.only(
top: 12.0,
left: 12.0,
right: 12.0,
),
child: Text(
_bodyText,
style: Theme.of(context).textTheme.bodyText2,
),
),
],
),
);
}

View File

@ -48,7 +48,6 @@ dev_dependencies:
build_runner: ^2.1.4
copy_with_extension_gen: ^2.0.3
flutter_gen_runner: ^4.0.0
flutter_oss_licenses: ^1.0.1
flutter_test:
sdk: flutter
@ -63,7 +62,7 @@ flutter_gen:
output: lib/generated/assets/
flutter:
generate: true
generate: false
uses-material-design: true
assets: