mirror of
https://gitlab.com/comunic/comunicmobile
synced 2024-11-25 22:39:22 +00:00
Start to display banner
This commit is contained in:
parent
4fd8c4d613
commit
bfe932c053
@ -17,6 +17,7 @@ class ServerConfigurationHelper {
|
|||||||
(await APIRequest.withoutLogin("server/config").execWithThrow())
|
(await APIRequest.withoutLogin("server/config").execWithThrow())
|
||||||
.getObject();
|
.getObject();
|
||||||
|
|
||||||
|
final banner = response["banner"];
|
||||||
final pushNotificationsPolicy = response["push_notifications"];
|
final pushNotificationsPolicy = response["push_notifications"];
|
||||||
final passwordPolicy = response["password_policy"];
|
final passwordPolicy = response["password_policy"];
|
||||||
final dataConservationPolicy = response["data_conservation_policy"];
|
final dataConservationPolicy = response["data_conservation_policy"];
|
||||||
@ -31,6 +32,15 @@ class ServerConfigurationHelper {
|
|||||||
contactEmail: response["contact_email"],
|
contactEmail: response["contact_email"],
|
||||||
playStoreURL: response["play_store_url"],
|
playStoreURL: response["play_store_url"],
|
||||||
androidDirectDownloadURL: response["android_direct_download_url"],
|
androidDirectDownloadURL: response["android_direct_download_url"],
|
||||||
|
banner: banner == null
|
||||||
|
? null
|
||||||
|
: Banner(
|
||||||
|
enabled: banner["enabled"],
|
||||||
|
expire: banner["expire"],
|
||||||
|
nature: BannerNatureExt.fromStr(banner["nature"]),
|
||||||
|
message: Map<String, dynamic>.from(banner["message"])
|
||||||
|
.map((key, value) => MapEntry(key, value.toString())),
|
||||||
|
link: banner["link"]),
|
||||||
notificationsPolicy: NotificationsPolicy(
|
notificationsPolicy: NotificationsPolicy(
|
||||||
hasFirebase: pushNotificationsPolicy["has_firebase"],
|
hasFirebase: pushNotificationsPolicy["has_firebase"],
|
||||||
hasIndependent: pushNotificationsPolicy["has_independent"],
|
hasIndependent: pushNotificationsPolicy["has_independent"],
|
||||||
@ -98,3 +108,5 @@ class ServerConfigurationHelper {
|
|||||||
|
|
||||||
/// Shortcut for server configuration
|
/// Shortcut for server configuration
|
||||||
ServerConfig get srvConfig => ServerConfigurationHelper.config;
|
ServerConfig get srvConfig => ServerConfigurationHelper.config;
|
||||||
|
|
||||||
|
bool get showBanner => srvConfig.banner != null && srvConfig.banner.visible;
|
@ -1,3 +1,4 @@
|
|||||||
|
import 'package:comunic/utils/date_utils.dart';
|
||||||
import 'package:flutter/widgets.dart';
|
import 'package:flutter/widgets.dart';
|
||||||
import 'package:version/version.dart';
|
import 'package:version/version.dart';
|
||||||
|
|
||||||
@ -132,6 +133,42 @@ class AccountInformationPolicy {
|
|||||||
assert(maxLocationLength != null);
|
assert(maxLocationLength != null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
enum BannerNature { Information, Warning, Success }
|
||||||
|
|
||||||
|
extension BannerNatureExt on BannerNature {
|
||||||
|
static BannerNature fromStr(String s) {
|
||||||
|
switch (s) {
|
||||||
|
case "information":
|
||||||
|
return BannerNature.Information;
|
||||||
|
case "success":
|
||||||
|
return BannerNature.Success;
|
||||||
|
case "warning":
|
||||||
|
default:
|
||||||
|
return BannerNature.Warning;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class Banner {
|
||||||
|
final bool enabled;
|
||||||
|
final int expire;
|
||||||
|
final BannerNature nature;
|
||||||
|
final Map<String, String> message;
|
||||||
|
final String link;
|
||||||
|
|
||||||
|
const Banner({
|
||||||
|
@required this.enabled,
|
||||||
|
@required this.expire,
|
||||||
|
@required this.nature,
|
||||||
|
@required this.message,
|
||||||
|
@required this.link,
|
||||||
|
}) : assert(enabled != null),
|
||||||
|
assert(nature != null),
|
||||||
|
assert(message != null);
|
||||||
|
|
||||||
|
bool get visible => enabled && (expire == null || expire > time());
|
||||||
|
}
|
||||||
|
|
||||||
class ServerConfig {
|
class ServerConfig {
|
||||||
final Version minSupportedMobileVersion;
|
final Version minSupportedMobileVersion;
|
||||||
final String termsURL;
|
final String termsURL;
|
||||||
@ -139,6 +176,7 @@ class ServerConfig {
|
|||||||
final String contactEmail;
|
final String contactEmail;
|
||||||
final String playStoreURL;
|
final String playStoreURL;
|
||||||
final String androidDirectDownloadURL;
|
final String androidDirectDownloadURL;
|
||||||
|
final Banner banner;
|
||||||
final NotificationsPolicy notificationsPolicy;
|
final NotificationsPolicy notificationsPolicy;
|
||||||
final PasswordPolicy passwordPolicy;
|
final PasswordPolicy passwordPolicy;
|
||||||
final ServerDataConservationPolicy dataConservationPolicy;
|
final ServerDataConservationPolicy dataConservationPolicy;
|
||||||
@ -152,6 +190,7 @@ class ServerConfig {
|
|||||||
@required this.contactEmail,
|
@required this.contactEmail,
|
||||||
@required this.playStoreURL,
|
@required this.playStoreURL,
|
||||||
@required this.androidDirectDownloadURL,
|
@required this.androidDirectDownloadURL,
|
||||||
|
@required this.banner,
|
||||||
@required this.notificationsPolicy,
|
@required this.notificationsPolicy,
|
||||||
@required this.passwordPolicy,
|
@required this.passwordPolicy,
|
||||||
@required this.dataConservationPolicy,
|
@required this.dataConservationPolicy,
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import 'package:comunic/ui/routes/main_route/main_route.dart';
|
import 'package:comunic/ui/routes/main_route/main_route.dart';
|
||||||
import 'package:comunic/ui/routes/main_route/page_info.dart';
|
import 'package:comunic/ui/routes/main_route/page_info.dart';
|
||||||
import 'package:comunic/ui/screens/notifications_screen.dart';
|
import 'package:comunic/ui/screens/notifications_screen.dart';
|
||||||
|
import 'package:comunic/ui/widgets/banner_widget.dart';
|
||||||
import 'package:comunic/ui/widgets/mobile_mode/mobile_appbar_widget.dart';
|
import 'package:comunic/ui/widgets/mobile_mode/mobile_appbar_widget.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
@ -33,7 +34,14 @@ class _MainRouteState extends MainController {
|
|||||||
appBar: currentPage.hideNavBar
|
appBar: currentPage.hideNavBar
|
||||||
? null
|
? null
|
||||||
: ComunicMobileAppBar(currentPage: currentPage),
|
: ComunicMobileAppBar(currentPage: currentPage),
|
||||||
body: SafeArea(key: currentPage.key, child: currentPage.child),
|
body: SafeArea(
|
||||||
|
key: currentPage.key,
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
BannerWidget(),
|
||||||
|
Expanded(child: currentPage.child)
|
||||||
|
],
|
||||||
|
)),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
89
lib/ui/widgets/banner_widget.dart
Normal file
89
lib/ui/widgets/banner_widget.dart
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
import 'package:comunic/helpers/server_config_helper.dart';
|
||||||
|
import 'package:comunic/models/server_config.dart';
|
||||||
|
import 'package:comunic/utils/intl_utils.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:url_launcher/url_launcher.dart';
|
||||||
|
|
||||||
|
bool _bannerDismissed = false;
|
||||||
|
|
||||||
|
class BannerWidget extends StatefulWidget {
|
||||||
|
const BannerWidget({Key key}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
_BannerWidgetState createState() => _BannerWidgetState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _BannerWidgetState extends State<BannerWidget> {
|
||||||
|
void _hideBanner() {
|
||||||
|
setState(() => _bannerDismissed = true);
|
||||||
|
}
|
||||||
|
|
||||||
|
void _openLink() {
|
||||||
|
launch(srvConfig.banner.link);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
if (!showBanner || _bannerDismissed) return Container();
|
||||||
|
|
||||||
|
final banner = srvConfig.banner;
|
||||||
|
return Card(
|
||||||
|
color: banner.nature == BannerNature.Information
|
||||||
|
? Colors.blue
|
||||||
|
: banner.nature == BannerNature.Success
|
||||||
|
? Colors.green
|
||||||
|
: Colors.red,
|
||||||
|
child: Padding(
|
||||||
|
padding: const EdgeInsets.all(2.0),
|
||||||
|
child: Row(
|
||||||
|
children: [
|
||||||
|
BannerButton(
|
||||||
|
icon: Icon(
|
||||||
|
banner.nature == BannerNature.Information
|
||||||
|
? Icons.info
|
||||||
|
: banner.nature == BannerNature.Success
|
||||||
|
? Icons.check
|
||||||
|
: Icons.warning,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
Flexible(
|
||||||
|
child: Text(
|
||||||
|
banner.message.containsKey(lang())
|
||||||
|
? banner.message[lang()]
|
||||||
|
: banner.message["en"],
|
||||||
|
style: TextStyle(color: Colors.white),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
banner.link == null
|
||||||
|
? Container()
|
||||||
|
: BannerButton(
|
||||||
|
onPressed: _openLink,
|
||||||
|
icon: Icon(Icons.open_in_new),
|
||||||
|
),
|
||||||
|
BannerButton(
|
||||||
|
onPressed: _hideBanner,
|
||||||
|
icon: Icon(Icons.close),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class BannerButton extends StatelessWidget {
|
||||||
|
final Function() onPressed;
|
||||||
|
final Widget icon;
|
||||||
|
|
||||||
|
const BannerButton({this.onPressed, this.icon, Key key}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return IconButton(
|
||||||
|
onPressed: onPressed,
|
||||||
|
icon: icon,
|
||||||
|
disabledColor: Colors.white,
|
||||||
|
padding: EdgeInsets.all(1.0),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
@ -48,3 +48,8 @@ String tr(String string, {Map<String, String> args}) {
|
|||||||
|
|
||||||
return string;
|
return string;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Get current lang
|
||||||
|
String lang() {
|
||||||
|
return _currLang != null ? _currLang : "en";
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user