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

CSS Calc Problem

March 08 (5 years ago)

Edited March 08 (5 years ago)
Rago
Pro

I noticed when I set the width property of a HTML element directly on the style attribute (instead use a class) the widths were I used "calc" are ignored (they shows as having blank value on inspection).


Source:

                      <label style="width: calc(2 * (100% / 3) - 6px);margin: 0px 1px 0px 5px">Unit</label>
                      <label style="width: calc(100% / 3 - 6px);margin: 0px 1px 0px 5px">Class</label>


Inspect:



Does anyone experienced that and know how to solve it? (I mean, besides creating a different CSS class for each single-used width size).

I really rather avoid creating a class for each of those widths...



March 08 (5 years ago)
GiGs
Pro
Sheet Author
API Scripter

Its probably because of the limited DOM we have access to as sheet makes. Roll20 has locked down a lot of features for security reasons - no jquery style scripting, for instance.

In any case, you should really be using CSS in place of style in every instance. 

With your example code, I'd create 3 classes

.sheet-twothirds {    width: calc(2 * (100% / 3) - 6px); }
.sheet-onethirds {    width: calc(100% / 3 - 6px); }
.sheet-thirdsmargin {    margin: 0px 1px 0px 5px; }

then use them

<label style="twothirds thirdsmargin">Unit</label>
<label class="onethirds thirdsmargin">Class</label>

I probably wouldnt use those class names, but you get the idea.

March 08 (5 years ago)

Edited March 08 (5 years ago)
Rago
Pro

Yeah.. "calc" is just pure css, but I understand.

I'll create a single class for each width; thanks!

March 08 (5 years ago)
vÍnce
Pro
Sheet Author

Sidenote; as a rule of thumb, try to only include an inline style as a last resort.  Sidenote 2; same goes for using "!important" in css. Both cause headaches down the road when you or someone else needs to make style changes.

March 08 (5 years ago)
Finderski
Pro
Sheet Author
Compendium Curator

Sidenote 3, for some reason I've found the input types of number get overridden (at least for the width) by the .charsheet styling, so for numbers I've always had to either use inline styling or !important in the css for any number fields.

March 08 (5 years ago)

Edited March 08 (5 years ago)
vÍnce
Pro
Sheet Author

@Finderski 

That's interesting.  Seems that you could just add more specificity (I love saying that...) to override anything that roll20's css might be affecting.

e.g.  .charsheet input[type="number"].sheet-my-style-rules-all { ... }

hmm. Is it OK to include .charsheet in our sheet css?

cool tool to check specificity https://codepen.io/certainlyakey/pen/ycEAh

I think I recall needing to use !important on some of the repcontrol elements or similar roll20-specific html/css. I do abuse the heck out of !important with the stylus extension.

Sorry for hi-jacking your thread Rago. ;-(

March 08 (5 years ago)
Caden
Forum Champion
Sheet Author
API Scripter
Compendium Curator

@Finderski can you provide an example ? I almost never use inline styles or !important for inputs. Are you doing input[type="number"] ? Doing just input may result in the inherent style overriding your option.


@Rago

Inline styles are a bad practice. They cause a cascading override issue and often create unnecessary excess code.A better solution if you want to avoid making multiple classes is to use CSS Selectors. In particular nth-of-type() can be really useful for this.

In this example all of your labels will use the same margin. Label 1 will have a different width than label 2.

HTML:

<div class="example">
    <label>1</label>
    <label>2</label>
</div>

CSS:

div.sheet-example label {
   margin: 0px 1px 0px 5px;
 }
div.sheet-example label:nth-of-type(1) { 
    width: calc(2 * (100% / 3) - 6px);
}
div.sheet-example label:nth-of-type(2) {
    width: calc(100% / 3 - 6px);
}
March 09 (5 years ago)

Edited March 09 (5 years ago)
Rago
Pro

@Cassie, CSS selectors can't solve the problem this time; it's really a bunch of 1 or 2 elements of same size (for many sizes...); in the end I created a CSS for all of them.

@Vince, I'm well aware of both practices, I was just trying to avoid create too many css classes. Also, speaking about Roll20 charsheet, it is nearly  impossible avoid !important (that's kinda bad, I know) - the default css has too many weird element style preset (like margins and padding, arg!). I do abuse of !important on Character sheets. I think this specific point is one strong factor that make a large number of premade character sheets visually unappealing. (that was in fact exactly what made me subscribe to pro... the ability to create my own character sheets.... very aligned character sheets).


March 09 (5 years ago)
GiGs
Pro
Sheet Author
API Scripter

I've never found a situation that needs !important. I have used it a few times till i figured out exactly what was needed to remove it - it can be very hard, but there's always a way. You just need to be extremely specific with the classes in some cases.

March 09 (5 years ago)

Edited March 09 (5 years ago)
GiGs
Pro
Sheet Author
API Scripter


Finderski said:

Sidenote 3, for some reason I've found the input types of number get overridden (at least for the width) by the .charsheet styling, so for numbers I've always had to either use inline styling or !important in the css for any number fields.

As Vince says, you shouldnt need to do that. Either

 input[type="number"]

or 

 input[type="number"].sheet-some-style {}

should override the sheet styling. I dont know if the first is enough, but the second should be.

Edit: oops just noticed Cassie said the same thing.

Vince said:

hmm. Is it OK to include .charsheet in our sheet css?

You can, but I'm not sure it does anything because I think its prepended to all user styles automatically, in the same way sheet- is added to class names. I could be wrong, I've never tested, but it's always there when i examine styles in Chrome Inspector.


cool tool to check specificity https://codepen.io/certainlyakey/pen/ycEAh
That site looks interesting. I'll definitely be playing around with it.

March 10 (5 years ago)
Rago
Pro

@GiGs

 input[type="number"]

This should not be enough, but the second option...

 input[type="number"].sheet-some-style {}

...should.

CSS tries to prioritize by "how much specific" is your selector, and that's more specific than just a class.

BUT increase the selector specificity on purpose just to override a style is arguably as bad as !important - but, at least "!important" exists exactly for that - override styles you don't have control over.

March 10 (5 years ago)
Finderski
Pro
Sheet Author
Compendium Curator


Cassie said:

@Finderski can you provide an example ? I almost never use inline styles or !important for inputs. Are you doing input[type="number"] ? Doing just input may result in the inherent style overriding your option.


@Rago

Inline styles are a bad practice. They cause a cascading override issue and often create unnecessary excess code.A better solution if you want to avoid making multiple classes is to use CSS Selectors. In particular nth-of-type() can be really useful for this.

In this example all of your labels will use the same margin. Label 1 will have a different width than label 2.

HTML:

<div class="example">
    <label>1</label>
    <label>2</label>
</div>

CSS:

div.sheet-example label {
   margin: 0px 1px 0px 5px;
 }
div.sheet-example label:nth-of-type(1) { 
    width: calc(2 * (100% / 3) - 6px);
}
div.sheet-example label:nth-of-type(2) {
    width: calc(100% / 3 - 6px);
}

Look at the current Savage Worlds Tabbed character sheet on the Vehicle tab...the left hand column of inputs have differently sized inputs (I think that changed when there were some updates that caused a lot of CSS havoc on character sheets a while back, because they were all sized the same initially).  As I've been re-writing the sheet, I've had to use !important because I didn't think to use your method of input[type="number"].class (not an HTML guy...just picked up enough to do a character sheet or two).  I realize it's about specificity and just found it frustrating that the roll20 class kept overriding my class.  So...I'm lazy and just started using !important on number fields.

March 11 (5 years ago)

Edited March 11 (5 years ago)
Rago
Pro

 I realize it's about specificity and just found it frustrating that the roll20 class kept overriding my class.  So...I'm lazy and just started using !important on number fields.

Laziness is about to make short work now thinking less about the future updates. Settings style by element (instead of use classes) is laziness; even more then you know some children code will be influenced. I love Roll20, I'm a Pro subscriber for some time now and do not think about change that, but I really have a bad image about current sheet customization.

When the parent CSS is out of your hand, already full of present and may change it is SAFER to enforce your style - not lazy.

Nothing should be preset on the sheet character style.

March 11 (5 years ago)
Natha
KS Backer
Sheet Author
API Scripter


Finderski said:

Sidenote 3, for some reason I've found the input types of number get overridden (at least for the width) by the .charsheet styling, so for numbers I've always had to either use inline styling or !important in the css for any number fields.

Using an CSS class often resolves the problem (which is real).