%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /home/graphicd/www/textmarketing/wp-content/themes/oceanwp/assets/src/js/theme/components/
Upload File :
Create Path :
Current File : /home/graphicd/www/textmarketing/wp-content/themes/oceanwp/assets/src/js/theme/components/footer.js

import { DOM } from "../../constants";

export default class Footer {
    #footerPositionState = null;

    constructor() {
        if (!DOM.main) {
            return;
        }

        this.#setupEventListeners();
    }

    #setupEventListeners = () => {
        window.addEventListener("load", this.#onWindowLoad);
        window.addEventListener("resize", this.#onWindowResize);
    };

    #onWindowLoad = event => {
        this.#fixedFooter();
        this.#parallaxFooter();
    };

    #onWindowResize = event => {
        this.#fixedFooter();
        this.#parallaxFooter();
    };

    #fixedFooter = () => {
        if (!document.body.classList.contains("has-fixed-footer")) {
            return;
        }

        const wpAdminbarHeight = DOM.WPAdminbar?.offsetHeight ?? 0;
        const footerBarHeight = DOM.footer.footerBar?.offsetHeight ?? 0;
        const htmlHeight = DOM.html.offsetHeight - wpAdminbarHeight;

        if (htmlHeight < window.innerHeight) {
            DOM.wrap.style.cssText = `
                display: flex;
                flex-direction: column;
                min-height: calc(100vh - ${wpAdminbarHeight}px - ${footerBarHeight}px);
            `;

            if (!!DOM.footer.calloutFooter) {
                DOM.footer.calloutFooter.style.marginTop = "auto";
            } else if (!!DOM.footer.siteFooter) {
                DOM.footer.siteFooter.style.marginTop = "auto";
            }

            this.#footerPositionState = "changed";
        } else if (this.#footerPositionState === "changed") {
            DOM.wrap.style.cssText = "";

            if (!!DOM.footer.calloutFooter) {
                DOM.footer.calloutFooter.style.marginTop = null;
            } else {
                DOM.footer.siteFooter.style.marginTop = null;
            }

            this.#footerPositionState = null;
        }
    };

    #parallaxFooter = () => {
        if (DOM.body.classList.contains("has-parallax-footer")) {
            setTimeout(() => {
                let mainSectionMarginBottom = 0;

                mainSectionMarginBottom += DOM.footer.parallax?.offsetHeight;

                if (!!DOM.footer.calloutFooter) {
                    DOM.footer.calloutFooter.style.bottom = `${mainSectionMarginBottom}px`;
                    mainSectionMarginBottom +=
                        DOM.footer.calloutFooter.offsetHeight;
                }

                DOM.main.style.marginBottom = `${mainSectionMarginBottom}px`;
            }, 10);
        }
    };
}

Zerion Mini Shell 1.0