From f818737a89fa7784dc8312dd7030e6601de6a3ec Mon Sep 17 00:00:00 2001 From: Bojan Rajh <117360292+bojanrajh@users.noreply.github.com> Date: Tue, 31 Dec 2024 12:47:59 +0100 Subject: [PATCH 1/3] dx: cherry cleanup (#1629) * fix: improve xml comments * fix: improve inconsistent php code block languages * fix: improve inconsistent javascript code block languages * feat: editor config * fix: markdownlint * fix: revert * fix: config path --------- Co-authored-by: jrson83 --- .editorconfig | 17 ++++++++++ .gitignore | 7 ++-- .vscode/settings.json | 5 +++ .../configurations/observability/profiling.md | 4 +-- guides/hosting/performance/k6.md | 4 +-- .../add-cms-element-via-admin-sdk.md | 12 +++---- .../add-custom-action-button.md | 4 +-- .../apps/administration/add-custom-modules.md | 6 ++-- guides/plugins/apps/app-base-guide.md | 4 +-- .../apps/app-scripts/cart-manipulation.md | 2 +- .../app-sdks/javascript/01-getting_started.md | 2 +- .../apps/app-sdks/javascript/02-lifecycle.md | 2 +- .../apps/app-sdks/javascript/03-context.md | 2 +- .../apps/custom-data/custom-entities.md | 2 +- ...add-custom-flow-actions-from-app-system.md | 2 +- ...dd-custom-flow-triggers-from-app-system.md | 4 +-- guides/plugins/apps/shipping-methods.md | 16 ++++----- .../plugins/apps/starter/add-api-endpoint.md | 2 +- .../apps/starter/starter-admin-extension.md | 4 +-- .../apps/storefront/cookies-with-apps.md | 4 +-- guides/plugins/apps/storefront/index.md | 2 +- .../add-rule-assignment-configuration.md | 8 ++--- .../plugins/administration/using-assets.md | 2 +- .../checkout/cart/add-cart-validator.md | 2 +- .../plugins/content/cms/add-cms-block.md | 2 +- .../framework/flow/add-flow-builder-action.md | 8 ++--- .../store-api/add-store-api-route.md | 2 +- guides/plugins/plugins/plugin-base-guide.md | 2 +- .../add-plugin-dependencies.md | 2 +- ...add-theme-inheritance-without-resources.md | 2 +- .../plugins/themes/add-theme-inheritance.md | 4 +-- ...override-bootstrap-variables-in-a-theme.md | 2 +- guides/plugins/themes/theme-configuration.md | 34 +++++++++---------- .../themes/theme-inheritance-configuration.md | 4 +-- .../guides/03-payment-process.md | 2 +- .../guides/04-add-new-approval-condition.md | 8 ++--- .../guides/quotes-conversion.md | 4 +-- .../07-embedding-external-repositories.md | 6 ++-- .../2020-08-21-unified-notification-titles.md | 4 +-- ...-import-acl-privileges-from-other-roles.md | 2 +- ...021-12-07-admin-extension-api-standards.md | 6 ++-- ...-02-27-native-extension-system-with-vue.md | 2 +- .../adr/2023-05-10-experimental-features.md | 2 +- ...ure-property-for-experimental-anotation.md | 2 +- 44 files changed, 122 insertions(+), 97 deletions(-) create mode 100644 .editorconfig create mode 100644 .vscode/settings.json diff --git a/.editorconfig b/.editorconfig new file mode 100644 index 000000000..60011af3d --- /dev/null +++ b/.editorconfig @@ -0,0 +1,17 @@ +# Shopware platform editor configuration normalization +# http://editorconfig.org/ + +# This is the top-most .editorconfig file; do not search in parent directories. +root = true + +# All files. +[*] +end_of_line = lf +indent_style = space +indent_size = 2 +charset = utf-8 +trim_trailing_whitespace = true +insert_final_newline = true + +[*.md] +trim_trailing_whitespace = false diff --git a/.gitignore b/.gitignore index daca60d87..ca02b484a 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,6 @@ .idea -.vscode -/dictionary.dic \ No newline at end of file +/dictionary.dic + +# VSCode-Project +/.vscode/ +!/.vscode/settings.json \ No newline at end of file diff --git a/.vscode/settings.json b/.vscode/settings.json new file mode 100644 index 000000000..9a1056a11 --- /dev/null +++ b/.vscode/settings.json @@ -0,0 +1,5 @@ +{ + "editor.tabSize": 2, + "editor.insertSpaces": true, + "editor.detectIndentation": false +} diff --git a/guides/hosting/configurations/observability/profiling.md b/guides/hosting/configurations/observability/profiling.md index 2a99e0f27..d5ce6761a 100644 --- a/guides/hosting/configurations/observability/profiling.md +++ b/guides/hosting/configurations/observability/profiling.md @@ -34,7 +34,7 @@ The OpenTelemetry profiler is not installed by default. Checkout the [OpenTeleme To add custom spans to the profiler, you can use the `Shopware\Core\Profiling\Profiler::trace` method: -```PHP +```php use Shopware\Core\Profiling\Profiler; $value = Profiler::trace('my-example-trace', function () { @@ -50,7 +50,7 @@ To add a custom profiler backend, you need to implement the `Shopware\Core\Profi The following example shows a custom profiler backend that logs the traces to the console: -```PHP +```php namespace App\Profiler; diff --git a/guides/hosting/performance/k6.md b/guides/hosting/performance/k6.md index e045525fe..085ca4cac 100644 --- a/guides/hosting/performance/k6.md +++ b/guides/hosting/performance/k6.md @@ -68,7 +68,7 @@ The command `framework:demodata` can also execute multiple times in parallel, so To run the tests, we need an scenario file. The repository comes with a example scenario file that you can use to test your store. -```js +```javascript // example.js import { accountRegister, @@ -127,7 +127,7 @@ so now the test will run with 10 virtual users and 100 iterations. You can also run multiple scenarios in the same file. To do this, you can define them in the options like so: -```js +```javascript // example.js import { productChangePrice, productChangeStocks, fetchBearerToken, useCredentials, productImport } from "./helpers/api.js"; import { diff --git a/guides/plugins/apps/administration/add-cms-element-via-admin-sdk.md b/guides/plugins/apps/administration/add-cms-element-via-admin-sdk.md index f4933d50f..e56b65e5b 100644 --- a/guides/plugins/apps/administration/add-cms-element-via-admin-sdk.md +++ b/guides/plugins/apps/administration/add-cms-element-via-admin-sdk.md @@ -51,7 +51,7 @@ When our extension is finished, you will get the following file structure: Everything starts in the `main.ts` file: -```js +```javascript import 'regenerator-runtime/runtime'; import { location } from '@shopware-ag/meteor-admin-sdk'; @@ -88,7 +88,7 @@ Observe that every file is named according to the component and prefixed with `s Let us see how the component loading via `viewRenderer.ts` looks like: -```js +```javascript import Vue from 'vue'; import { location } from '@shopware-ag/meteor-admin-sdk'; @@ -135,7 +135,7 @@ Those will be available after **registering the component**, which we will do in For this topic we head to `mainCommands.ts`, since the registration of CMS elements is something to be done in a global scope. -```js +```javascript import { cms } from '@shopware-ag/meteor-admin-sdk'; const CMS_ELEMENT_NAME = 'swag-dailymotion'; @@ -181,7 +181,7 @@ You can vary the structure of `swag-dailymotion`'s contents and create folders f Let's go through each of the files to talk about it's contents, starting with `swag-dailymotion-config.ts`: -```js +```javascript import Vue from 'vue' import { data } from "@shopware-ag/meteor-admin-sdk"; import CONSTANTS from "../../base/mainCommands"; @@ -247,7 +247,7 @@ With these small additions to typical CMS element behavior, you have already don Now let's have a look at the result of `swag-dailymotion-element.ts`: -```js +```javascript import Vue from 'vue' import { data } from "@shopware-ag/meteor-admin-sdk"; import CONSTANTS from "../../base/mainCommands"; @@ -311,7 +311,7 @@ It initially fetches the `element` data, as you've already seen it in the config Lastly, have a look at `swag-dailymotion-preview.ts`. In most cases, not much logic is to be found here, since this is the preview loaded when choosing a CMS element for your block. It makes sense to show an example preview, a miniature skeleton of the result, or just the Dailymotion logo. Therefore, the following code will suffice for your example extension: -```js +```javascript import Vue from 'vue' export default Vue.extend({ diff --git a/guides/plugins/apps/administration/add-custom-action-button.md b/guides/plugins/apps/administration/add-custom-action-button.md index dd334aa97..7e768751a 100644 --- a/guides/plugins/apps/administration/add-custom-action-button.md +++ b/guides/plugins/apps/administration/add-custom-action-button.md @@ -20,7 +20,7 @@ One extension possibility in the Administration is the ability to add custom act To get those buttons, you start in the `admin` section of your manifest file. There you can define `` elements in order to add your button, as seen as below: ```xml -// manifest.xml + @@ -297,7 +297,7 @@ This feature was added in Shopware 6.4.10.0, previous versions don't support rel To use custom endpoints as the target url for action buttons you can define the target url as a relative url in your apps manifest.xml: ```xml -// manifest.xml + diff --git a/guides/plugins/apps/administration/add-custom-modules.md b/guides/plugins/apps/administration/add-custom-modules.md index 4ddd1f2d9..7fdb4df60 100644 --- a/guides/plugins/apps/administration/add-custom-modules.md +++ b/guides/plugins/apps/administration/add-custom-modules.md @@ -36,7 +36,7 @@ To configure your module, you can set it up with with some additional attributes Additionally you can define `label` elements inside of your `module` element, to set up how your module will be displayed in the admin menu. ```xml -// manifest.xml + @@ -136,7 +136,7 @@ When you define a module, it gets automatically loaded by the Administration. Ad The navigation id of your modules always uses the pattern `app--`. So, within your manifest you can add a reference to modules that you just created: ```xml -// manifest.xml + @@ -176,7 +176,7 @@ Your main module can be defined by adding a `main-module` element within your `a To avoid mixing other modules with your main module, we decided to separate the main module from modules with navigation entries. You can still use the same URL on both, a module that is available through the menu and your main module. ```xml -// manifest.xml + diff --git a/guides/plugins/apps/app-base-guide.md b/guides/plugins/apps/app-base-guide.md index a5a12ad57..4e9bc58be 100644 --- a/guides/plugins/apps/app-base-guide.md +++ b/guides/plugins/apps/app-base-guide.md @@ -38,7 +38,7 @@ To get started with your app, create an `apps` folder inside the `custom` folder The manifest file is the central point of your app. It defines the interface between your app and the Shopware instance. It provides all the information concerning your app, as seen in the minimal version below: ```xml -// manifest.xml + @@ -299,7 +299,7 @@ Since version 6.4.12.0, your app can also request additional non-CRUD privileges Sample permissions to read, create and update products, delete orders, as well as reading the cache configuration look like this: ```xml -// manifest.xml + diff --git a/guides/plugins/apps/app-scripts/cart-manipulation.md b/guides/plugins/apps/app-scripts/cart-manipulation.md index 090e1708a..32db3176a 100644 --- a/guides/plugins/apps/app-scripts/cart-manipulation.md +++ b/guides/plugins/apps/app-scripts/cart-manipulation.md @@ -96,7 +96,7 @@ In general, Shopware prices consist of gross and net prices and are currency dep You can define price fields for [custom fields](../custom-data/custom-fields) ```xml -// manifest.xml + custom_field_test diff --git a/guides/plugins/apps/app-sdks/javascript/01-getting_started.md b/guides/plugins/apps/app-sdks/javascript/01-getting_started.md index 6ca5306cd..2f771f798 100644 --- a/guides/plugins/apps/app-sdks/javascript/01-getting_started.md +++ b/guides/plugins/apps/app-sdks/javascript/01-getting_started.md @@ -21,7 +21,7 @@ After the installation, you can use the SDK in your project. Here is an example: ## Registration process -```js +```javascript import { AppServer, InMemoryShopRepository } from '@shopware-ag/app-server-sdk' const app = new AppServer({ diff --git a/guides/plugins/apps/app-sdks/javascript/02-lifecycle.md b/guides/plugins/apps/app-sdks/javascript/02-lifecycle.md index 91caa67ef..06b07c877 100644 --- a/guides/plugins/apps/app-sdks/javascript/02-lifecycle.md +++ b/guides/plugins/apps/app-sdks/javascript/02-lifecycle.md @@ -32,7 +32,7 @@ The lifecycle registration in the `manifest.xml` would look like this: The implementation is similar to [Registration](./01-getting_started), -```js +```javascript import { AppServer, InMemoryShopRepository } from '@shopware-ag/app-server-sdk' const app = new AppServer({ diff --git a/guides/plugins/apps/app-sdks/javascript/03-context.md b/guides/plugins/apps/app-sdks/javascript/03-context.md index f7d7fc1f3..ae53f8e08 100644 --- a/guides/plugins/apps/app-sdks/javascript/03-context.md +++ b/guides/plugins/apps/app-sdks/javascript/03-context.md @@ -11,7 +11,7 @@ The ContextResolver helps you to validate the Request, resolve the Shop and prov ## Usage -```js +```javascript import { AppServer } from '@shopware-ag/app-server-sdk' const app = new AppServer(/** ... */); diff --git a/guides/plugins/apps/custom-data/custom-entities.md b/guides/plugins/apps/custom-data/custom-entities.md index b6bd140a4..6926584e9 100644 --- a/guides/plugins/apps/custom-data/custom-entities.md +++ b/guides/plugins/apps/custom-data/custom-entities.md @@ -67,7 +67,7 @@ To enable the usage of custom fields, the `custom-fields-aware` setting should b Now you will find your entity in the "Entity Type" select when creating a custom field of type "Entity Select". Without a snippet label for the entity, it will display as `custom_entity_bundle.label`. You can create a snippet to add a label like so: -```js +```javascript // Resources/app/administration/snippet/en-GB.json { "custom_entity_bundle": { diff --git a/guides/plugins/apps/flow-builder/add-custom-flow-actions-from-app-system.md b/guides/plugins/apps/flow-builder/add-custom-flow-actions-from-app-system.md index 084fe0076..df5342110 100644 --- a/guides/plugins/apps/flow-builder/add-custom-flow-actions-from-app-system.md +++ b/guides/plugins/apps/flow-builder/add-custom-flow-actions-from-app-system.md @@ -60,7 +60,7 @@ From 6.5.2.0, you can define the flow action in `flow.xml`. The `flow-action.xml The manifest file is the central point of your app. It defines the interface between your app and the Shopware instance. It provides all the information concerning your app, as seen in the minimal version below: ```xml -// manifest.xml + diff --git a/guides/plugins/apps/flow-builder/add-custom-flow-triggers-from-app-system.md b/guides/plugins/apps/flow-builder/add-custom-flow-triggers-from-app-system.md index e161bc30b..48adbcfe3 100644 --- a/guides/plugins/apps/flow-builder/add-custom-flow-triggers-from-app-system.md +++ b/guides/plugins/apps/flow-builder/add-custom-flow-triggers-from-app-system.md @@ -59,7 +59,7 @@ To get started with your app, create an `apps` folder inside the `custom` folder The manifest file is the central point of your app. It defines the interface between your app and the Shopware instance. It provides all the information concerning your app, as seen in the minimal version below: ```xml -// manifest.xml + @@ -216,7 +216,7 @@ Snippet keys should be defined based on your trigger name defined at `` in ``` -```js +```javascript // custom/apps/FlowBuilderTriggerApp/Resources/app/administration/snippet/en-GB.json { "sw-flow-custom-event": { diff --git a/guides/plugins/apps/shipping-methods.md b/guides/plugins/apps/shipping-methods.md index ba68601d7..313e1bec7 100644 --- a/guides/plugins/apps/shipping-methods.md +++ b/guides/plugins/apps/shipping-methods.md @@ -28,7 +28,7 @@ The following example represents the most minimal configuration for a shipping m Ensure that the `` of your shipping method remains unchanged, as Shopware will deactivate or delete shipping methods that do no longer appear in the manifest during app updates. ```xml -// manifest.xml + diff --git a/guides/plugins/apps/starter/starter-admin-extension.md b/guides/plugins/apps/starter/starter-admin-extension.md index c3394aba8..260cc15c1 100644 --- a/guides/plugins/apps/starter/starter-admin-extension.md +++ b/guides/plugins/apps/starter/starter-admin-extension.md @@ -41,7 +41,7 @@ When you are using a self-hosted Shopware version, you can also create the proje Next, we will put our basic configuration into the file we just created. ```xml -// manifest.xml + @@ -113,7 +113,7 @@ The final step of the setup is to configure your app to use that file as an entr To do that, we have to add an `admin` section to our `manifest.xml` file and pass it into the `base-app-url` tag: ```xml -// manifest.xml + diff --git a/guides/plugins/apps/storefront/cookies-with-apps.md b/guides/plugins/apps/storefront/cookies-with-apps.md index ede118903..d2cffd465 100644 --- a/guides/plugins/apps/storefront/cookies-with-apps.md +++ b/guides/plugins/apps/storefront/cookies-with-apps.md @@ -18,7 +18,7 @@ You should be familiar with the concept of apps. To add new cookies to the cookie consent manager, you can add a `cookies` section to your `manifest.xml`. Inside this section, you can add new `cookie` elements, as shown in the following example. Note that you don't need a `setup` section in your `manifest.xml` since extending the Storefront doesn't need a registration nor an own server to run. ```xml -// manifest.xml + @@ -55,7 +55,7 @@ When adding multiple cookies through your app it may become handy to group them. To add a cookie group, you can add a `groups` section within your `cookies` section in your `manifest.xml`. In the following example, we use the cookie that we created in the previous section but display it in a cookie group: ```xml -// manifest.xml + diff --git a/guides/plugins/apps/storefront/index.md b/guides/plugins/apps/storefront/index.md index 6abeb3b6f..d7581efd9 100644 --- a/guides/plugins/apps/storefront/index.md +++ b/guides/plugins/apps/storefront/index.md @@ -46,7 +46,7 @@ Note that this feature was introduced in Shopware 6.4.12.0, and is not supported You may want your templates loaded before or after other extensions. To do so, you can define a `template-load-priority` inside your `manifest.xml`. The default value to this is 0, with positive numbers your template will be loaded earlier, and with negative numbers later. ```xml -// manifest.xml + diff --git a/guides/plugins/plugins/administration/add-rule-assignment-configuration.md b/guides/plugins/plugins/administration/add-rule-assignment-configuration.md index 6f302884c..6d03f4c8c 100644 --- a/guides/plugins/plugins/administration/add-rule-assignment-configuration.md +++ b/guides/plugins/plugins/administration/add-rule-assignment-configuration.md @@ -162,7 +162,7 @@ Let's go through the most important entries, how to configure your rule assignme If you want to provide to delete an assignment, you have to define the `deleteContext`. There are two types of the `deleteContext`. The first one is the `one-to-many` type, which link to a column of the assignment entity like this: -```js +```javascript // Example of a one-to-many deleteContext deleteContext: { type: 'one-to-many', @@ -173,7 +173,7 @@ deleteContext: { The other type is `many-to-many`, which has to link to the `ManyToManyAssociationField` of the extension like this: -```js +```javascript // Example of a many-to-many deleteContext deleteContext: { type: 'many-to-many', @@ -187,7 +187,7 @@ deleteContext: { If you want to provide to add an assignment, you have to define the `addContext`. This context has the same two types as the `deleteContext` (see above), but the `addContext` has more options to fill out, because an add assignment modal has to be configured: -```js +```javascript // Example of a one-to-many addContext addContext: { type: 'one-to-many', @@ -241,7 +241,7 @@ Also, the context needs the `column` of the assignment and the `searchColumn` of A context of the `many-to-many` type would look like this: -```js +```javascript // Example of a many-to-many addContext addContext: { type: 'many-to-many', diff --git a/guides/plugins/plugins/administration/using-assets.md b/guides/plugins/plugins/administration/using-assets.md index b10e92c75..cce52c4c5 100644 --- a/guides/plugins/plugins/administration/using-assets.md +++ b/guides/plugins/plugins/administration/using-assets.md @@ -65,7 +65,7 @@ Note that [Vue filters](https://vuejs.org/v2/guide/filters.html) are no longer s Create a computed component to make them easy to use in your template. -```js +```javascript computed: { assetFilter() { return Shopware.Filter.getByName('asset'); diff --git a/guides/plugins/plugins/checkout/cart/add-cart-validator.md b/guides/plugins/plugins/checkout/cart/add-cart-validator.md index a75813d5d..940c78b43 100644 --- a/guides/plugins/plugins/checkout/cart/add-cart-validator.md +++ b/guides/plugins/plugins/checkout/cart/add-cart-validator.md @@ -182,7 +182,7 @@ You've defined the error key to be `custom-line-item-blocked` in your custom err Now let's have a look at an example snippet file: -```js +```javascript // /src/Resources/snippet/en\_GB/example.en-GB.json { "checkout": { diff --git a/guides/plugins/plugins/content/cms/add-cms-block.md b/guides/plugins/plugins/content/cms/add-cms-block.md index d1dc8cc8d..21164e6d2 100644 --- a/guides/plugins/plugins/content/cms/add-cms-block.md +++ b/guides/plugins/plugins/content/cms/add-cms-block.md @@ -198,7 +198,7 @@ The preview element doesn't have to deal with mobile viewports or anything alike Also, you need to create a computed component to access the asset filter in your template. -```js +```javascript // /src/Resources/app/administration/src/module/sw-cms/blocks/text-image/my-image-text-reversed/preview/index.js computed: { assetFilter() { diff --git a/guides/plugins/plugins/framework/flow/add-flow-builder-action.md b/guides/plugins/plugins/framework/flow/add-flow-builder-action.md index 304762851..bfc7f40e3 100644 --- a/guides/plugins/plugins/framework/flow/add-flow-builder-action.md +++ b/guides/plugins/plugins/framework/flow/add-flow-builder-action.md @@ -163,7 +163,7 @@ There are three scopes for the `CreateTagAction`: - Just define the empty array in `CreateTagAction::requirements` -```PHP +```php // plugin root>/src/Core/Content/Flow/Dispatching/Action/CreateTagAction.php ... @@ -185,7 +185,7 @@ Here, the action name is empty as the action name snippet is not yet defined. Make the `CreateTagAction` available for all events related to Order and Customer. -```PHP +```php // /src/Core/Content/Flow/Dispatching/Action/CreateTagAction.php ... @@ -203,7 +203,7 @@ Make the `CreateTagAction` available for all events related to Order and Custome - Event must implement the `TagAware` -```PHP +```php // /src/Core/Content/Flow/Subscriber/BusinessEventCollectorSubscriber.php /src/Core/Content/Flow/Dispatching/Action/CreateTagAction.php ... diff --git a/guides/plugins/plugins/framework/store-api/add-store-api-route.md b/guides/plugins/plugins/framework/store-api/add-store-api-route.md index 3d2c2a9f6..ceee65e48 100644 --- a/guides/plugins/plugins/framework/store-api/add-store-api-route.md +++ b/guides/plugins/plugins/framework/store-api/add-store-api-route.md @@ -163,7 +163,7 @@ $ ./bin/console debug:router store-api.example.search To add the route to the Swagger page, a JSON file is needed in a specific [format](https://swagger.io/specification/#paths-object). It contains information about the paths, methods, parameters, and more. You must place the JSON file in `/src/Resources/Schema/StoreApi/` so the shopware internal OpenApi3Generator can find it (for Admin API endpoints, use `AdminApi`). -```js +```javascript // /src/Resources/Schema/StoreApi/example.json { "openapi": "3.0.0", diff --git a/guides/plugins/plugins/plugin-base-guide.md b/guides/plugins/plugins/plugin-base-guide.md index 4ff2d8ed3..0f1fbd3ff 100644 --- a/guides/plugins/plugins/plugin-base-guide.md +++ b/guides/plugins/plugins/plugin-base-guide.md @@ -96,7 +96,7 @@ and the `require` field must include at least `shopware/core`, to check for comp Here's an example `composer.json` for this guide, which will do the trick: -```js +```javascript // /composer.json { "name": "swag/basic-example", diff --git a/guides/plugins/plugins/plugin-fundamentals/add-plugin-dependencies.md b/guides/plugins/plugins/plugin-fundamentals/add-plugin-dependencies.md index 9e9029305..ea9acf422 100644 --- a/guides/plugins/plugins/plugin-fundamentals/add-plugin-dependencies.md +++ b/guides/plugins/plugins/plugin-fundamentals/add-plugin-dependencies.md @@ -30,7 +30,7 @@ Important to note is the `name` as well as the `version` mentioned here, the res In order to require the `SwagBasicExample` plugin now, you simply have to add these two information to your own `composer.json` as a key value pair: -```js +```javascript // /composer.json { "name": "swag/plugin-dependency", diff --git a/guides/plugins/themes/add-theme-inheritance-without-resources.md b/guides/plugins/themes/add-theme-inheritance-without-resources.md index 1172a64bd..2d5108f72 100644 --- a/guides/plugins/themes/add-theme-inheritance-without-resources.md +++ b/guides/plugins/themes/add-theme-inheritance-without-resources.md @@ -15,7 +15,7 @@ The Shopware default theme is using [Bootstrap](https://getbootstrap.com/) with If you want to build your theme only upon the Bootstrap SCSS you can use the `@StorefrontBootstrap` placeholder instead of the `@Storefront` bundle in the `style` section of your `theme.json`. This gives you the ability to use the Bootstrap SCSS without the Shopware Storefront "skin". Therefore all the SCSS from `src/Storefront/Resources/app/storefront/src/scss/skin` will not be available in your theme. -```js +```javascript // /src/Resources/theme.json { ... diff --git a/guides/plugins/themes/add-theme-inheritance.md b/guides/plugins/themes/add-theme-inheritance.md index 3653c4de8..817439460 100644 --- a/guides/plugins/themes/add-theme-inheritance.md +++ b/guides/plugins/themes/add-theme-inheritance.md @@ -27,7 +27,7 @@ To set up the inheritance we need to edit the theme configuration file called `t The content of the `theme.json` file looks like this: -```js +```javascript // /src/Resources/theme.json { "name": "SwagBasicExampleThemeExtend", @@ -59,7 +59,7 @@ Now it is easy to see how we can inherit from our base theme `SwagBasicExampleTh Here is an example: -```js +```javascript // /src/Resources/theme.json { "name": "SwagBasicExampleThemeExtend", diff --git a/guides/plugins/themes/override-bootstrap-variables-in-a-theme.md b/guides/plugins/themes/override-bootstrap-variables-in-a-theme.md index fca843d9f..d8b6a5a0f 100644 --- a/guides/plugins/themes/override-bootstrap-variables-in-a-theme.md +++ b/guides/plugins/themes/override-bootstrap-variables-in-a-theme.md @@ -29,7 +29,7 @@ To be able to override Bootstrap variables there is an additional SCSS entry poi This entry point is called `overrides.scss`: -```js +```javascript // /src/Resources/theme.json { "name": "SwagBasicExampleTheme", diff --git a/guides/plugins/themes/theme-configuration.md b/guides/plugins/themes/theme-configuration.md index 15839b0f3..4f543fced 100644 --- a/guides/plugins/themes/theme-configuration.md +++ b/guides/plugins/themes/theme-configuration.md @@ -25,7 +25,7 @@ This guide is built upon the guide on creating a first theme: The theme configuration for a theme is located in the `theme.json` file `/src/Resources` folder. Open up the `/src/Resources/theme.json` file with your favorite code-editor. The configuration looks like this. -```js +```javascript // /src/Resources/theme.json { "name": "SwagBasicExampleTheme", @@ -66,7 +66,7 @@ If you make changes or additions to the `theme.json` file, you must then execute Let's have a closer look at each section. -```js +```javascript // /src/Resources/theme.json { "name": "SwagBasicExampleTheme", @@ -83,7 +83,7 @@ Here change the `name` of your theme and the `author`. The `description` section The `views` section controls the template inheritance. This will be covered in the [Theme inheritance](add-theme-inheritance) guide. -```js +```javascript // /src/Resources/theme.json { ... @@ -98,7 +98,7 @@ The `views` section controls the template inheritance. This will be covered in t The `previewMedia` field provides a path `app/storefront/dist/assets/defaultThemePreview.jpg` to an image file that is relative to the root directory of the theme. It serves as a visual preview of the theme. This preview image is typically displayed within the Shopware administration interface or theme marketplace as a thumbnail or preview of the theme's appearance to give users an idea of how the theme will appear on their storefront before they activate it. -```js +```javascript // /src/Resources/theme.json { ... @@ -109,7 +109,7 @@ The `previewMedia` field provides a path `app/storefront/dist/assets/defaultThem The `style` section determines the order of the CSS compilation. In the `/app/storefront/src/scss/base.scss` file you can apply your changes you want to make to the `@Storefront` standard styles or add other styles you need. The `/app/storefront/src/scss/overrides.scss` file is used for a special case. Maybe you need to override some defined `variables` or `functions` defined by Shopware or Bootstrap, you can implement your changes here. Checkout the [Override bootstrap variables in a theme](override-bootstrap-variables-in-a-theme) guide for further information. -```js +```javascript // /src/Resources/theme.json { ... @@ -126,7 +126,7 @@ The `style` section determines the order of the CSS compilation. In the `/app/storefront/src/assets` folder. Checkout the [Add assets to theme](add-assets-to-theme) guide for further information. -```js +```javascript // /src/Resources/theme.json { ... @@ -139,7 +139,7 @@ The `asset` option you can configure your paths to your assets like images, font If you need the assets from the default storefront theme for your custom theme, just add `@Storefront` as asset path -```js +```javascript // /src/Resources/theme.json { ... @@ -155,7 +155,7 @@ If you need the assets from the default storefront theme for your custom theme, One of the benefits of creating a theme is that you can overwrite the theme configuration of the default theme or add your own configurations. -```js +```javascript // /src/Resources/theme.json { ... @@ -202,7 +202,7 @@ You can use different field types in your theme manager: A text field example: -```js +```javascript // /src/Resources/theme.json { ... @@ -224,7 +224,7 @@ A text field example: A number field example: -```js +```javascript // /src/Resources/theme.json { ... @@ -251,7 +251,7 @@ A number field example: Two boolean field examples: -```js +```javascript // /src/Resources/theme.json { ... @@ -273,7 +273,7 @@ Two boolean field examples: or -```js +```javascript // /src/Resources/theme.json { ... @@ -297,7 +297,7 @@ or A custom single-select field example -```js +```javascript // /src/Resources/theme.json { "name": "Just another theme", @@ -388,7 +388,7 @@ A custom single-select field example A custom multi-select field example -```js +```javascript // /src/Resources/theme.json { "name": "Just another theme", @@ -495,7 +495,7 @@ You can use tabs, blocks and sections to structure and group the config options. In the picture above are four tabs. In the "Colours" tab there is one block "Theme colours" which contains two sections named "Important colors" and "Other". You can define the block and section individually for each item. Example: -```js +```javascript // /src/Resources/theme.json { "name": "Just another theme", @@ -524,7 +524,7 @@ The tab and section property is not required. You can extend the config to add translated labels for the tabs, blocks and sections: -```js +```javascript // /src/Resources/theme.json { "name": "Just another theme", @@ -577,7 +577,7 @@ You can extend the config to add translated labels for the tabs, blocks and sect The `configInheritance` option lets you configure additional themes from which your theme will inherit its fields configuration and snippets. Every theme will always inherit the fields from the `Storefront` standard theme. With this option you can add additional other themes. For example, you can have a basic theme for your corporate design and special themes for different sales channels with specific changes only needed for a single sales channel. -```js +```javascript // /src/Resources/theme.json { ... diff --git a/guides/plugins/themes/theme-inheritance-configuration.md b/guides/plugins/themes/theme-inheritance-configuration.md index 75618a7c6..3f4b72153 100644 --- a/guides/plugins/themes/theme-inheritance-configuration.md +++ b/guides/plugins/themes/theme-inheritance-configuration.md @@ -27,7 +27,7 @@ Create the two themes like described in [Theme inheritance](./add-theme-inherita Add some configuration fields you need in your basic theme inside the `theme.json` of the `SwagBasicExampleTheme` -```js +```javascript // /src/Resources/theme.json { "name": "SwagBasicExampleTheme", @@ -88,7 +88,7 @@ Add some configuration fields you need in your basic theme inside the `theme.jso Add configurations to your extended theme -```js +```javascript // /src/Resources/theme.json { "name": "SwagBasicExampleThemeExtend", diff --git a/products/extensions/b2b-components/order-approval/guides/03-payment-process.md b/products/extensions/b2b-components/order-approval/guides/03-payment-process.md index 843162c4d..2ba9e039b 100644 --- a/products/extensions/b2b-components/order-approval/guides/03-payment-process.md +++ b/products/extensions/b2b-components/order-approval/guides/03-payment-process.md @@ -19,7 +19,7 @@ The payment process of the order approval component can be customized by extendi Normally, after reviewer approves the order, the payment process will be executed automatically. However, if you just want to approve the order without executing the payment process, you can subscribe to the `PendingOrderApprovedEvent` event and set the `PendingOrderApprovedEvent::shouldProceedPlaceOrder` to `false`. This event is dispatched in the `Shopware\Commercial\B2B\OrderApproval\Storefront\Controller\ApprovalPendingOrderController::order` method. -```PHP +```php use Shopware\Commercial\B2B\OrderApproval\Event\PendingOrderApprovedEvent; diff --git a/products/extensions/b2b-components/order-approval/guides/04-add-new-approval-condition.md b/products/extensions/b2b-components/order-approval/guides/04-add-new-approval-condition.md index 282457441..4471a1411 100644 --- a/products/extensions/b2b-components/order-approval/guides/04-add-new-approval-condition.md +++ b/products/extensions/b2b-components/order-approval/guides/04-add-new-approval-condition.md @@ -15,7 +15,7 @@ To add a custom rule, following this document [Add custom rule](../../../../../g Example: -```PHP +```php cart_tax_status_rule_script @@ -194,7 +194,7 @@ We then use the variables `operator` and `totalPrice`, provided by the constrain ![App Approval Rule Condition Single Select](../../../../../assets/approval-rule-condition-single-select-example.png) ```xml -// manifest.xml + cart_tax_status_rule_script @@ -241,7 +241,7 @@ We then use the variables `operator` and `totalPrice`, provided by the constrain ![App Approval Rule Condition Multi Select](../../../../../assets/approval-rule-condition-multi-select-example.png) ```xml -// manifest.xml + cart_currency_rule_script diff --git a/products/extensions/b2b-components/quotes-management/guides/quotes-conversion.md b/products/extensions/b2b-components/quotes-management/guides/quotes-conversion.md index f3fe57e36..a5649b304 100644 --- a/products/extensions/b2b-components/quotes-management/guides/quotes-conversion.md +++ b/products/extensions/b2b-components/quotes-management/guides/quotes-conversion.md @@ -13,7 +13,7 @@ Customers can convert their shopping carts into quotes to facilitate seamless pr When a customer wants to request a quote for their shopping cart, the process involves converting a cart to an order and then proceeding to enrich the data for the quote. The method `convertToQuote` of class `Shopware\Commercial\B2B\QuoteManagement\Domain\CartToQuote\CartToQuoteConverter` is responsible for this process. -```PHP +```php use Shopware\Core\Checkout\Cart\Order\OrderConversionContext; use Shopware\Core\Checkout\Cart\Cart; use Shopware\Core\Checkout\Cart\Order\OrderConverter; @@ -36,7 +36,7 @@ public function convertToQuote(Cart $cart, SalesChannelContext $context, OrderCo When a customer wants to place an order based on a quote, a new cart is created based on the quote data. The method `convertToCart` of class `Shopware\Commercial\B2B\QuoteManagement\Domain\QuoteToCart\QuoteToCartConverter` is responsible for this process. -```PHP +```php use Shopware\Core\Checkout\Cart\Cart; use Shopware\Core\Framework\Uuid\Uuid; use Shopware\Core\System\SalesChannel\SalesChannelContext; diff --git a/resources/guidelines/documentation-guidelines/07-embedding-external-repositories.md b/resources/guidelines/documentation-guidelines/07-embedding-external-repositories.md index 1ffc1781c..73a63dba3 100644 --- a/resources/guidelines/documentation-guidelines/07-embedding-external-repositories.md +++ b/resources/guidelines/documentation-guidelines/07-embedding-external-repositories.md @@ -53,7 +53,7 @@ By default, contents are grouped under `General` section in the Algolia search u Update `sections: SwagSectionsConfig[]` with all the regex matches for your sections and define the title of new section displayed in the Algolia search modal. -```js +```javascript const sections: SwagSectionsConfig[] = [ // ... { @@ -71,7 +71,7 @@ Every article has a `Edit this page on GitHub` link in the bottom left corner. B You can do that by updating `const embeds: SwagEmbedsConfig[]`. -```js +```javascript const embeds: SwagEmbedsConfig[] = [ // ... { @@ -102,7 +102,7 @@ Update `themeConfig.swag.colorCoding` with your settings for color coding in the When you also want to share static assets from your repository such as `.pdf` or `.zip` files (excluding statically linked images in articles), make sure to copy them in the `buildEnd` hook. -```js +```javascript export default { // ... async buildEnd() { diff --git a/resources/references/adr/2020-08-21-unified-notification-titles.md b/resources/references/adr/2020-08-21-unified-notification-titles.md index 283254870..f5757d11e 100644 --- a/resources/references/adr/2020-08-21-unified-notification-titles.md +++ b/resources/references/adr/2020-08-21-unified-notification-titles.md @@ -46,7 +46,7 @@ For more information on snippets deleted in this course see CHANGELOG-6.3.md * Create error notification -```js +```javascript this.createNotificationError({ message: this.$tc('sw-module.messageError') }); @@ -59,7 +59,7 @@ this.createNotificationError({ * Avoid cheap solutions like -```js +```javascript this.createNotificationError({ message: err }); diff --git a/resources/references/adr/2020-08-28-import-acl-privileges-from-other-roles.md b/resources/references/adr/2020-08-28-import-acl-privileges-from-other-roles.md index bfcce2aaf..34d466ee0 100644 --- a/resources/references/adr/2020-08-28-import-acl-privileges-from-other-roles.md +++ b/resources/references/adr/2020-08-28-import-acl-privileges-from-other-roles.md @@ -24,7 +24,7 @@ To avoid duplication of these privileges we use a helper function. These function returns all privileges from the other module dynamically. You can use it directly in the privileges: -```js +```javascript Shopware.Service('privileges') .addPrivilegeMappingEntry({ category: 'permissions', diff --git a/resources/references/adr/2021-12-07-admin-extension-api-standards.md b/resources/references/adr/2021-12-07-admin-extension-api-standards.md index 5ba088853..2cd2308ce 100644 --- a/resources/references/adr/2021-12-07-admin-extension-api-standards.md +++ b/resources/references/adr/2021-12-07-admin-extension-api-standards.md @@ -29,7 +29,7 @@ An app wants to render a custom iFrame in a card on the dashboard. The "location The app want to render different views depending on the "location" of the iFrame. So the app developer can render the correct view depending on the "locationID": -```js +```javascript if (sw.location.is('sw-dashboard-example-app-dashboard-card')) { renderDashboardCard(); } @@ -46,7 +46,7 @@ Developers can extend existing areas or create new areas in the administration w An app wants to add a new tab item to a tab-bar. In the administration are many tab-bars available. So the developer needs to choose the correct "positionID" to determine which tab-bar should be extended. In this example the developer adds a new tab item to the tab-bar in the product detail page. -```js +```javascript sw.ui.tabs('sw-product-detail').addTabItem({ ... }) ``` @@ -59,7 +59,7 @@ In most cases developers will directly use the extension capabilities of the UI To give them more flexibility we introduce a feature named "Component Sections". These are sections where any extension developer can inject components. These components are prebuilt and they can also contain custom render views with iFrames. The developer needs to use the feature and choose the matching positionID for the component position. -```js +```javascript // Adding a card before the manufacturer card with custom fields entries. sw.ui.componentSection('sw-manufacturer-card-custom-fields__before').add({ // The Extension-API provides different components out of the box diff --git a/resources/references/adr/2023-02-27-native-extension-system-with-vue.md b/resources/references/adr/2023-02-27-native-extension-system-with-vue.md index e9a78325d..a86a79733 100644 --- a/resources/references/adr/2023-02-27-native-extension-system-with-vue.md +++ b/resources/references/adr/2023-02-27-native-extension-system-with-vue.md @@ -29,7 +29,7 @@ Our main idea for the template part was to use native Vue components named sw-bl For the script and logic part, we aimed to use the Composition API. Before returning all the component data and methods, we would provide a hook point for plugins so they could modify or inject everything they want. -```js +```javascript // The original component