question-mark
Stuck on an issue?

Lightrun Answers was designed to reduce the constant googling that comes with debugging 3rd party libraries. It collects links to all the places you might be looking at while hunting down a tough bug.

And, if you’re still stuck at the end, we’re happy to hop on a call to see how we can help out.

Stylesheet not applying to button control

See original GitHub issue

I have gone through the page on how to apply css classes programmatically by extending the Stylesheet class. The problem I am having, and I’m sure the solution to correct this is simple, is that when applying the stylesheet to the app, like so:

open class MainApp : App() {
    private var mainWindow: MainWindow? = null
    private lateinit var springContext: AnnotationConfigApplicationContext

    init {
        importStylesheet(Styles::class) // <---- HERE
        reloadStylesheetsOnFocus()
    }
    ...
    private fun showMain() {
        try {
            this.mainWindow = springContext.getBean(MainWindow::class.java)
        } catch (e: BeansException) {
            if (mainWindow == null) {
                LOG.error("Failed to instantiate main window.", e)
                stop()
            }
        }
        val stage = Stage()
        stage.title = "Eve Ore Bust"
        stage.scene = Scene(this.mainWindow?.root)
        stage.isMaximized = true
        stage.isResizable = true
        stage.show()
        stage.toFront()
    }
}

With my style class:

class Styles : Stylesheet() {

    companion object {
        val navigation by cssclass()
    }

    init {
        navigation {
            button {
                backgroundColor += Color.RED
                textFill = Color.GREEN
                selected {
                    backgroundColor += Color.BLUE
                }
            }
        }
    }
}

And attempt to apply the navigation reverence to a button:

class NavMenu : View("Navigation View") {

    override var root = vbox()

    private val btnGeneral = button {
        addClass(Styles.navigation) // <---- HERE
        padding = Insets(5.0, 10.0, 5.0, 10.0)
        imageview("/images/icons/gear.png") {
            fitHeight = 25.0
            fitWidth = 25.0
        }
        alignment = Pos.CENTER_LEFT
        useMaxWidth = true
        graphicTextGap = 20.0
        text = "General"
    }

    init {
        with(root) {
            maxWidth = 150.0
            minWidth = 150.0
            add(btnGeneral)
    }
}

The style does not get applied to the button. However, the style properties will display when I apply those style properties directly in the button body.

The NavMenu is being added to my main view by:

@Component
class MainWindow @Autowired constructor(
    private val viewModel: MainWindowViewModel
) : View("Main Window") {
    override val root = vbox()

    @PostConstruct
    fun postConstruct() {
        ...
        with(root) {
            ...
            gridpane {
                visibleWhen { loggedIn }
                row {
                    constraintsForRow(0).apply {
                         percentHeight = 100.0
                    }
                    add(NavMenu()) // <---- HERE
                }
            }
        }
    }
}

Issue Analytics

  • State:closed
  • Created 4 years ago
  • Comments:11 (7 by maintainers)

github_iconTop GitHub Comments

1reaction
edvincommented, Jan 18, 2020

Give me some time and I’ll go through your examples and highlight the issues I see (hopefully later today), and explain what should be done differently. Almost every line in your code examples are sub optimal, except for the stylesheet which looks fine 😃 I figured you hadn’t looked much at the guide since it shouldn’t contain any code like this and on the contrary provides plenty of best practice examples.

0reactions
edvincommented, Jan 23, 2020

Thank you, Dallas 😃 I’m closing the issue for now. Will be good to get some fresh eyes on the guide!

Read more comments on GitHub >

github_iconTop Results From Across the Web

HTML/CSS Input Button Styling Not Working - Stack Overflow
Buttons have a lot of default styling attached to them. Consider implementing a reset stylesheet, like: Eric Meyer's Reset · Normalize.css.
Read more >
ASP.NET Core Blazor CSS isolation - Microsoft Learn
Isolate CSS styles to individual pages, views, and components to reduce or avoid: Dependencies on global styles that can be challenging to ...
Read more >
Dynamic style - manipulating CSS with JavaScript - W3C Wiki
In this article we will look at how to dynamically update the styling applied to your elements by manipulating your CSS at runtime...
Read more >
Telerik Web Forms Setting the CSS Class of Buttons
CssClass: controls the appearance of the button in all states. ... The CSS class of a button is applied to the anchor (<a>)...
Read more >
HTML button tag - W3Schools
That is not possible with a button created with the <input> element! ... Look at the examples below or visit our CSS Buttons...
Read more >

github_iconTop Related Medium Post

No results found

github_iconTop Related StackOverflow Question

No results found

github_iconTroubleshoot Live Code

Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free

github_iconTop Related Reddit Thread

No results found

github_iconTop Related Hackernoon Post

No results found

github_iconTop Related Tweet

No results found

github_iconTop Related Dev.to Post

No results found

github_iconTop Related Hashnode Post

No results found