Email templates
This commit is contained in:
parent
d29e7a53c3
commit
bbedc86fb9
|
|
@ -1,6 +1,7 @@
|
||||||
import 'package:invoiceninja_flutter/data/models/entities.dart';
|
import 'package:invoiceninja_flutter/data/models/entities.dart';
|
||||||
import 'package:invoiceninja_flutter/ui/app/buttons/elevated_button.dart';
|
import 'package:invoiceninja_flutter/ui/app/buttons/elevated_button.dart';
|
||||||
import 'package:invoiceninja_flutter/ui/app/dialogs/loading_dialog.dart';
|
import 'package:invoiceninja_flutter/ui/app/dialogs/loading_dialog.dart';
|
||||||
|
import 'package:invoiceninja_flutter/ui/app/form_card.dart';
|
||||||
import 'package:invoiceninja_flutter/ui/app/invoice/email_invoice_dialog_vm.dart';
|
import 'package:invoiceninja_flutter/ui/app/invoice/email_invoice_dialog_vm.dart';
|
||||||
import 'package:flutter/foundation.dart';
|
import 'package:flutter/foundation.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
|
@ -25,25 +26,61 @@ class _EmailInvoiceViewState extends State<EmailInvoiceView> {
|
||||||
String emailSubject;
|
String emailSubject;
|
||||||
String emailBody;
|
String emailBody;
|
||||||
|
|
||||||
|
final _subjectController = TextEditingController();
|
||||||
|
final _bodyController = TextEditingController();
|
||||||
|
|
||||||
|
List<TextEditingController> _controllers = [];
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void didChangeDependencies() {
|
void didChangeDependencies() {
|
||||||
super.didChangeDependencies();
|
super.didChangeDependencies();
|
||||||
|
|
||||||
final localization = AppLocalization.of(context);
|
final localization = AppLocalization.of(context);
|
||||||
final company = widget.viewModel.company;
|
final company = widget.viewModel.company;
|
||||||
|
|
||||||
selectedTemplate = EmailTemplate.initial;
|
selectedTemplate = EmailTemplate.initial;
|
||||||
emailSubject = company.emailSubjectInvoice;
|
emailSubject = company.emailSubjectInvoice;
|
||||||
emailBody = company.emailBodyInvoice;
|
emailBody = company.emailBodyInvoice;
|
||||||
|
|
||||||
updateTemplate();
|
updateTemplate();
|
||||||
|
|
||||||
|
_controllers = [
|
||||||
|
_subjectController,
|
||||||
|
_bodyController,
|
||||||
|
];
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void dispose() {
|
||||||
|
_controllers.forEach((dynamic controller) {
|
||||||
|
controller.removeListener(_onChanged);
|
||||||
|
controller.dispose();
|
||||||
|
});
|
||||||
|
|
||||||
|
super.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
void _onChanged() {
|
||||||
|
setState(() {
|
||||||
|
updateTemplate();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void updateTemplate() {
|
void updateTemplate() {
|
||||||
final viewModel = widget.viewModel;
|
final viewModel = widget.viewModel;
|
||||||
|
|
||||||
emailSubject = processTemplate(
|
_controllers
|
||||||
emailSubject, viewModel.invoice, context);
|
.forEach((dynamic controller) => controller.removeListener(_onChanged));
|
||||||
emailBody = processTemplate(
|
|
||||||
emailBody, viewModel.invoice, context);
|
_subjectController.text = emailSubject;
|
||||||
|
_bodyController.text = emailBody;
|
||||||
|
|
||||||
|
_controllers
|
||||||
|
.forEach((dynamic controller) => controller.addListener(_onChanged));
|
||||||
|
|
||||||
|
emailSubject = processTemplate(emailSubject, viewModel.invoice, context);
|
||||||
|
emailBody = processTemplate(emailBody, viewModel.invoice, context);
|
||||||
}
|
}
|
||||||
|
|
||||||
Widget _buildSend(BuildContext context) {
|
Widget _buildSend(BuildContext context) {
|
||||||
|
|
@ -132,7 +169,8 @@ class _EmailInvoiceViewState extends State<EmailInvoiceView> {
|
||||||
Container(
|
Container(
|
||||||
color: Colors.white,
|
color: Colors.white,
|
||||||
child: Padding(
|
child: Padding(
|
||||||
padding: const EdgeInsets.all(13.0),
|
padding: const EdgeInsets.only(
|
||||||
|
left: 13.0, top: 13.0, right: 13.0, bottom: 20.0),
|
||||||
child: Text(
|
child: Text(
|
||||||
emailSubject,
|
emailSubject,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
|
|
@ -157,6 +195,30 @@ class _EmailInvoiceViewState extends State<EmailInvoiceView> {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Widget _buildEdit(BuildContext context) {
|
||||||
|
final localization = AppLocalization.of(context);
|
||||||
|
|
||||||
|
return FormCard(
|
||||||
|
children: <Widget>[
|
||||||
|
TextFormField(
|
||||||
|
controller: _subjectController,
|
||||||
|
decoration: InputDecoration(
|
||||||
|
labelText: localization.subject,
|
||||||
|
),
|
||||||
|
keyboardType: TextInputType.text,
|
||||||
|
),
|
||||||
|
TextFormField(
|
||||||
|
controller: _bodyController,
|
||||||
|
decoration: InputDecoration(
|
||||||
|
labelText: localization.body,
|
||||||
|
),
|
||||||
|
maxLines: 6,
|
||||||
|
keyboardType: TextInputType.multiline,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final viewModel = widget.viewModel;
|
final viewModel = widget.viewModel;
|
||||||
|
|
@ -190,7 +252,7 @@ class _EmailInvoiceViewState extends State<EmailInvoiceView> {
|
||||||
body: TabBarView(
|
body: TabBarView(
|
||||||
children: [
|
children: [
|
||||||
_buildSend(context),
|
_buildSend(context),
|
||||||
Icon(Icons.directions_transit),
|
_buildEdit(context),
|
||||||
Icon(Icons.directions_bike),
|
Icon(Icons.directions_bike),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
|
|
|
||||||
|
|
@ -48,6 +48,7 @@ class InvoiceEditDetailsState extends State<InvoiceEditDetails> {
|
||||||
_surcharge1Controller,
|
_surcharge1Controller,
|
||||||
_surcharge2Controller,
|
_surcharge2Controller,
|
||||||
];
|
];
|
||||||
|
|
||||||
_controllers
|
_controllers
|
||||||
.forEach((dynamic controller) => controller.removeListener(_onChanged));
|
.forEach((dynamic controller) => controller.removeListener(_onChanged));
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -194,6 +194,8 @@ class AppLocalization {
|
||||||
'third_reminder': 'Third Reminder',
|
'third_reminder': 'Third Reminder',
|
||||||
'template': 'Template',
|
'template': 'Template',
|
||||||
'send': 'Send',
|
'send': 'Send',
|
||||||
|
'subject': 'Subject',
|
||||||
|
'body': 'Body',
|
||||||
|
|
||||||
'payment': 'Payment',
|
'payment': 'Payment',
|
||||||
'payments': 'Payments',
|
'payments': 'Payments',
|
||||||
|
|
@ -443,6 +445,8 @@ class AppLocalization {
|
||||||
String get thirdReminder => _localizedValues[locale.languageCode]['third_reminder'];
|
String get thirdReminder => _localizedValues[locale.languageCode]['third_reminder'];
|
||||||
String get template => _localizedValues[locale.languageCode]['template'];
|
String get template => _localizedValues[locale.languageCode]['template'];
|
||||||
String get send => _localizedValues[locale.languageCode]['send'];
|
String get send => _localizedValues[locale.languageCode]['send'];
|
||||||
|
String get subject => _localizedValues[locale.languageCode]['subject'];
|
||||||
|
String get body => _localizedValues[locale.languageCode]['body'];
|
||||||
|
|
||||||
String get payment => _localizedValues[locale.languageCode]['payment'];
|
String get payment => _localizedValues[locale.languageCode]['payment'];
|
||||||
String get payments => _localizedValues[locale.languageCode]['payments'];
|
String get payments => _localizedValues[locale.languageCode]['payments'];
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue