All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.dominokit.domino.ui.cards.Card Maven / Gradle / Ivy

There is a newer version: 1.0.139
Show newest version
package org.dominokit.domino.ui.cards;

import elemental2.dom.*;
import org.dominokit.domino.ui.grid.flex.FlexAlign;
import org.dominokit.domino.ui.grid.flex.FlexItem;
import org.dominokit.domino.ui.grid.flex.FlexLayout;
import org.dominokit.domino.ui.icons.BaseIcon;
import org.dominokit.domino.ui.icons.Icons;
import org.dominokit.domino.ui.keyboard.KeyboardEvents;
import org.dominokit.domino.ui.style.Color;
import org.dominokit.domino.ui.style.Style;
import org.dominokit.domino.ui.style.Styles;
import org.dominokit.domino.ui.utils.BaseDominoElement;
import org.dominokit.domino.ui.utils.DominoElement;
import org.dominokit.domino.ui.utils.HasBackground;
import org.dominokit.domino.ui.utils.TextNode;
import org.jboss.elemento.EventType;
import org.jboss.elemento.HtmlContentBuilder;
import org.jboss.elemento.IsElement;

import static java.util.Objects.isNull;
import static java.util.Objects.nonNull;
import static org.dominokit.domino.ui.cards.CardStyles.*;
import static org.jboss.elemento.Elements.*;

public class Card extends BaseDominoElement implements HasBackground {

    private final FlexItem logoContainer;
    private DominoElement root = DominoElement.div().addCss(CARD);
    private DominoElement header = DominoElement.div().addCss(HEADER);
    private DominoElement headerTitle = DominoElement.of(h(2));
    private DominoElement headerDescription = DominoElement.of(small());
    private DominoElement headerBar = DominoElement.of(ul()).addCss(HEADER_ACTIONS);
    private DominoElement body = DominoElement.div().addCss(BODY);

    private Text title = TextNode.empty();
    private Text description = TextNode.empty();
    private boolean collapsible = false;
    private HTMLLIElement collapseAction;
    private BaseIcon collapseIcon;
    private Color headerBackground;
    private Color bodyBackground;
    private HtmlContentBuilder collapseAnchor;

    public Card() {
        headerTitle
                .appendChild(title)
                .appendChild(headerDescription);

        logoContainer = FlexItem.create();
        header.appendChild(FlexLayout.create()
                .appendChild(logoContainer
                        .css(Styles.m_r_10)
                        .setAlignSelf(FlexAlign.CENTER))
                .appendChild(FlexItem.create()
                        .setAlignSelf(FlexAlign.CENTER)
                        .setFlexGrow(1)
                        .appendChild(headerTitle))
                .appendChild(FlexItem.create().appendChild(headerBar))
        );

        root.appendChild(header)
                .appendChild(body);

        headerDescription.appendChild(description);

        body.getCollapsible().addHideHandler(() -> {
            if (collapsible) {
                collapseIcon.element().textContent = Icons.ALL.keyboard_arrow_down().getName();
            }
        });

        body.getCollapsible().addShowHandler(() -> {
            if (collapsible) {
                collapseIcon.element().textContent = Icons.ALL.keyboard_arrow_up().getName();
            }
        });

        init(this);
    }

    public static Card create() {
        Card card = new Card();
        card.header.hide();
        return card;
    }

    public static Card create(String title) {
        Card card = new Card();
        card.setTitle(title);
        return card;
    }

    public static Card create(String title, String description) {
        Card card = new Card();
        card.setTitle(title);
        card.setDescription(description);
        return card;
    }

    public static Card createProfile(String name, String info) {
        Card profileCard = Card.create(name, info);
        profileCard.style().setMarginBottom("0px");
        profileCard.setBackground(Color.THEME);
        return profileCard;
    }

    public Card setTitle(String titleText) {
        title.textContent = titleText;
        return this;
    }

    public Card setDescription(String descriptionText) {
        description.textContent = descriptionText;
        return this;
    }


    public Card appendDescriptionChild(Node node) {
        headerDescription.appendChild(node);
        return this;
    }

    public Card appendDescriptionChild(IsElement element) {
        return appendDescriptionChild(element.element());
    }


    public Card appendChild(Node content) {
        getBody().appendChild(content);
        return this;
    }

    public Card appendChild(IsElement element) {
        getBody().appendChild(element.element());
        return this;
    }

    public Card setHeaderBackground(Color headerBackground) {
        if (nonNull(this.headerBackground)) {
            header.style().remove(this.headerBackground.getBackground());
        }
        this.headerBackground = headerBackground;
        header.style().add(headerBackground.getBackground());
        return this;
    }

    public Card setBodyBackground(Color bodyBackground) {
        if (nonNull(this.bodyBackground)) {
            body.style().remove(this.bodyBackground.getBackground());
        }
        this.bodyBackground = bodyBackground;
        body.style().add(bodyBackground.getBackground());
        return this;
    }

    public Card fitContent() {
        style.add(FIT_CONTENT);
        return this;
    }

    public Card unFitContent() {
        style.remove(FIT_CONTENT);
        return this;
    }

    @Override
    public Card setBackground(Color background) {
        setHeaderBackground(background);
        setBodyBackground(background);
        return this;
    }

    public DominoElement getHeader() {
        return header;
    }

    public DominoElement getHeaderBar() {
        return headerBar;
    }

    public DominoElement getBody() {
        return body;
    }

    public DominoElement getHeaderTitle() {
        return headerTitle;
    }

    public DominoElement getHeaderDescription() {
        return headerDescription;
    }

    public static HTMLLIElement createIcon(BaseIcon icon) {
        return li().add(
                a().add(icon))
                .element();
    }

    public Card addHeaderAction(BaseIcon icon, EventListener eventListener) {
        HTMLLIElement actionItem = createHeaderAction(icon);
        actionItem.addEventListener("click", eventListener);

        putAction(actionItem);

        return this;
    }

    public Card addHeaderAction(HeaderAction headerAction) {
        putAction(headerAction.element());
        return this;
    }

    private void putAction(HTMLLIElement actionItem) {
        if (nonNull(collapseAction) && collapsible) {
            headerBar.insertBefore(actionItem, collapseAction);
        } else {
            headerBar.appendChild(actionItem);
        }
    }

    private HTMLLIElement createHeaderAction(BaseIcon icon) {
        return li().add(collapseAnchor = a()
                .attr("tabindex", "0")
                .attr("aria-expanded", "true")
                .attr("href", "#")
                .on(EventType.click, Event::preventDefault)
                .add(icon
                        .clickable()
                        .styler(style -> style
                                .add(Styles.pull_right, ACTION_ICON))))
                .element();
    }

    public Card setCollapsible() {
        collapseIcon = Icons.ALL.keyboard_arrow_up();

        collapseIcon.setAttribute("tabindex", "0");

        if (isNull(collapseAction)) {
            collapseAction = createHeaderAction(collapseIcon);
        }

        KeyboardEvents.listenOn(collapseAction).onEnter(evt -> switchVisibilty());

        collapseAction.addEventListener("click", evt -> switchVisibilty());

        putAction(collapseAction);

        this.collapsible = true;

        return this;
    }

    private void switchVisibilty() {
        if (collapsible) {
            if (body.getCollapsible().isHidden()) {
                show();
                collapseAnchor.element().setAttribute("aria-expanded", "true");
            } else {
                hide();
                collapseAnchor.element().setAttribute("aria-expanded", "false");
            }
        }
    }

    public Card toggle() {
        if (isHidden()) {
            show();
        } else {
            hide();
        }
        return this;
    }

    @Override
    public Card show() {
        body.getCollapsible().show();
        return this;
    }

    @Override
    public Card hide() {
        body.getCollapsible().hide();
        return this;
    }

    @Override
    public boolean isHidden() {
        return body.getCollapsible().isHidden();
    }

    public Card setBodyPadding(String padding) {
        body.style().setPadding(padding);
        return this;
    }

    public Card setBodyPaddingLeft(String padding) {
        body.style().setPaddingLeft(padding);
        return this;
    }

    public Card setBodyPaddingRight(String padding) {
        body.style().setPaddingRight(padding);
        return this;
    }

    public Card setBodyPaddingTop(String padding) {
        body.style().setPaddingTop(padding);
        return this;
    }

    public Card setBodyPaddingBottom(String padding) {
        body.style().setPaddingBottom(padding);
        return this;
    }

    public Card setHeaderLogo(Node node) {
        logoContainer.clearElement();
        logoContainer.appendChild(node);
        return this;
    }

    public Card setHeaderLogo(IsElement element) {
        setHeaderLogo(element.element());
        return this;
    }

    public Card showHeader() {
        return setHeaderVisible(true);
    }

    public Card hideHeader() {
        return setHeaderVisible(false);
    }

    public Card setHeaderVisible(boolean headerVisible) {
        this.header.toggleDisplay(headerVisible);
        return this;
    }

    public BaseIcon getCollapseIcon() {
        return collapseIcon;
    }

    public Style> bodyStyle() {
        return body.style();
    }

    public Card clearBody() {
        getBody().clearElement();
        return this;
    }

    @Override
    public HTMLDivElement element() {
        return root.element();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy