What's in the box.
Sevin Vue is a creative water sports web application built as a fully functional Vue 3 app using the Composition API, Vite, and Bootstrap 4. It ships with 38+ view components, a filterable surf gallery, a “Ride the Wave” blog module, map integration, written entirely with script setup and the Composition API — zero Options API usage.
Built for Vue developers delivering surf school, beach club, and water sports centre sites and applications. The codebase uses Vue 3 Composition API throughout — ref(), reactive(), computed(), watch(), and composables for shared logic. Single File Components (.vue) keep template, script setup, and scoped styles co-located. Replace the static JSON data sources with any REST API or headless CMS and the reactive layer adapts immediately.
Everything in the Package
- 38+ view-level Single File Components with Vue Router 4 history mode routing
- Vue 3 with script setup syntax and Vite — fast HMR dev server and optimised production build
- Vue Router 4 — history mode with lazy-loaded routes via defineAsyncComponent
- Pinia store for global state management — state, getters, and actions with localStorage persist plugin
- Bootstrap 4 — responsive grid and utility classes
- VeeValidate 4 — schema-based form validation with v-model two-way binding on all booking and enquiry forms
- Swiper Vue — touch-friendly carousels via SwiperSlide components
- All data sourced from typed JSON in src/data/ — swap to fetch() or axios for live API
- Scoped CSS inside each .vue file — no global style bleed between components
- Retina-ready, fully responsive from 320px to 1920px+
- Vue DevTools compatible — Pinia store fully inspectable in browser
Composition API and Component Architecture
- All views use script setup — defineProps, defineEmits, ref(), computed(), and watch()
- Composables encapsulate reusable logic — useFilter, useBooking, useForm, and feature-specific hooks
- Pinia store: defineStore with typed state, computed getters, and async actions
- defineAsyncComponent applied to secondary view bundles — route-level code splitting
- v-model, v-for, v-if, v-show used throughout — idiomatic Vue 3 template syntax
- storeToRefs used for reactive destructuring of Pinia store properties in setup()
- Folder structure: src/views/, src/components/, src/composables/, src/stores/, src/data/
All 38 Views
- /home-v1 — v10 — Ten distinct surf and beach hero showcase layouts
- /about-us — Surf school story and beach resort mission
- /services — Water sports activity listing (things to do)
- /service-details — Individual activity detail page
- /portfolio — Surf and location gallery
- /blog — “Ride the Wave” news and editorial
- /blog-details — Full article view
- /contact-us — Contact form and map
Key Features
- 38 Fully Designed HTML5 Pages across home demos, services, portfolio, and blog
- 10 Unique Home Layouts — ten diverse surf and beach hero styles and showcase arrangements
- Bootstrap 4 — responsive, mobile-first grid system
- Services Pages — water sports activity listing and individual service detail pages
- Portfolio Pages — surf gallery and location showcases
- Blog Content — “Ride the Wave” news and editorial articles
- Swiper Carousel — featured locations and guest testimonial sliders
- Fancybox Lightbox — full-screen beach media and gallery image popup
- FontAwesome Icons — comprehensive icon library for the water sports UI
- Well Documented — step-by-step documentation for easy setup & customisation
- Cross-Browser Compatible — Chrome, Firefox, Safari, Edge, Opera
Performance and SEO
- useHead (VueUse) sets per-route title and meta description reactively for SEO
- defineAsyncComponent and Suspense code-split secondary view bundles on route change
- Vite production build applies Rollup tree-shaking, chunk splitting, and asset fingerprinting
- All images carry descriptive :alt bindings meeting WCAG 1.1.1
- Google Fonts loaded with font-display: swap to prevent invisible-text flash
Use Cases
- Water Sports Businesses: Fast Vue 3 SPA with Composition API — reactive, composable, and easy to maintain
- Vue Developers: Composables, Pinia stores, and Vue Router 4 patterns — production architecture from day one
- Freelancers and Agencies: Deliver a polished surf school and beach club site to clients with Vite build tooling and DevTools support
- Startups: Lightweight bundle, defineAsyncComponent code-splitting, and VeeValidate forms ready to go
Credits and Dependencies
- Vue 3 — MIT License
- Vite — MIT License
- Vue Router 4 — MIT License
- Pinia — MIT License
- VeeValidate 4 — MIT License
- Bootstrap 4 — MIT License
- Swiper Vue — MIT License
- Swiper — MIT License
- Lightbox — MIT License
- Font Awesome 6 — Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT
- Google Fonts — SIL Open Font License
- Demo images: Unsplash — Unsplash License (free for commercial use, no attribution required)
- Demo images: Freepik — Freepik License (free for commercial use with attribution)
- All demo images are for preview purposes only and are NOT included in the download.
Open the source. Read the actual code.
Every Sevin — Aquatic Sports Vue.js Website Template template ships hand-written, semantic, and accessibility-ready. Tabs preserved. Comments in plain English. BEM naming. WCAG 2.2 AA tested. No spaghetti, no inline JavaScript scattered through the document. Your team extends without rewriting — and your users get a site that works for screen readers, keyboard navigation, and reduced-motion preferences out of the box.
<section> / <article> / <nav> tags — not div soup.prefers-reduced-motion media query disables non-essential transitions.What's changed.
- Initial release.
- Vue 3 with Composition API; reactive state and reusable components.
- Detailed documentation included with quick-start guide.
Don’t have hosting? We launch Sevin — Aquatic Sports Vue.js Website Template for you.
Skip cPanel. Skip the FTP upload. Skip the DNS configuration. Each hosting tier includes the install, plugin config, and your domain pointed live in 24 hours. Same NYC team that built the template handles your launch.
- 1 Website
- 10 GB Storage
- Free SSL
- 1 Database
- 1 Website
- 25 GB Storage
- Free SSL
- 10 Databases
- 10 Websites
- 50 GB Storage
- Free SSL (all sites)
- 25 Databases
- 25 Websites
- 75 GB Storage
- Free SSL (all sites)
- 50 Databases
- 100 GB Storage
- 4 GB RAM
- 2 CPUs
- Free SSL
- 200 GB Storage
- 8 GB RAM
- 4 CPUs
- Free SSL
- 300 GB Storage
- 16 GB RAM
- 8 CPUs
- Free SSL
- 400 GB Storage
- 32 GB RAM
- 16 CPUs
- Free SSL
Free SSL · 99.9% uptime · 24/7 support · No domain included
Every tier includes — NYC infrastructure
Save $5 on Sevin — Aquatic Sports Vue.js Website Template today.
Plus weekly drops · AICE rebuild reports · early access to designs we haven't listed publicly. Same email goes to designers shipping with Letam, Bunlicious, and Aiga.
No spam · unsubscribe anytime








Reviews
There are no reviews yet.