mirror of
https://github.com/inventree/inventree-app.git
synced 2025-04-27 21:16:48 +00:00
* Display stock quantity more prominently * Cleanup search widget * Update for stock_detail widget * More tweaks * Change bottom bar icon * Display boolean parameters appropriately * Adds ability to edit part parameters * Bump icon size a bit * Improvements to filter options - Allow filtering by "option" type - To start with, filter stock by status code * Remove debug message * Remove getTriState method - No longer needed - Remove associated unit tests * Adjust filters based on server API version * Muted colors
149 lines
3.6 KiB
Dart
149 lines
3.6 KiB
Dart
import "package:flutter/material.dart";
|
|
import "package:font_awesome_flutter/font_awesome_flutter.dart";
|
|
|
|
import "package:inventree/api.dart";
|
|
import "package:inventree/l10.dart";
|
|
|
|
import "package:inventree/inventree/model.dart";
|
|
import "package:inventree/inventree/part.dart";
|
|
|
|
import "package:inventree/widget/paginator.dart";
|
|
import "package:inventree/widget/part_detail.dart";
|
|
import "package:inventree/widget/refreshable_state.dart";
|
|
|
|
|
|
class PartList extends StatefulWidget {
|
|
|
|
const PartList(this.filters, {this.title = ""});
|
|
|
|
final String title;
|
|
|
|
final Map<String, String> filters;
|
|
|
|
@override
|
|
_PartListState createState() => _PartListState(filters, title);
|
|
}
|
|
|
|
|
|
class _PartListState extends RefreshableState<PartList> {
|
|
|
|
_PartListState(this.filters, this.title);
|
|
|
|
final String title;
|
|
|
|
final Map<String, String> filters;
|
|
|
|
bool showFilterOptions = false;
|
|
|
|
@override
|
|
String getAppBarTitle() => title.isNotEmpty ? title : L10().parts;
|
|
|
|
@override
|
|
List<Widget> appBarActions(BuildContext context) => [
|
|
IconButton(
|
|
icon: FaIcon(FontAwesomeIcons.filter),
|
|
onPressed: () async {
|
|
setState(() {
|
|
showFilterOptions = !showFilterOptions;
|
|
});
|
|
},
|
|
)
|
|
];
|
|
|
|
@override
|
|
Widget getBody(BuildContext context) {
|
|
return PaginatedPartList(filters, showFilterOptions);
|
|
}
|
|
|
|
}
|
|
|
|
|
|
class PaginatedPartList extends PaginatedSearchWidget {
|
|
|
|
const PaginatedPartList(Map<String, String> filters, bool showSearch) : super(filters: filters, showSearch: showSearch);
|
|
|
|
@override
|
|
_PaginatedPartListState createState() => _PaginatedPartListState();
|
|
}
|
|
|
|
|
|
class _PaginatedPartListState extends PaginatedSearchState<PaginatedPartList> {
|
|
|
|
_PaginatedPartListState() : super();
|
|
|
|
@override
|
|
String get prefix => "part_";
|
|
|
|
@override
|
|
Map<String, String> get orderingOptions => {
|
|
"name": L10().name,
|
|
"in_stock": L10().stock,
|
|
"IPN": L10().internalPartNumber,
|
|
};
|
|
|
|
@override
|
|
Map<String, Map<String, dynamic>> get filterOptions => {
|
|
"cascade": {
|
|
"default": true,
|
|
"label": L10().includeSubcategories,
|
|
"help_text": L10().includeSubcategoriesDetail,
|
|
},
|
|
"active": {
|
|
"label": L10().filterActive,
|
|
"help_text": L10().filterActiveDetail,
|
|
"tristate": true,
|
|
},
|
|
"assembly": {
|
|
"label": L10().filterAssembly,
|
|
"help_text": L10().filterAssemblyDetail
|
|
},
|
|
"component": {
|
|
"label": L10().filterComponent,
|
|
"help_text": L10().filterComponentDetail,
|
|
},
|
|
"is_template": {
|
|
"label": L10().filterTemplate,
|
|
"help_text": L10().filterTemplateDetail
|
|
},
|
|
"trackable": {
|
|
"label": L10().filterTrackable,
|
|
"help_text": L10().filterTrackableDetail,
|
|
},
|
|
"virtual": {
|
|
"label": L10().filterVirtual,
|
|
"help_text": L10().filterVirtualDetail,
|
|
},
|
|
"has_stock": {
|
|
"label": L10().filterInStock,
|
|
"help_text": L10().filterInStockDetail,
|
|
}
|
|
};
|
|
|
|
@override
|
|
Future<InvenTreePageResponse?> requestPage(int limit, int offset, Map<String, String> params) async {
|
|
final page = await InvenTreePart().listPaginated(limit, offset, filters: params);
|
|
return page;
|
|
}
|
|
|
|
@override
|
|
Widget buildItem(BuildContext context, InvenTreeModel model) {
|
|
|
|
InvenTreePart part = model as InvenTreePart;
|
|
|
|
return ListTile(
|
|
title: Text(part.fullname),
|
|
subtitle: Text(part.description),
|
|
trailing: Text(
|
|
part.stockString(),
|
|
style: TextStyle(
|
|
fontSize: 16,
|
|
fontWeight: FontWeight.bold
|
|
)
|
|
),
|
|
leading: InvenTreeAPI().getThumbnail(part.thumbnail),
|
|
onTap: () {
|
|
Navigator.push(context, MaterialPageRoute(builder: (context) => PartDetailWidget(part)));
|
|
},
|
|
);
|
|
}
|
|
} |