View Source Ecspanse.Template.Component behaviour (ECSpanse v0.7.2)
A template component is a generic way of defining the structure for related components. They share the same state fields and tags.
The template component, coupled with tags allow a flexible way to manage collections of related components.
See Ecspanse.Component for more details.
The template component guarantees that the component that uses it will have certain fields in its state and certain tags. The component itself can define additional fields or tags, specific to its implementation. It can also override the initial values of the template fields.
The framework embeds some predefined component templates:
- Ecspanse.Template.Component.Timer- a component template that is used to create timer components.
Options
See Ecspanse.Component for the list of options.
Examples
    defmodule Demo.Componenets.Resource do
      use Ecspanse.Template.Component, state: [amount: 0], tags: [:resource]
    end
    defmodule Demo.Componenets.Gold do
      use Demo.Components.Resource, state: [amount: 5, exchange_rate: 2], tags: [:available]
    endSummary
Callbacks
Optional callback to validate the template and component state fields.
Callbacks
Optional callback to validate the template and component state fields.
It runs only at compile time, and it takes the list of fields as the only argument and returns :ok or an error tuple.
Info
When an error tuple is returned, it raises an exception with the provided error message.
For runtime component state validation see Ecspanse.Component.validate/1.
Examples
  defmodule Demo.Components.Resources do
    use Ecspanse.Template.Component, state: [amount: 0]
    def validate(state_fields) do
      amount = Keyword.get(state_fields, :amount, 0)
      if is_integer(amount) and amount >= 0 do
        :ok
      else
        {:error, "Invalid amount value"}
      end
    end
  end