Announcements implemented

merge-requests/1/merge
haroon amjad 3 years ago
parent 556215807b
commit d614532956

@ -3,8 +3,8 @@ class GetAnnouncementDetails {
String? titleAR; String? titleAR;
String? emailBodyEN; String? emailBodyEN;
String? emailBodyAR; String? emailBodyAR;
String? bodyEN; String? bodyEN = "";
String? bodyAR; String? bodyAR = "";
String? bannerImage; String? bannerImage;
String? rowID; String? rowID;
String? awarenessName; String? awarenessName;

@ -3,9 +3,13 @@ import 'dart:convert';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_html/flutter_html.dart'; import 'package:flutter_html/flutter_html.dart';
import 'package:mohem_flutter_app/api/pending_transactions_api_client.dart'; import 'package:mohem_flutter_app/api/pending_transactions_api_client.dart';
import 'package:mohem_flutter_app/app_state/app_state.dart';
import 'package:mohem_flutter_app/classes/colors.dart';
import 'package:mohem_flutter_app/classes/utils.dart'; import 'package:mohem_flutter_app/classes/utils.dart';
import 'package:mohem_flutter_app/extensions/int_extensions.dart';
import 'package:mohem_flutter_app/models/get_announcement_details.dart'; import 'package:mohem_flutter_app/models/get_announcement_details.dart';
import 'package:mohem_flutter_app/widgets/app_bar_widget.dart'; import 'package:mohem_flutter_app/widgets/app_bar_widget.dart';
import 'package:url_launcher/url_launcher.dart';
class AnnouncementDetails extends StatefulWidget { class AnnouncementDetails extends StatefulWidget {
const AnnouncementDetails({Key? key}) : super(key: key); const AnnouncementDetails({Key? key}) : super(key: key);
@ -36,7 +40,8 @@ class _AnnouncementDetailsState extends State<AnnouncementDetails> {
title: "Announcements", title: "Announcements",
), ),
body: SingleChildScrollView( body: SingleChildScrollView(
child: Container( child: getAnnouncementDetailsObj != null
? Container(
width: double.infinity, width: double.infinity,
padding: const EdgeInsets.all(10.0), padding: const EdgeInsets.all(10.0),
margin: const EdgeInsets.all(12.0), margin: const EdgeInsets.all(12.0),
@ -55,6 +60,11 @@ class _AnnouncementDetailsState extends State<AnnouncementDetails> {
crossAxisAlignment: CrossAxisAlignment.start, crossAxisAlignment: CrossAxisAlignment.start,
mainAxisSize: MainAxisSize.min, mainAxisSize: MainAxisSize.min,
children: [ children: [
12.height,
AppState().isArabic(context)
? Text(getAnnouncementDetailsObj?.titleAR ?? "", style: const TextStyle(color: MyColors.darkTextColor, fontSize: 16, letterSpacing: -0.64, fontWeight: FontWeight.w600))
: Text(getAnnouncementDetailsObj?.titleEN ?? "", style: const TextStyle(color: MyColors.darkTextColor, fontSize: 16, letterSpacing: -0.64, fontWeight: FontWeight.w600)),
12.height,
SizedBox( SizedBox(
width: double.infinity, width: double.infinity,
height: 150.0, height: 150.0,
@ -69,26 +79,29 @@ class _AnnouncementDetailsState extends State<AnnouncementDetails> {
Container( Container(
margin: const EdgeInsets.only(top: 12.0), margin: const EdgeInsets.only(top: 12.0),
child: Html( child: Html(
data: getAnnouncementDetailsObj?.bodyEN, data: AppState().isArabic(context) ? getAnnouncementDetailsObj?.bodyAR : getAnnouncementDetailsObj?.bodyEN ?? "",
), onLinkTap: (String? url, RenderContext context, Map<String, String> attributes, _) {
launchUrl(Uri.parse(url!));
}),
), ),
], ],
), ),
), )
: Utils.getNoDataWidget(context),
), ),
); );
} }
getRequestID() { getRequestID() async {
if (currentPageNo == 0) { if (currentPageNo == 0) {
final arguments = (ModalRoute.of(context)?.settings.arguments ?? <String, dynamic>{}) as Map; final arguments = (ModalRoute.of(context)?.settings.arguments ?? <String, dynamic>{}) as Map;
currentPageNo = arguments["currentPageNo"]; currentPageNo = arguments["currentPageNo"];
rowID = arguments["rowID"]; rowID = arguments["rowID"];
getAnnouncementDetails(0, rowID); await getAnnouncementDetails(0, rowID);
} }
} }
void getAnnouncementDetails(int itgAwarenessID, int itgRowID) async { Future getAnnouncementDetails(int itgAwarenessID, int itgRowID) async {
try { try {
Utils.showLoading(context); Utils.showLoading(context);
jsonResponse = await PendingTransactionsApiClient().getAnnouncements(itgAwarenessID, currentPageNo, itgRowID); jsonResponse = await PendingTransactionsApiClient().getAnnouncements(itgAwarenessID, currentPageNo, itgRowID);

@ -27,11 +27,22 @@ class _AnnouncementsState extends State<Announcements> {
List<GetAnnouncementsObject> getAnnouncementsObject = []; List<GetAnnouncementsObject> getAnnouncementsObject = [];
List<GetAnnouncementsObject> _foundAnnouncements = []; List<GetAnnouncementsObject> _foundAnnouncements = [];
TextEditingController searchController = TextEditingController(); TextEditingController searchController = TextEditingController();
final ScrollController _controller = ScrollController();
@override @override
void initState() { void initState() {
getAnnouncements(0, 0); getAnnouncements(0, 0);
super.initState(); super.initState();
_controller.addListener(() {
if (_controller.position.atEdge) {
bool isTop = _controller.position.pixels == 0;
if (!isTop) {
print('At the bottom');
currentPageNo++;
getAnnouncements(0, 0);
}
}
});
} }
@override @override
@ -71,6 +82,7 @@ class _AnnouncementsState extends State<Announcements> {
child: ListView.separated( child: ListView.separated(
physics: const BouncingScrollPhysics(), physics: const BouncingScrollPhysics(),
shrinkWrap: true, shrinkWrap: true,
controller: _controller,
itemBuilder: (BuildContext context, int index) { itemBuilder: (BuildContext context, int index) {
return InkWell( return InkWell(
onTap: () { onTap: () {
@ -125,7 +137,8 @@ class _AnnouncementsState extends State<Announcements> {
); );
}, },
separatorBuilder: (BuildContext context, int index) => 1.height, separatorBuilder: (BuildContext context, int index) => 1.height,
itemCount: _foundAnnouncements.length ?? 0)) itemCount: _foundAnnouncements.length ?? 0)),
20.height,
], ],
), ),
) )

@ -68,6 +68,7 @@ dependencies:
open_file: ^3.2.1 open_file: ^3.2.1
wifi_iot: ^0.3.16 wifi_iot: ^0.3.16
flutter_html: ^2.2.1 flutter_html: ^2.2.1
url_launcher: ^6.0.15
dev_dependencies: dev_dependencies:
flutter_test: flutter_test:

Loading…
Cancel
Save