Sha256: 1f090684678b39cbf482bdde28637c7404233477e49e58b37e2f6f9015b3f8fe

Contents?: true

Size: 1.72 KB

Versions: 7

Compression:

Stored size: 1.72 KB

Contents

import tippy from "@assets/js/libs/tippy";
import { CocoComponent } from "@assets/js/shared/coco";

export default CocoComponent("appSidebarNavItem", () => {
  return {
    menu: null,
    menuObserver: null,
    active: false,

    init() {
      if (this.menuTemplate) {
        this.initMenu();
        this.observeMenuForChanges();
      }

      this.$watch("mobileLayout", () => this.onOrientationChange());
    },

    initMenu() {
      this.menu = tippy(this.$root, {
        theme: "coco-naked-dropdown",
        placement: this.menuPlacement,
        arrow: false,
        offset: [0, 0],
        trigger: "click",
        interactive: true,
        maxWidth: null,
        onShow: () => {
          this.active = true;
        },
        onHide: () => {
          this.active = false;
        },
        content: () => this.menuTemplate.innerHTML,
      });
    },

    observeMenuForChanges() {
      this.menuObserver = new MutationObserver((mutations) => {
        this.$nextTick(() => this.menu.setContent(this.menuTemplate.innerHTML));
      });

      this.menuObserver.observe(this.$root, {
        subtree: true,
        childList: true,
      });
    },

    onOrientationChange() {
      if (this.menu) {
        this.menu.setProps({
          placement: this.menuPlacement,
        });
      }
    },

    destroy() {
      if (this.menuObserver) {
        this.menuObserver.disconnect();
      }
    },

    root: {
      ["@turbo:load.document"]() {
        if (this.menu) {
          this.menu.hide();
        }
      },
      ":class": "{active}",
    },

    get menuTemplate() {
      return this.$root.querySelector("template");
    },

    get menuPlacement() {
      return this.mobileLayout ? "top" : "right-start";
    },
  };
});

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
coveragebook_components-0.12.2 app/components/coco/app/blocks/sidebar_nav/item/item.js
coveragebook_components-0.12.1 app/components/coco/app/blocks/sidebar_nav/item/item.js
coveragebook_components-0.12.0 app/components/coco/app/blocks/sidebar_nav/item/item.js
coveragebook_components-0.11.0 app/components/coco/app/blocks/sidebar_nav/item/item.js
coveragebook_components-0.10.1.beta.2 app/components/coco/app/blocks/sidebar_nav/item/item.js
coveragebook_components-0.10.1.beta.1 app/components/coco/app/blocks/sidebar_nav/item/item.js
coveragebook_components-0.10.1.beta.0 app/components/coco/app/blocks/sidebar_nav/item/item.js