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" } }