projects
/
vchess.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
textareas fit to content in UserBio and Problems
[vchess.git]
/
client
/
src
/
views
/
Problems.vue
diff --git
a/client/src/views/Problems.vue
b/client/src/views/Problems.vue
index
28a7b0d
..
b989fbc
100644
(file)
--- a/
client/src/views/Problems.vue
+++ b/
client/src/views/Problems.vue
@@
-42,14
+42,16
@@
main
)
#diagram(v-html="curproblem.diag")
fieldset
)
#diagram(v-html="curproblem.diag")
fieldset
- textarea(
+ textarea
.instructions-edit
(
:placeholder="st.tr['Instructions']"
:placeholder="st.tr['Instructions']"
+ @input="adjustHeight('instructions')"
v-model="curproblem.instruction"
)
p(v-html="parseHtml(curproblem.instruction)")
fieldset
v-model="curproblem.instruction"
)
p(v-html="parseHtml(curproblem.instruction)")
fieldset
- textarea(
+ textarea
.solution-edit
(
:placeholder="st.tr['Solution']"
:placeholder="st.tr['Solution']"
+ @input="adjustHeight('solution')"
v-model="curproblem.solution"
)
p(v-html="parseHtml(curproblem.solution)")
v-model="curproblem.solution"
)
p(v-html="parseHtml(curproblem.solution)")
@@
-210,6
+212,12
@@
export default {
document.getElementById("inputFen").focus();
}
},
document.getElementById("inputFen").focus();
}
},
+ adjustHeight: function(elt) {
+ // https://stackoverflow.com/a/48460773
+ let t = document.querySelector("." + elt + "-edit");
+ t.style.height = "";
+ t.style.height = (t.scrollHeight + 3) + "px";
+ },
setVname: function(prob) {
prob.vname = this.st.variants.find(v => v.id == prob.vid).name;
},
setVname: function(prob) {
prob.vname = this.st.variants.find(v => v.id == prob.vid).name;
},
@@
-281,7
+289,10
@@
export default {
},
parseHtml: function(txt) {
return !txt.match(/<[/a-zA-Z]+>/)
},
parseHtml: function(txt) {
return !txt.match(/<[/a-zA-Z]+>/)
- ? txt.replace(/\n/g, "<br/>") //no HTML tag
+ ?
+ // No HTML tag
+ txt.replace(/\n\n/g, "<br/><div class='br'></div>")
+ .replace(/\n/g, "<br/>")
: txt;
},
changeVariant: function(prob) {
: txt;
},
changeVariant: function(prob) {
@@
-394,6
+405,8
@@
export default {
},
prepareNewProblem: function() {
this.resetCurProb();
},
prepareNewProblem: function() {
this.resetCurProb();
+ this.adjustHeight("instructions");
+ this.adjustHeight("solution");
window.doClick("modalNewprob");
},
sendProblem: function() {
window.doClick("modalNewprob");
},
sendProblem: function() {
@@
-441,6
+454,8
@@
export default {
// prob.diag might correspond to some other problem or be empty:
this.setDiagram(prob); //V is loaded at this stage
this.copyProblem(prob, this.curproblem);
// prob.diag might correspond to some other problem or be empty:
this.setDiagram(prob); //V is loaded at this stage
this.copyProblem(prob, this.curproblem);
+ this.adjustHeight("instructions");
+ this.adjustHeight("solution");
window.doClick("modalNewprob");
},
deleteProblem: function(prob) {
window.doClick("modalNewprob");
},
deleteProblem: function(prob) {
@@
-479,7
+494,7
@@
export default {
this.decorate(res.problems);
this.problems[mode] =
this.problems[mode].concat(res.problems)
this.decorate(res.problems);
this.problems[mode] =
this.problems[mode].concat(res.problems)
- // TODO: problems are alrady sorted, would just need to insert
+ // TODO: problems are alr
e
ady sorted, would just need to insert
// the current individual problem in list; more generally
// there is probably only one misclassified problem.
// (Unless the user navigated several times by URL to show a
// the current individual problem in list; more generally
// there is probably only one misclassified problem.
// (Unless the user navigated several times by URL to show a
@@
-498,6
+513,9
@@
export default {
<style lang="sass">
@import "@/styles/_board_squares_img.sass"
@import "@/styles/_rules.sass"
<style lang="sass">
@import "@/styles/_board_squares_img.sass"
@import "@/styles/_rules.sass"
+.br
+ display: block
+ margin: 10px 0
</style>
<style lang="sass" scoped>
</style>
<style lang="sass" scoped>
@@
-505,11
+523,26
@@
export default {
max-width: 767px
max-height: 100%
max-width: 767px
max-height: 100%
+#rulesDiv > .card
+ padding: 5px 0
+ max-width: 50%
+ max-height: 100%
+ @media screen and (max-width: 1500px)
+ max-width: 67%
+ @media screen and (max-width: 1024px)
+ max-width: 85%
+ @media screen and (max-width: 767px)
+ max-width: 100%
+
#inputFen
width: 100%
textarea
width: 100%
#inputFen
width: 100%
textarea
width: 100%
+ &.instructions-edit
+ min-height: 70px
+ &.solution-edit
+ min-height: 100px
#diagram
margin: 0 auto
#diagram
margin: 0 auto