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

org.dominokit.domino.ui.mediaquery.MediaQuery Maven / Gradle / Ivy

package org.dominokit.domino.ui.mediaquery;

import elemental2.dom.EventTarget;
import elemental2.dom.MediaQueryList;
import elemental2.dom.MediaQueryListListener;
import jsinterop.base.Js;

import java.util.HashMap;
import java.util.Map;

import static elemental2.dom.DomGlobal.window;

public class MediaQuery {

    private static final String XLARGE_MEDIA_QUERY = "(min-width: 1800px)";
    private static final String LARGE_MEDIA_QUERY = "(min-width: 1200px) and (max-width: 1800px)";
    private static final String MEDIUM_MEDIA_QUERY = "(min-width: 992px) and (max-width: 1200px)";
    private static final String SMALL_MEDIA_QUERY = "(min-width: 768px) and (max-width: 992px)";
    private static final String XSMALL_MEDIA_QUERY = "(max-width: 768px)";

    private static final String XLARGE_AND_UP_MEDIA_QUERY = "(min-width: 1800px)";
    private static final String LARGE_AND_UP_MEDIA_QUERY = "(min-width: 1200px)";
    private static final String MEDIUM_AND_UP_MEDIA_QUERY = "(min-width: 992px)";
    private static final String SMALL_AND_UP_MEDIA_QUERY = "(min-width: 768px)";
    private static final String XSMALL_AND_UP_MEDIA_QUERY = "(min-width: 0x)";

    private static final String XLARGE_AND_DOWN_MEDIA_QUERY = "(max-width: 1800px)";
    private static final String LARGE_AND_DOWN_MEDIA_QUERY = "(max-width: 1800px)";
    private static final String MEDIUM_AND_DPOWN_MEDIA_QUERY = "(max-width: 1200px)";
    private static final String SMALL_AND_DOWN_MEDIA_QUERY = "(max-width: 992px)";
    private static final String XSMALL_AND_DOWN_MEDIA_QUERY = "(max-width: 768px)";

    private static MediaQueryList xlargeMediaQueryList = window.matchMedia(XLARGE_MEDIA_QUERY);
    private static MediaQueryList largeMediaQueryList = window.matchMedia(LARGE_MEDIA_QUERY);
    private static MediaQueryList mediumMediaQueryList = window.matchMedia(MEDIUM_MEDIA_QUERY);
    private static MediaQueryList smallMediaQueryList = window.matchMedia(SMALL_MEDIA_QUERY);
    private static MediaQueryList xsmallMediaQueryList = window.matchMedia(XSMALL_MEDIA_QUERY);

    private static MediaQueryList xlargeAndUpMediaQueryList = window.matchMedia(XLARGE_AND_UP_MEDIA_QUERY);
    private static MediaQueryList largeAndUpMediaQueryList = window.matchMedia(LARGE_AND_UP_MEDIA_QUERY);
    private static MediaQueryList mediumAndUpMediaQueryList = window.matchMedia(MEDIUM_AND_UP_MEDIA_QUERY);
    private static MediaQueryList smallAndUpMediaQueryList = window.matchMedia(SMALL_AND_UP_MEDIA_QUERY);
    private static MediaQueryList xsmallAndUpMediaQueryList = window.matchMedia(XSMALL_AND_UP_MEDIA_QUERY);

    private static MediaQueryList xlargeAndDownMediaQueryList = window.matchMedia(XLARGE_AND_DOWN_MEDIA_QUERY);
    private static MediaQueryList largeAndDownMediaQueryList = window.matchMedia(LARGE_AND_DOWN_MEDIA_QUERY);
    private static MediaQueryList mediumAndDownMediaQueryList = window.matchMedia(MEDIUM_AND_DPOWN_MEDIA_QUERY);
    private static MediaQueryList smallAndDownMediaQueryList = window.matchMedia(SMALL_AND_DOWN_MEDIA_QUERY);
    private static MediaQueryList xsmallAndDownMediaQueryList = window.matchMedia(XSMALL_AND_DOWN_MEDIA_QUERY);


    private static Map listenersMap = new HashMap<>();
    private static Map mediaQueries = new HashMap<>();

    public static void addOnXLargeListener(MediaQueryListener listener) {
        addListener(listener, xlargeMediaQueryList);
    }

    public static void addOnLargeListener(MediaQueryListener listener) {
        addListener(listener, largeMediaQueryList);
    }

    public static void addOnMediumListener(MediaQueryListener listener) {
        addListener(listener, mediumMediaQueryList);
    }

    public static void addOnSmallListener(MediaQueryListener listener) {
        addListener(listener, smallMediaQueryList);
    }

    public static void addOnXSmallListener(MediaQueryListener listener) {
        addListener(listener, xsmallMediaQueryList);
    }

    public static void addOnXLargeAndUpListener(MediaQueryListener listener) {
        addListener(listener, xlargeAndUpMediaQueryList);
    }

    public static void addOnLargeAndUpListener(MediaQueryListener listener) {
        addListener(listener, largeAndUpMediaQueryList);
    }

    public static void addOnMediumAndUpListener(MediaQueryListener listener) {
        addListener(listener, mediumAndUpMediaQueryList);
    }

    public static void addOnSmallAndUpListener(MediaQueryListener listener) {
        addListener(listener, smallAndUpMediaQueryList);
    }

    public static void addOnXSmallAndUpListener(MediaQueryListener listener) {
        addListener(listener, xsmallAndUpMediaQueryList);
    }

    public static void addPortraitOrientationListener(MediaQueryListener listener) {
        addCustomQueryListener("(orientation : portrait)", listener);
    }

    public static void addLandscapeOrientationListener(MediaQueryListener listener) {
        addCustomQueryListener("(orientation : landscape)", listener);
    }

    public static void addOnXLargeAndDownListener(MediaQueryListener listener) {
        addListener(listener, xlargeAndDownMediaQueryList);
    }

    public static void addOnLargeAndDownListener(MediaQueryListener listener) {
        addListener(listener, largeAndDownMediaQueryList);
    }

    public static void addOnMediumAndDownListener(MediaQueryListener listener) {
        addListener(listener, mediumAndDownMediaQueryList);
    }

    public static void addOnSmallAndDownListener(MediaQueryListener listener) {
        addListener(listener, smallAndDownMediaQueryList);
    }

    public static void addOnXSmallAndDownListener(MediaQueryListener listener) {
        addListener(listener, xsmallAndDownMediaQueryList);
    }

    private static void addListener(MediaQueryListener listener, MediaQueryList mediaQueryList) {
        MediaQueryListListener mediaQueryListListener = p0 -> {
            if (p0.matches) {
                listener.onMatch();
            }
        };
        mediaQueryList.addListener(mediaQueryListListener);
        listenersMap.put(listener, mediaQueryListListener);
        mediaQueryListListener.onInvoke(mediaQueryList);
    }

    public static void removeOnXLargeListener(MediaQueryListener listener) {
        removeListener(listener, xlargeMediaQueryList);
    }

    public static void removeOnLargeListener(MediaQueryListener listener) {
        removeListener(listener, largeMediaQueryList);
    }

    public static void removeOnMediumListener(MediaQueryListener listener) {
        removeListener(listener, mediumMediaQueryList);
    }

    public static void removeOnSmallListener(MediaQueryListener listener) {
        removeListener(listener, smallMediaQueryList);
    }

    public static void removeOnXSmallListener(MediaQueryListener listener) {
        removeListener(listener, xsmallMediaQueryList);
    }

    public static void removeOnXLargeAndUpListener(MediaQueryListener listener) {
        removeListener(listener, xlargeAndUpMediaQueryList);
    }

    public static void removeOnLargeAndUpListener(MediaQueryListener listener) {
        removeListener(listener, largeAndUpMediaQueryList);
    }

    public static void removeOnMediumAndUpListener(MediaQueryListener listener) {
        removeListener(listener, mediumAndUpMediaQueryList);
    }

    public static void removeOnSmallAndUpListener(MediaQueryListener listener) {
        removeListener(listener, smallAndUpMediaQueryList);
    }

    public static void removeOnXSmallAndUpListener(MediaQueryListener listener) {
        removeListener(listener, xsmallMediaQueryList);
    }


    public static void removeOnXLargeAndDownListener(MediaQueryListener listener) {
        removeListener(listener, xlargeAndDownMediaQueryList);
    }

    public static void removeOnLargeAndDownListener(MediaQueryListener listener) {
        removeListener(listener, largeAndDownMediaQueryList);
    }

    public static void removeOnMediumAndDownListener(MediaQueryListener listener) {
        removeListener(listener, mediumAndDownMediaQueryList);
    }

    public static void removeOnSmallAndDownListener(MediaQueryListener listener) {
        removeListener(listener, smallAndDownMediaQueryList);
    }

    public static void removeOnXSmallAndDownListener(MediaQueryListener listener) {
        removeListener(listener, xsmallAndDownMediaQueryList);
    }

    private static void removeListener(MediaQueryListener listener, MediaQueryList mediaQueryList) {
        if (listenersMap.containsKey(listener)) {
            mediaQueryList.removeListener(listenersMap.get(listener));
            listenersMap.remove(listener);
        }
    }

    public static void addCustomQueryListener(String mediaQuery, MediaQueryListener listener) {
        if (!mediaQueries.containsKey(mediaQuery)) {
            MediaQueryList mediaQueryList = window.matchMedia(mediaQuery);
            mediaQueries.put(mediaQuery, mediaQueryList);
        }
        EventTarget mediaQueryList = mediaQueries.get(mediaQuery);
        addListener(listener, Js.uncheckedCast(mediaQueryList));
    }

    public static void removeCustomQueryListener(String mediaQuery, MediaQueryListener listener) {
        if (mediaQueries.containsKey(mediaQuery)) {
            removeListener(listener, mediaQueries.get(mediaQuery));
        }
    }

    @FunctionalInterface
    public interface MediaQueryListener {
        void onMatch();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy