diff --git a/.eslintignore b/.eslintignore
new file mode 100644
index 0000000000..86f4257f41
--- /dev/null
+++ b/.eslintignore
@@ -0,0 +1,2 @@
+**/webpack.config.js
+vendor
diff --git a/.eslintrc.json b/.eslintrc.json
index 7c88e4121f..011399debe 100644
--- a/.eslintrc.json
+++ b/.eslintrc.json
@@ -1,31 +1,3 @@
{
- "plugins": ["prettier"],
- "extends": ["prettier", "eslint:recommended"],
- "env": {
- "browser": true,
- "commonjs": true,
- "es6": true,
- "node": true
- },
- "parser": "babel-eslint",
- "parserOptions": {
- "ecmaFeatures": {
- "jsx": true,
- "classes": true,
- "experimentalObjectRestSpread": true
- },
- "sourceType": "module"
- },
- "rules": {
- "no-const-assign": "warn",
- "no-console": "off",
- "no-this-before-super": "warn",
- "no-undef": "warn",
- "no-unreachable": "warn",
- "no-unused-vars": "warn",
- "constructor-super": "warn",
- "valid-typeof": "warn",
- "no-extra-semi": "error",
- "no-extra-boolean-cast": "off"
- }
+ "extends": "eslint-config-ibexa/eslint"
}
diff --git a/.github/workflows/build.yaml b/.github/workflows/build.yaml
index 7bda6b4764..5ab6fb5afb 100644
--- a/.github/workflows/build.yaml
+++ b/.github/workflows/build.yaml
@@ -35,6 +35,11 @@ jobs:
- name: Run PHP CS Fixer
run: tools/php-cs-fixer/vendor/bin/php-cs-fixer fix --config=.php-cs-fixer.php -v --show-progress=dots
+ - name: Run Prettier
+ run: |
+ yarn install
+ yarn prettier-test --write
+
- name: Commit changes
uses: stefanzweifel/git-auto-commit-action@v4
with:
diff --git a/.gitignore b/.gitignore
index d30a4f0faa..ab03be3cad 100644
--- a/.gitignore
+++ b/.gitignore
@@ -6,3 +6,6 @@ __pycache__/*
.php-cs-fixer.cache
composer.lock
tools/php-cs-fixer/vendor
+node_modules/
+.yarn
+yarn.lock
diff --git a/.prettierignore b/.prettierignore
new file mode 100644
index 0000000000..d1a24d79d9
--- /dev/null
+++ b/.prettierignore
@@ -0,0 +1 @@
+**/webpack.config.js
diff --git a/code_samples/back_office/image_editor/assets/random_dot/random-dot-stem.js b/code_samples/back_office/image_editor/assets/random_dot/random-dot-stem.js
index 2583ff3580..29cd7d2aa0 100644
--- a/code_samples/back_office/image_editor/assets/random_dot/random-dot-stem.js
+++ b/code_samples/back_office/image_editor/assets/random_dot/random-dot-stem.js
@@ -29,5 +29,5 @@ ibexa.addConfig(
icon: ibexa.helpers.icon.getIconPath('radio-button'), // Path to an icon that will be displayed in the UI
identifier: IDENTIFIER, // The identifier must match the one from the configuration yaml file
},
- true
+ true,
);
diff --git a/code_samples/back_office/image_editor/assets/random_dot/random-dot.js b/code_samples/back_office/image_editor/assets/random_dot/random-dot.js
index 04420bad14..0d714c89f6 100644
--- a/code_samples/back_office/image_editor/assets/random_dot/random-dot.js
+++ b/code_samples/back_office/image_editor/assets/random_dot/random-dot.js
@@ -65,5 +65,5 @@ ibexa.addConfig(
icon: ibexa.helpers.icon.getIconPath('radio-button'),
identifier: IDENTIFIER,
},
- true
+ true,
);
diff --git a/code_samples/back_office/online_editor/assets/js/online_editor/buttons/date.js b/code_samples/back_office/online_editor/assets/js/online_editor/buttons/date.js
deleted file mode 100644
index e3ea1fe79c..0000000000
--- a/code_samples/back_office/online_editor/assets/js/online_editor/buttons/date.js
+++ /dev/null
@@ -1,41 +0,0 @@
-import PropTypes from 'prop-types';
-import AlloyEditor from 'alloyeditor';
-import IbexaButton
- from '../../../../vendor/ezsystems/ezplatform-richtext/src/bundle/Resources/public/js/OnlineEditor/buttons/base/ibexa-button.js';
-
-export default class BtnDate extends IbexaButton {
- static get key() {
- return 'date';
- }
-
- insertDate(data) {
- this.execCommand(data);
- }
-
- render() {
- const title = 'Date';
-
- return (
-
- );
- }
-}
-
-AlloyEditor.Buttons[BtnDate.key] = AlloyEditor.BtnDate = BtnDate;
-ibexa.addConfig('ezAlloyEditor.BtnDate', BtnDate);
-
-BtnDate.propTypes = {
- command: PropTypes.string,
-};
-
-BtnDate.defaultProps = {
- command: 'InsertDate',
-};
diff --git a/code_samples/back_office/online_editor/assets/js/online_editor/buttons/hr.js b/code_samples/back_office/online_editor/assets/js/online_editor/buttons/hr.js
deleted file mode 100644
index b684fd249c..0000000000
--- a/code_samples/back_office/online_editor/assets/js/online_editor/buttons/hr.js
+++ /dev/null
@@ -1,48 +0,0 @@
-import PropTypes from 'prop-types';
-import AlloyEditor from 'alloyeditor';
-import IbexaButton
- from '../../../../vendor/ezsystems/ezplatform-richtext/src/bundle/Resources/public/js/OnlineEditor/buttons/base/ibexa-button.js';
-
-export default class IbexaBtnHr extends IbexaButton {
- static get key() {
- return 'hr';
- }
-
- addHr() {
- this.execCommand({
- tagName: 'hr',
- });
- }
-
- render() {
- const title = "Hr";
- return (
-
- );
- }
-}
-
-AlloyEditor.Buttons[IbexaBtnHr.key] = AlloyEditor.IbexaBtnHr = IbexaBtnHr;
-
-const ibexa = (window.ibexa = window.ibexa || {});
-
-ibexa.ezAlloyEditor = ibexa.ezAlloyEditor || {};
-ibexa.ezAlloyEditor.IbexaBtnHr = IbexaBtnHr;
-
-IbexaBtnHr.propTypes = {
- command: PropTypes.string,
- modifiesSelection: PropTypes.bool,
-};
-
-IbexaBtnHr.defaultProps = {
- command: 'ibexaAddContent',
- modifiesSelection: true,
-};
diff --git a/code_samples/back_office/online_editor/assets/js/online_editor/plugins/date.js b/code_samples/back_office/online_editor/assets/js/online_editor/plugins/date.js
index d75bf3364d..c306895cff 100644
--- a/code_samples/back_office/online_editor/assets/js/online_editor/plugins/date.js
+++ b/code_samples/back_office/online_editor/assets/js/online_editor/plugins/date.js
@@ -6,10 +6,10 @@
const InsertDate = {
exec: function (editor) {
const now = new Date();
- editor.insertHtml( now.toString() );
+ editor.insertHtml(now.toString());
},
};
-
+
global.CKEDITOR.plugins.add('date', {
init: (editor) => editor.addCommand('InsertDate', InsertDate),
});
diff --git a/code_samples/back_office/search/append_to_webpack.config.js b/code_samples/back_office/search/append_to_webpack.config.js
index 3fa0b8d917..5146bc2a0e 100644
--- a/code_samples/back_office/search/append_to_webpack.config.js
+++ b/code_samples/back_office/search/append_to_webpack.config.js
@@ -1,8 +1,7 @@
-
const ibexaConfigManager = require('./ibexa.webpack.config.manager.js');
ibexaConfigManager.add({
ibexaConfig,
entryName: 'ibexa-admin-ui-layout-js',
- newItems: [ path.resolve(__dirname, './assets/js/admin.search.autocomplete.product.js'), ],
+ newItems: [path.resolve(__dirname, './assets/js/admin.search.autocomplete.product.js')],
});
diff --git a/code_samples/back_office/search/assets/js/admin.search.autocomplete.product.js b/code_samples/back_office/search/assets/js/admin.search.autocomplete.product.js
index c9a80f0b16..7394a84a93 100644
--- a/code_samples/back_office/search/assets/js/admin.search.autocomplete.product.js
+++ b/code_samples/back_office/search/assets/js/admin.search.autocomplete.product.js
@@ -1,14 +1,16 @@
(function (global, doc, ibexa, Routing) {
const renderItem = (result, searchText) => {
const globalSearch = doc.querySelector('.ibexa-global-search');
- const {highlightText} = ibexa.helpers.highlight;
- const autocompleteHighlightTemplate = globalSearch.querySelector('.ibexa-global-search__autocomplete-list').dataset.templateHighlight;
- const {getContentTypeIconUrl, getContentTypeName} = ibexa.helpers.contentType;
+ const { highlightText } = ibexa.helpers.highlight;
+ const autocompleteHighlightTemplate = globalSearch.querySelector('.ibexa-global-search__autocomplete-list').dataset
+ .templateHighlight;
+ const { getContentTypeIconUrl, getContentTypeName } = ibexa.helpers.contentType;
- const autocompleteItemTemplate = globalSearch.querySelector('.ibexa-global-search__autocomplete-product-template').dataset.templateItem;
+ const autocompleteItemTemplate = globalSearch.querySelector('.ibexa-global-search__autocomplete-product-template').dataset
+ .templateItem;
return autocompleteItemTemplate
- .replace('{{ productHref }}', Routing.generate('ibexa.product_catalog.product.view', {productCode: result.productCode}))
+ .replace('{{ productHref }}', Routing.generate('ibexa.product_catalog.product.view', { productCode: result.productCode }))
.replace('{{ productName }}', highlightText(searchText, result.name, autocompleteHighlightTemplate))
.replace('{{ productCode }}', result.productCode)
.replace('{{ productTypeIconHref }}', getContentTypeIconUrl(result.productTypeIdentifier))
diff --git a/code_samples/back_office/udw/assets/js/image-tab/components/image.js b/code_samples/back_office/udw/assets/js/image-tab/components/image.js
index 9319aad37f..4466982251 100644
--- a/code_samples/back_office/udw/assets/js/image-tab/components/image.js
+++ b/code_samples/back_office/udw/assets/js/image-tab/components/image.js
@@ -13,7 +13,6 @@ const Image = ({ restInfo, location }) => {
const [selectedLocations, dispatchSelectedLocationsAction] = useContext(SelectedLocationsContext);
const [multiple] = useContext(MultipleConfigContext);
const updateVersionInfoState = (response) => {
-
setContent(response.View.Result.searchHits.searchHit[0].value.Content);
};
const markLocation = ({ nativeEvent }) => {
@@ -29,11 +28,10 @@ const Image = ({ restInfo, location }) => {
if (!multiple) {
dispatchSelectedLocationsAction({ type: 'CLEAR_SELECTED_LOCATIONS' });
- dispatchSelectedLocationsAction({ type: 'ADD_SELECTED_LOCATION', location });
+ dispatchSelectedLocationsAction({ type: 'ADD_SELECTED_LOCATION', location });
}
};
let src =
-
'';
let alt = 'Loading meta data ...';
diff --git a/code_samples/back_office/udw/assets/js/image-tab/image.tab.module.js b/code_samples/back_office/udw/assets/js/image-tab/image.tab.module.js
index d8cd9f159e..65e25e0d91 100644
--- a/code_samples/back_office/udw/assets/js/image-tab/image.tab.module.js
+++ b/code_samples/back_office/udw/assets/js/image-tab/image.tab.module.js
@@ -22,7 +22,7 @@ ibexa.addConfig(
icon: '/bundles/ibexaadminui/img/ibexa-icons.svg#image',
},
],
- true
+ true,
);
export default ImageTabModule;
diff --git a/code_samples/forms/custom_form_attribute/assets/js/formbuilder-richtext-checkbox.js b/code_samples/forms/custom_form_attribute/assets/js/formbuilder-richtext-checkbox.js
index 80a2cd40ca..3c8b1e1c0f 100644
--- a/code_samples/forms/custom_form_attribute/assets/js/formbuilder-richtext-checkbox.js
+++ b/code_samples/forms/custom_form_attribute/assets/js/formbuilder-richtext-checkbox.js
@@ -3,19 +3,15 @@
const richtext = new ibexa.BaseRichText();
// Enable editor in all ibexa-data-source divs
- doc.querySelectorAll('.ibexa-data-source').forEach(
- (ibexaDataSource) => {
- const richtextContainer = ibexaDataSource.querySelector(
- '.ibexa-data-source__richtext'
- );
+ doc.querySelectorAll('.ibexa-data-source').forEach((ibexaDataSource) => {
+ const richtextContainer = ibexaDataSource.querySelector('.ibexa-data-source__richtext');
- if (richtextContainer.classList.contains('ck')) {
- return;
- }
-
- richtext.init(richtextContainer);
+ if (richtextContainer.classList.contains('ck')) {
+ return;
}
- );
+
+ richtext.init(richtextContainer);
+ });
});
const openUdw = (config) => {
diff --git a/code_samples/page/react_app_block/assets/page-builder/react/blocks/Calculator.js b/code_samples/page/react_app_block/assets/page-builder/react/blocks/Calculator.js
index ce01850290..1c3f055d0c 100644
--- a/code_samples/page/react_app_block/assets/page-builder/react/blocks/Calculator.js
+++ b/code_samples/page/react_app_block/assets/page-builder/react/blocks/Calculator.js
@@ -1,4 +1,4 @@
-import Calculator from "/assets/page-builder/components/Calculator";
+import Calculator from '/assets/page-builder/components/Calculator';
export default {
Calculator: Calculator,
diff --git a/docs/administration/back_office/customize_search_suggestion.md b/docs/administration/back_office/customize_search_suggestion.md
index 426353baa5..79061413aa 100644
--- a/docs/administration/back_office/customize_search_suggestion.md
+++ b/docs/administration/back_office/customize_search_suggestion.md
@@ -110,7 +110,7 @@ To allow template override and ease HTML writing, the example is also loading a
Here is a complete `assets/js/admin.search.autocomplete.product.js` from the product suggestion example:
-``` js hl_lines="8"
+``` js hl_lines="9"
[[= include_file('code_samples/back_office/search/assets/js/admin.search.autocomplete.product.js') =]]
```
diff --git a/package.json b/package.json
index 9a72290f2a..79d74fcc33 100644
--- a/package.json
+++ b/package.json
@@ -4,9 +4,17 @@
"main": "index.js",
"repository": "git@github.com:ibexa/documentation-developer.git",
"scripts": {
- "scss": "node-sass --watch scss -o docs/css"
+ "scss": "sass --watch scss:docs/css",
+ "test": "yarn prettier-test && yarn eslint-test",
+ "fix": "yarn prettier-test --write && yarn eslint-test --fix",
+ "eslint-test": "eslint \"./code_samples/**/*.js\"",
+ "prettier-test": "yarn prettier \"./code_samples/**/*.{js,scss}\" --check"
+ },
+ "prettier": "eslint-config-ibexa/prettier",
+ "devDependencies": {
+ "eslint-config-ibexa": "https://github.com/ibexa/eslint-config-ibexa.git#~v1.1.1"
},
"dependencies": {
- "node-sass": "^9.0.0"
+ "sass": "^1.82.0"
}
}