Foxy is an agency landing page theme built with Vue 3.0 and Bootstrap 5.0. It features a range of content sections, including a portfolio gallery, testimonials, services showcase, contact info, and more.
The theme brings together cozy shades of orange with clean, minimalistic dark and white tones for a fresh, modern feel. The fox-inspired theme adds a charming touch, creating a UI that's both inviting and visually engaging.
Check out a live version of the template here.
The theme is optimized to adapt to any desktop screen, from 4:3 ratios to wider resolutions.
It's also designed for mobile devices, maintaining the sleek one-page layout with a toggle navigation.
- Clone the repo:
git clone https://github.com/ryanbalieiro/vue-landing-page-template
- Go to the project's root folder and use npm to install all required components:
npm install
- Launch the project in developer mode:
npm run dev
- To temporarily deactivate the preload animation during theme adjustments, go to
public/data/general.json
and modify the following field:
"preloaderEnabled": false
- For a production build, go to
vite.config.js
and configure the base directory for your application. This setting establishes the primary path under which your website will be hosted.
export default defineConfig({
base: '/',
plugins: [vue()],
})
- Run the following command to compile the project into
dist
:
npm run build
- If your deployment is targeted at GitHub Pages, ensure to run the following build command instead:
npm run ghdeploy
This command will build the project and make a copy of index.html
named 404.html
inside the dist folder, serving as a workaround to the problem discussed in detail at https://stackoverflow.com/questions/48521177/404-when-reloading-a-vue-website-published-to-github-pages.
The content of the application, encompassing text and images, is located within the public/
directory. Inside the directory, you'll find:
/data/general.json
➔ A JSON file that contains the core information about the application./data/sections.json
➔ A JSON file that holds the content for each individual section./data/pages.json
➔ A JSON file that holds the content for secondary pages, such as the Privacy Policy and the legal sections./images/(...)
➔ Icons and photos used in the application.
You can quickly customize the theme colors to fit your style. Simply access src/scss/_variables.scss
and make adjustments to the color variables. For example, you can alter the primary color from orange to blue just by changing this line:
$primary: #07c5ee; /** making the primary color blue! **/
$dark: #212529;
Inside the sections.json
file, you have the ability to include or exclude items in the sections array. Keep in mind that the arrangement of sections within the array will determine how they appear in the display order.
{
"id": "about",
"component": "AboutSection",
"class": "agency-section",
"navbar": {
"label": "About",
"faIcon": "fa-solid fa-file"
},
"headline": {
(...)
},
"items": [
(...)
],
"footer": {
(...)
}
},
{
"id": "services",
"component": "ServicesSection",
"class": "agency-section-primary",
"navbar": {
"label": "Services",
"faIcon": "fa-solid fa-wrench"
},
"headline": {
(...)
},
"items": [
(...)
],
"footer": {
(...)
}
},
Enabling the functionality of the contact form requires you developing your own server-side implementation within the ContactSection.vue
file. It's important to mention that the existing template solely contains the client-side implementation, along with a simulated delay using a placeholder timeout:
const _sendMessage = (values) => {
const feedbackView = layout.getFeedbackView()
feedbackView.showActivitySpinner("Sending Message...")
submitAttempts++
/** The message sending logic goes here... **/
// setTimeout(() => {
// if(submitAttempts % 2 !== 0) {
// _onMessageSent()
// }
// else {
// _onMessageError()
// }
// }, 1000)
/** ************************************** **/
}
This template was created by and is maintained by Ryan Balieiro.
The template is based on the Bootstrap framework created by Mark Otto and Jacob Thorton; and the Vue framework created by Evan You.
Code released under the MIT license.