Merge branch 'working' into 'master'

Fix de la récupération fatigue & boutons d'actions

See merge request LeRatierBretonnien/foundryvtt-reve-de-dragon!25
This commit is contained in:
Leratier Bretonnien 2020-11-20 11:06:06 +00:00
commit 8370a3b6a8
13 changed files with 307 additions and 120 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.3 KiB

58
icons/heures/hd05.svg Normal file
View File

@ -0,0 +1,58 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
width="44.0995mm"
height="44.0995mm"
viewBox="0 0 250 250"
version="1.1"
id="svg3"
sodipodi:docname="hd05.svg"
inkscape:version="1.0.1 (3bc2e813f5, 2020-09-07)">
<metadata
id="metadata9">
<rdf:RDF>
<cc:Work
rdf:about="">
<dc:format>image/svg+xml</dc:format>
<dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title></dc:title>
</cc:Work>
</rdf:RDF>
</metadata>
<defs
id="defs7" />
<sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="881"
inkscape:window-height="480"
id="namedview5"
showgrid="false"
inkscape:zoom="6.0476878"
inkscape:cx="83.337635"
inkscape:cy="83.337635"
inkscape:window-x="0"
inkscape:window-y="0"
inkscape:window-maximized="0"
inkscape:current-layer="svg3" />
<path
id="Sélection"
fill="none"
stroke="black"
stroke-width="1"
d="M 98.00,39.00 C 104.37,41.03 108.79,45.33 114.00,49.35 114.00,49.35 141.00,68.80 141.00,68.80 145.95,71.80 157.43,75.86 160.00,80.00 151.99,79.61 145.44,76.06 138.00,73.32 134.63,72.08 130.70,70.21 127.04,71.24 125.22,71.75 124.14,72.58 123.09,74.14 120.99,77.27 118.46,89.46 121.40,92.30 126.99,97.69 139.54,89.73 143.97,98.06 145.89,101.65 143.71,105.37 143.21,109.00 142.45,114.46 142.94,123.68 144.43,129.00 146.90,137.81 149.99,144.61 155.48,152.00 159.39,157.26 165.49,162.68 168.00,168.00 149.35,160.92 137.02,149.38 131.21,130.00 129.86,125.51 128.65,117.74 128.17,113.00 127.83,109.67 128.19,106.09 125.43,103.59 123.52,101.87 115.92,100.67 113.00,99.85 113.00,99.85 87.00,91.42 87.00,91.42 84.20,90.80 76.77,88.69 75.29,92.31 74.23,94.92 79.37,102.34 80.74,105.00 84.82,112.90 88.37,121.20 89.92,130.00 89.92,130.00 92.02,146.86 92.02,146.86 94.27,150.71 102.85,151.96 107.00,153.36 115.10,156.08 125.51,161.42 131.00,168.00 126.53,166.73 125.02,165.59 121.00,163.87 112.41,160.20 103.22,158.43 94.00,157.28 89.82,156.76 79.35,156.54 76.60,153.49 73.74,150.32 75.56,142.93 75.93,139.00 76.78,129.78 76.45,120.92 73.65,112.00 70.44,101.77 65.56,92.68 57.99,85.00 52.24,79.18 44.49,75.38 41.00,68.00 41.00,68.00 90.00,86.85 90.00,86.85 93.16,87.71 104.80,90.80 107.40,88.31 108.73,86.69 107.61,81.43 107.40,79.00 107.82,59.49 102.23,54.68 98.00,39.00 Z M 34.11,181.00 C 40.60,182.26 45.30,186.55 51.00,190.00 52.90,191.15 56.91,193.29 57.84,195.29 59.27,198.40 55.28,199.88 56.68,204.01 58.94,210.71 71.35,215.81 78.00,214.64 79.80,214.33 81.43,213.64 82.96,212.66 95.64,204.48 78.62,193.89 73.11,187.96 71.14,185.85 69.68,183.92 69.24,181.00 67.13,166.96 84.13,170.12 92.00,172.44 116.36,179.62 137.88,205.28 164.00,188.45 167.46,186.22 171.09,183.08 173.82,180.00 193.36,157.94 179.27,126.82 179.00,104.00 178.88,93.46 179.12,77.25 191.00,72.74 201.87,68.60 226.22,82.46 220.11,96.90 218.03,101.81 212.47,102.10 208.02,100.53 206.19,99.88 202.82,97.98 204.17,95.54 205.18,93.70 210.19,93.24 210.68,88.98 211.12,85.09 205.20,78.98 199.00,81.73 191.98,84.84 188.65,91.59 189.18,99.00 189.83,108.04 192.45,116.31 194.63,125.00 200.94,150.27 202.39,189.15 173.00,200.53 167.38,202.71 161.94,203.06 156.00,203.00 140.14,202.82 124.54,194.37 111.00,186.86 106.21,184.21 93.11,176.64 88.00,178.06 83.00,179.45 81.32,183.60 84.03,188.00 88.51,195.26 107.85,204.83 98.57,216.96 97.42,218.47 95.60,220.10 94.00,221.11 91.52,222.66 89.84,222.88 87.00,222.98 76.33,223.37 67.85,220.03 59.00,214.30 59.00,214.30 49.00,207.02 49.00,207.02 43.20,204.22 36.26,210.05 34.11,202.94 34.03,201.89 34.02,200.11 34.11,199.00 34.11,199.00 34.11,181.00 34.11,181.00 Z"
style="stroke:none;fill:#ffffff" />
</svg>

After

Width:  |  Height:  |  Size: 5.0 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 16 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.1 KiB

58
icons/heures/hd08.svg Normal file
View File

@ -0,0 +1,58 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
width="44.0995mm"
height="44.0995mm"
viewBox="0 0 250 250"
version="1.1"
id="svg3"
sodipodi:docname="hd08.svg"
inkscape:version="1.0.1 (3bc2e813f5, 2020-09-07)">
<metadata
id="metadata9">
<rdf:RDF>
<cc:Work
rdf:about="">
<dc:format>image/svg+xml</dc:format>
<dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title></dc:title>
</cc:Work>
</rdf:RDF>
</metadata>
<defs
id="defs7" />
<sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="1742"
inkscape:window-height="1326"
id="namedview5"
showgrid="false"
inkscape:zoom="6.0476878"
inkscape:cx="83.337635"
inkscape:cy="83.337635"
inkscape:window-x="0"
inkscape:window-y="0"
inkscape:window-maximized="0"
inkscape:current-layer="svg3" />
<path
id="Sélection"
fill="none"
stroke="black"
stroke-width="1"
d="M 52.00,130.00 C 53.85,124.67 61.10,123.93 66.00,122.34 66.00,122.34 76.00,119.00 76.00,119.00 82.04,118.18 86.75,122.19 87.42,128.00 88.15,131.16 87.40,133.04 87.42,136.00 86.76,141.34 89.78,147.40 96.00,145.46 101.06,143.87 112.60,134.73 120.00,134.11 125.88,133.61 130.92,135.79 132.28,142.00 133.57,147.92 127.52,158.96 127.09,166.00 125.97,184.34 152.19,197.73 167.24,178.91 176.80,166.96 179.68,147.49 169.48,135.04 164.13,128.50 155.45,124.43 148.00,120.76 138.93,116.29 120.90,108.08 124.81,95.00 125.79,91.71 128.59,87.80 131.29,85.70 133.23,84.19 137.60,82.43 140.00,81.42 149.54,77.42 167.00,72.05 175.55,80.79 178.58,83.88 176.90,86.82 173.89,89.04 168.96,92.67 161.12,95.70 155.00,96.00 155.88,93.85 158.12,90.22 157.55,88.04 155.59,80.55 140.46,83.79 139.50,92.00 138.67,99.05 150.46,108.81 156.00,111.74 166.86,117.48 183.61,123.01 187.36,136.00 188.13,138.65 188.03,142.22 188.00,145.00 187.91,152.60 186.28,162.28 182.68,169.00 175.19,182.96 153.25,197.59 137.00,196.51 132.61,196.22 125.65,193.35 122.00,190.90 111.19,183.62 112.68,174.83 115.98,164.00 117.25,159.82 119.98,151.93 117.39,148.06 114.26,143.38 110.37,144.37 106.00,146.31 101.20,148.44 88.46,155.23 84.00,155.77 67.93,157.75 77.68,138.65 71.49,131.14 66.64,125.26 58.25,129.12 52.00,130.00 Z"
style="stroke:none;fill:#ffffff" />
</svg>

After

Width:  |  Height:  |  Size: 3.2 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 12 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.2 KiB

58
icons/heures/hd12.svg Normal file
View File

@ -0,0 +1,58 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
width="44.0995mm"
height="44.0995mm"
viewBox="0 0 250 250"
version="1.1"
id="svg3"
sodipodi:docname="hd12.svg"
inkscape:version="1.0.1 (3bc2e813f5, 2020-09-07)">
<metadata
id="metadata9">
<rdf:RDF>
<cc:Work
rdf:about="">
<dc:format>image/svg+xml</dc:format>
<dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title></dc:title>
</cc:Work>
</rdf:RDF>
</metadata>
<defs
id="defs7" />
<sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="1677"
inkscape:window-height="1199"
id="namedview5"
showgrid="false"
inkscape:zoom="6.0476878"
inkscape:cx="83.337635"
inkscape:cy="83.337635"
inkscape:window-x="0"
inkscape:window-y="0"
inkscape:window-maximized="0"
inkscape:current-layer="svg3" />
<path
id="Sélection"
fill="none"
stroke="black"
stroke-width="1"
d="M 102.00,85.00 C 103.52,80.22 108.58,75.80 111.95,72.00 111.95,72.00 129.04,52.00 129.04,52.00 131.05,49.89 136.07,44.32 138.91,44.03 141.98,43.71 146.79,50.73 148.73,53.00 155.56,60.97 172.57,75.08 175.00,84.00 175.00,84.00 149.00,87.00 149.00,87.00 153.29,92.15 156.10,92.61 156.82,100.00 157.46,106.55 153.87,113.90 158.70,119.73 162.56,124.38 171.39,125.40 175.61,120.85 178.19,118.07 179.15,113.97 182.21,111.74 184.59,110.00 187.21,110.04 190.00,110.00 190.00,110.00 215.00,111.00 215.00,111.00 215.00,111.00 214.01,126.00 214.01,126.00 213.76,137.17 217.00,155.49 218.58,167.00 218.58,167.00 219.22,174.00 219.22,174.00 220.68,182.36 230.05,186.01 228.81,197.00 227.58,207.94 217.04,214.55 207.00,216.00 210.12,209.40 214.10,208.12 216.42,203.00 221.54,191.67 205.81,177.37 195.00,178.10 188.87,178.50 181.51,183.14 176.43,178.99 172.59,175.86 175.57,172.15 171.35,166.00 163.04,153.90 145.57,146.08 131.00,147.09 118.57,147.95 105.08,155.07 95.00,162.02 91.86,164.19 82.69,171.58 80.00,172.40 74.35,174.13 70.62,168.55 65.00,165.92 56.00,161.70 50.05,164.60 43.04,170.62 33.18,179.08 27.52,193.04 37.21,203.96 43.94,211.55 52.20,211.38 50.34,216.83 48.69,221.67 39.23,222.53 35.00,221.61 25.95,219.65 21.12,210.66 21.00,202.00 20.81,188.03 24.29,180.65 35.00,171.29 35.00,171.29 49.28,159.70 49.28,159.70 52.38,155.57 53.97,138.57 54.00,133.00 54.02,129.36 54.86,112.57 55.89,110.04 56.59,108.33 57.51,107.11 59.13,106.17 61.27,104.95 70.35,104.64 74.00,103.88 77.02,103.25 83.02,100.59 85.69,102.11 89.88,104.50 86.81,114.70 88.60,118.86 90.35,122.94 96.23,122.95 100.00,123.00 103.13,123.03 108.13,123.24 110.86,121.69 116.54,118.46 115.69,103.16 117.80,97.04 119.78,91.30 122.77,93.12 126.00,87.00 113.39,84.46 114.66,85.00 102.00,85.00 Z M 152.00,80.00 C 151.84,78.07 151.89,76.83 150.98,75.00 148.96,70.96 140.96,63.07 136.00,63.91 128.98,65.09 120.86,73.73 118.00,80.00 125.55,82.97 142.99,80.00 152.00,80.00 Z M 190.00,173.00 C 193.41,173.00 200.06,173.61 202.69,171.40 205.61,168.94 204.85,165.28 204.21,162.00 204.21,162.00 204.21,144.00 204.21,144.00 204.21,144.00 203.18,130.00 203.18,130.00 203.40,126.88 204.56,122.21 203.69,119.13 202.70,115.68 199.07,114.76 196.04,116.21 190.21,119.02 192.06,125.43 185.96,128.96 179.03,132.71 165.81,129.71 158.00,128.96 154.03,128.77 149.60,128.88 146.70,125.58 143.35,121.79 144.05,114.76 144.00,110.00 143.93,104.57 142.71,92.24 134.11,95.87 129.96,97.61 130.24,101.27 129.84,105.00 129.09,111.80 129.71,125.23 122.96,128.57 120.63,129.72 105.07,131.06 102.00,130.96 102.00,130.96 92.00,130.00 92.00,130.00 88.23,129.82 82.09,129.48 79.31,126.69 74.72,122.07 79.63,112.61 72.94,110.45 68.77,109.10 66.17,113.75 65.17,117.00 63.69,121.87 62.07,137.69 62.00,143.00 61.96,146.67 61.66,151.65 63.45,154.90 67.32,161.89 78.89,164.05 86.00,161.96 97.27,158.65 100.61,151.89 115.00,145.14 132.59,137.26 154.51,136.17 172.00,145.14 182.48,150.24 189.85,156.60 190.00,169.00 190.00,169.00 190.00,173.00 190.00,173.00 Z"
style="stroke:none;fill:#ffffff" />
</svg>

After

Width:  |  Height:  |  Size: 5.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 15 KiB

View File

@ -332,39 +332,47 @@ export class RdDActor extends Actor {
/* -------------------------------------------- */ /* -------------------------------------------- */
async dormir(heures=1) { async dormir(heures=1) {
let message = { title : "Récupération", content :"Vous dormez " + heures + " heure" + (heures > 1 ? "s": "") }; let message = { title : "Récupération", content :"Vous dormez " + heures + " heure" + (heures > 1 ? "s": "") };
this.recupereEndurance(message); await this.recupereEndurance(message);
for (let i=0; i<heures; i++) { for (let i=0; i<heures; i++) {
await this.recupererFatigueUneHeure(message); await this.recupererFatigue(message);
this.recuperationReve(message); await this.recuperationReve(message);
} }
ChatMessage.create( message ); ChatMessage.create( message );
} }
/* -------------------------------------------- */ /* -------------------------------------------- */
recupereEndurance(message) { async recupereEndurance(message) {
const avant = this.data.data.sante.endurance.value; const manquant = this._computeEnduranceMax() - this.data.data.sante.endurance.value;
this.santeIncDec("endurance", this.data.data.sante.endurance.max - avant); if (manquant > 0) {
const recupere = this.data.data.sante.endurance.value - avant; await this.santeIncDec("endurance", manquant);
if (recupere>0) { message.content += "<br>Vous récuperez " + manquant + " points d'endurance";
message.content += "<br>Vous récuperez " + recupere + " points d'endurance";
} }
} }
/* -------------------------------------------- */ /* -------------------------------------------- */
async recupererFatigueUneHeure(message) { async recupererFatigue(message) {
let fatigue = duplicate(this.data.data.sante.fatigue) let fatigue = duplicate(this.data.data.sante.fatigue)
if (fatigue.value == 0) { const fatigueMin = this._computeFatigueMin();
if (fatigue.value <= fatigueMin) {
message.content += "<br>Vous êtes déjà reposé"; message.content += "<br>Vous êtes déjà reposé";
return; return;
} }
fatigue.value = Math.max(fatigueMin, this._calculRecuperationSegment(fatigue.value));
console.log("recupererFatigue", fatigue)
await this.update( {"data.sante.fatigue": fatigue } );
if (fatigue.value == 0)
{
message.content += "<br>Vous êtes bien reposé";
}
}
_calculRecuperationSegment(actuel)
{
const segments = RdDUtility.getSegmentsFatigue(this.data.data.sante.endurance.max); const segments = RdDUtility.getSegmentsFatigue(this.data.data.sante.endurance.max);
let cumul = 0; let cumul = 0;
console.log("recupererFatigue", segments);
let i; let i;
for (i=0; i <11; i++) { for (i=0; i <11; i++) {
cumul += segments[i]; cumul += segments[i];
let diff = cumul - fatigue.value ; let diff = cumul - actuel;
if (diff >= 0) if (diff >= 0)
{ {
const limit2Segments = Math.floor(segments[i] / 2); const limit2Segments = Math.floor(segments[i] / 2);
@ -374,17 +382,11 @@ export class RdDActor extends Actor {
cumul -= segments[i]; cumul -= segments[i];
break; break;
} }
} };
fatigue.value = cumul; return cumul;
await this.update( {"data.sante.fatigue": fatigue } );
if (fatigue.value == 0)
{
message.content += "<br>Vous êtes bien reposé";
}
} }
/* -------------------------------------------- */ /* -------------------------------------------- */
recuperationReve(message) { async recuperationReve(message) {
const seuil = this.data.data.reve.seuil.value; const seuil = this.data.data.reve.seuil.value;
const reve = this.getReveActuel(); const reve = this.getReveActuel();
if (reve >= seuil) { if (reve >= seuil) {
@ -740,9 +742,9 @@ export class RdDActor extends Actor {
testSiSonne( sante, endurance ) testSiSonne( sante, endurance )
{ {
let result = new Roll("d20").roll().total; let result = new Roll("d20").roll().total;
if ( result <= endurance.value) if ( result <= endurance)
sante.sonne.value = false; sante.sonne.value = false;
if ( result > endurance.value || result == 20) // 20 is always a failure if ( result > endurance || result == 20) // 20 is always a failure
sante.sonne.value = true; sante.sonne.value = true;
if (result == 1) { if (result == 1) {
sante.sonne.value = false; sante.sonne.value = false;
@ -766,44 +768,51 @@ export class RdDActor extends Actor {
async santeIncDec(name, inc ) { async santeIncDec(name, inc ) {
const sante = duplicate(this.data.data.sante); const sante = duplicate(this.data.data.sante);
let data = sante[name]; let data = sante[name];
let lastValue = data.value; // Useful for Endurance and Sonné let minValue = name == "vie" ? - this.data.data.attributs.sconst : 0;
data.value = data.value + inc; let newValue = Math.max(minValue, Math.min(data.value + inc, data.max));
if ( data.value > data.max ) data.value = data.max;
if ( data.value < 0 ) data.value = 0;
if (name == "endurance" && this.data.type != 'entite' ) { if (name == "endurance" && this.data.type != 'entite' ) {
if ( sante.fatigue && inc < 0 ) { // Each endurance lost -> fatigue lost if ( sante.fatigue && inc < 0 ) { // Each endurance lost -> fatigue lost
sante.fatigue.value = sante.fatigue.value - inc sante.fatigue.value = sante.fatigue.value - inc
} }
// If endurance is 0 -> -1 vie if ( newValue == 0 && inc < 0) { // perte endurance et endurance devient 0 -> -1 vie
if ( data.value == 0 && sante.vie.value > 0) {
sante.vie.value = sante.vie.value - 1; sante.vie.value = sante.vie.value - 1;
} }
let diffVie = sante.vie.max - sante.vie.value; newValue = Math.max(0, newValue);
if ( data.value > data.max - (diffVie*2) ) { if (inc>0) { // le max d'endurance s'applique seulement à la récupération
data.value = data.max - (diffVie*2); newValue = Math.max(newValue, this._computeEnduranceMax())
}
if (data.value - newValue > 1) {
this.testSiSonne(sante, newValue); // Peut-être sonné si 2 points d'endurance perdus d'un coup
} else if (inc>0) {
sante.sonne.value = false;
} }
if ( data.value < 0 ) data.value = 0; // Security
let blessures = this.data.data.blessures;
let nbGraves = this.GetNumberBlessures(blessures.graves.liste);
let nbCritiques = this.GetNumberBlessures(blessures.critiques.liste);
let maxEnd = Math.floor( data.max / (2*nbGraves));
if (data.value > maxEnd ) data.value = maxEnd;
if ( nbCritiques > 0 && data.value > 1) data.value = 1;
if (lastValue - data.value > 1) this.testSiSonne(sante, data); // Peut-être sonné si 2 points d'endurance perdus d'un coup
} }
data.value = newValue;
//console.log(name, inc, data.value); //console.log(name, inc, data.value);
if ( sante.fatigue) { // If endurance lost, then the same amount of fatigue cannot be recovered
let diffEndurance = sante.endurance.max - this.data.data.sante.endurance.value; sante.fatigue.value = Math.max(sante.fatigue.value, this._computeFatigueMin());
if ( sante.fatigue && sante.fatigue.value < diffEndurance) // If endurance lost, then the same amount of fatigue cannot be recovered }
sante.fatigue.value = diffEndurance;
//console.log("SANTE::::", sante); //console.log("SANTE::::", sante);
await this.update( {"data.sante": sante } ); await this.update( {"data.sante": sante } );
} }
_computeFatigueMin() {
return this.data.data.sante.endurance.max - this.data.data.sante.endurance.value;
}
_computeEnduranceMax() {
let blessures = this.data.data.blessures;
let diffVie = this.data.data.sante.vie.max - this.data.data.sante.vie.value;
let maxEndVie = this.data.data.sante.endurance.max - (diffVie * 2);
let nbGraves = this.GetNumberBlessures(blessures.graves.liste);
let nbCritiques = this.GetNumberBlessures(blessures.critiques.liste);
let maxEndGraves = Math.floor(this.data.data.sante.endurance.max / (2 * nbGraves));
let maxEndCritiques = nbCritiques > 0 ? 1 : this.data.data.sante.endurance.max;
return Math.max(0, Math.min(maxEndVie, maxEndGraves, maxEndCritiques));
}
/* -------------------------------------------- */ /* -------------------------------------------- */
async manageBlessureFromSheet( bType, index, active ) { async manageBlessureFromSheet( bType, index, active ) {
let bList = duplicate(this.data.data.blessures); let bList = duplicate(this.data.data.blessures);

View File

@ -225,6 +225,12 @@
margin-right: 10px; margin-right: 10px;
} }
.button-img {
width: 8%;
height: 8%;
border-width: 0;
}
.foundryvtt-reve-de-dragon .sheet-header .header-fields { .foundryvtt-reve-de-dragon .sheet-header .header-fields {
-webkit-box-flex: 1; -webkit-box-flex: 1;
-ms-flex: 1; -ms-flex: 1;
@ -348,8 +354,8 @@
/* ======================================== */ /* ======================================== */
/* Sheet */ /* Sheet */
.sheet header.sheet-header .flex-group-center.flex-hp, .sheet header.sheet-header .flex-group-center.flex-fatigue {font-family: "GrenzeGotisch-Regular";} .sheet header.sheet-header .flex-group-center.flex-compteurs, .sheet header.sheet-header .flex-group-center.flex-actions-bar {font-family: "GrenzeGotisch-Regular";}
.sheet header.sheet-header .flex-hp {text-align: right;} .sheet header.sheet-header .flex-compteurs {text-align: right;}
.sheet header.sheet-header .resource-content {width: 3rem;} .sheet header.sheet-header .resource-content {width: 3rem;}
.window-app.sheet .window-content .sheet-header{ .window-app.sheet .window-content .sheet-header{
@ -365,16 +371,6 @@
background: #f5f4f1 url("img/bg_left.jpg") no-repeat left top; background: #f5f4f1 url("img/bg_left.jpg") no-repeat left top;
} }
.sheet header.sheet-header img {
flex: 0 0 64px;
height: 64px;
width: 64px;
object-fit: cover;
object-position: 50% 0;
margin: 0.5rem;
border: none;
}
section.sheet-body{padding: 0.25rem 0.5rem;} section.sheet-body{padding: 0.25rem 0.5rem;}
.sheet nav.sheet-tabs { .sheet nav.sheet-tabs {
@ -556,7 +552,7 @@ button {
.table-fatigue .fatigue-malus { .table-fatigue .fatigue-malus {
font-size: 0.8rem; font-size: 0.8rem;
} }
.flex-fatigue { .flex-actions-bar {
flex-grow: 2; flex-grow: 2;
} }
@ -883,6 +879,7 @@ background: rgba(0, 0, 0, 0.5);
.tooltip .tooltiptext { .tooltip .tooltiptext {
visibility: hidden; visibility: hidden;
width: 360px; width: 360px;
background-color: rgba(0,0,0,0.9);
text-align: center; text-align: center;
padding: 5px 0; padding: 5px 0;
border-radius: 6px; border-radius: 6px;
@ -890,7 +887,8 @@ background: rgba(0, 0, 0, 0.5);
/* Position the tooltip text */ /* Position the tooltip text */
position: absolute; position: absolute;
z-index: 1; z-index: 1;
left: -100%; top: 30px;
left: -30%;
/* Fade in tooltip */ /* Fade in tooltip */
opacity: 0; opacity: 0;

View File

@ -2,48 +2,69 @@
{{!-- Sheet Header --}} {{!-- Sheet Header --}}
<header class="sheet-header"> <header class="sheet-header">
<div class="header-fields"> <div class="header-fields">
<div class="flexrow"> <div class="flexrow">
<img class="profile-img" src="{{actor.img}}" data-edit="img" title="{{actor.name}}" /> <img class="profile-img" src="{{actor.img}}" data-edit="img" title="{{actor.name}}" />
<h1 class="charname"><input name="name" type="text" value="{{actor.name}}" placeholder="Name"/></h1> <h1 class="charname"><input name="name" type="text" value="{{actor.name}}" placeholder="Name"/></h1>
</div> </div>
<div class="flexrow"> <div class="flexrow">
<div class="flex-group-center flex-hp"> <div class="flex-group-center flex-compteurs">
<div> <div>
<span>Vie <a id="vie-plus">+</a> / <a id="vie-moins">-</a></span> <span>Vie <a id="vie-plus">+</a> / <a id="vie-moins">-</a></span>
<input class="resource-content" type="text" name="data.sante.vie.value" value="{{data.sante.vie.value}}" data-dtype="Number"/>/{{data.sante.vie.max}} <input class="resource-content" type="text" name="data.sante.vie.value" value="{{data.sante.vie.value}}" data-dtype="Number"/>/{{data.sante.vie.max}}
</div>
<div>
<span>Endurance <a id="endurance-plus">+</a> / <a id="endurance-moins">-</a></span>
<input class="resource-content" type="text" name="data.sante.endurance.value" value="{{data.sante.endurance.value}}" data-dtype="Number"/>/{{data.sante.endurance.max}}
</div>
<div>
<span>Fatigue <a id="fatigue-plus">+</a> / <a id="fatigue-moins">-</a></span>
<input class="resource-content" id="fatigue-value" type="text" name="data.sante.fatigue.value" value="{{data.sante.fatigue.value}}" data-dtype="Number" />/{{data.sante.fatigue.max}}
</div>
<div>
<span>Sonné :</span>
<input class="resource-content" type="checkbox" name="data.sante.sonne.value" value="{{data.sante.sonne.value}}" {{#if data.sante.sonne.value}}checked{{/if}} />
</div>
<div>
<span><span class="ptreve-actuel"><a>Rêve</a></span> <a id="ptreve-actuel-plus">+</a> / <a id="ptreve-actuel-moins">-</a></span>
<input class="resource-content" id="pointsreve-value" type="text" name="data.reve.reve.value" value="{{data.reve.reve.value}}" data-dtype="Number" />/{{data.reve.seuil.value}}
</div>
</div> </div>
<div class="flex-group-center flex-fatigue"> <div>
<div class="tooltip">Malus de fatigue : {{data.fatigue.malus}} <span>Endurance <a id="endurance-plus">+</a> / <a id="endurance-moins">-</a></span>
<input class="resource-content" type="text" name="data.sante.endurance.value" value="{{data.sante.endurance.value}}" data-dtype="Number"/>/{{data.sante.endurance.max}}
</div>
<div>
<span class="tooltip">Fatigue <a id="fatigue-plus">+</a> / <a id="fatigue-moins">-</a>
<span class="tooltiptext">{{{data.fatigue.html}}}</span> <span class="tooltiptext">{{{data.fatigue.html}}}</span>
</div> </span>
<input class="resource-content" id="fatigue-value" type="text" name="data.sante.fatigue.value" value="{{data.sante.fatigue.value}}" data-dtype="Number" />/{{data.sante.fatigue.max}}
</div>
<div>
<span>Sonné :</span>
<input class="resource-content" type="checkbox" name="data.sante.sonne.value" value="{{data.sante.sonne.value}}" {{#if data.sante.sonne.value}}checked{{/if}} />
</div>
<div>
<span><span class="ptreve-actuel"><a>Rêve</a></span> <a id="ptreve-actuel-plus">+</a> / <a id="ptreve-actuel-moins">-</a></span>
<input class="resource-content" id="pointsreve-value" type="text" name="data.reve.reve.value" value="{{data.reve.reve.value}}" data-dtype="Number" />/{{data.reve.seuil.value}}
</div> </div>
</div> </div>
<div class="flexrow flex-wound"> <div class="flex-group-center flex-actions-bar">
<div>
<span class="encaisser-direct"><a title="Encaisser des dommages"><img class="button-img" src="icons/svg/bones.svg" alt="Encaisser des dommages"/></a></span>
<span class="dormir-une-heure"><a title="Dormir une heure"><img class="button-img" src="icons/svg/sleep.svg" alt="Dormir une heure"/></a></span>
<span class="chateau-dormant"><a title="Chateau Dormant"><img class="button-img" src="systems/foundryvtt-reve-de-dragon/icons/heures/hd12.svg" alt="Chateau Dormant"/></a></span>
<span class="monte-tmr"><a title="Montée dans les Terres Medianes !"><img class="button-img" src="systems/foundryvtt-reve-de-dragon/icons/heures/hd08.svg" alt="Montée dans les Terres Medianes !"/></a></span>
<span class="monte-tmr-rapide"><a title="Montée accélérée dans les Terres Medianes !"><img class="button-img" src="systems/foundryvtt-reve-de-dragon/icons/heures/hd05.svg" alt="Montée accélérée dans les Terres Medianes !"/></a></span>
<span class="visu-tmr"><a title="Regarder les Terres Medianes"><img class="button-img" src="icons/svg/eye.svg" alt="Regarder les Terres Medianes"/></a></span>
</div>
<div class="flexrow"> <div class="flexrow">
<div class="flex-group-center">Blessures légères : {{data.nbLegeres}}</div> <span class="tooltip">Malus de fatigue : {{data.fatigue.malus}}
<div class="flex-group-center">Blessures graves : {{data.nbGraves}}</div> <span class="tooltiptext">{{{data.fatigue.html}}}</span>
<div class="flex-group-center">Blessure critique : {{data.nbCritiques}}</div> </span>
<span>
{{#if data.nbLegeres}}
Blessures: {{data.nbLegeres}} légères
{{#if data.nbGraves}}, {{data.nbGraves}} graves{{/if}}
{{#if data.nbCritiques}}, une CRITIQUE !{{/if}}
{{else}}
{{#if data.nbGraves}}
Blessures:{{data.nbGraves}} graves
{{#if data.nbCritiques}}et une CRITIQUE !{{data.nbCritiques}}{{/if}}
{{else}}
{{#if data.nbCritiques}}une CRITIQUE !{{data.nbCritiques}}
{{else}}Aucune blessure
{{/if}}
{{/if}}
{{/if}}
</span>
</div> </div>
</div> </div>
</div> </div>
</div>
</header> </header>
{{!-- Sheet Tab Navigation --}} {{!-- Sheet Tab Navigation --}}
@ -266,9 +287,6 @@
{{!-- Combat Tab --}} {{!-- Combat Tab --}}
<div class="tab combat" data-group="primary" data-tab="combat"> <div class="tab combat" data-group="primary" data-tab="combat">
<div>
<span class="encaisser-direct"><a>Encaisser des dommages</a></span>
</div>
<header class="competence-header flexrow"> <header class="competence-header flexrow">
<span class="competence-title">Armes</span> <span class="competence-title">Armes</span>
<span class="competence-title">compétence</span> <span class="competence-title">compétence</span>
@ -289,10 +307,6 @@
{{!-- Compteurs/Blessures Tab --}} {{!-- Compteurs/Blessures Tab --}}
<div class="tab blessurescompteurs" data-group="primary" data-tab="blessurescompteurs"> <div class="tab blessurescompteurs" data-group="primary" data-tab="blessurescompteurs">
<div class="flex-group-left">
<span class="dormir-une-heure"><a title="Dormir une heure"><img src="icons/svg/sleep.svg" alt="Dormir une heure" width="50" height="50"/></a></span>
<span class="chateau-dormant"><a title="Chateau Dormant"><img src="systems/foundryvtt-reve-de-dragon/icons/heures/hd12br.png" alt="Chateau Dormant" width="50" height="50"/></a></span>
</div>
<div class="flex-group-left flexrow"> <div class="flex-group-left flexrow">
<ol class="item-list"> <ol class="item-list">
{{#each data.compteurs as |compteur key|}} {{#each data.compteurs as |compteur key|}}
@ -412,14 +426,6 @@
{{/if}} {{/if}}
</span> </span>
</li> </li>
<li class="item flexrow" >
<span class="competence-label"></span>
<div>
<span class="monte-tmr"><a title="Montée dans les Terres Medianes !"><img src="systems/foundryvtt-reve-de-dragon/icons/heures/hd08br.png" alt="Montée dans les Terres Medianes !" width="50" height="50"/></a></span>
<span class="monte-tmr-rapide"><a title="Montée accélérée dans les Terres Medianes !"><img src="systems/foundryvtt-reve-de-dragon/icons/heures/hd05br.png" alt="Montée accélérée dans les Terres Medianes !" width="50" height="50"/></a></span>
<span class="visu-tmr"><a title="Regarder les Terres Medianes"><img src="icons/svg/eye.svg" alt="Regarder les Terres Medianes" width="50" height="50"/></a></span>
</div>
</li>
<li class="item flexrow"> <li class="item flexrow">
<span class="competence-label">Seuil de Rêve :</span> <span class="competence-label">Seuil de Rêve :</span>
<span> <span>

View File

@ -23,7 +23,7 @@
<div class="flex-group-center"> <div class="flex-group-center">
Refoulement : <span id="refoulement-value">0</span> Refoulement : <span id="refoulement-value">0</span>
</div> </div>
<div class="flex-group-center flex-fatigue"> <div class="flex-group-center flex-actions-bar">
Fatigue Fatigue
<span id="fatigue-table">{{{fatigue.html}}}</span> <span id="fatigue-table">{{{fatigue.html}}}</span>
</div> </div>