What's in the box.
Swimo Vue is a energetic Swimming Club & Aquatic Sports HTML5 web application built as a fully functional Vue 3 app using the Composition API, Vite, and Bootstrap 5. It ships with 19+ view components, a filterable photo gallery, a blog module, written entirely with script setup and the Composition API — zero Options API usage.
Built for Vue developers delivering swimming club & aquatic sports html5 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
- 19+ 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 5 — responsive grid and utility classes
- VeeValidate 4 — schema-based form validation with v-model two-way binding on all 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, useCart, 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 19 Views
- /home-v1 — v3 — Three distinct hero and aquatic showcase layouts
- /about — Club story and swimming mission
- /portfolio-grid — Facility and programme in grid layout
- /portfolio-masonry — Facility and programme in masonry layout
- /services — Swimming programme and coaching services
- /team — Coach and staff profiles
- /faq — Frequently asked questions
- /blog-grid — Editorial content in grid layout
- /blog-standard — Editorial content in standard layout
- /contact — Contact form and membership enquiry
Key Features
- 19 Fully Designed HTML5 Pages across home, portfolio, services, team, blog, and FAQ
- 3 Unique Home Layouts — distinct hero styles and aquatic showcase arrangements
- Bootstrap — responsive, mobile-first grid system
- Portfolio Grid & Masonry — facility and programme showcase in two layouts
- Services Section — swimming programme and coaching service pages
- Team Profiles — coach and staff team pages
- FAQ Page — frequently asked questions for swimmers and members
- Blog Grid & Standard — editorial content in grid and standard layouts
- Slick Carousel — featured programme and achievement sliders
- Isotope Grid Filtering — filter portfolio by programme or discipline
- CounterUp Animated Statistics — swimmers, medals, and achievement counters
- MeanMenu — mobile-optimised responsive navigation
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
- Swimming Club & Aquatic Sports HTML5 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 swimming club & aquatic sports html5 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 5 — MIT License
- Swiper Vue — MIT License
- Slick — MIT License
- Isotope — MIT License
- CounterUp — MIT License
- Magnific — 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.
v1.0 Initial Vue Release - Vue 3 Composition API with script setup syntax throughout - Vite build tooling with fast HMR and optimised production output - 19+ view-level Single File Components with Vue Router 4 history mode - Pinia store with localStorage persist plugin for global state management - VeeValidate 4 schema-based form validation on all form views - defineAsyncComponent route-level code splitting on secondary views - useHead per-route SEO meta tags via VueUse
Open the source. Read the actual code.
Every Swimo — Swimming Vue.js 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.
What customers actually said.
No reviews yet — be the first.
Don’t have hosting? We launch Swimo — Swimming Vue.js 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
Get $5 off Swimo — Swimming Vue.js Template + free Bootstrap 5 starter kit.
Plus weekly drops from the studio · AICE reports · early access to new templates before they hit the catalog.







