export default { init() { if (!this.initialized) { this.$window = $(window); this.$rightSidebar = $('.js-right-sidebar'); this.$navHeight = $('.navbar-gitlab').outerHeight() + $('.layout-nav').outerHeight() + $('.sub-nav-scroll').outerHeight(); const throttledSetSidebarHeight = _.throttle(() => this.setSidebarHeight(), 20); const debouncedSetSidebarHeight = _.debounce(() => this.setSidebarHeight(), 200); this.$window.on('scroll', throttledSetSidebarHeight); this.$window.on('resize', debouncedSetSidebarHeight); this.initialized = true; } }, setSidebarHeight() { const currentScrollDepth = window.pageYOffset || 0; const diff = this.$navHeight - currentScrollDepth; if (diff > 0) { const newSidebarHeight = window.innerHeight - diff; this.$rightSidebar.outerHeight(newSidebarHeight); this.sidebarHeightIsCustom = true; } else if (this.sidebarHeightIsCustom) { this.$rightSidebar.outerHeight('100%'); this.sidebarHeightIsCustom = false; } }, };