fix : ui changes
This commit is contained in:
@@ -1,70 +1,69 @@
|
|||||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android">
|
<manifest xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
|
||||||
<uses-permission android:name="android.permission.INTERNET" />
|
<uses-permission android:name="android.permission.INTERNET"/>
|
||||||
<uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
|
<uses-permission android:name="android.permission.FOREGROUND_SERVICE"/>
|
||||||
<uses-permission android:name="android.permission.ACCESS_BACKGROUND_LOCATION" />
|
<uses-permission android:name="android.permission.ACCESS_BACKGROUND_LOCATION"/>
|
||||||
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
|
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
|
||||||
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
|
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
|
||||||
<uses-permission android:name="android.permission.REQUEST_INSTALL_PACKAGES" />
|
<uses-permission android:name="android.permission.MANAGE_EXTERNAL_STORAGE"/>
|
||||||
<uses-permission android:name="android.permission.MANAGE_EXTERNAL_STORAGE" />
|
|
||||||
<uses-permission android:name="android.permission.REQUEST_INSTALL_PACKAGES" />
|
|
||||||
|
|
||||||
<uses-permission
|
<uses-permission
|
||||||
android:name="android.permission.READ_EXTERNAL_STORAGE"
|
android:name="android.permission.READ_EXTERNAL_STORAGE"
|
||||||
android:maxSdkVersion="32" />
|
android:maxSdkVersion="32"/>
|
||||||
<uses-permission
|
<uses-permission
|
||||||
android:name="android.permission.WRITE_EXTERNAL_STORAGE"
|
android:name="android.permission.WRITE_EXTERNAL_STORAGE"
|
||||||
android:maxSdkVersion="28" />
|
android:maxSdkVersion="28"/>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<application
|
<application
|
||||||
android:largeHeap="true"
|
android:largeHeap="true"
|
||||||
android:name="${applicationName}"
|
android:name="${applicationName}"
|
||||||
android:icon="@mipmap/launcher_icon"
|
android:icon="@mipmap/launcher_icon"
|
||||||
android:label="رصــدیـار">
|
android:label="رصــدیـار">
|
||||||
<activity
|
<activity
|
||||||
android:name=".MainActivity"
|
android:name=".MainActivity"
|
||||||
android:configChanges="orientation|keyboardHidden|keyboard|screenSize|smallestScreenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode"
|
android:configChanges="orientation|keyboardHidden|keyboard|screenSize|smallestScreenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode"
|
||||||
android:enableOnBackInvokedCallback="true"
|
android:enableOnBackInvokedCallback="true"
|
||||||
android:exported="true"
|
android:exported="true"
|
||||||
android:hardwareAccelerated="true"
|
android:hardwareAccelerated="true"
|
||||||
android:launchMode="singleTop"
|
android:launchMode="singleTop"
|
||||||
android:requestLegacyExternalStorage="true"
|
android:requestLegacyExternalStorage="true"
|
||||||
android:taskAffinity=""
|
android:taskAffinity=""
|
||||||
android:theme="@style/LaunchTheme"
|
android:theme="@style/LaunchTheme"
|
||||||
android:windowSoftInputMode="adjustResize">
|
android:windowSoftInputMode="adjustResize">
|
||||||
<!-- Specifies an Android theme to apply to this Activity as soon as
|
<!-- Specifies an Android theme to apply to this Activity as soon as
|
||||||
the Android process has started. This theme is visible to the user
|
the Android process has started. This theme is visible to the user
|
||||||
while the Flutter UI initializes. After that, this theme continues
|
while the Flutter UI initializes. After that, this theme continues
|
||||||
to determine the Window background behind the Flutter UI. -->
|
to determine the Window background behind the Flutter UI. -->
|
||||||
<meta-data
|
<meta-data
|
||||||
android:name="io.flutter.embedding.android.NormalTheme"
|
android:name="io.flutter.embedding.android.NormalTheme"
|
||||||
android:resource="@style/NormalTheme" />
|
android:resource="@style/NormalTheme"/>
|
||||||
<intent-filter>
|
<intent-filter>
|
||||||
<action android:name="android.intent.action.MAIN" />
|
<action android:name="android.intent.action.MAIN"/>
|
||||||
<category android:name="android.intent.category.LAUNCHER" />
|
<category android:name="android.intent.category.LAUNCHER"/>
|
||||||
</intent-filter>
|
</intent-filter>
|
||||||
</activity>
|
</activity>
|
||||||
|
|
||||||
<activity
|
<activity
|
||||||
android:name="com.yalantis.ucrop.UCropActivity"
|
android:name="com.yalantis.ucrop.UCropActivity"
|
||||||
android:screenOrientation="fullSensor"
|
android:screenOrientation="fullSensor"
|
||||||
android:theme="@style/Ucrop.CropTheme"/>
|
android:theme="@style/Ucrop.CropTheme"/>
|
||||||
|
|
||||||
<!-- Don't delete the meta-data below.
|
<!-- Don't delete the meta-data below.
|
||||||
This is used by the Flutter tool to generate GeneratedPluginRegistrant.java -->
|
This is used by the Flutter tool to generate GeneratedPluginRegistrant.java -->
|
||||||
<meta-data
|
<meta-data
|
||||||
android:name="flutterEmbedding"
|
android:name="flutterEmbedding"
|
||||||
android:value="2" />
|
android:value="2"/>
|
||||||
|
|
||||||
<provider
|
<provider
|
||||||
android:name="androidx.core.content.FileProvider"
|
android:name="androidx.core.content.FileProvider"
|
||||||
android:authorities="${applicationId}.fileprovider"
|
android:authorities="${applicationId}.fileprovider"
|
||||||
android:exported="false"
|
android:exported="false"
|
||||||
android:grantUriPermissions="true">
|
android:grantUriPermissions="true">
|
||||||
<meta-data
|
<meta-data
|
||||||
android:name="android.support.FILE_PROVIDER_PATHS"
|
android:name="android.support.FILE_PROVIDER_PATHS"
|
||||||
android:resource="@xml/file_paths" />
|
android:resource="@xml/file_paths"/>
|
||||||
</provider>
|
</provider>
|
||||||
</application>
|
</application>
|
||||||
<!-- Required to query activities that can process text, see:
|
<!-- Required to query activities that can process text, see:
|
||||||
@@ -74,8 +73,8 @@
|
|||||||
In particular, this is used by the Flutter engine in io.flutter.plugin.text.ProcessTextPlugin. -->
|
In particular, this is used by the Flutter engine in io.flutter.plugin.text.ProcessTextPlugin. -->
|
||||||
<queries>
|
<queries>
|
||||||
<intent>
|
<intent>
|
||||||
<action android:name="android.intent.action.PROCESS_TEXT" />
|
<action android:name="android.intent.action.PROCESS_TEXT"/>
|
||||||
<data android:mimeType="text/plain" />
|
<data android:mimeType="text/plain"/>
|
||||||
</intent>
|
</intent>
|
||||||
</queries>
|
</queries>
|
||||||
</manifest>
|
</manifest>
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
sdk.dir=C:/Users/Housh11/AppData/Local/Android/Sdk
|
sdk.dir=C:/Users/Housh11/AppData/Local/Android/Sdk
|
||||||
flutter.sdk=C:\\src\\flutter
|
flutter.sdk=C:\\src\\flutter
|
||||||
flutter.buildMode=release
|
flutter.buildMode=debug
|
||||||
flutter.versionName=1.3.13
|
flutter.versionName=1.3.13
|
||||||
flutter.versionCode=10
|
flutter.versionCode=10
|
||||||
@@ -9,8 +9,6 @@ import 'package:rasadyar_chicken/presentation/utils/nested_keys_utils.dart';
|
|||||||
import 'package:rasadyar_chicken/presentation/widget/base_page/view.dart';
|
import 'package:rasadyar_chicken/presentation/widget/base_page/view.dart';
|
||||||
import 'package:rasadyar_chicken/presentation/widget/filter_bottom_sheet.dart';
|
import 'package:rasadyar_chicken/presentation/widget/filter_bottom_sheet.dart';
|
||||||
import 'package:rasadyar_chicken/presentation/widget/steward/inventory_widget.dart';
|
import 'package:rasadyar_chicken/presentation/widget/steward/inventory_widget.dart';
|
||||||
|
|
||||||
import 'package:rasadyar_chicken/presentation/widget/page_route.dart';
|
|
||||||
import 'package:rasadyar_core/core.dart';
|
import 'package:rasadyar_core/core.dart';
|
||||||
|
|
||||||
import 'logic.dart';
|
import 'logic.dart';
|
||||||
@@ -27,59 +25,69 @@ class SalesOutOfProvincePage extends GetView<SalesOutOfProvinceLogic> {
|
|||||||
onFilterTap: () {
|
onFilterTap: () {
|
||||||
Get.bottomSheet(filterBottomSheet());
|
Get.bottomSheet(filterBottomSheet());
|
||||||
},
|
},
|
||||||
widgets: [
|
child: Stack(
|
||||||
inventoryWidget(controller.rootLogic),
|
|
||||||
Expanded(
|
|
||||||
child: ObxValue((data) {
|
|
||||||
return RPaginatedListView(
|
|
||||||
onLoadMore: () async => controller.getOutProvinceSales(true),
|
|
||||||
onRefresh: () async {
|
|
||||||
controller.currentPage.value = 1;
|
|
||||||
await controller.getOutProvinceSales();
|
|
||||||
},
|
|
||||||
hasMore: data.value.data?.next != null,
|
|
||||||
listType: ListType.separated,
|
|
||||||
resource: data.value,
|
|
||||||
padding: EdgeInsets.fromLTRB(8, 8, 8, 80),
|
|
||||||
itemBuilder: (context, index) {
|
|
||||||
var item = data.value.data!.results![index];
|
|
||||||
return ObxValue((val) {
|
|
||||||
return ExpandableListItem2(
|
|
||||||
selected: val.contains(index),
|
|
||||||
onTap: () => controller.isExpandedList.toggle(index),
|
|
||||||
index: index,
|
|
||||||
child: itemListWidget(item),
|
|
||||||
secondChild: itemListExpandedWidget(item, index),
|
|
||||||
labelColor: AppColor.blueLight,
|
|
||||||
labelIcon: Assets.vec.timerSvg.path,
|
|
||||||
);
|
|
||||||
}, controller.isExpandedList);
|
|
||||||
},
|
|
||||||
itemCount: data.value.data?.results?.length ?? 0,
|
|
||||||
separatorBuilder: (context, index) => SizedBox(height: 8.h),
|
|
||||||
);
|
|
||||||
}, controller.salesList),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
floatingActionButton: Row(
|
|
||||||
children: [
|
children: [
|
||||||
RFab.add(
|
Positioned.fill(
|
||||||
onPressed: () {
|
child: Column(
|
||||||
Get.bottomSheet(addOrEditSaleBottomSheet(), isScrollControlled: true);
|
children: [
|
||||||
},
|
inventoryWidget(controller.rootLogic),
|
||||||
|
ObxValue((data) {
|
||||||
|
return RPaginatedListView(
|
||||||
|
onLoadMore: () async => controller.getOutProvinceSales(true),
|
||||||
|
onRefresh: () async {
|
||||||
|
controller.currentPage.value = 1;
|
||||||
|
await controller.getOutProvinceSales();
|
||||||
|
},
|
||||||
|
hasMore: data.value.data?.next != null,
|
||||||
|
listType: ListType.separated,
|
||||||
|
resource: data.value,
|
||||||
|
padding: EdgeInsets.fromLTRB(8, 8, 8, 80),
|
||||||
|
itemBuilder: (context, index) {
|
||||||
|
var item = data.value.data!.results![index];
|
||||||
|
return ObxValue((val) {
|
||||||
|
return ExpandableListItem2(
|
||||||
|
selected: val.contains(index),
|
||||||
|
onTap: () => controller.isExpandedList.toggle(index),
|
||||||
|
index: index,
|
||||||
|
child: itemListWidget(item),
|
||||||
|
secondChild: itemListExpandedWidget(item, index),
|
||||||
|
labelColor: AppColor.blueLight,
|
||||||
|
labelIcon: Assets.vec.timerSvg.path,
|
||||||
|
);
|
||||||
|
}, controller.isExpandedList);
|
||||||
|
},
|
||||||
|
itemCount: data.value.data?.results?.length ?? 0,
|
||||||
|
separatorBuilder: (context, index) => SizedBox(height: 8.h),
|
||||||
|
);
|
||||||
|
}, controller.salesList),
|
||||||
|
],
|
||||||
|
),
|
||||||
),
|
),
|
||||||
Spacer(),
|
Positioned(
|
||||||
RFab(
|
right: 5,
|
||||||
icon: Icon(CupertinoIcons.person_add_solid, color: Colors.white, size: 35.w),
|
left: 0,
|
||||||
backgroundColor: AppColor.blueNormal,
|
bottom: 95,
|
||||||
onPressed: () {
|
child: Row(
|
||||||
Get.toNamed(ChickenRoutes.salesOutOfProvinceBuyerSteward, id: 1);
|
children: [
|
||||||
},
|
RFab.add(
|
||||||
|
onPressed: () {
|
||||||
|
Get.bottomSheet(addOrEditSaleBottomSheet(), isScrollControlled: true);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
Spacer(),
|
||||||
|
RFab(
|
||||||
|
icon: Icon(CupertinoIcons.person_add_solid, color: Colors.white, size: 35.w),
|
||||||
|
backgroundColor: AppColor.blueNormal,
|
||||||
|
onPressed: () {
|
||||||
|
Get.toNamed(ChickenRoutes.salesOutOfProvinceBuyerSteward, id: stewardSecondKey);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
SizedBox(width: 25),
|
||||||
|
],
|
||||||
|
),
|
||||||
),
|
),
|
||||||
SizedBox(width: 25),
|
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
floatingActionButtonLocation: FloatingActionButtonLocation.startFloat,
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,11 +1,9 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:rasadyar_chicken/data/models/response/iran_province_city/iran_province_city_model.dart';
|
import 'package:rasadyar_chicken/data/models/response/iran_province_city/iran_province_city_model.dart';
|
||||||
import 'package:rasadyar_chicken/data/models/response/out_province_carcasses_buyer/out_province_carcasses_buyer.dart';
|
import 'package:rasadyar_chicken/data/models/response/out_province_carcasses_buyer/out_province_carcasses_buyer.dart';
|
||||||
|
import 'package:rasadyar_chicken/presentation/utils/nested_keys_utils.dart';
|
||||||
import 'package:rasadyar_chicken/presentation/widget/base_page/view.dart';
|
import 'package:rasadyar_chicken/presentation/widget/base_page/view.dart';
|
||||||
import 'package:rasadyar_chicken/presentation/widget/filter_bottom_sheet.dart';
|
import 'package:rasadyar_chicken/presentation/widget/filter_bottom_sheet.dart';
|
||||||
|
|
||||||
|
|
||||||
import 'package:rasadyar_chicken/presentation/widget/page_route.dart';
|
|
||||||
import 'package:rasadyar_core/core.dart';
|
import 'package:rasadyar_core/core.dart';
|
||||||
|
|
||||||
import 'logic.dart';
|
import 'logic.dart';
|
||||||
@@ -17,52 +15,56 @@ class SalesOutOfProvinceBuyersPage extends GetView<SalesOutOfProvinceBuyersLogic
|
|||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return ChickenBasePage(
|
return ChickenBasePage(
|
||||||
routes: controller.routesName,
|
routes: controller.routesName,
|
||||||
backId: 1,
|
backId: stewardSecondKey,
|
||||||
onSearchChanged: (data) => controller.setSearchValue(data),
|
onSearchChanged: (data) => controller.setSearchValue(data),
|
||||||
filteringWidget: filterBottomSheet(),
|
filteringWidget: filterBottomSheet(),
|
||||||
widgets: [
|
child: Stack(
|
||||||
Expanded(
|
children: [
|
||||||
child: ObxValue((data) {
|
Positioned.fill(
|
||||||
return RPaginatedListView(
|
child: ObxValue((data) {
|
||||||
onLoadMore: () async => controller.getOutProvinceCarcassesBuyer(true),
|
return RPaginatedListView(
|
||||||
onRefresh: () async {
|
onLoadMore: () async => controller.getOutProvinceCarcassesBuyer(true),
|
||||||
controller.currentPage.value = 1;
|
onRefresh: () async {
|
||||||
await controller.getOutProvinceCarcassesBuyer();
|
controller.currentPage.value = 1;
|
||||||
|
await controller.getOutProvinceCarcassesBuyer();
|
||||||
|
},
|
||||||
|
hasMore: data.value.data?.next != null,
|
||||||
|
listType: ListType.separated,
|
||||||
|
resource: data.value,
|
||||||
|
padding: EdgeInsets.fromLTRB(8, 8, 8, 80),
|
||||||
|
itemBuilder: (context, index) {
|
||||||
|
var item = data.value.data!.results![index];
|
||||||
|
return ObxValue((val) {
|
||||||
|
return ExpandableListItem2(
|
||||||
|
selected: val.contains(index),
|
||||||
|
onTap: () => controller.isExpandedList.toggle(index),
|
||||||
|
index: index,
|
||||||
|
child: itemListWidget(item),
|
||||||
|
secondChild: itemListExpandedWidget(item),
|
||||||
|
labelColor: AppColor.blueLight,
|
||||||
|
labelIcon: Assets.vec.userRaduisSvg.path,
|
||||||
|
);
|
||||||
|
}, controller.isExpandedList);
|
||||||
|
},
|
||||||
|
itemCount: data.value.data?.results?.length ?? 0,
|
||||||
|
separatorBuilder: (context, index) => SizedBox(height: 8.h),
|
||||||
|
);
|
||||||
|
}, controller.buyerList),
|
||||||
|
),
|
||||||
|
Positioned(
|
||||||
|
bottom: 100,
|
||||||
|
child: RFab.add(
|
||||||
|
onPressed: () {
|
||||||
|
Get.bottomSheet(
|
||||||
|
addOrEditBuyerBottomSheet(),
|
||||||
|
isScrollControlled: true,
|
||||||
|
ignoreSafeArea: false,
|
||||||
|
).whenComplete(() => controller.resetSubmitForm());
|
||||||
},
|
},
|
||||||
hasMore: data.value.data?.next != null,
|
),
|
||||||
listType: ListType.separated,
|
),
|
||||||
resource: data.value,
|
],
|
||||||
padding: EdgeInsets.fromLTRB(8, 8, 8, 80),
|
|
||||||
itemBuilder: (context, index) {
|
|
||||||
var item = data.value.data!.results![index];
|
|
||||||
return ObxValue((val) {
|
|
||||||
return ExpandableListItem2(
|
|
||||||
selected: val.contains(index),
|
|
||||||
onTap: () => controller.isExpandedList.toggle(index),
|
|
||||||
index: index,
|
|
||||||
child: itemListWidget(item),
|
|
||||||
secondChild: itemListExpandedWidget(item),
|
|
||||||
labelColor: AppColor.blueLight,
|
|
||||||
labelIcon: Assets.vec.userRaduisSvg.path,
|
|
||||||
);
|
|
||||||
}, controller.isExpandedList);
|
|
||||||
},
|
|
||||||
itemCount: data.value.data?.results?.length ?? 0,
|
|
||||||
separatorBuilder: (context, index) => SizedBox(height: 8.h),
|
|
||||||
);
|
|
||||||
}, controller.buyerList),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
floatingActionButton: RFab.add(
|
|
||||||
onPressed: () {
|
|
||||||
Get.bottomSheet(
|
|
||||||
addOrEditBuyerBottomSheet(),
|
|
||||||
isScrollControlled: true,
|
|
||||||
ignoreSafeArea: false,
|
|
||||||
).whenComplete(() => controller.resetSubmitForm());
|
|
||||||
},
|
|
||||||
),
|
),
|
||||||
floatingActionButtonLocation: FloatingActionButtonLocation.startFloat,
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -206,7 +208,7 @@ class SalesOutOfProvinceBuyersPage extends GetView<SalesOutOfProvinceBuyersLogic
|
|||||||
}, controller.cites);
|
}, controller.cites);
|
||||||
}
|
}
|
||||||
|
|
||||||
itemListWidget(OutProvinceCarcassesBuyer item) {
|
Padding itemListWidget(OutProvinceCarcassesBuyer item) {
|
||||||
return Padding(
|
return Padding(
|
||||||
padding: const EdgeInsets.only(right: 8),
|
padding: const EdgeInsets.only(right: 8),
|
||||||
child: Row(
|
child: Row(
|
||||||
|
|||||||
@@ -21,9 +21,9 @@ class SegmentationPage extends GetView<SegmentationLogic> {
|
|||||||
Get.bottomSheet(filterBottomSheet());
|
Get.bottomSheet(filterBottomSheet());
|
||||||
},
|
},
|
||||||
hasBack: false,
|
hasBack: false,
|
||||||
widgets: [
|
child: Stack(
|
||||||
Expanded(
|
children: [
|
||||||
child: ObxValue((data) {
|
Positioned.fill(child: ObxValue((data) {
|
||||||
return RPaginatedListView(
|
return RPaginatedListView(
|
||||||
onLoadMore: () async => controller.getAllSegmentation(true),
|
onLoadMore: () async => controller.getAllSegmentation(true),
|
||||||
onRefresh: () async {
|
onRefresh: () async {
|
||||||
@@ -52,21 +52,24 @@ class SegmentationPage extends GetView<SegmentationLogic> {
|
|||||||
itemCount: data.value.data?.results?.length ?? 0,
|
itemCount: data.value.data?.results?.length ?? 0,
|
||||||
separatorBuilder: (context, index) => SizedBox(height: 8.h),
|
separatorBuilder: (context, index) => SizedBox(height: 8.h),
|
||||||
);
|
);
|
||||||
}, controller.segmentationList),
|
}, controller.segmentationList)),
|
||||||
),
|
Positioned(
|
||||||
],
|
right: 10,
|
||||||
floatingActionButtonLocation: FloatingActionButtonLocation.startFloat,
|
bottom: 90.h,
|
||||||
floatingActionButton: RFab.add(
|
child: RFab.add(
|
||||||
onPressed: () {
|
onPressed: () {
|
||||||
Get.bottomSheet(
|
Get.bottomSheet(
|
||||||
addOrEditBottomSheet(),
|
addOrEditBottomSheet(),
|
||||||
isScrollControlled: true,
|
isScrollControlled: true,
|
||||||
ignoreSafeArea: false,
|
ignoreSafeArea: false,
|
||||||
).whenComplete(() {
|
).whenComplete(() {
|
||||||
controller.clearForm();
|
controller.clearForm();
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
))
|
||||||
|
],
|
||||||
),
|
),
|
||||||
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user