Compare commits

...

7 Commits

6 changed files with 299 additions and 126 deletions

View File

@ -87,7 +87,7 @@ import * as api from "../api";
console.log("got a response back", resp); console.log("got a response back", resp);
} }
const inputs = document.querySelectorAll("#basicInfo input"); const inputs = document.querySelectorAll("#basics input");
inputs.forEach(input => { inputs.forEach(input => {
console.log('got an input', input); console.log('got an input', input);

View File

@ -2,6 +2,7 @@
<html> <html>
<head> <head>
<meta charset="utf-8" /> <meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>Tera Demo</title> <title>Tera Demo</title>
</head> </head>
<body> <body>

View File

@ -7,28 +7,57 @@
font-family: Liberation Sans, Arial; font-family: Liberation Sans, Arial;
} }
#attributes { #basics .flex-container {
padding: 4px; display: flex;
border-collapse: collapse; flex-flow: row wrap;
}
.basics-row {
display: block;
}
.basics-entry {
display: flex;
border: 1px solid gray;
margin-left: -1px;
margin-top: -1px;
}
.basics-entry label {
display: inline;
width: 5em;
text-align: right;
vertical-align: text-bottom;
padding: 8px;
margin: 0;
}
.basics-entry input {
display: inline;
padding: 8px;
border: none;
background-color: lightgray;
margin: 0;
}
#attributes .flex-container {
display: flex;
flex-flow: row wrap;
} }
#attributes .attributes-section { #attributes .attributes-section {
border: 1px solid gray; border: 1px solid gray;
border-collapse: collapse; margin-left: -1px;
display: table-cell; margin-top: -1px;
} }
.attribute { .attribute {
margin: 0;
padding: 0;
display: flex; display: flex;
} }
.attribute label { .attribute label {
display: inline-block;
float: left;
clear: left;
width: 10em; width: 10em;
display: inline;
text-align: right; text-align: right;
vertical-align: text-bottom; vertical-align: text-bottom;
padding: 8px; padding: 8px;
@ -37,8 +66,7 @@
.attribute input { .attribute input {
max-width: 4em; max-width: 4em;
display: inline-block; display: inline;
float: left;
padding: 8px; padding: 8px;
border: none; border: none;
background-color: lightgray; background-color: lightgray;
@ -46,26 +74,25 @@
} }
#skills { #skills {
padding: 4px;
border-collapse: collapse; }
#skills .flex-container {
display: flex;
flex-flow: row wrap;
} }
#skills .skills-section { #skills .skills-section {
border: 1px solid gray; border: 1px solid gray;
border-collapse: collapse; margin-top: -1px;
display: table-cell; margin-left: -1px;
} }
.skill { .skill {
margin: 0;
padding: 0;
display: flex; display: flex;
} }
.skill label { .skill label {
display: inline-block;
float: left;
clear: left;
width: 10em; width: 10em;
text-align: right; text-align: right;
vertical-align: text-bottom; vertical-align: text-bottom;
@ -75,8 +102,6 @@
.skill input { .skill input {
max-width: 4em; max-width: 4em;
display: inline-block;
float: left;
padding: 8px; padding: 8px;
border: none; border: none;
background-color: lightgray; background-color: lightgray;
@ -140,73 +165,93 @@
{# Webpack Templating for API script #} {# Webpack Templating for API script #}
<%= htmlWebpackPlugin.tags.bodyTags %> <%= htmlWebpackPlugin.tags.bodyTags %>
<h1>Core Sheet</h1>
<div> <div>
<div id="basicInfo"> <div id="basics">
<h1> <h1>
<label for="characterName">Name:</label> <label for="characterName">Name</label>
<input type="text" id="characterName" name="characterName" value="{{name}}" /> <input type="text" id="characterName" name="characterName" value="{{name}}" />
</h1> </h1>
<div class="links">
<a href="/">Home</a> |
<a href="/characters/{{username}}/{{id}}">Save Changes</a> |
<a href="/characters/{{username}}/{{id}}/delete">Delete Character</a>
</div>
<h2>Basics</h2>
<div>System: {{data_type}}</div> <div>System: {{data_type}}</div>
<div> <div class="flex-container">
<label for="gender">Gender:</label> <div class="basics-row">
<input type="text" id="gender" name="gender" value="{{sheet.gender}}" /> <div class="basics-entry">
</div> <label for="gender">Gender:</label>
<input type="text" id="gender" name="gender" value="{{sheet.gender}}" />
</div>
<div> <div class="basics-entry">
<label for="age">Age:</label> <label for="age">Age:</label>
<input type="number" id="age" name="age" min="0" value="{{sheet.age}}" /> <input type="number" id="age" name="age" min="0" value="{{sheet.age}}" />
</div> </div>
</div>
<div> <div class="basics-row">
<label for="concept">Concept:</label> <div class="basics-entry">
<input type="text" id="concept" name="concept" value="{{sheet.concept}}" /> <label for="concept">Concept:</label>
</div> <input type="text" id="concept" name="concept" value="{{sheet.concept}}" />
</div>
<div> <div class="basics-entry">
<label for="chronicle">Chronicle:</label> <label for="chronicle">Chronicle:</label>
<input type="text" id="chronicle" name="chronicle" value="{{sheet.chronicle}}" /> <input type="text" id="chronicle" name="chronicle" value="{{sheet.chronicle}}" />
</div>
</div>
</div> </div>
</div> </div>
<div id="attributes"> <div id="attributes">
<div class="attributes-section" id="mentalAttributes"> <h2>Attributes</h2>
{{ macros::attribute(name="Intelligence", value=sheet.intelligence) }} <div class="flex-container">
{{ macros::attribute(name="Wits", value=sheet.wits) }} <div class="attributes-section" id="mentalAttributes">
{{ macros::attribute(name="Resolve", value=sheet.resolve) }} {{ macros::attribute(name="Intelligence", value=sheet.intelligence) }}
</div> {{ macros::attribute(name="Wits", value=sheet.wits) }}
{{ macros::attribute(name="Resolve", value=sheet.resolve) }}
</div>
<div class="attributes-section" id="physicalAttributes"> <div class="attributes-section" id="physicalAttributes">
{{ macros::attribute(name="Strength", value=sheet.strength) }} {{ macros::attribute(name="Strength", value=sheet.strength) }}
{{ macros::attribute(name="Dexterity", value=sheet.dexterity) }} {{ macros::attribute(name="Dexterity", value=sheet.dexterity) }}
{{ macros::attribute(name="Stamina", value=sheet.stamina) }} {{ macros::attribute(name="Stamina", value=sheet.stamina) }}
</div> </div>
<div class="attributes-section" id="socicalAttributes"> <div class="attributes-section" id="socicalAttributes">
{{ macros::attribute(name="Presence", value=sheet.presence) }} {{ macros::attribute(name="Presence", value=sheet.presence) }}
{{ macros::attribute(name="Manipulation", value=sheet.manipulation) }} {{ macros::attribute(name="Manipulation", value=sheet.manipulation) }}
{{ macros::attribute(name="Composure", value=sheet.composure) }} {{ macros::attribute(name="Composure", value=sheet.composure) }}
</div>
</div> </div>
</div> </div>
<div id="skills"> <div id="skills">
<div class="skills-section" id="mentalSkills"> <h2>Skills</h2>
{% for skill_name, skill in sheet.mentalSkills %}
{{ macros::skill(name=skill_name, value=skill.dots) }}
{% endfor %}
</div>
<div class="skills-section" id="physicalSkills"> <div class="flex-container">
{% for skill_name, skill in sheet.physicalSkills %} <div class="skills-section" id="mentalSkills">
{{ macros::skill(name=skill_name, value=skill.dots) }} {% for skill_name, skill in sheet.mentalSkills %}
{% endfor %} {{ macros::skill(name=skill_name, value=skill.dots) }}
</div> {% endfor %}
</div>
<div class="skills-section" id="socialSkills"> <div class="skills-section" id="physicalSkills">
{% for skill_name, skill in sheet.socialSkills %} {% for skill_name, skill in sheet.physicalSkills %}
{{ macros::skill(name=skill_name, value=skill.dots) }} {{ macros::skill(name=skill_name, value=skill.dots) }}
{% endfor %} {% endfor %}
</div>
<div class="skills-section" id="socialSkills">
{% for skill_name, skill in sheet.socialSkills %}
{{ macros::skill(name=skill_name, value=skill.dots) }}
{% endfor %}
</div>
</div> </div>
</div> </div>

View File

@ -8,40 +8,67 @@
font-family: Liberation Sans, Arial; font-family: Liberation Sans, Arial;
} }
#attributes { #basics .flex-container {
padding: 4px;
border-collapse: collapse;
}
#attributes .attributes-section {
border: 1px solid gray;
border-collapse: collapse;
display: table-cell;
}
.attribute {
margin: 0;
padding: 0;
display: flex; display: flex;
flex-flow: row wrap;
} }
.attribute label { .basics-row {
display: inline-block; display: block;
float: left; }
clear: left;
width: 10em; .basics-entry {
display: flex;
border: 1px solid gray;
margin-left: -1px;
margin-top: -1px;
}
.basics-entry label {
display: inline;
width: 5em;
text-align: right; text-align: right;
vertical-align: text-bottom; vertical-align: text-bottom;
padding: 8px; padding: 8px;
margin: 0; margin: 0;
} }
.attribute div.value { .basics-entry span {
min-width: 1.5em; width: 15em;
max-width: 4em; overflow: hidden;
text-align: center; padding: 8px;
display: inline-block; border: none;
float: left; background-color: lightgray;
margin: 0;
}
#attributes .flex-container {
display: flex;
flex-flow: row wrap;
}
#attributes .attributes-section {
border: 1px solid gray;
margin-left: -1px;
margin-top: -1px;
}
.attribute {
display: flex;
}
.attribute label {
width: 10em;
display: inline;
text-align: right;
vertical-align: text-bottom;
padding: 8px;
margin: 0;
}
.attribute span {
width: 2em;
overflow: hidden;
padding: 8px; padding: 8px;
border: none; border: none;
background-color: lightgray; background-color: lightgray;
@ -49,26 +76,25 @@
} }
#skills { #skills {
padding: 4px;
border-collapse: collapse; }
#skills .flex-container {
display: flex;
flex-flow: row wrap;
} }
#skills .skills-section { #skills .skills-section {
border: 1px solid gray; border: 1px solid gray;
border-collapse: collapse; margin-top: -1px;
display: table-cell; margin-left: -1px;
} }
.skill { .skill {
margin: 0;
padding: 0;
display: flex; display: flex;
} }
.skill label { .skill label {
display: inline-block;
float: left;
clear: left;
width: 10em; width: 10em;
text-align: right; text-align: right;
vertical-align: text-bottom; vertical-align: text-bottom;
@ -76,32 +102,115 @@
margin: 0; margin: 0;
} }
.skill div.value { .skill span {
min-width: 1.5em; width: 2em;
max-width: 4em; overflow: hidden;
display: inline-block;
text-align: center;
float: left;
padding: 8px; padding: 8px;
border: none; border: none;
background-color: lightgray; background-color: lightgray;
margin: 0; margin: 0;
} }
#merits {
padding: 4px;
}
#merit-list {
display: inline-flex;
flex-direction: column;
}
.merit {
/* margin: 0;
padding: 0; */
display: flex;
border: 1px solid gray;
margin-top: -1px;
}
.merit span {
width: 3em;
text-align: left;
padding: 8px;
margin: 0;
}
.merit .merit-name {
width: 10em;
white-space: nowrap;
overflow: auto;
padding: 0;
margin: 8px;
border: none;
border: 0px solid gray;
border-bottom-width: 1px;
}
.merit .merit-dots {
max-width: 4em;
padding: 8px;
border: none;
background-color: lightgray;
margin: 0;
}
.merit .remove-merit {
max-width: 4em;
padding: 0;
padding: 3px;
padding-left: 6px;
padding-right:6px;
margin: 3px;
background-color: lightgray;
}
</style> </style>
<h1>Core Sheet</h1>
<div> <div>
<h1>Character {{name}}</h1> <div id="basics">
<h3>User: {{username}}</h3> <h1>
<p>System: {{data_type}}</h3> <span id="characterName" name="characterName">{{name}}</span>
</div> </h1>
<div> <div class="links">
<h1>Core Sheet</h1> <a href="/">Home</a> |
<div> <a href="/characters/{{username}}/{{id}}/edit">Edit Character</a> |
<h1>Name: <input type="text" value="{{name}}" /></h1> <a href="/characters/{{username}}/{{id}}/delete">Delete Character</a>
<p>System: {{data_type}}</p> </div>
<div id="attributes">
<h2>Basics</h2>
<div>System: {{data_type}}</div>
<div class="flex-container">
<div class="basics-row">
<div class="basics-entry">
<label for="gender">Gender:</label>
<span id="gender" name="gender">{{sheet.gender}}</span>
</div>
<div class="basics-entry">
<label for="age">Age:</label>
<span id="age" name="age">{{sheet.age}}</span>
</div>
</div>
<div class="basics-row">
<div class="basics-entry">
<label for="concept">Concept:</label>
<span id="concept" name="concept">{{sheet.concept}}</span>
</div>
<div class="basics-entry">
<label for="chronicle">Chronicle:</label>
<span id="chronicle" name="chronicle">{{sheet.chronicle}}</span>
</div>
</div>
</div>
</div>
<div id="attributes">
<h2>Attributes</h2>
<div class="flex-container">
<div class="attributes-section" id="mentalAttributes"> <div class="attributes-section" id="mentalAttributes">
{{ macros::attribute(name="Intelligence", value=sheet.intelligence) }} {{ macros::attribute(name="Intelligence", value=sheet.intelligence) }}
{{ macros::attribute(name="Wits", value=sheet.wits) }} {{ macros::attribute(name="Wits", value=sheet.wits) }}
@ -120,8 +229,11 @@
{{ macros::attribute(name="Composure", value=sheet.composure) }} {{ macros::attribute(name="Composure", value=sheet.composure) }}
</div> </div>
</div> </div>
</div>
<div id="skills"> <div id="skills">
<h2>Skills</h2>
<div class="flex-container">
<div class="skills-section" id="mentalSkills"> <div class="skills-section" id="mentalSkills">
{% for skill_name, skill in sheet.mentalSkills %} {% for skill_name, skill in sheet.mentalSkills %}
{{ macros::skill(name=skill_name, value=skill.dots) }} {{ macros::skill(name=skill_name, value=skill.dots) }}
@ -142,7 +254,13 @@
</div> </div>
</div> </div>
<div> <div id="merits">
<a href="/characters/{{username}}/{{id}}/edit">Edit Character</a> <h2>Merits</h2>
<div id="merit-list">
{% for merit in sheet.merits %}
{{ macros::merit(name=merit.name, value=merit.dots) }}
{% endfor %}
</div>
</div> </div>
</div>
{% endblock content %} {% endblock content %}

View File

@ -1,13 +1,20 @@
{% macro attribute(name, value) %} {% macro attribute(name, value) %}
<div class="attribute"> <div class="attribute">
<label for="{{name}}">{{name}}:</label> <label for="{{name}}">{{name}}:</label>
<div class="value" id="{{name}}">{{value}}</div> <span class="value" id="{{name}}">{{value}}</span>
</div> </div>
{% endmacro attribute %} {% endmacro attribute %}
{% macro skill(name, value) %} {% macro skill(name, value) %}
<div class="skill"> <div class="skill">
<label for="{{name}}">{{name}}:</label> <label for="{{name}}">{{name}}:</label>
<div class="value" id="{{name}}">{{value}}</div> <span class="value" id="{{name}}">{{value}}</span>
</div> </div>
{% endmacro skill %} {% endmacro skill %}
{% macro merit(name, value) %}
<div class="merit">
<span class="merit-name">{{name}}</span>
<span class="merit-dots">{{value}}</span> <span>Dots</span>
</div>
{% endmacro merit %}

View File

@ -10,6 +10,7 @@ use strum::IntoEnumIterator;
struct EditCharacterContext<'a> { struct EditCharacterContext<'a> {
pub name: &'a str, pub name: &'a str,
pub username: &'a str, pub username: &'a str,
pub id: i32,
pub data_type: &'a CharacterDataType, pub data_type: &'a CharacterDataType,
pub sheet: Box<DynCharacterData>, pub sheet: Box<DynCharacterData>,
pub state: FormStateContext<'a>, pub state: FormStateContext<'a>,
@ -26,6 +27,7 @@ fn edit_character_template(user: &User, character: Character) -> Result<Template
let context = EditCharacterContext { let context = EditCharacterContext {
name: &character.character_name, name: &character.character_name,
username: &user.username, username: &user.username,
id: character.id,
data_type: &character.data_type, data_type: &character.data_type,
sheet: character.dyn_deserialize()?, sheet: character.dyn_deserialize()?,
state: FormStateContext { state: FormStateContext {