Roll20 uses cookies to improve your experience on our site. Cookies enable you to enjoy certain features, social sharing functionality, and tailor message and display ads to your interests on our site and others. They also help us understand how our site is being used. By continuing to use our site, you consent to our use of cookies. Update your cookie preferences .
×
Create a free account

Request help for HTML 'collapse text' function

March 15 (6 years ago)
Rain
Plus
Sheet Author
Hi all, I'm trying to improve my Monster of the Week sheet and want to place some collapsible text on the sheet so people can see the starting options for the character, then hide it so it doesn't take up space once finished. 

Looking online I have tried this code: 

<div>
<button type="button" data-toggle="collapse" data-target="#demo">Simple collapsible</button>
<div id="demo">
[text here]
</div>
</div>

This produces a button which is clickable, but doesn't actually  do anything, the text does not collapse. Can anyone help me find what is wrong or give me some code that will work as I am not a software programmer. (I'm amazed I got this far). Also I don't want it to only be text, it was have lists of options etc so I just need a collapsible section that I can put anything into.

Thanks all (again)

March 15 (6 years ago)

Edited March 15 (6 years ago)
vÍnce
Pro
Sheet Author
You cannot use id's on roll20 since they would effect all sheets in the game.
https://wiki.roll20.net/Building_Character_Sheets#...
Here's a css example of hiding areas.
https://wiki.roll20.net/CSS_Wizardry#Hide_Areas
I believe you can "simulate" a button by using pseudo elements 
https://wiki.roll20.net/CSS_Wizardry#Styling_Check...
March 15 (6 years ago)
Rain
Plus
Sheet Author
Thanks
March 15 (6 years ago)
Rain
Plus
Sheet Author
This from the link also does not work unless I'm doing it wrong

<div>
<input type="checkbox">
<h4>Stuff and Things</h4>
<div>
<input type="text" placeholder="Name" name="attr_name"><br>
<input type="text" placeholder="Description" name="attr_description">
<input type="number" min="0" max="20" value="0" name="attr_level"><br>
<textarea placeholder="Fulltext" name="attr_bio"></textarea>
</div>
</div>
March 15 (6 years ago)
vÍnce
Pro
Sheet Author
Can you post your relevant
css and html 
that will help figure out what's not working and how to fix it.  Thanks
March 15 (6 years ago)
chris b.
Pro
Sheet Author
API Scripter

for html the first checkbox should be something lke
<input type="checkbox" name="attr_hideinstructions" class="sheet-hide-next-div" value="1" /> hide next area!

then in css something like this (not tested)

.sheet-hide-next-div:checked ~ div {
	display:none;
}

March 16 (6 years ago)

Edited March 16 (6 years ago)
Rain
Plus
Sheet Author
So here is my CSS. It's basically a sheet where you choose the class you want and then the sheet for that class comes up: 

div.sheet-Null,
div.sheet-Chosen,
div.sheet-Crooked,
div.sheet-Divine,
div.sheet-Expert,
[[etc]]
div.sheet-Custom
{
display: none;
}
input[type="radio"][value="0"]:checked ~ div.sheet-Null,
input[type="radio"][value="1"]:checked ~ div.sheet-Chosen,
input[type="radio"][value="2"]:checked ~ div.sheet-Crooked,
[[etc]]
input[type="radio"][value="99"]:checked ~ div.sheet-Custom
{
display: block;
}
select.sheet-SkinSelect
{
position: relative;
top: 4px;
}
option.sheet-SkinSelect:checked
{
display: none;
}

What I want is for a portion within each of those class sheets to be collapsible once people have chosen their starting stats. I have no current html for the collapsing section- that's what I'm trying to figure out, but the start is choosing a class: 

<div>
<p align="center"><div><p align="center">
<b><i>Name:</i></b> <input type="text" name="attr_CharName" />
<b><i>Gender:</i></b> <input type="text" name="attr_Gender">
<b><i>Playbook:</i></b>
<select name="attr_SkinName" >
<option value="0" checked="checked"> Choose A Playbook</option>
<option value="1"> The Chosen</option>
[[etc]]
<option value="99"> Custom Playbook</option>
</select>
</p></div>
<div><p align="center"><b><i>Look:</i></b> <input type="text" name="attr_Look" style="width: 750px"><br>
</div>
<input type="radio" name="attr_SkinCheck" value="0" checked="checked"> <input type="radio" name="attr_SkinCheck" value="1"> 
[[etc]]
 <input type="radio" name="attr_SkinCheck" value="99">
<div><p align="center"><b><i>Select a Playbook above to get started</i></b></p></div>

Then once they choose a class the relevant sheet comes up and what I want is for the collapsible portion to be ther so they choose Class A and the starting options for class A come up (stats, look, etc) then they can fill in which options they choose and collapse it so that it doesn't take up space:

<div name="sheet-Chosen">
[[Collapsible portion here]]
<div><p align="center">
[[character sheet is here]]

March 16 (6 years ago)

Edited March 16 (6 years ago)
GiGs
Pro
Sheet Author
API Scripter
I've had more success with the "not" version of CSS values for this.
First, either create a hidden attribute and stick it at the start of your sheet:
<input type="hidden" name="attr_SkinCheck" class="toggle-playbook" value="0">
or add the class to each of your skincheck radio buttons.
You need that class for the bit below.

You will need to put all the skinchecks inside a styled div, like say <div class="sheet-skinselections">
You'll need a checkbox or some thing to allow you to switch between the selections and character sheet.

So maybe the html will look something like this. Note those 99 radio buttons you had have been removed, and replaced with divs.
<input type="hidden" name="attr_SkinCheck" class="toggle-playbook" value="1">

<div>
    <p align="center"><div><p align="center">
        <b><i>Name:</i></b>  <input type="text" name="attr_CharName" />   
        <b><i>Gender:</i></b> <input type="text" name="attr_Gender">   
        <b><i>Playbook:</i></b>         
            <select name="attr_SkinName" class="toggle-playbook"> <!-- add class here for CSS -->
                <option value="0" checked="checked"> Choose A Playbook</option> <!-- does checked=checked work here? I've never tried that. -->
                <option value="1"> The Chosen</option>
[[etc]]
                <option value="99"> Custom Playbook</option>
            </select>
    </p></div>
    <div><p align="center"><b><i>Look:</i></b> <input type="text" name="attr_Look" style="width: 750px"><br>
    </div>
    <div class="sheet-playbook0"> <!-- add class here for CSS -->
	<!-- list some instructions here, this is what will show up by default with 0 in the select. -->

    </div>
    <div class="sheet-playbook1"> <!-- add class here for CSS -->


    </div>
    <div class="sheet-playbook2">


    </div>
<!-- and so on -->
    <div class="sheet-playbook99">


    </div>
Each playbook will need to be inside its own named div, like <div class="sheet-playbook1"> Obviously you can switch them to "sheet-Chosen" and so on, just make sure they are matched up with their values in the select for the CSS below

Then in CSS,
input.toggle-playbook:not([value='0']) ~ div.sheet-playbook0, // you might use "0" for some instructions
input.toggle-playbook:not([value='1']) ~ div.sheet-playbook1, 
input.toggle-playbook:not([value='2']) ~ div.sheet-playbook2,
... etc
input.toggle-playbook:not([value='99']) ~ div.sheet-playbook99 {
    display: none;
}
With this approach, if I've got my code right, whenever you select a playbook in the selection drop down, that playbook's div will become visible. 
March 16 (6 years ago)

Edited March 16 (6 years ago)
vÍnce
Pro
Sheet Author

G G said:

I've had more success with the "not" version of CSS values for this.

GG, I'm just ignorant (go figure) ;-P
would you mind elaborating a little?

input.toggle-playbook:not([value='0']) ~ div.sheet-playbook0 {display:none;} 
vs 
input[value="0"].toggle-playbook:checked ~ div.sheet-playbook0 {display:block;}

I believe that's the right syntax... Won't they accomplish the same thing?

Thanks
March 19 (6 years ago)
Rain
Plus
Sheet Author
Does this hide or show the whole sheet? Because I only want a portion of the sheet to be hidden and it's different info for every sheet. At the moment you choose a playbook and that playbook's info comes up. 
What I want is a portion within that which is collapsible for certain info
March 19 (6 years ago)

Edited March 19 (6 years ago)
Jakob
Sheet Author
API Scripter
Here's a generic code you can use for collapsible sections (change the bold name to match every instance, unless you want them all to be collapsed or be shown at the same time, which would be fine for playbook details, since you're only ever going to see one of them). Just put this wherever you want it to be. Depending on how you want it to look, you can of course tweak it, but this should be a base for you to work from.
<input type="checkbox" class="sheet-hider" name="attr_show_details" value="1" checked="checked"><span>Show details?</span>
<div>
  <!-- your content -->
</div>
CSS:
.sheet-hider:not(:checked) + span + div {
  display: none;
}
GG, I'm just ignorant (go figure) ;-P
would you mind elaborating a little?

input.toggle-playbook:not([value='0']) ~ div.sheet-playbook0 {display:none;}
vs
input[value="0"].toggle-playbook:checked ~ div.sheet-playbook0 {display:block;}

I believe that's the right syntax... Won't they accomplish the same thing?
There's two different things going on here:
1) GG is using a hidden input instead of checkboxes, so that it's possible to use a selector with [value="xxx"] instead of :checked - this means that only one input is necessary, instead of having to have a different input for every tab (which is fine if the tab radios are siblings to the tabs anyway, but painful if they're not).
2) GG is using the :not() instead of first setting display:none and then resetting it if it should be displayed, which makes for shorter and easier-to-debug code (If you do not use :not(), you will always have to have 2 CSS rules: one setting display:none for every element by default, and one that resets the display property to block (or something else) under the right conditions. :not() allows you to only have one rule).
March 19 (6 years ago)
GiGs
Pro
Sheet Author
API Scripter
Jakob explained it better than I could. since I'm still learning CSS too :)
March 19 (6 years ago)

Edited March 19 (6 years ago)
Jakob
Sheet Author
API Scripter

G G said:

Jakob explained it better than I could. since I'm still learning CSS too :)

So am I. :)

As an aside, I would recommend that you give a descriptive value to your tab radios/select options instead of a number ... e.g.
value="chosen"
instead of
value="1"
etc in the HTML, and corresponding changes in the CSS. That saves you the need to keep track of which number belongs to which playbook... . Of course, this is a bit more problematic if this is a sheet that has already been published, since the choice does not transfer for existing sheets without some extra work.
March 19 (6 years ago)
vÍnce
Pro
Sheet Author
Thanks for the extra explanation.  I often use the hidden input method.  I don't have to work as hard when creating a bunch of selector rules to the various elements I want to hide. 
April 06 (6 years ago)
Rain
Plus
Sheet Author
Thanks very much everyone. 

Jakob you are amazing, the code worked perfectly and now I can make my sheets much more user friendly so they won't need the paper sheets to get set up with characters. You're all great. 

/topic closed