Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docs: refactor the setup guide docs #975

Merged
merged 11 commits into from
May 16, 2022
31 changes: 31 additions & 0 deletions docs/.vuepress/components/Asciinema.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
<template>
<div ref="container">
<a :href="'https://asciinema.org/a/' + id" target="_blank">
<img :src="'https://asciinema.org/a/' + id + '.svg'" />
</a>
</div>
</template>

<script>
export default {
name: 'Asciinema',
props: {
id: String,
},
mounted() {
const container = this.$refs.container;

if (!container) return;

container.removeChild(container.firstChild);

const script = window.document.createElement('script');

script.id = 'asciicast-' + this.id;
script.src = 'https://asciinema.org/a/' + this.id + '.js';
script.async = true;

container.appendChild(script);
},
};
</script>
24 changes: 9 additions & 15 deletions docs/.vuepress/config.js
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ module.exports = {
'@vuepress/search',
],
themeConfig: {
sidebarDepth: 0,
repo: 'https://github.com/vuestorefront/magento2/',
editLinks: true,
docsDir: 'docs',
Expand All @@ -46,40 +47,33 @@ module.exports = {
nav: [
{ text: 'Vue Storefront', link: 'https://vuestorefront.io/' },
{ text: 'Core Documentation', link: 'https://docs.vuestorefront.io/v2/' },
{ text: 'Demo', link: 'https://demo-magento2.europe-west1.gcp.storefrontcloud.io/' },
{ text: 'GitHub', link: 'https://github.com/vuestorefront/magento2' },
{ text: 'Roadmap', link: 'https://docs.vuestorefront.io/magento/guide/roadmap.html' },
{ text: 'Environments', link: 'https://docs.vuestorefront.io/magento/guide/environments.html' },
],
sidebar: [
{
title: 'Essentials',
title: '',
collapsable: false,
children: [
['/', 'Introduction'],
['/guide/environments', 'Demo environments'],
['/guide/supported-features', 'Supported features'],
['/guide/about', 'About'],
['/guide/roadmap', 'Roadmap'],
],
},
{
title: 'Creating a Storefront',
title: 'Getting started',
collapsable: false,
children: [
['/guide/creating-a-store', 'Creating a Store'],
['/guide/configuration', 'Configuration'],
['/guide/override-queries', 'Override queries'],
['/guide/testing', 'Testing'],
['/guide/recaptcha', 'ReCaptcha'],
['/getting-started/configure-magento', 'Configuring Magento'],
['/getting-started/configure-integration', 'Configuring Vue Storefront'],
],
},
{
title: 'Performance',
title: 'Guides',
collapsable: false,
children: [
['/guide/graphql-get', 'Varnish & GET for GraphQL Queries'],
['/guide/ssr', 'Server Side Rendering Cache'],
['/guide/override-queries', 'Override queries'],
['/guide/testing', 'Testing'],
['/guide/recaptcha', 'ReCaptcha'],
],
},
{
Expand Down
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
162 changes: 162 additions & 0 deletions docs/getting-started/configure-integration.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,162 @@
# Configuring Vue Storefront for Magento 2

This guide explains the steps needed to install and set up Vue Storefront for Magento 2.

## Prerequisites

Before you can get started, you need the following:

- **Node.js 16** installed,
- Magento 2 server configured following the [Configuring Magento](/getting-started/configure-magento.html) guide.

## Creating the Vue Storefront for Magento 2

To install Vue Storefront, run the command below. It will ask you for the project name and the integration of your choice. Keep in mind that the project name will also be used as the folder name, and be sure to select the Magento 2 integration.

```sh
npx @vue-storefront/cli init
```

Here's a recording of these steps:

<Asciinema id="493286" />

## Setting environment variables

After installation, the first step is to configure the integration using the environment variables.

1. Go to the root folder of your project.
2. Make a copy of the `.env.example` file and rename it to `.env`. You can do it manually or use the following command:

```sh
cp .env.example .env
```

3. Update values in the `.env` file.

## Populating store configuration

The `plugins/storeConfigPlugin.ts` plugin loads store configuration data from Magento and saves it into the Pinia store under the `$state.storeConfig` property. By default, the amount of data loaded from Magento is minimal to avoid over-fetching, but as your application grows, you might need to pull more data.

This plugin loads the store configuration data based on a query in the `plugins/query/StoreConfig.gql.ts` file. You can modify this file to change what data is loaded.

## Configuring multistore and localization

Each Magento store view needs a corresponding locale configuration object in the `i18n` object in the `nuxt.config.js` file.

### `i18n.locales`

The `i18n.locales` array contains all supported locales. Each item in this array is an object containing the following properties:

- `code` - unique identifier of the locale corresponding to Magento store view code.
- `file` - the name of the file containing translations for this locale in the `lang` folder.
- `iso` - corresponding ISO country code.

For other properties please follow official [nuxt-i18n documentation](https://i18n.nuxtjs.org/options-reference#locales).

In the example configuration below, you need to have two Magento store views with corresponding store codes: `default` and `german`.

```javascript
// nuxt.config.js

export default {
locales: [
{
code: 'default',
file: 'en.js',
iso: 'en_US',
},
{
code: 'german',
file: 'de.js',
iso: 'de_DE',
}
]
};
```

### Translations

When working with translation in your application, you need to:

1. Add translations in Magento for products and categories.
2. Update the `i18n.locales` array in the `nuxt.config.js` file and add translations to the corresponding files in the `lang` directory.

## Optimizing images

You can use external image providers to optimize your images thanks to the [nuxt-img](https://image.nuxtjs.org/) module.

By default, Vue Storefront uses the `ipx` provider, an open-source, self-hosted image optimizer.

### Configuring external image provider

If you decide to use an external image provider, you have to update the following environment variables inside the `.env` file:

1. `VSF_MAGENTO_BASE_URL` - base URL of Magento shop. The `useImage` composable uses it to extract the image path from the full Magento URL.
2. `VSF_IMAGE_PROVIDER` - name of the external provider, e.g. `cloudinary`. See the [Providers](https://image.nuxtjs.org/getting-started/providers) page for more information.
3. `VSF_IMAGE_PROVIDER_DOMAIN` - domain of the image provider.
4. `VSF_IMAGE_PROVIDER_BASE_URL` - base URL of the image provider to upload images.

See the `image` property in the `nuxt.config.js` to learn how these environment variables are used and to configure any [other options](https://image.nuxtjs.org/api/options) supported by the [nuxt-img](https://image.nuxtjs.org/) plugin.

### Synchronize Magento images with an external provider

You need to synchronize all your images from the two folders below manually or create a script to do so:

- `media` folder in Magento. We recommend using the same path as in Magento. For example, if your image path is `{MAGENTO_BASE_URL}/media/catalog/product/{IMAGE_PATH}`, you should have the corresponding image in your external provider with the same path, e.g. `media/catalog/product/{IMAGE_PATH}`.
- `static` folder in Vue Storefront.

### The `useImage()` composable

Magento GraphQL API returns an URL to cached images, e.g. `{MAGENTO_BASE_URL}/media/catalog/product/cache/{IMAGE_PATH}`. When you download all images from your server's `media` directory, paths don't include the `cache/***/` part.

Because of that, we created the `useImage()` hook, which provides the `getMagentoImage(fullImageUrl: string)` method. This method returns an URL to the image without the Magento base URL and cache part. You can use it to get images from external providers.

Here's an example of how to use the `useImage()` composable:

```vue
<template>
<SfImage
image-tag="nuxt-img"
:src="getMagentoImage(wishlistGetters.getItemImage(product))"
:alt="wishlistGetters.getItemName(product)"
:width="140"
:height="200"
/>
</template>

<script>
import { useImage } from '~/composables';

export default {
setup() {
const { getMagentoImage } = useImage();

return {
getMagentoImage
};
}
};
</script>
```

### ImageSizes enum

There is a helper object in the `enums/imageEnums.js` file that export configuration for various image types:

```javascript
module.exports = {
productCard: {
width: 216,
height: 268,
},
productCardHorizontal: {
width: 140,
height: 200,
},
cartItem: {
width: 100,
height: 100,
},
};
```
120 changes: 120 additions & 0 deletions docs/getting-started/configure-magento.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,120 @@
# Configuring Magento store

This guide explains the step needed to install and set up Magento 2 store for Vue Storefront.

## Prerequisites

Before you can get started, you need the following:

- **Docker Desktop** to setup Magento 2 locally,
- **Magento Marketplace account** to download Magento 2. To create it, visit [this page](https://account.magento.com/customer/account/create/).

## Creating the Magento 2 store

We're going to install Magento 2 inside the `server` folder. Run the following commands to create a `server` folder first:

```sh
mkdir server
cd server
```

### Getting access keys for Magento

Registry that stores Magento and other third-party packages requires authentication. You'll need to generate access keys in the Magento Marketplace to install them.

Follow the [Get your authentication keys](https://devdocs.magento.com/guides/v2.4/install-gde/prereq/connect-auth.html) guide to generate new access keys.

![Access keys generated in Magento Marketplace](../assets/images/magento-marketplace-access-keys.jpg)

### Setting up the Magento 2 store

To simplify the setup, let's use the [`markshust/docker-magento`](https://github.com/markshust/docker-magento) script.

Run the command below to create the store. It will ask you for the Username and Password. Use your public access key as a username and your private access key as a password from the previous step.

```sh
curl -s https://raw.githubusercontent.com/markshust/docker-magento/master/lib/onelinesetup | bash -s -- magento.test 2.4.4
```

Here's a recording of these steps:

<Asciinema id="493276" />

### Setting up the authentication

In the Magento 2 folder, copy the `src/auth.json.sample` file and rename it to `src/auth.json`. You can do it manually or use the following command:

```sh
cp src/auth.json.sample src/auth.json
```

Update the username and password values with your Magento public and private keys.

```json
{
"http-basic": {
"repo.magento.com": {
"username": "a1c69cb…",
"password": "af041560…"
}
}
}
```

Finally, copy the file to the container by running the following command:

```sh
bin/copytocontainer auth.json
```

### Populating with sample data

In the Magento 2 folder, execute the commands below to add sample data to your store.

```sh
bin/magento sampledata:deploy
```

Then update the configuration:

```sh
bin/magento setup:upgrade
```

### Enabling CORS

You may need to enable CORS origins in your Magento store to accept requests from other domains, e.g., `magento.dev`. In the Magento 2 folder, add the package `graycore/magento2-cors` by running the command below:

```sh
bin/composer require graycore/magento2-cors
```

Then, add the following configuration at the end of `src/app/etc/env.php`:

```php
'system' => [
'default' => [
'web' => [
'graphql' => [
'cors_max_age' => 86400,
'cors_allow_credentials' => 0,
'cors_allowed_methods' => 'POST, OPTIONS, GET',
'cors_allowed_headers' => 'Content-Currency, Store, X-Magento-Cache-Id, X-Captcha, Content-Type, Authorization, DNT, TE',
'cors_allowed_origins' => '*'
]
]
]
]
```

Enable the graycore cors.

```sh
bin/magento module:enable Graycore_Cors
```

Then update the configuration:

```sh
bin/magento setup:upgrade
```
filipsobol marked this conversation as resolved.
Show resolved Hide resolved
bartoszherba marked this conversation as resolved.
Show resolved Hide resolved
6 changes: 4 additions & 2 deletions docs/guide/about.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,9 @@

## Resources

- [Vue Storefront Documentation](https://docs.vuestorefront.io/v2/)
- [Magento 2 integration Documentation (WIP)](https://docs.vuestorefront.io/magento)
- [GitHub repository](https://github.com/vuestorefront/magento2/)
- [Vue Storefront website](https://www.vuestorefront.io/)
- [Core Documentation](https://docs.vuestorefront.io/v2/)
- [Community Chat](https://discord.vuestorefront.io)

## Support
Expand All @@ -13,6 +14,7 @@ If you have any questions about this integration we will be happy to answer them
## Contributors ✨

### Honorable Mentions

- [Cyberfuze](https://cyberfuze.com/)
- [Leonex](https://www.leonex.de/)

Expand Down
Loading