Skip to content

Commit

Permalink
DEP Upgrade front-end build stack
Browse files Browse the repository at this point in the history
  • Loading branch information
GuySartorelli committed Jan 17, 2023
1 parent 8bacd1d commit 8a7ccd4
Show file tree
Hide file tree
Showing 26 changed files with 5,624 additions and 7,847 deletions.
2 changes: 1 addition & 1 deletion .nvmrc
Original file line number Diff line number Diff line change
@@ -1 +1 @@
10
18
6 changes: 6 additions & 0 deletions babel.config.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
{
"presets": [
"@babel/preset-env",
"@babel/preset-react"
]
}
110 changes: 109 additions & 1 deletion client/dist/js/bundle.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion client/dist/styles/bundle.css

Large diffs are not rendered by default.

4 changes: 3 additions & 1 deletion client/src/components/ElementActions/ArchiveAction.js
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,9 @@ const ArchiveAction = (MenuComponent) => (props) => {
if (handleArchiveBlock && window.confirm(archiveMessage)) {
handleArchiveBlock(id).then(() => {
const preview = window.jQuery('.cms-preview');
preview.entwine('ss.preview')._loadUrl(preview.find('iframe').attr('src'));
if (preview && typeof preview.entwine === 'function') {
preview.entwine('ss.preview')._loadUrl(preview.find('iframe').attr('src'));
}
});
}
};
Expand Down
1 change: 0 additions & 1 deletion client/src/components/ElementActions/SaveAction.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
/* global window */
import React from 'react';
import { compose } from 'redux';
import { connect } from 'react-redux';
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@ describe('ArchiveAction', () => {
const mockMutation = jest.fn(() => new Promise((resolve) => { resolve(); }));
const WrappedComponent = (props) => <div>{props.children}</div>;
const ActionComponent = ArchiveAction(WrappedComponent);
const jQuery = jest.fn();
window.jQuery = jQuery;

beforeEach(() => {
wrapper = mount(
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,12 @@
/* eslint-disable import/no-extraneous-dependencies */
/* global jest, describe, it, expect, window */

jest.mock('isomorphic-fetch', () =>
() => Promise.resolve({
json: () => ({}),
})
);

import React from 'react';
import { Component as PublishAction } from '../PublishAction';
import Enzyme, { mount } from 'enzyme';
Expand Down
6 changes: 6 additions & 0 deletions client/src/components/ElementActions/tests/SaveAction-test.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,12 @@
/* eslint-disable import/no-extraneous-dependencies */
/* global jest, describe, it, expect */

jest.mock('isomorphic-fetch', () =>
() => Promise.resolve({
json: () => ({}),
})
);

import React from 'react';
import { Component as SaveAction } from '../SaveAction';
import Enzyme, { mount } from 'enzyme';
Expand Down
4 changes: 2 additions & 2 deletions client/src/components/ElementEditor/Content.js
Original file line number Diff line number Diff line change
Expand Up @@ -65,8 +65,8 @@ Content.propTypes = {
fileUrl: PropTypes.string,
fileTitle: PropTypes.string,
previewExpanded: PropTypes.bool,
SummaryComponent: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),
InlineEditFormComponent: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),
SummaryComponent: PropTypes.elementType,
InlineEditFormComponent: PropTypes.elementType,
handleLoadingError: PropTypes.func,
broken: PropTypes.bool,
};
Expand Down
2 changes: 1 addition & 1 deletion client/src/components/ElementEditor/Header.js
Original file line number Diff line number Diff line change
Expand Up @@ -217,7 +217,7 @@ Header.propTypes = {
areaId: PropTypes.number,
activeTab: PropTypes.string,
simple: PropTypes.bool,
ElementActionsComponent: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),
ElementActionsComponent: PropTypes.elementType,
previewExpanded: PropTypes.bool,
disableTooltip: PropTypes.bool,
formDirty: PropTypes.bool,
Expand Down
2 changes: 1 addition & 1 deletion client/src/components/ElementEditor/Toolbar.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ Toolbar.defaultProps = {};
Toolbar.propTypes = {
elementTypes: PropTypes.arrayOf(elementTypeType).isRequired,
areaId: PropTypes.number.isRequired,
AddNewButtonComponent: PropTypes.oneOfType([PropTypes.node, PropTypes.func]).isRequired,
AddNewButtonComponent: PropTypes.elementType.isRequired,
connectDropTarget: PropTypes.func.isRequired,
onDragOver: PropTypes.func, // eslint-disable-line react/no-unused-prop-types
onDragDrop: PropTypes.func, // eslint-disable-line react/no-unused-prop-types
Expand Down
20 changes: 14 additions & 6 deletions client/src/legacy/ElementEditor/entwine.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

import jQuery from 'jquery';
import React from 'react';
import ReactDOM from 'react-dom';
import { createRoot } from 'react-dom/client';
import { loadComponent } from 'lib/Injector';
import { getConfig } from 'state/editor/elementConfig';
import { destroy } from 'redux-form';
Expand Down Expand Up @@ -40,6 +40,8 @@ const resetStores = () => {
*/
jQuery.entwine('ss', ($) => {
$('.js-injector-boot .element-editor__container').entwine({
ReactRoot: null,

onmatch() {
const context = {};
const ElementEditorComponent = loadComponent('ElementEditor', context);
Expand All @@ -53,15 +55,21 @@ jQuery.entwine('ss', ($) => {
elementTypes,
};

ReactDOM.render(
<ElementEditorComponent {...props} />,
this[0]
);
let root = this.getReactRoot();
if (!root) {
root = createRoot(this[0]);
this.setReactRoot(root);
}
root.render(<ElementEditorComponent {...props} />);
},

onunmatch() {
resetStores();
ReactDOM.unmountComponentAtNode(this[0]);
const root = this.getReactRoot();
if (root) {
root.unmount();
this.setReactRoot(null);
}
},

/**
Expand Down
2 changes: 1 addition & 1 deletion client/src/state/editor/addElementMutation.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { graphql } from 'react-apollo';
import { graphql } from '@apollo/client/react/hoc';
import gql from 'graphql-tag';
import { query as readBlocksQuery, config as readBlocksConfig } from './readBlocksForAreaQuery';

Expand Down
2 changes: 1 addition & 1 deletion client/src/state/editor/archiveBlockMutation.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { graphql } from 'react-apollo';
import { graphql } from '@apollo/client/react/hoc';
import gql from 'graphql-tag';
import { config as readBlocksConfig, query as readBlocksQuery } from './readBlocksForAreaQuery';

Expand Down
2 changes: 1 addition & 1 deletion client/src/state/editor/duplicateBlockMutation.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { graphql } from 'react-apollo';
import { graphql } from '@apollo/client/react/hoc';
import gql from 'graphql-tag';
import { config as readBlocksConfig, query as readBlocksQuery } from './readBlocksForAreaQuery';

Expand Down
2 changes: 1 addition & 1 deletion client/src/state/editor/publishBlockMutation.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { graphql } from 'react-apollo';
import { graphql } from '@apollo/client/react/hoc';
import gql from 'graphql-tag';
import { config as readBlocksConfig, query as readBlocksQuery } from './readBlocksForAreaQuery';

Expand Down
2 changes: 1 addition & 1 deletion client/src/state/editor/readBlocksForAreaQuery.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { graphql } from 'react-apollo';
import { graphql } from '@apollo/client/react/hoc';
import gql from 'graphql-tag';

// GraphQL query for retrieving the current state of elements for an area. The results of the query
Expand Down
5 changes: 3 additions & 2 deletions client/src/state/editor/sortBlockMutation.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { graphql } from 'react-apollo';
import { graphql } from '@apollo/client/react/hoc';
import gql from 'graphql-tag';
import { query as readBlocksQuery, config as readBlocksConfig } from './readBlocksForAreaQuery';

Expand Down Expand Up @@ -26,7 +26,8 @@ const config = {
optimisticResponse: {
sortBlock: {
id: blockId,
liveVersion: false,
isLiveVersion: false,
isPublished: false,
__typename: 'Block',
},
},
Expand Down
2 changes: 1 addition & 1 deletion client/src/state/editor/unpublishBlockMutation.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { graphql } from 'react-apollo';
import { graphql } from '@apollo/client/react/hoc';
import gql from 'graphql-tag';
import { config as readBlocksConfig, query as readBlocksQuery } from './readBlocksForAreaQuery';

Expand Down
2 changes: 1 addition & 1 deletion client/src/state/history/readOneBlockQuery.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { graphql } from 'react-apollo';
import { graphql } from '@apollo/client/react/hoc';
import gql from 'graphql-tag';

// GraphQL query for retrieving the version history of a specific block. The results of
Expand Down
2 changes: 1 addition & 1 deletion client/src/state/history/revertToBlockVersionMutation.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { graphql } from 'react-apollo';
import { graphql } from '@apollo/client/react/hoc';
import gql from 'graphql-tag';

const mutation = gql`
Expand Down
2 changes: 1 addition & 1 deletion client/src/types/elementTypeType.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ const elementTypeType = PropTypes.shape({
// A font-icon class to be used for the icon of the element
icon: PropTypes.string,
// Whether the element is in-line editable
inlineEditable: PropTypes.boolean,
inlineEditable: PropTypes.bool,
// The top level edit tabs for this element (Usually "Content" and "Settings")
editTabs: PropTypes.arrayOf(PropTypes.shape({
title: PropTypes.string,
Expand Down
79 changes: 40 additions & 39 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,11 @@
"name": "silverstripe-elemental",
"version": "1.0.0",
"description": "Compose your SilverStripe content of Elements",
"engines": {
"node": "^18.x"
},
"scripts": {
"build": "yarn && yarn lint && yarn test && NODE_ENV=production webpack -p --bail --progress",
"build": "yarn && yarn lint && yarn test && rm -rf client/dist/* && NODE_ENV=production webpack --mode production --bail --progress",
"dev": "NODE_ENV=development webpack --progress",
"watch": "NODE_ENV=development webpack --watch --progress",
"css": "WEBPACK_CHILD=css npm run build",
Expand Down Expand Up @@ -31,45 +34,55 @@
},
"homepage": "https://github.com/dnadesign/silverstripe-elemental#readme",
"dependencies": {
"apollo-client": "^2.3.1",
"bootstrap": "^4.3.1",
"classnames": "^2.2.5",
"graphql": "^14.0.0",
"graphql-tag": "^2.10.0",
"jquery": "^3.5.0",
"popper.js": "^1.14.7",
"prop-types": "^15.6.2",
"react": "^16.6.1",
"react-apollo": "^2.1.0",
"@apollo/client": "^3.7.1",
"@popperjs/core": "^2.11.6",
"bootstrap": "^4.6.2",
"classnames": "^2.3.2",
"graphql": "^16.6.0",
"graphql-tag": "^2.12.6",
"prop-types": "^15.8.1",
"react": "^18.2.0",
"react-dnd": "^5.0.0",
"react-dnd-html5-backend": "^5.0.1",
"react-dom": "^16.6.1",
"react-redux": "^5.0.7",
"reactstrap": "^6.4.0",
"redux": "^4.0.0",
"redux-form": "^6.8.0"
"react-dom": "^18.2.0",
"react-redux": "^8.0.4",
"reactstrap": "^8.9.0",
"redux": "^4.2.0",
"redux-form": "^8.3.8"
},
"devDependencies": {
"@silverstripe/eslint-config": "^0.1.0",
"@silverstripe/webpack-config": "^1.5.0",
"babel-jest": "^23.6.0",
"enzyme": "^3.6.0",
"enzyme-adapter-react-16": "^1.5.0",
"jest-cli": "^23.6.0"
"@silverstripe/eslint-config": "^1.0.0-alpha6",
"@silverstripe/webpack-config": "^2.0.0-alpha5",
"babel-jest": "^29.2.2",
"enzyme": "^3.11.0",
"enzyme-adapter-react-16": "^1.15.6",
"jest-cli": "^29.2.2",
"jest-environment-jsdom": "^29.3.1",
"react-16": "npm:react@^16.14.0",
"react-dom-16": "npm:react-dom@^16.14.0",
"webpack": "^5.74.0",
"webpack-cli": "^5.0.0"
},
"resolutions": {
"colors": "1.1.2"
"colors": "1.4.0"
},
"browserslist": [
"defaults"
],
"jest": {
"testEnvironment": "jsdom",
"moduleNameMapper": {
"^react-dom/client$": "react-dom-16",
"^react-dom((/.*)?)$": "react-dom-16$1",
"^react((/.*)?)$": "react-16$1"
},
"roots": [
"client/src"
],
"moduleDirectories": [
"client/src",
"node_modules",
"node_modules/@silverstripe/webpack-config/node_modules",
"../../admin/client/src",
"../../admin/node_modules",
"../admin/client/src",
"../admin/node_modules",
"vendor/silverstripe/admin/client/src",
"vendor/silverstripe/admin/node_modules"
],
Expand All @@ -79,17 +92,5 @@
"transform": {
".*": "babel-jest"
}
},
"babel": {
"presets": [
"env",
"react"
],
"plugins": [
"transform-object-rest-spread"
]
},
"engines": {
"node": "^10.x"
}
}
51 changes: 12 additions & 39 deletions webpack.config.js
Original file line number Diff line number Diff line change
@@ -1,56 +1,29 @@
const Path = require('path');
// Import the core config
const webpackConfig = require('@silverstripe/webpack-config');
const {
resolveJS,
externalJS,
moduleJS,
pluginJS,
moduleCSS,
pluginCSS,
} = webpackConfig;
const { JavascriptWebpackConfig, CssWebpackConfig } = require('@silverstripe/webpack-config');

const ENV = process.env.NODE_ENV;
const PATHS = {
MODULES: 'node_modules',
FILES_PATH: '../',
ROOT: Path.resolve(),
SRC: Path.resolve('client/src'),
DIST: Path.resolve('client/dist'),
};

const config = [
{
name: 'js',
entry: {
// Main JS bundle
new JavascriptWebpackConfig('js', PATHS, 'dnadesign/silverstripe-elemental')
.setEntry({
bundle: `${PATHS.SRC}/bundles/bundle.js`,
},
output: {
path: PATHS.DIST,
filename: 'js/[name].js',
},
devtool: (ENV !== 'production') ? 'source-map' : '',
resolve: resolveJS(ENV, PATHS),
externals: externalJS(ENV, PATHS),
module: moduleJS(ENV, PATHS),
plugins: pluginJS(ENV, PATHS),
},
{
name: 'css',
entry: {
})
.getConfig(),
// sass to css
new CssWebpackConfig('css', PATHS)
.setEntry({
bundle: `${PATHS.SRC}/styles/bundle.scss`,
},
output: {
path: PATHS.DIST,
filename: 'styles/[name].css',
},
devtool: (ENV !== 'production') ? 'source-map' : '',
module: moduleCSS(ENV, PATHS),
plugins: pluginCSS(ENV, PATHS),
},
})
.getConfig(),
];

// Use WEBPACK_CHILD=js or WEBPACK_CHILD=css env var to run a single config
module.exports = (process.env.WEBPACK_CHILD)
? config.find((entry) => entry.name === process.env.WEBPACK_CHILD)
: module.exports = config;
: config;
Loading

0 comments on commit 8a7ccd4

Please sign in to comment.