diff --git a/src/content/tutorial/step-1/vue.mdx b/src/content/tutorial/step-1/vue.mdx index 09a9614250..d2b9cce347 100644 --- a/src/content/tutorial/step-1/vue.mdx +++ b/src/content/tutorial/step-1/vue.mdx @@ -452,8 +452,6 @@ src/views └── RepoPage ``` -_Note: We could adopt the same folder + index.js layout we did for the TutorialHeader component. However as our views only consist of a single component we'll proceed with the simpler structure above._ - Create the following files in the `LandingPage` folder: ```bash @@ -522,7 +520,7 @@ Lucky for you, as part of the Vue CLI project set up we added vue-router. This c #### src/router.js -First let's replae the contents of `src/router.js` with: +We need to adjust it by replacing the contents of `src/router.js` with: ```javascript import Vue from 'vue'; diff --git a/src/content/tutorial/step-2/vue.mdx b/src/content/tutorial/step-2/vue.mdx index 3513c41c43..a59db024f0 100644 --- a/src/content/tutorial/step-2/vue.mdx +++ b/src/content/tutorial/step-2/vue.mdx @@ -51,7 +51,7 @@ $ git fetch upstream $ git checkout -b vue-step-2 upstream/vue-step-2 ``` -_Note: This builds on top of step 1, but be sure to check out the upstream step 2 branch because it includes the static assets required to get through this step._ +_Note: This builds on top of step 1, but be sure to check out the upstream step 2 branch because it includes the static assets and fixes required to get through this step._ ### Build and start app @@ -248,7 +248,7 @@ Same goes for the `CvTabs` opening tag: ``` -Give yourself a pat on the back if you actually ran the DAP tool and added an aria label to the header navigation too. We'll install the DAP tool in a later step, so don't worry if you didn't. +Give yourself a pat on the back if you actually ran the DAP tool. We'll install the DAP tool in a later step, so don't worry if you didn't. Next, we'll need to add a styling override to move the tabs to the right on large viewports. Create a file `_carbon-overrides.scss` in `src/content/LandingPage` with this declaration block. diff --git a/src/content/tutorial/step-3/vue.mdx b/src/content/tutorial/step-3/vue.mdx index 0e96db339f..6e1c39301c 100644 --- a/src/content/tutorial/step-3/vue.mdx +++ b/src/content/tutorial/step-3/vue.mdx @@ -89,9 +89,9 @@ $ vue add apollo At the following prompts answer 'No' to each of the questions. -? Add example code No -? Add a GraphQL API Server? No -? Configure Apollo Engine? No +- Add example code? No +- Add a GraphQL API Server? No +- Configure Apollo Engine? No ## Create access token @@ -115,9 +115,9 @@ Go ahead and start your app with `yarn serve`, or, if your app is running, you'l ## Connect to Apollo -The `vue-apollo` library gives us a component that we need to put at the base of our application. Typically the best place for things that need to wrap the entire application is at the root of the application. For us, that's at `src/main.js`. +The `vue-apollo` plugin has made a number of changes to our project. -If you open `src/main.js` you will see that the CLI has updated this file as follows:. +If you open `src/main.js` you will see that the CLI has updated this file with the following:. ##### src/main.js @@ -139,7 +139,7 @@ Update the following values: ```javascript // Use our access token -AUTH_TOKEN = process.env.VUE_APP_GITHUB_PERSONAL_ACCESS_TOKEN; +const AUTH_TOKEN = process.env.VUE_APP_GITHUB_PERSONAL_ACCESS_TOKEN; // Target github api const httpEndpoint = @@ -160,7 +160,7 @@ const defaultOptions = { Add the following imports to the top of the script section of `RepoPage.vue`: -##### src/content/RepoPage/RepoTable.vue +##### src/content/RepoPage/RepoPage.vue ```javascript import gql from 'graphql-tag'; @@ -176,8 +176,6 @@ If you'd like some more information regarding writing queries and using the Quer Add this after your imports: -Replace the rows constant with this query in the script section. - ##### src/content/RepoPage/RepoPage.vue ```graphql @@ -216,8 +214,6 @@ const REPO_QUERY = gql` `; ``` -We should have our table headers set in a previous step that are good to go. - Next let's we need to configure apollo in our component script, adding the following after the data() declaration. ##### src/content/RepoPage/RepoPage.vue @@ -244,7 +240,7 @@ Revert this last change and continue. This data is not quite in the format our RepoTable component is expecting so we'll use a computed property to transform it. Computed properties in Vue cache and watch their reactive dependencies for us. -Remove 'rows' from the data declaration and add this computed property. +Remove 'rows' constant and the data declaration and add this computed property. ##### src/content/RepoPage/RepoPage.vue @@ -327,7 +323,7 @@ At the top of the script section import the link list component: import LinkList from './LinkList'; ``` -And below the name of the component added +And below the name of the component add: ##### src/content/RepoPage/RepoTable.vue @@ -381,9 +377,9 @@ Next we'll update our row description, update the computed property data() in `R Check the output again and you should find the descriptions are updated. -After this many refreshes you may have noticed a slight delay in the data loading. As outlined in the (documentation)[https://vue-apollo.netlify.com/guide/apollo/#apollo] all components contained under one with an apolloProvider have a \$apollo attribute. As we added the apolloProvider to our app when creating the Vue instance it is available to us everywhere. +After this many refreshes you may have noticed a slight delay in the data loading. As outlined in the [documentation](https://vue-apollo.netlify.com/guide/apollo/#apollo) all components contained under one with an apolloProvider have a `$apollo` attribute. As we added the apolloProvider to our app when creating the Vue instance it is available to us everywhere. -We can use the property to react to (loading state)[https://vue-apollo.netlify.com/guide/apollo/queries.html#loading-state]. +We can use the property to react to [loading state](https://vue-apollo.netlify.com/guide/apollo/queries.html#loading-state). First lets demonstrate that this works. @@ -392,7 +388,13 @@ First lets demonstrate that this works. Pass the loading state into our RepoTable component by updating the template with the following. ```html - + ``` Next add this property to the `RepoTable` component @@ -452,7 +454,7 @@ We need to tell the loading skeleton how many rows to render, so let's use 10 sk Pagination! Instead of rendering every repository, let's add pagination to the data table to only render 10 at a time. Depending on your specific requirements, you may need to fetch new data each time that you interact with the pagination component, but for simplicity, we're going to make one request to fetch all data, and then paginate the in-memory row data. -Let's start by adjusting our `PageTable' component template to add pagination. If you review the (storybook notes)[http://vue.carbondesignsystem.com/?path=/info/components-cvdatatable--default] you'll see that pagination is added to the data table by supplying a pagination object and listening for pagination events as follows. +Let's start by adjusting our `PageTable' component template to add pagination. If you review the [storybook notes](http://vue.carbondesignsystem.com/?path=/info/components-cvdatatable--default) you'll see that pagination is added to the data table by supplying a pagination object and listening for pagination events as follows. ##### src/content/RepoPage/RepoTable.vue @@ -477,15 +479,27 @@ In the pagination event we've used $emit and $event to re-raise the pagination e We also need to add the `totalRows` property used in the data tables pagination property. ```javascript -totalRows: Number; +totalRows: Number, ``` Next to our `RepoPage` component, let's first update our template by updating our `RepoTable` use with the following attributes. ##### src/content/RepoPage/RepoPage.vue + +```html +:rows="pagedRows" +:totalRows="rows.length" +@pagination="onPagination" +``` + + +replacing + +##### src/content/RepoPage/RepoPage.vue + ```html -:rows="pagedRows" :totalRows="rows.length" @pagination="onPagination" +:rows="rows" ``` Next in the data property of our component add the following to support our pagination. @@ -505,20 +519,20 @@ Then before we can see our paginated table we need to add; a pagedRows computed ##### src/content/RepoPage/RepoPage.vue ```javascript -computed: { - // other computed properties - // ... - pagedData() { - return this.data.slice(this.pageStart, this.pageStart + this.pageSize); - } -}, -methods: { - onPagination(val) { - this.pageSize = val.length; - this.pageStart = val.start; - this.page = val.page; + computed: { + // other computed properties + // ... + pagedRows() { + return this.rows.slice(this.pageStart, this.pageStart + this.pageSize); + } + }, + methods: { + onPagination(val) { + this.pageSize = val.length; + this.pageStart = val.start; + this.page = val.page; + } } -}; ``` _Note: Like the other Carbon Vue components,_ `Pagination` _component examples can be found in [Storybook](http://vue.carbondesignsystem.com/?path=/story/components-cvpagination--default) by browsing the story and knobs._ diff --git a/src/content/tutorial/step-5/vue.mdx b/src/content/tutorial/step-5/vue.mdx index 8545b89e54..a7321d10ac 100644 --- a/src/content/tutorial/step-5/vue.mdx +++ b/src/content/tutorial/step-5/vue.mdx @@ -76,7 +76,7 @@ Before we get started, [create an IBM Cloud account](https://cloud.ibm.com/regis So far we've been developing in a, well, development environment where static asset optimization hasn't been a priority. If you reference `/src/styles/_carbon.scss`, you'll see one `@import` that is pulling in Carbon's full Sass build. -##### src/styles/_carbon.scss +##### src/styles/\_carbon.scss ```scss $feature-flags: ( @@ -86,9 +86,9 @@ $feature-flags: ( @import 'carbon-components/scss/globals/scss/styles.scss'; ``` -To give you an idea of what's all included, open up `node_modules/carbon-components/scss/globals/scss/styles.scss`. You'll see imports for components like accordion, slider, tooltip, etc. Since we aren't using those components, let's exclude them from our built stylesheets. Keeping the `$feature-flags` Sass map, replace the `styles.scss` import with: +To give you an idea of what's all included, open up `node_modules/carbon-components/scss/globals/scss/styles.scss`. You'll see imports for components like accordion, slider, tooltip, etc. Since we aren't using those components, let's exclude them from our built stylesheets. Keeping the `$feature-flags` Sass map, replace the `styles.scss` import only with: -##### src/styles/_carbon.scss +##### src/styles/\_carbon.scss ```scss // Feature flags