init refilc-plus
This commit is contained in:
commit
6edc2029bd
37 changed files with 6988 additions and 0 deletions
157
lib/ui/mobile/settings/welcome_message.dart
Normal file
157
lib/ui/mobile/settings/welcome_message.dart
Normal file
|
@ -0,0 +1,157 @@
|
|||
import 'package:refilc/api/providers/user_provider.dart';
|
||||
import 'package:refilc/models/settings.dart';
|
||||
import 'package:refilc/theme/colors/colors.dart';
|
||||
import 'package:refilc_mobile_ui/common/panel/panel_button.dart';
|
||||
import 'package:refilc_plus/models/premium_scopes.dart';
|
||||
import 'package:refilc_plus/providers/plus_provider.dart';
|
||||
import 'package:refilc_plus/ui/mobile/plus/upsell.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter_feather_icons/flutter_feather_icons.dart';
|
||||
import 'package:refilc_mobile_ui/screens/settings/settings_screen.i18n.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'package:i18n_extension/i18n_extension.dart';
|
||||
|
||||
// ignore: must_be_immutable
|
||||
class WelcomeMessagePanelButton extends StatelessWidget {
|
||||
late SettingsProvider settingsProvider;
|
||||
late UserProvider user;
|
||||
|
||||
WelcomeMessagePanelButton(this.settingsProvider, this.user, {super.key});
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
String finalName = ((user.nickname ?? '') != ''
|
||||
? user.nickname
|
||||
: (user.displayName ?? '') != ''
|
||||
? user.displayName
|
||||
: 'János') ??
|
||||
'János';
|
||||
|
||||
return PanelButton(
|
||||
onPressed: () {
|
||||
showDialog(
|
||||
context: context,
|
||||
builder: (context) => WelcomeMessageEditor(settingsProvider));
|
||||
},
|
||||
title: Text(
|
||||
"welcome_msg".i18n,
|
||||
style: TextStyle(
|
||||
color: AppColors.of(context).text.withOpacity(.95),
|
||||
),
|
||||
),
|
||||
leading: Icon(
|
||||
FeatherIcons.smile,
|
||||
size: 22.0,
|
||||
color: AppColors.of(context).text.withOpacity(.95),
|
||||
),
|
||||
trailing: Container(
|
||||
constraints: const BoxConstraints(maxWidth: 100),
|
||||
child: Text(
|
||||
settingsProvider.welcomeMessage.replaceAll(' ', '') != ''
|
||||
? localizeFill(
|
||||
settingsProvider.welcomeMessage,
|
||||
[finalName],
|
||||
)
|
||||
: 'default'.i18n,
|
||||
style: const TextStyle(fontSize: 14.0),
|
||||
textAlign: TextAlign.end,
|
||||
softWrap: true,
|
||||
overflow: TextOverflow.ellipsis,
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
// ignore: must_be_immutable
|
||||
class WelcomeMessageEditor extends StatefulWidget {
|
||||
late SettingsProvider settingsProvider;
|
||||
|
||||
WelcomeMessageEditor(this.settingsProvider, {super.key});
|
||||
|
||||
@override
|
||||
State<WelcomeMessageEditor> createState() => _WelcomeMessageEditorState();
|
||||
}
|
||||
|
||||
class _WelcomeMessageEditorState extends State<WelcomeMessageEditor> {
|
||||
final _welcomeMsg = TextEditingController();
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
_welcomeMsg.text =
|
||||
widget.settingsProvider.welcomeMessage.replaceAll('%s', '%name%');
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return AlertDialog(
|
||||
title: Text("edit_welcome_msg".i18n),
|
||||
content: TextField(
|
||||
controller: _welcomeMsg,
|
||||
autofocus: true,
|
||||
decoration: InputDecoration(
|
||||
border: const OutlineInputBorder(),
|
||||
label: Text('welcome_msg'.i18n),
|
||||
suffixIcon: IconButton(
|
||||
icon: const Icon(FeatherIcons.x),
|
||||
onPressed: () {
|
||||
setState(() {
|
||||
_welcomeMsg.text = "";
|
||||
});
|
||||
},
|
||||
),
|
||||
),
|
||||
),
|
||||
actions: [
|
||||
TextButton(
|
||||
child: Text(
|
||||
"cancel".i18n,
|
||||
style: const TextStyle(fontWeight: FontWeight.w500),
|
||||
),
|
||||
onPressed: () {
|
||||
Navigator.of(context).maybePop();
|
||||
},
|
||||
),
|
||||
TextButton(
|
||||
child: Text(
|
||||
"done".i18n,
|
||||
style: const TextStyle(fontWeight: FontWeight.w500),
|
||||
),
|
||||
onPressed: () {
|
||||
// var trimmed = _welcomeMsg.text.trim();
|
||||
|
||||
// var defLen = trimmed.length;
|
||||
// var replacedLen = trimmed.replaceAll('%s', '').length;
|
||||
|
||||
// if (defLen - 2 > replacedLen) {
|
||||
// print('fuck yourself rn');
|
||||
// }
|
||||
var finalText = _welcomeMsg.text
|
||||
.trim()
|
||||
.replaceFirst('%name%', '\$s')
|
||||
.replaceFirst('%user%', '\$s')
|
||||
.replaceFirst('%username%', '\$s')
|
||||
.replaceFirst('%me%', '\$s')
|
||||
.replaceFirst('%profile%', '\$s')
|
||||
.replaceAll('%', '')
|
||||
.replaceFirst('\$s', '%s');
|
||||
// .replaceAll('\$s', 's');
|
||||
|
||||
if (!Provider.of<PlusProvider>(context, listen: false)
|
||||
.hasScope(PremiumScopes.welcomeMessage) &&
|
||||
finalText.replaceAll(' ', '') != '') {
|
||||
PlusLockedFeaturePopup.show(
|
||||
context: context, feature: PremiumFeature.welcomeMessage);
|
||||
return;
|
||||
}
|
||||
|
||||
widget.settingsProvider
|
||||
.update(welcomeMessage: finalText, store: true);
|
||||
Navigator.of(context).pop(true);
|
||||
},
|
||||
),
|
||||
],
|
||||
);
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue