Mask-Up / Scale-Down Effect

CODE
let proxy = { skew: 0 },
	skewSetter = gsap.quickSetter(".skew .post_image", "skewY", "deg"), // fast
	clamp = gsap.utils.clamp(-10, 10); // don't let the skew go beyond 20 degrees. 

ScrollTrigger.create({
  onUpdate: (self) => {
	let skew = clamp(self.getVelocity() / -300);
	// only do something if the skew is MORE severe. Remember, we're always tweening back to 0, so if the user slows their scrolling quickly, it's more natural to just let the tween handle that smoothly rather than jumping to the smaller skew.
	if (Math.abs(skew) > Math.abs(proxy.skew)) {
	  proxy.skew = skew;
	  gsap.to(proxy, {skew: 0, duration: 0.8, ease: "power3", overwrite: true, onUpdate: () => skewSetter(proxy.skew)});
	}
  }
});

// make the right edge "stick" to the scroll bar. force3D: true improves performance
gsap.set(".skew .post_image", {transformOrigin: "right center", force3D: true});