How to do Square-like animation?


Hi all! Has anyone ever did similar animation to this hero section? https://squareup.com/us/en

Where a large hero section collapses into a small box on scroll - how should I even approach this? Is it possible with no custom coding? (if custom code is needed, then what should I use?)

Thanks!