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

org.dominokit.domino.ui.loaders.IosLoader Maven / Gradle / Ivy

/*
 * Copyright © 2019 Dominokit
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.dominokit.domino.ui.loaders;

import static org.dominokit.domino.ui.utils.Domino.*;

import elemental2.dom.HTMLDivElement;
import org.dominokit.domino.ui.IsElement;
import org.dominokit.domino.ui.elements.DivElement;
import org.dominokit.domino.ui.style.GenericCss;
import org.dominokit.domino.ui.utils.DominoElement;

/**
 * A loader component that displays an iOS-style loader animation to indicate progress or loading.
 *
 * 

This loader consists of twelve bouncing elements forming an iOS-style animation. * *

Example usage: * *

 * IosLoader loader = IosLoader.create();
 * loader.setSize("50px", "50px");
 * loader.setLoadingText("Loading...");
 * // Add the loader to a container element
 * container.appendChild(loader.element());
 * 
*/ public class IosLoader extends BaseLoader implements IsElement { private final DivElement progress1 = div().addCss(wait_me_progress_elem_1, dui_loader_darker); private final DivElement progress2 = div().addCss(wait_me_progress_elem_2, dui_loader_darker); private final DivElement progress3 = div().addCss(wait_me_progress_elem_3, dui_loader_darker); private final DivElement progress4 = div().addCss(wait_me_progress_elem_4, dui_loader_darker); private final DivElement progress5 = div().addCss(wait_me_progress_elem_5, dui_loader_darker); private final DivElement progress6 = div().addCss(wait_me_progress_elem_6, dui_loader_darker); private final DivElement progress7 = div().addCss(wait_me_progress_elem_7, dui_loader_darker); private final DivElement progress8 = div().addCss(wait_me_progress_elem_8, dui_loader_darker); private final DivElement progress9 = div().addCss(wait_me_progress_elem_9, dui_loader_darker); private final DivElement progress10 = div().addCss(wait_me_progress_elem_10, dui_loader_darker); private final DivElement progress11 = div().addCss(wait_me_progress_elem_11, dui_loader_darker); private final DivElement progress12 = div().addCss(wait_me_progress_elem_12, dui_loader_darker); private final DivElement loader = div() .addCss(wait_me_progress, ios) .appendChild(progress1) .appendChild(progress2) .appendChild(progress3) .appendChild(progress4) .appendChild(progress5) .appendChild(progress6) .appendChild(progress7) .appendChild(progress8) .appendChild(progress9) .appendChild(progress10) .appendChild(progress11) .appendChild(progress12); private final DivElement content = div() .addCss(wait_me_content, GenericCss.dui_vertical_center) .appendChild(div().appendChild(loader).appendChild(loadingText)); private final DivElement element = div().addCss(wait_me).style("background: var(--dui-loader-background);").appendChild(content); /** Initializes a new instance of the {@code IosLoader} class. */ public IosLoader() { init(this); } /** * Creates a new instance of the {@code IosLoader} class. * * @return A new {@code IosLoader} instance. */ public static IosLoader create() { return new IosLoader(); } /** * Sets the loading text to be displayed by the loader. * * @param text The text to display as loading text. */ @Override public void setLoadingText(String text) { loadingText.textContent = text; } /** * Sets the size of the loader. * * @param width The width of the loader. * @param height The height of the loader. */ @Override public void setSize(String width, String height) { onAttached(mutationRecord -> loader.setWidth(width).setHeight(height)); } /** Removes the loading text from the loader. */ @Override public void removeLoadingText() { onAttached(mutationRecord -> loadingText.remove()); } /** * Gets the content element of the loader. * * @return A {@code DominoElement} representing the content element. */ @Override public DominoElement getContentElement() { return content.toDominoElement(); } /** * Gets the HTMLDivElement element associated with this loader. * * @return The HTMLDivElement element of the loader. */ @Override public HTMLDivElement element() { return element.element(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy