mirror of
https://github.com/inventree/inventree-app.git
synced 2025-04-27 21:16:48 +00:00
* Add new models for SalesOrder - Create generic Order and OrderLine models with common functionality * Refactor - Move some widgets around - Cleanup directory structure * Add link to home screen and nav drawer * Add SalesOrder list widget * Linting fixes * Fix string * Refactor PurchaseOrderDetailWidget * Tweaks to existing code * linting * Fixes for drawer widget * Add "detail" page for SalesOrder * Add more tiles to SalesOrder detail * Allow editing of salesorder * add list filters for sales orders * Display list of line items * Customer updates - Display customer icon on home screen - Fetch sales orders for customer detail page * Cleanup company detail view * Create new sales order from list * Stricter typing for formFields method * Create new PurchaseOrder and SalesOrder from company deatil * Status code updates - Add function for name comparison - Remove hard-coded values * Update view permission checks for home widget * Add ability to manually add SalesOrderLineItem * Add nice progress bar widgets * Display detail view for sales order line item * edit SalesOrderLineItem * Fix unused import * Hide "shipped items" tab - Will be added in a future update
95 lines
2.5 KiB
Dart
95 lines
2.5 KiB
Dart
import "package:flutter/material.dart";
|
|
|
|
import "package:inventree/api.dart";
|
|
import "package:inventree/l10.dart";
|
|
import "package:inventree/inventree/stock.dart";
|
|
import "package:inventree/inventree/model.dart";
|
|
|
|
import "package:inventree/widget/paginator.dart";
|
|
import "package:inventree/widget/refreshable_state.dart";
|
|
|
|
class StockItemHistoryWidget extends StatefulWidget {
|
|
const StockItemHistoryWidget(this.item, {Key? key}) : super(key: key);
|
|
|
|
final InvenTreeStockItem item;
|
|
|
|
@override
|
|
_StockItemHistoryDisplayState createState() => _StockItemHistoryDisplayState(item);
|
|
}
|
|
|
|
class _StockItemHistoryDisplayState extends RefreshableState<StockItemHistoryWidget> {
|
|
_StockItemHistoryDisplayState(this.item);
|
|
|
|
final InvenTreeStockItem item;
|
|
|
|
@override
|
|
String getAppBarTitle() => L10().stockItemHistory;
|
|
|
|
@override
|
|
List<Widget> appBarActions(BuildContext context) => [];
|
|
|
|
@override
|
|
Widget getBody(BuildContext context) {
|
|
Map<String, String> filters = {
|
|
"item": widget.item.pk.toString(),
|
|
};
|
|
|
|
return PaginatedStockHistoryList(filters);
|
|
}
|
|
|
|
}
|
|
|
|
/*
|
|
* Widget which displays a paginated stock history list
|
|
*/
|
|
class PaginatedStockHistoryList extends PaginatedSearchWidget {
|
|
const PaginatedStockHistoryList(Map<String, String> filters) : super(filters: filters);
|
|
|
|
@override
|
|
String get searchTitle => L10().stockItemHistory;
|
|
|
|
@override
|
|
_PaginatedStockHistoryState createState() => _PaginatedStockHistoryState();
|
|
}
|
|
|
|
/*
|
|
* State class for the paginated stock history list
|
|
*/
|
|
class _PaginatedStockHistoryState
|
|
extends PaginatedSearchState<PaginatedStockHistoryList> {
|
|
_PaginatedStockHistoryState() : super();
|
|
|
|
@override
|
|
String get prefix => "stock_history";
|
|
|
|
@override
|
|
Map<String, String> get orderingOptions => {};
|
|
|
|
@override
|
|
Map<String, Map<String, dynamic>> get filterOptions => {
|
|
// TODO: Add filter options
|
|
};
|
|
|
|
@override
|
|
Future<InvenTreePageResponse?> requestPage(
|
|
int limit, int offset, Map<String, String> params) async {
|
|
await InvenTreeAPI().StockHistoryStatus.load();
|
|
|
|
final page = await InvenTreeStockItemHistory().listPaginated(limit, offset, filters: params);
|
|
|
|
return page;
|
|
}
|
|
|
|
@override
|
|
Widget buildItem(BuildContext context, InvenTreeModel model) {
|
|
InvenTreeStockItemHistory entry = model as InvenTreeStockItemHistory;
|
|
|
|
return ListTile(
|
|
leading: Text(entry.dateString),
|
|
trailing: entry.userString.isNotEmpty ? Text(entry.userString) : null,
|
|
title: Text(entry.label),
|
|
subtitle: entry.notes.isNotEmpty ? Text(entry.notes) : null,
|
|
);
|
|
}
|
|
}
|