mirror of
https://git.selfprivacy.org/kherel/selfprivacy.org.app.git
synced 2025-01-23 01:06:44 +00:00
Merge branch 'master' into release-party
This commit is contained in:
commit
e0c04468bc
33
fastlane/metadata/android/en-US/changelogs/0.8.0.txt
Normal file
33
fastlane/metadata/android/en-US/changelogs/0.8.0.txt
Normal file
|
@ -0,0 +1,33 @@
|
|||
Server setup:
|
||||
- Added support for Digital Ocean as server provider
|
||||
- You can now choose server region
|
||||
- You can now choose server tier
|
||||
- Server installation UI has been refreshed
|
||||
- Fields now have more specific error messages
|
||||
|
||||
Common UI:
|
||||
- New app bar used in most of the screens
|
||||
|
||||
Services:
|
||||
- Services are now sorted by their status
|
||||
|
||||
Server settings:
|
||||
- Timezone search screen now has a search bar
|
||||
- Fixed job creation when switching the setting multiple times
|
||||
- Server destruction now works
|
||||
|
||||
Jobs:
|
||||
- Jobs panel now should take slightly less space
|
||||
|
||||
Auth:
|
||||
- Recovery key page can now be reloaded by dragging down
|
||||
|
||||
Logging:
|
||||
- Log console now has a limit of 500 lines
|
||||
- GraphQL API requests are now logged in the console
|
||||
- Networks errors are better handled
|
||||
|
||||
For developers:
|
||||
- App now only uses GraphQL API to communicate with the server. All REST API calls have been removed.
|
||||
- Server can now be deployed with staging ACME certificates
|
||||
- Language assets have been reorganized
|
File diff suppressed because it is too large
Load diff
|
@ -4,5 +4,5 @@ class StagingOptions {
|
|||
/// Whether we request for staging temprorary certificates.
|
||||
/// Hardcode to 'true' in the middle of testing to not
|
||||
/// get your domain banned by constant certificate renewal
|
||||
static bool get stagingAcme => true;
|
||||
static bool get stagingAcme => false;
|
||||
}
|
||||
|
|
|
@ -9,5 +9,9 @@ class ConsoleModel extends ChangeNotifier {
|
|||
void addMessage(final Message message) {
|
||||
messages.add(message);
|
||||
notifyListeners();
|
||||
// Make sure we don't have too many messages
|
||||
if (messages.length > 500) {
|
||||
messages.removeAt(0);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -105,13 +105,13 @@ class ServiceStorageUsage {
|
|||
}
|
||||
|
||||
enum ServiceStatus {
|
||||
failed,
|
||||
reloading,
|
||||
activating,
|
||||
active,
|
||||
deactivating,
|
||||
failed,
|
||||
inactive,
|
||||
off,
|
||||
reloading;
|
||||
off;
|
||||
|
||||
factory ServiceStatus.fromGraphQL(final Enum$ServiceStatusEnum graphQL) {
|
||||
switch (graphQL) {
|
||||
|
|
|
@ -15,7 +15,7 @@ class BrandBottomSheet extends StatelessWidget {
|
|||
Widget build(final BuildContext context) {
|
||||
final double mainHeight = MediaQuery.of(context).size.height -
|
||||
MediaQuery.of(context).padding.top -
|
||||
100;
|
||||
300;
|
||||
late Widget innerWidget;
|
||||
if (isExpended) {
|
||||
innerWidget = Scaffold(
|
||||
|
@ -29,31 +29,28 @@ class BrandBottomSheet extends StatelessWidget {
|
|||
child: IntrinsicHeight(child: child),
|
||||
);
|
||||
}
|
||||
return ConstrainedBox(
|
||||
constraints: BoxConstraints(maxHeight: mainHeight + 4 + 6),
|
||||
child: Column(
|
||||
mainAxisSize: MainAxisSize.min,
|
||||
children: [
|
||||
Center(
|
||||
child: Container(
|
||||
height: 4,
|
||||
width: 30,
|
||||
decoration: BoxDecoration(
|
||||
borderRadius: BorderRadius.circular(2),
|
||||
color: BrandColors.gray4,
|
||||
),
|
||||
return Column(
|
||||
mainAxisSize: MainAxisSize.min,
|
||||
children: [
|
||||
Center(
|
||||
child: Container(
|
||||
height: 4,
|
||||
width: 30,
|
||||
decoration: BoxDecoration(
|
||||
borderRadius: BorderRadius.circular(2),
|
||||
color: BrandColors.gray4,
|
||||
),
|
||||
),
|
||||
const SizedBox(height: 6),
|
||||
ClipRRect(
|
||||
borderRadius: const BorderRadius.vertical(top: Radius.circular(20)),
|
||||
child: ConstrainedBox(
|
||||
constraints: BoxConstraints(maxHeight: mainHeight),
|
||||
child: innerWidget,
|
||||
),
|
||||
),
|
||||
const SizedBox(height: 6),
|
||||
ClipRRect(
|
||||
borderRadius: const BorderRadius.vertical(top: Radius.circular(20)),
|
||||
child: ConstrainedBox(
|
||||
constraints: BoxConstraints(maxHeight: mainHeight),
|
||||
child: innerWidget,
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
],
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import 'dart:math';
|
||||
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:fl_chart/fl_chart.dart';
|
||||
import 'package:selfprivacy/logic/common_enum/common_enum.dart';
|
||||
|
@ -82,7 +84,10 @@ class CpuChart extends StatelessWidget {
|
|||
),
|
||||
],
|
||||
minY: 0,
|
||||
maxY: 100,
|
||||
// Maximal value of data by 100 step
|
||||
maxY:
|
||||
((data.map((final e) => e.value).reduce(max) - 1) / 100).ceil() *
|
||||
100.0,
|
||||
minX: 0,
|
||||
titlesData: FlTitlesData(
|
||||
topTitles: AxisTitles(sideTitles: SideTitles(showTitles: false)),
|
||||
|
|
|
@ -41,6 +41,10 @@ class _ServicesPageState extends State<ServicesPage> {
|
|||
final isReady = context.watch<ServerInstallationCubit>().state
|
||||
is ServerInstallationFinished;
|
||||
|
||||
final services = [...context.watch<ServicesCubit>().state.services];
|
||||
services
|
||||
.sort((final a, final b) => a.status.index.compareTo(b.status.index));
|
||||
|
||||
return Scaffold(
|
||||
appBar: PreferredSize(
|
||||
preferredSize: const Size.fromHeight(52),
|
||||
|
@ -58,10 +62,7 @@ class _ServicesPageState extends State<ServicesPage> {
|
|||
BrandText.body1('basis.services_title'.tr()),
|
||||
const SizedBox(height: 24),
|
||||
if (!isReady) ...[const NotReadyCard(), const SizedBox(height: 24)],
|
||||
...context
|
||||
.read<ServicesCubit>()
|
||||
.state
|
||||
.services
|
||||
...services
|
||||
.map(
|
||||
(final service) => Padding(
|
||||
padding: const EdgeInsets.only(
|
||||
|
|
|
@ -254,9 +254,9 @@ class SelectTypePage extends StatelessWidget {
|
|||
const SizedBox(width: 8),
|
||||
Text(
|
||||
'initializing.choose_server_type_storage'
|
||||
.tr(args: [
|
||||
type.disk.gibibyte.toString()
|
||||
]),
|
||||
.tr(
|
||||
args: [type.disk.gibibyte.toString()],
|
||||
),
|
||||
style:
|
||||
Theme.of(context).textTheme.bodyMedium,
|
||||
),
|
||||
|
@ -275,9 +275,11 @@ class SelectTypePage extends StatelessWidget {
|
|||
const SizedBox(width: 8),
|
||||
Text(
|
||||
'initializing.choose_server_type_payment_per_month'
|
||||
.tr(args: [
|
||||
'${type.price.value.toString()} ${type.price.currency}'
|
||||
]),
|
||||
.tr(
|
||||
args: [
|
||||
'${type.price.value.toString()} ${type.price.currency}'
|
||||
],
|
||||
),
|
||||
style:
|
||||
Theme.of(context).textTheme.bodyLarge,
|
||||
),
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
name: selfprivacy
|
||||
description: selfprivacy.org
|
||||
publish_to: 'none'
|
||||
version: 0.7.0+16
|
||||
version: 0.8.0+17
|
||||
|
||||
environment:
|
||||
sdk: '>=2.17.0 <3.0.0'
|
||||
|
|
Loading…
Reference in a new issue