2A News

2A Community Cautiously Celebrates California Victory

Reading Time: 3:27 min

It’s self-defeating to be skeptical of every victory or even sliver of good news, but gun rights advocates are accustomed to tempering their expectations. So, while Friday’s ruling striking down…

View post

DOJ Files Brief Supporting Challenge to California’s Ammunition Restrictions

Reading Time: 1:54 min

The revamped Department of Justice’s Civil Rights Division filed an amicus brief on Monday supporting the plaintiff’s challenge to California’s onerous ammunition regulations. After all, Second Amendment rights mean little…

View post

Rest in Peace: Hated NFA Stamp Tax Dead and Gone in 2026

Reading Time: 1:54 min

Along with raucous New Year’s celebrations and an endless deluge of football, the changing of the calendar brought a welcome update for law-abiding American gun owners. As of January 1,…

View post

Man Who Defended Son from Campus Assault Allegedly Receiving Death Threats

Reading Time: 1:52 min

Gun owners must be aware that there are times when even the most justified self-defense shooting sparks unjustified and troubling reactions.  A terrifying self-defense incident unfolded at Kentucky State University…

View post

Hawaii Presents Novel Argument in Supreme Court Gun Control Case

Reading Time: 1:60 min

Hawaii undoubtedly has a unique status as a U.S. state surrounded by the Pacific Ocean and the last to join the Union, and its history is rich and fascinating. Unfortunately,…

View post

Victory: Ninth Circuit Strikes Down California Ban on Open Carry

Reading Time: 1:58 min

The Ninth Circuit Court of Appeals on Friday struck down California’s ban on open carry of firearms in populated areas.  The state prohibition applied to residents of counties with populations…

View post
<script>
  /*Source: https://github.com/Krzysztof-Antosik/Two-direction-Sticky-Sidebar*/
  
  // Verificar el ancho de pantalla al cargar y redimensionar
  function checkScreenWidth() {
    if (window.innerWidth <= 767) {
      // Si la pantalla es menor o igual a 676px, no ejecutar el código
      return;
    }

    const stickyElement = document.querySelector('.fb-sidebar__aside');
    const startPosition = stickyElement.getBoundingClientRect().top;

    let endScroll = window.innerHeight - stickyElement.offsetHeight - 500;
    let currPos = window.scrollY;
    let screenHeight = window.innerHeight;
    let stickyElementHeight = stickyElement.offsetHeight;
    let topGap = 40;
    let bottomGap = 40;

    setTimeout(() => {
      if (stickyElement.hasAttribute('data-top-gap')) {
        const dataTopGap = stickyElement.getAttribute('data-top-gap');
        topGap = dataTopGap === 'auto' ? startPosition : parseInt(dataTopGap);
      }

      if (stickyElement.hasAttribute('data-bottom-gap')) {
        bottomGap = parseInt(stickyElement.getAttribute('data-bottom-gap'));
      }
    }, 100);

    stickyElement.style.position = 'sticky';
    stickyElement.style.top = `${topGap}px`;
    stickyElement.style.height = 'fit-content';

    function positionStickySidebar() {
      endScroll = window.innerHeight - stickyElement.offsetHeight - bottomGap;
      const stickyElementTop = parseInt(stickyElement.style.top.replace('px', ''));

      if (stickyElementHeight + topGap + bottomGap > screenHeight) {
        if (window.scrollY < currPos) {
          if (stickyElementTop < topGap) {
            stickyElement.style.top = `${stickyElementTop + currPos - window.scrollY}px`;
          } else if (stickyElementTop >= topGap && stickyElementTop !== topGap) {
            stickyElement.style.top = `${topGap}px`;
          }
        } else {
          if (stickyElementTop > endScroll) {
            stickyElement.style.top = `${stickyElementTop + currPos - window.scrollY}px`;
          } else if (stickyElementTop < endScroll && stickyElementTop !== endScroll) {
            stickyElement.style.top = `${endScroll}px`;
          }
        }
      } else {
        stickyElement.style.top = `${topGap}px`;
      }
      currPos = window.scrollY;
    }

    function stickyElementToMe() {
      stickyElement.style.top = `${topGap}px`;
    }

    function updateSticky() {
      screenHeight = window.innerHeight;
      stickyElementHeight = stickyElement.offsetHeight;
      positionStickySidebar();
    }

    setTimeout(() => {
      window.addEventListener('resize', () => {
        currPos = window.scrollY;
        updateSticky();
      });

      document.addEventListener('scroll', updateSticky, {
        capture: true,
        passive: true
      });
    }, 1000);
  }

  // Verificar el ancho de pantalla al cargar y redimensionar
  window.addEventListener('load', checkScreenWidth);
  window.addEventListener('resize', checkScreenWidth);
</script>