UCLA Library websites: library-website-nuxt & ftva-website-nuxt
This template should help get you started developing with Vue 3 and TypeScript in Vite. The template uses Vue 3 <script setup>
SFCs, check out the script setup docs to learn more.
- VS Code + Volar (and disable Vetur) + TypeScript Vue Plugin (Volar).
TypeScript cannot handle type information for .vue
imports by default, so we replace the tsc
CLI with vue-tsc
for type checking. In editors, we need TypeScript Vue Plugin (Volar) to make the TypeScript language service aware of .vue
types.
If the standalone TypeScript plugin doesn't feel fast enough to you, Volar has also implemented a Take Over Mode that is more performant. You can enable it by the following steps:
- Disable the built-in TypeScript Extension
- Run
Extensions: Show Built-in Extensions
from VSCode's command palette - Find
TypeScript and JavaScript Language Features
, right click and selectDisable (Workspace)
- Run
- Reload the VSCode window by running
Developer: Reload Window
from the command palette.
Helpful reminders to future selves:
- Use the commit message conventions that trigger semantic releases
- feat: A new feature
- fix: A bug fix
- docs: Documentation only changes
- style: Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)
- refactor: A code change that neither fixes a bug nor adds a feature
- perf: A code change that improves performance
- test: Adding missing or correcting existing tests
- chore: Do not use it for any source code changes, only use it when Changes to the build process or auxiliary tools and libraries such as documentation generation
STEPS
Make sure to install the dependencies:
# pnpm
pnpm install
Start the development server on http://localhost:5173
:
# pnpm
pnpm run dev
Start the vite server on http://localhost:5174
:
# pnpm
pnpm run serve
Start the storybook on http://localhost:6006
:
# pnpm
pnpm run storybook
Build library using vite:
# pnpm
pnpm run vite
If you already have a local copy of be sure to save it locally because they will be deleted if you reclone this repo. You can add a page to the Wiki with your version.
Be sure to add the APP.vue
and mock.js
in the src
file
There are example files here: https://github.com/UCLALibrary/ucla-library-website-components/wiki/AppDotVueAndMockJS.md
(Add APP.vue
and mock.js
in the src
file)
[plugin:vite:import-analysis] Failed to resolve import "./App.vue" from "src/main.ts". Does the file exist?
/Users/jendiamond/UCLA/ucla-library-website-components/src/main.ts:8:16
5 | import "ucla-library-design-tokens/scss/app-global.scss";
6 | import "@/styles/global.scss";
7 | import App from "./App.vue";
| ^
8 | createApp(App).use(router).use(createPinia()).mount("#app");
src
> assets
> composables
> lib-components
> stores
> stories
> styles
> types
> utils
App.vue
entry.js
main.ts
mock.js
router.js
style.css
vue-global-props.d.ts
You have two choices
from
"ucla-library-website-components": "2.39.0-alpha.100"
(whatever it is currently)
to
"ucla-library-website-components": "file:../ucla-library-website-components"
(whatever your path to ucla-library-website-components
is)
- In your terminal, in
ucla-library-website-components
- Run: $
pnpm run build
- Run: $
- Then run: $
pnpm link --global
- On either the library-website-nuxt or the ftva-website-nuxt
- Run: $
pnpm link --global ucla-library-website-components
- Run: $
- Now the repos are linked.
- The add the new components to a page on either the library-website-nuxt or the ftva-website-nuxt and
- Run: $
pnpm run dev
- Run: $