debian-mirror-gitlab/debian/patches/0740-use-packaged-modules.patch

243 lines
7.8 KiB
Diff
Raw Normal View History

2020-04-13 13:49:04 +05:30
Use debian packaged node modules when available
- Exclude packaged modules from transpiling
- Remove webpack-bundle-analyzer
- Resolve .json files
- Add more plugins to babel.config.js
- Add mkdirp 1.0 and loader-utils 2.0 to ensure compatibility for packaged
modules (See #976310)
2020-04-13 13:49:04 +05:30
2019-08-08 15:17:34 +05:30
--- a/config/webpack.config.js
+++ b/config/webpack.config.js
2020-02-23 17:54:41 +05:30
@@ -6,7 +6,6 @@
2019-08-08 15:17:34 +05:30
const StatsWriterPlugin = require('webpack-stats-plugin').StatsWriterPlugin;
const CompressionPlugin = require('compression-webpack-plugin');
2020-07-29 00:16:15 +05:30
const MonacoWebpackPlugin = require('./plugins/monaco_webpack');
2019-08-08 15:17:34 +05:30
-const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
const CopyWebpackPlugin = require('copy-webpack-plugin');
2020-01-01 14:40:56 +05:30
const vendorDllHash = require('./helpers/vendor_dll_hash');
2019-08-08 15:17:34 +05:30
@@ -150,6 +149,8 @@
entry: generateEntries,
+ externals: [ 'canvas' ],
+
output: {
path: path.join(ROOT_PATH, 'public/assets/webpack'),
publicPath: '/assets/webpack/',
@@ -159,13 +160,13 @@
},
2019-08-08 15:17:34 +05:30
resolve: {
- extensions: ['.js', '.gql', '.graphql'],
2019-08-08 15:17:34 +05:30
- modules: ['/usr/share/gitlab/node_modules','/usr/share/gitlab/node_modules/mermaid/node_modules', '/usr/lib/nodejs'],
+ extensions: ['.js', '.gql', '.graphql', '.json'],
+ modules: ['/usr/share/gitlab/node_modules','/usr/share/gitlab/vendor/node_modules','/usr/share/gitlab/node_modules/mermaid/node_modules', '/usr/share/nodejs/markdown-it/node_modules/', '/usr/lib/nodejs', '/usr/share/nodejs'],
2019-08-08 15:17:34 +05:30
alias,
},
resolveLoader: {
- modules: ['/usr/share/gitlab/node_modules', '/usr/lib/nodejs'],
+ modules: ['/usr/share/gitlab/node_modules', '/usr/lib/nodejs','/usr/share/nodejs'],
},
module: {
@@ -178,9 +179,13 @@
2020-03-28 19:53:26 +05:30
},
{
test: /\.js$/,
2020-04-08 15:34:39 +05:30
- exclude: path =>
+ exclude: [ path =>
/node_modules\/(?!tributejs)|node_modules|vendor[\\/]assets/.test(path) &&
!/\.vue\.js/.test(path),
+ /\/usr\/share\/nodejs/,
+ /\/usr\/lib\/nodejs/,
+ /\/usr\/share\/javascript/
2020-04-08 15:34:39 +05:30
+ ],
2020-03-28 19:53:26 +05:30
loader: 'babel-loader',
options: {
cacheDirectory: path.join(CACHE_PATH, 'babel-loader'),
@@ -516,19 +521,6 @@
2019-08-08 15:17:34 +05:30
// enable HMR only in webpack-dev-server
DEV_SERVER_LIVERELOAD && new webpack.HotModuleReplacementPlugin(),
- // optionally generate webpack bundle analysis
- WEBPACK_REPORT &&
- new BundleAnalyzerPlugin({
- analyzerMode: 'static',
- generateStatsFile: true,
- openAnalyzer: false,
- reportFilename: path.join(ROOT_PATH, 'webpack-report/index.html'),
- statsFilename: path.join(ROOT_PATH, 'webpack-report/stats.json'),
2019-12-21 21:33:11 +05:30
- statsOptions: {
- source: false,
- },
2019-08-08 15:17:34 +05:30
- }),
-
new webpack.DefinePlugin({
// This one is used to define window.gon.ee and other things properly in tests:
2019-12-21 21:33:11 +05:30
'process.env.IS_EE': JSON.stringify(IS_EE),
@@ -563,6 +555,7 @@
2019-08-08 15:17:34 +05:30
node: {
fs: 'empty', // sqljs requires fs
+ Buffer: 'mock',
setImmediate: false,
},
2019-08-08 15:17:34 +05:30
};
--- a/package.json
+++ b/package.json
2020-07-29 00:16:15 +05:30
@@ -35,12 +35,6 @@
"webpack-prod": "NODE_OPTIONS=\"--max-old-space-size=3584\" NODE_ENV=production webpack --config config/webpack.config.js"
},
"dependencies": {
2020-06-23 00:43:41 +05:30
- "@babel/core": "^7.10.1",
- "@babel/plugin-proposal-class-properties": "^7.10.1",
- "@babel/plugin-proposal-json-strings": "^7.10.1",
- "@babel/plugin-proposal-private-methods": "^7.10.1",
- "@babel/plugin-syntax-import-meta": "^7.10.1",
- "@babel/preset-env": "^7.10.1",
"@gitlab/at.js": "1.5.5",
2020-11-24 16:42:00 +05:30
"@gitlab/svgs": "1.164.0",
"@gitlab/ui": "21.3.1",
@@ -55,29 +49,12 @@
2020-10-25 00:47:17 +05:30
"apollo-link": "^1.2.14",
"apollo-link-batch-http": "^1.2.14",
"apollo-upload-client": "^13.0.0",
2020-04-08 15:34:39 +05:30
- "autosize": "^4.0.2",
"aws-sdk": "^2.637.0",
2020-11-24 16:42:00 +05:30
- "axios": "^0.20.0",
- "babel-loader": "^8.0.6",
2020-03-12 18:50:15 +05:30
"babel-plugin-lodash": "^3.3.4",
2020-06-23 00:43:41 +05:30
"bootstrap": "4.4.1",
- "brace-expansion": "^1.1.8",
- "cache-loader": "^4.1.0",
2020-02-23 17:54:41 +05:30
- "clipboard": "^1.7.1",
2020-07-03 14:39:25 +05:30
- "codemirror": "^5.48.4",
2020-04-08 15:34:39 +05:30
"codesandbox-api": "0.0.23",
- "compression-webpack-plugin": "^3.0.1",
- "copy-webpack-plugin": "^5.0.5",
2020-04-08 15:34:39 +05:30
- "core-js": "^3.6.4",
2020-10-25 00:47:17 +05:30
"cron-validator": "^1.1.1",
"cropper": "^2.3.0",
- "css-loader": "^2.1.1",
- "d3": "^5.16.0",
- "d3-sankey": "^0.12.3",
2020-04-22 19:44:27 +05:30
- "d3-scale": "^2.2.2",
- "d3-selection": "^1.2.0",
- "dateformat": "^3.0.3",
2020-03-12 18:50:15 +05:30
- "deckar01-task_list": "^2.3.1",
"diff": "^3.4.0",
2020-04-08 15:34:39 +05:30
"document-register-element": "1.14.3",
2020-10-25 00:47:17 +05:30
"dompurify": "^2.0.11",
@@ -85,81 +62,49 @@
2020-06-23 00:43:41 +05:30
"editorconfig": "^0.15.3",
"emoji-regex": "^7.0.3",
"emoji-unicode-version": "^0.2.1",
- "exports-loader": "^0.7.0",
2020-12-05 22:49:45 +05:30
- "file-loader": "^5.1.0",
2020-10-25 00:47:17 +05:30
"font-awesome": "4.7.0",
2020-04-08 15:34:39 +05:30
"fuzzaldrin-plus": "^0.6.0",
2020-07-01 16:06:17 +05:30
- "glob": "^7.1.6",
2020-10-25 00:47:17 +05:30
"graphql": "^14.7.0",
2020-07-29 00:16:15 +05:30
"graphql-tag": "^2.10.1",
2020-11-24 16:42:00 +05:30
"gray-matter": "^4.0.2",
"immer": "^7.0.7",
- "imports-loader": "^0.8.0",
2020-07-29 00:16:15 +05:30
"ipaddr.js": "^1.9.1",
- "jed": "^1.1.1",
"jest-transform-graphql": "^2.1.0",
2020-09-03 11:26:00 +05:30
- "jquery": "^3.5.0",
- "jquery-ujs": "1.2.2",
"jquery.caret": "^0.3.1",
"jquery.waitforimages": "^2.2.0",
2020-04-08 15:34:39 +05:30
- "js-cookie": "^2.2.1",
2020-07-29 00:16:15 +05:30
"js-yaml": "^3.13.1",
- "jszip": "^3.1.3",
- "jszip-utils": "^0.0.2",
- "katex": "^0.10.0",
2020-11-24 16:42:00 +05:30
- "lodash": "^4.17.20",
+ "loader-utils": "^2.0.0",
2020-04-08 15:34:39 +05:30
"marked": "^0.3.12",
- "mermaid": "^8.5.2",
2020-06-23 00:43:41 +05:30
"mersenne-twister": "1.1.0",
- "minimatch": "^3.0.4",
"miragejs": "^0.1.40",
+ "mkdirp": "^1.0.4",
"mock-apollo-client": "^0.4.0",
2020-07-29 00:16:15 +05:30
"monaco-editor": "^0.20.0",
"monaco-editor-webpack-plugin": "^1.9.0",
2020-10-25 00:47:17 +05:30
"monaco-yaml": "^2.4.1",
2020-11-24 16:42:00 +05:30
- "mousetrap": "1.6.5",
- "pdfjs-dist": "^2.0.943",
2020-01-11 19:09:17 +05:30
"pikaday": "^1.8.0",
2020-04-08 15:34:39 +05:30
- "popper.js": "^1.16.1",
2020-11-24 16:42:00 +05:30
- "prismjs": "^1.21.0",
- "prosemirror-markdown": "^1.3.0",
2020-02-23 17:54:41 +05:30
- "prosemirror-model": "^1.6.4",
"raphael": "^2.2.7",
- "raw-loader": "^4.0.0",
2020-10-25 00:47:17 +05:30
"select2": "3.5.2-browserify",
"smooshpack": "^0.0.62",
"sortablejs": "^1.10.2",
2020-12-06 00:42:19 +05:30
"sql.js": "^0.4.0",
"stickyfilljs": "^2.1.0",
"string-hash": "1.1.3",
- "style-loader": "^1.1.3",
2020-11-24 16:42:00 +05:30
"swagger-ui-dist": "^3.32.4",
"three": "^0.84.0",
- "three-orbit-controls": "^82.1.0",
- "three-stl-loader": "^1.0.4",
- "timeago.js": "^4.0.2",
"tiptap": "^1.8.0",
"tiptap-commands": "^1.4.0",
"tiptap-extensions": "^1.8.0",
2020-07-29 00:16:15 +05:30
"tributejs": "5.1.3",
2020-04-08 15:34:39 +05:30
- "url-loader": "^3.0.0",
- "uuid": "8.1.0",
"visibilityjs": "^1.2.4",
- "vue": "^2.6.10",
2020-05-24 23:50:06 +05:30
"vue-apollo": "^3.0.3",
"vue-loader": "^15.9.0",
2020-11-24 16:42:00 +05:30
"vue-router": "^3.4.3",
- "vue-template-compiler": "^2.6.10",
2020-03-12 18:50:15 +05:30
"vue-virtual-scroll-list": "^1.4.4",
"vuedraggable": "^2.23.0",
2020-11-24 16:42:00 +05:30
"vuex": "^3.5.1",
"web-vitals": "^0.2.4",
2020-04-08 15:34:39 +05:30
- "webpack": "^4.42.0",
- "webpack-bundle-analyzer": "^3.6.0",
- "webpack-cli": "^3.3.11",
- "webpack-stats-plugin": "^0.3.1",
2020-02-23 17:54:41 +05:30
- "worker-loader": "^2.0.0",
2020-07-02 01:55:08 +05:30
- "xterm": "3.14.5"
2020-04-08 15:34:39 +05:30
+ "webpack-stats-plugin": "^0.3.1"
},
2020-02-23 17:54:41 +05:30
"devDependencies": {
2020-10-25 00:47:17 +05:30
},
--- a/babel.config.js
+++ b/babel.config.js
2020-10-25 00:47:17 +05:30
@@ -34,9 +34,12 @@
// include stage 3 proposals
const plugins = [
'@babel/plugin-syntax-import-meta',
+ '@babel/plugin-syntax-dynamic-import',
'@babel/plugin-proposal-class-properties',
'@babel/plugin-proposal-json-strings',
'@babel/plugin-proposal-private-methods',
+ '@babel/plugin-proposal-optional-chaining',
+ '@babel/plugin-proposal-nullish-coalescing-operator',
2020-10-25 00:47:17 +05:30
// See: https://gitlab.com/gitlab-org/gitlab/-/issues/229146
'@babel/plugin-transform-arrow-functions',
'lodash',
--- a/app/assets/javascripts/pdf/index.vue
+++ b/app/assets/javascripts/pdf/index.vue
@@ -1,6 +1,6 @@
<script>
import pdfjsLib from 'pdfjs-dist/build/pdf';
-import workerSrc from 'pdfjs-dist/build/pdf.worker.min';
+import workerSrc from 'pdfjs-dist/build/pdf.worker';
import page from './page/index.vue';