Skip to content

Latest commit

 

History

History
159 lines (119 loc) · 3.66 KB

step-5.md

File metadata and controls

159 lines (119 loc) · 3.66 KB

Step 5: Use a class as a model

In this step, you define and use a model.

Keywords: class

Update imports

First, add the following import to piratebadge.dart:

import 'dart:math' show Random;

The Editor will complain about an unused import. Don't worry about that, we'll be using Random later in this step.

Create a PirateName class

Copy and paste the following code in piratebadge.dart:

class PirateName {
  String firstName, appellation;
  PirateName([this.firstName = '', this.appellation = '']);
}

This is the model for this app.

Update the controller

Add the following const lists inside BadgesController:

class BadgesController {
  // ...
  static const List names = const [
    'Anne', 'Mary', 'Jack', 'Morgan', 'Roger',
    'Bill', 'Ragnar', 'Ed', 'John', 'Jane' ];

  static const List appellations = const [
    'Black','Damned', 'Jackal', 'Red', 'Stalwart', 'Axe',
    'Young', 'Old', 'Angry', 'Brave', 'Crazy', 'Noble'];
  // ...
}

You'll write code later in this step to generate pirate names by obtaining random values from each list.

Add the following utility function that helps pick random names and appellations:

class BadgesController {
  // ...
  String _oneRandom(List<String> list) {
    return list[new Random().nextInt(list.length)];
  }
  // ...
}

Inside BadgesController, create a new model instance:

class BadgesController {
  // ...
  PirateName pn = new PirateName();
  // ...
}

Now add this pirateName getter to the controller.

class BadgesController {
  // ...
  String get pirateName => pn.firstName.isEmpty ? '' :
  '${pn.firstName} the ${pn.appellation}';
  // ...
}

This getter returns the complete name of the pirate. You will soon add code to pass the string returned by this getter as an argument to the component that we created in step 4.

BadgesController contains a name field:

class BadgesController {
  // ...
  String name = '';
  // ...
}

Replace that line with the following code:

class BadgesController {
  // ...
  String _name = '';

  get name => _name;

  set name(newName) {
    _name = newName;
    pn..firstName = name
      ..appellation = _oneRandom(appellations);
  }
  // ...
}

We've added a private _name field that we'll later bind into the UI, and we've defined a getter and a setter to get and set its value. The setter also sets the firstName and appelation fields of the PirateBadge object. Every time the value of _name changes, the change is reflected in pn, the PirateName object.

Update generateName(). So far, this method has produced a static name. Now you'll add code to generate a name based on randomly picked values from the names and appellations lists. Replace the version of generateName() with the following code:

generateName() {
  var randomName = _oneRandom(names);
  name = randomName;
}

Update data bindings

Remember the pirateName controller getter you defined a short while ago? Now, in piratebadge.html, update the data binding in the badge tag to use that getter:

<badge name="{{ctrl.pirateName}}"
    style='float: left; margin-left: 20px;'></badge>

Now run your code. You should be able to enter text into the input box and see a pirate name in the pirate badge. You should also be able to generate a random pirate name by clicking on the button.

Problems?

Check your code against the files in 5-classbadge.