A New Breed of MUSH Server

Modifying the Character Template

Now that we have our data being sent from the game to the website, we can actually show it on the web profile.

The actual profile template is located in ares-webportal/app/templates/char.hbs, but it leverages Ember components for the various pieces of the profile. This makes the code a bit cleaner. For example, all of the demographics information is located in a component named profile-demographics:

   <div class="row profile-wrap">
    {{profile-demographics char=model.char}}

You can find the components under ares-webportal/app/templates/components/<name>.hbs.

For this example, we’re going to put goals into the “System” section near character sheet and RP hooks. That file lives here: ares-webportal/app/templates/components/profile-system.hbs.

First we’ll need to add a new tab definition near the top. For example:

<li><a data-toggle="tab" href="#systemhooks">RP Hooks</a></li>
<li><a data-toggle="tab" href="#systemgoals">Goals</a></li> 
<li><a data-toggle="tab" href="#systembg">Background</a></li> 

Then we can add the goals themselves down below as a tab-pane div. For example:

    <div id="systemhooks" class="tab-pane fade">
        {{{ansi-format text=char.rp_hooks}}}
    <div id="systemgoals" class="tab-pane fade">
        {{{ansi-format text=char.goals}}}
    <div id="systembg" class="tab-pane fade">
        {{{ansi-format text=char.background}}}

Here we’re using the ansi-format helper because the goals can contain fancy formatting. For a raw text field we could have just used char.goals by itself.

Re-deploy the website using the website/deploy command. This will take a few minutes. Then you can test it!

This article is part of the Modifying the Web Portal tutorial.