mirror of https://github.com/flutter/samples.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
64 lines
1.7 KiB
64 lines
1.7 KiB
// Copyright 2019 The Flutter team. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
/// A proxy of the catalog of items the user can buy.
|
|
///
|
|
/// In a real app, this might be backed by a backend and cached on device.
|
|
/// In this sample app, the catalog is procedurally generated and infinite.
|
|
///
|
|
/// For simplicity, the catalog is expected to be immutable (no products are
|
|
/// expected to be added, removed or changed during the execution of the app).
|
|
class CatalogModel {
|
|
static const _itemNames = [
|
|
'Code Smell',
|
|
'Control Flow',
|
|
'Interpreter',
|
|
'Recursion',
|
|
'Sprint',
|
|
'Heisenbug',
|
|
'Spaghetti',
|
|
'Hydra Code',
|
|
'Off-By-One',
|
|
'Scope',
|
|
'Callback',
|
|
'Closure',
|
|
'Automata',
|
|
'Bit Shift',
|
|
'Currying',
|
|
];
|
|
|
|
/// Get item by [id].
|
|
///
|
|
/// In this sample, the catalog is infinite, looping over [_itemNames].
|
|
Item getById(int id) => Item(id, _itemNames[id % _itemNames.length]);
|
|
|
|
/// Get item by its position in the catalog.
|
|
Item getByPosition(int position) {
|
|
// In this simplified case, an item's position in the catalog
|
|
// is also its id.
|
|
return getById(position);
|
|
}
|
|
}
|
|
|
|
@immutable
|
|
class Item {
|
|
final int id;
|
|
final String name;
|
|
final Color color;
|
|
final int price = 42;
|
|
|
|
Item(this.id, this.name)
|
|
// To make the sample app look nicer, each item is given one of the
|
|
// Material Design primary colors.
|
|
: color = Colors.primaries[id % Colors.primaries.length];
|
|
|
|
@override
|
|
int get hashCode => id;
|
|
|
|
@override
|
|
bool operator ==(Object other) => other is Item && other.id == id;
|
|
}
|