Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/denys-petryniak/vue-graphql-mastery
https://github.com/denys-petryniak/vue-graphql-mastery
apollo-client graphql typescript vue
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/denys-petryniak/vue-graphql-mastery
- Owner: denys-petryniak
- Created: 2024-02-19T15:52:09.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-02-25T21:41:13.000Z (11 months ago)
- Last Synced: 2024-11-29T09:55:52.974Z (about 2 months ago)
- Topics: apollo-client, graphql, typescript, vue
- Language: Vue
- Homepage:
- Size: 58.6 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Vue GraphQL Mastery
## Requirements
This project requires [GraphQL Apollo Server](https://github.com/denys-petryniak/graphql-apollo-server) is running.
## Explore in StackBlitz
Click the button below to open the project in StackBlitz for preview and experimentation:
[![Open in StackBlitz](https://developer.stackblitz.com/img/open_in_stackblitz.svg)](https://stackblitz.com/github/denys-petryniak/vue-graphql-mastery)
Feel free to explore the code, make changes, and see the results in real-time!
## Recommended IDE Setup
[VSCode](https://code.visualstudio.com/) + [Volar](https://marketplace.visualstudio.com/items?itemName=Vue.volar) (and disable Vetur) + [TypeScript Vue Plugin (Volar)](https://marketplace.visualstudio.com/items?itemName=Vue.vscode-typescript-vue-plugin).
## Type Support for `.vue` Imports in TS
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)](https://marketplace.visualstudio.com/items?itemName=Vue.vscode-typescript-vue-plugin) 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](https://github.com/johnsoncodehk/volar/discussions/471#discussioncomment-1361669) that is more performant. You can enable it by the following steps:
1. Disable the built-in TypeScript Extension
1. Run `Extensions: Show Built-in Extensions` from VSCode's command palette
2. Find `TypeScript and JavaScript Language Features`, right click and select `Disable (Workspace)`
2. Reload the VSCode window by running `Developer: Reload Window` from the command palette.## Customize configuration
See [Vite Configuration Reference](https://vitejs.dev/config/).
## Project Setup
```sh
pnpm install
```### Compile and Hot-Reload for Development
```sh
pnpm dev
```### Type-Check, Compile and Minify for Production
```sh
pnpm build
```### Lint with [ESLint](https://eslint.org/)
```sh
pnpm lint
```