mirror of
https://github.com/inventree/inventree-app.git
synced 2025-04-28 05:26:47 +00:00
* Catch paginator bug if widget is disposed before request returns * Refactoring paginated query widget - Add option to enable / disable search filters * Major refactor of paginated search widget - Learned something new.. a state can access widget.<attribute> - THIS CHANGES EVERTHING * Preferences: Add code for tri-state values - Also improve unit testing for preferences code * Allow boolean form fields to be optionally tristate * paginator: Allow custom boolean filters * Remove outdated filtering preferences * Refactor filter options - Allow specification of more detailed options * Add custom filters for "part" list * filter tweaks * Remove legacy "SublocationList" widget * Add filtering option for locationlist * Updates for stock location widget * Refactor category display widget * More widget refactoring * Update main search widget * Fix unit tests * Improve filtering on BOM display page
81 lines
2.1 KiB
Dart
81 lines
2.1 KiB
Dart
|
|
import "package:flutter/material.dart";
|
|
|
|
import "package:inventree/api.dart";
|
|
import "package:inventree/inventree/company.dart";
|
|
import "package:inventree/inventree/model.dart";
|
|
import "package:inventree/widget/paginator.dart";
|
|
import "package:inventree/widget/refreshable_state.dart";
|
|
import "package:inventree/widget/company_detail.dart";
|
|
|
|
|
|
class CompanyListWidget extends StatefulWidget {
|
|
|
|
const CompanyListWidget(this.title, this.filters, {Key? key}) : super(key: key);
|
|
|
|
final String title;
|
|
|
|
final Map<String, String> filters;
|
|
|
|
@override
|
|
_CompanyListWidgetState createState() => _CompanyListWidgetState(title, filters);
|
|
}
|
|
|
|
|
|
class _CompanyListWidgetState extends RefreshableState<CompanyListWidget> {
|
|
|
|
_CompanyListWidgetState(this.title, this.filters);
|
|
|
|
final String title;
|
|
|
|
final Map<String, String> filters;
|
|
|
|
@override
|
|
String getAppBarTitle(BuildContext context) => title;
|
|
|
|
@override
|
|
Widget getBody(BuildContext context) {
|
|
return PaginatedCompanyList(filters, true);
|
|
}
|
|
|
|
}
|
|
|
|
class PaginatedCompanyList extends PaginatedSearchWidget {
|
|
|
|
const PaginatedCompanyList(Map<String, String> filters, bool showSearch) : super(filters: filters, showSearch: showSearch);
|
|
|
|
@override
|
|
_CompanyListState createState() => _CompanyListState();
|
|
}
|
|
|
|
class _CompanyListState extends PaginatedSearchState<PaginatedCompanyList> {
|
|
|
|
_CompanyListState() : super();
|
|
|
|
@override
|
|
Future<InvenTreePageResponse?> requestPage(int limit, int offset, Map<String, String> params) async {
|
|
|
|
final page = await InvenTreeCompany().listPaginated(limit, offset, filters: params);
|
|
|
|
return page;
|
|
}
|
|
|
|
@override
|
|
Widget buildItem(BuildContext context, InvenTreeModel model) {
|
|
|
|
InvenTreeCompany company = model as InvenTreeCompany;
|
|
|
|
return ListTile(
|
|
title: Text(company.name),
|
|
subtitle: Text(company.description),
|
|
leading: InvenTreeAPI().getImage(
|
|
company.image,
|
|
width: 40,
|
|
height: 40
|
|
),
|
|
onTap: () async {
|
|
Navigator.push(context, MaterialPageRoute(builder: (context) => CompanyDetailWidget(company)));
|
|
},
|
|
);
|
|
}
|
|
} |