@servicetitan/startup 27.4.0-canary.1 → 28.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli/commands/styles-check.js +1 -2
- package/dist/cli/commands/styles-check.js.map +1 -1
- package/dist/utils/get-jest-config.d.ts.map +1 -1
- package/dist/utils/get-jest-config.js +2 -10
- package/dist/utils/get-jest-config.js.map +1 -1
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +1 -0
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/load-shared-dependencies.d.ts +2 -0
- package/dist/utils/load-shared-dependencies.d.ts.map +1 -0
- package/dist/utils/load-shared-dependencies.js +34 -0
- package/dist/utils/load-shared-dependencies.js.map +1 -0
- package/dist/webpack/configs/dev-server-config.d.ts.map +1 -1
- package/dist/webpack/configs/dev-server-config.js +1 -1
- package/dist/webpack/configs/dev-server-config.js.map +1 -1
- package/dist/webpack/configs/plugins/define-exposed-dependencies-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/define-exposed-dependencies-plugin.js +9 -3
- package/dist/webpack/configs/plugins/define-exposed-dependencies-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/ignore-plugin/is-optional-anvil-peer-dependency.js +1 -1
- package/dist/webpack/configs/plugins/ignore-plugin/is-optional-anvil-peer-dependency.js.map +1 -1
- package/dist/webpack/configs/plugins/index.d.ts +1 -0
- package/dist/webpack/configs/plugins/index.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/index.js +1 -0
- package/dist/webpack/configs/plugins/index.js.map +1 -1
- package/dist/webpack/configs/plugins/watch-run-plugin.d.ts +8 -0
- package/dist/webpack/configs/plugins/watch-run-plugin.d.ts.map +1 -0
- package/dist/webpack/configs/plugins/watch-run-plugin.js +26 -0
- package/dist/webpack/configs/plugins/watch-run-plugin.js.map +1 -0
- package/dist/webpack/configs/plugins-config.d.ts.map +1 -1
- package/dist/webpack/configs/plugins-config.js +1 -0
- package/dist/webpack/configs/plugins-config.js.map +1 -1
- package/dist/webpack/configs/types.d.ts +1 -2
- package/dist/webpack/configs/types.d.ts.map +1 -1
- package/dist/webpack/create-webpack-config.d.ts.map +1 -1
- package/dist/webpack/create-webpack-config.js +1 -2
- package/dist/webpack/create-webpack-config.js.map +1 -1
- package/jest/jest-preset.js +9 -0
- package/package.json +13 -13
- package/src/cli/commands/__tests__/styles-check.test.ts +1 -5
- package/src/cli/commands/__tests__/tests.test.ts +4 -0
- package/src/cli/commands/styles-check.ts +1 -1
- package/src/cli/utils/__tests__/bundle.test.ts +7 -6
- package/src/cli/utils/__tests__/eslint.test.ts +4 -0
- package/src/utils/__tests__/get-jest-config.test.ts +1 -7
- package/src/utils/__tests__/load-shared-dependencies.test.ts +108 -0
- package/src/utils/get-jest-config.ts +2 -10
- package/src/utils/index.ts +1 -0
- package/src/utils/load-shared-dependencies.ts +38 -0
- package/src/webpack/__tests__/create-webpack-config-shared-dependencies.test.ts +1 -6
- package/src/webpack/__tests__/create-webpack-config.test.ts +5 -7
- package/src/webpack/configs/dev-server-config.ts +2 -1
- package/src/webpack/configs/plugins/define-exposed-dependencies-plugin.ts +15 -6
- package/src/webpack/configs/plugins/ignore-plugin/is-optional-anvil-peer-dependency.ts +1 -1
- package/src/webpack/configs/plugins/index.ts +1 -0
- package/src/webpack/configs/plugins/watch-run-plugin.ts +23 -0
- package/src/webpack/configs/plugins-config.ts +2 -0
- package/src/webpack/configs/types.ts +1 -2
- package/src/webpack/create-webpack-config.ts +1 -1
- package/tsconfig/base.json +1 -1
|
@@ -4,7 +4,6 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.StylesCheck = void 0;
|
|
7
|
-
const startup_utils_1 = require("@servicetitan/startup-utils");
|
|
8
7
|
const fs_1 = __importDefault(require("fs"));
|
|
9
8
|
const path_1 = __importDefault(require("path"));
|
|
10
9
|
const process_1 = __importDefault(require("process"));
|
|
@@ -80,7 +79,7 @@ function checkStylesLib(_files) {
|
|
|
80
79
|
}
|
|
81
80
|
function checkStylesApp(files) {
|
|
82
81
|
const { dependencies, sharedDependencies } = (0, utils_1.getPackageData)();
|
|
83
|
-
if ((0,
|
|
82
|
+
if ((0, utils_1.loadSharedDependencies)(dependencies, sharedDependencies)['@servicetitan/design-system'] &&
|
|
84
83
|
!files.some(f => f.relativePath === designSystem)) {
|
|
85
84
|
utils_1.log.warning("application doesn't have design-system.css. Please check https://docs.st.dev/docs/frontend/micro-frontends#host-configuration");
|
|
86
85
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styles-check.js","sourceRoot":"","sources":["../../../src/cli/commands/styles-check.ts"],"names":[],"mappings":";;;;;;AAAA
|
|
1
|
+
{"version":3,"file":"styles-check.js","sourceRoot":"","sources":["../../../src/cli/commands/styles-check.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-jest-config.d.ts","sourceRoot":"","sources":["../../src/utils/get-jest-config.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,iBAAiB,EAAwB,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"get-jest-config.d.ts","sourceRoot":"","sources":["../../src/utils/get-jest-config.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,iBAAiB,EAAwB,MAAM,qBAAqB,CAAC;AAqC9E;;;GAGG;AACH,eAAO,MAAM,aAAa,QAAO,iBAWhC,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,gBAAgB,SAAU,MAAM,CAAC,IAAI,KAAG,MAAM,CAAC,IAmB3D,CAAC"}
|
|
@@ -9,13 +9,6 @@ const get_configuration_1 = require("./get-configuration");
|
|
|
9
9
|
const get_destination_folders_1 = require("./get-destination-folders");
|
|
10
10
|
const to_array_1 = require("./to-array");
|
|
11
11
|
const getJestConfigBase = ({ coveragePathIgnorePatterns = [], setupFiles = [], testPathIgnorePatterns = [], }) => {
|
|
12
|
-
const transform = {
|
|
13
|
-
'^.+\\.jsx?$': [
|
|
14
|
-
'babel-jest',
|
|
15
|
-
{ presets: [['@babel/preset-env', { targets: { node: 'current' } }]] },
|
|
16
|
-
],
|
|
17
|
-
'^.+\\.tsx?$': ['ts-jest', { tsconfig: './tsconfig.test.json' }],
|
|
18
|
-
};
|
|
19
12
|
const moduleNameMapper = {
|
|
20
13
|
'\\.(css|scss|less|png|svg|jpg|jpeg|gif|woff|woff2|eot|ttf|otf)$': 'identity-obj-proxy',
|
|
21
14
|
};
|
|
@@ -25,7 +18,6 @@ const getJestConfigBase = ({ coveragePathIgnorePatterns = [], setupFiles = [], t
|
|
|
25
18
|
testRunner: 'jest-circus/runner',
|
|
26
19
|
transformIgnorePatterns: ['node_modules/(?!(@servicetitan|@react-hook|nanoid|axios)/)'],
|
|
27
20
|
modulePathIgnorePatterns: ['<rootDir>/.*/__mocks__'],
|
|
28
|
-
transform,
|
|
29
21
|
moduleNameMapper,
|
|
30
22
|
testPathIgnorePatterns: [
|
|
31
23
|
'\\.yalc',
|
|
@@ -36,6 +28,7 @@ const getJestConfigBase = ({ coveragePathIgnorePatterns = [], setupFiles = [], t
|
|
|
36
28
|
coveragePathIgnorePatterns: ['^.+\\.d\\.ts$', ...coveragePathIgnorePatterns],
|
|
37
29
|
coverageReporters: ['html-spa', 'text', 'json', 'cobertura', 'lcov'],
|
|
38
30
|
collectCoverageFrom: ['**/*.{ts,tsx}'],
|
|
31
|
+
preset: path_1.default.join(__dirname, '../../jest'),
|
|
39
32
|
};
|
|
40
33
|
};
|
|
41
34
|
/**
|
|
@@ -62,7 +55,7 @@ const getJestConfigCLI = (args) => {
|
|
|
62
55
|
...(0, get_configuration_1.getJestConfiguration)(),
|
|
63
56
|
...args,
|
|
64
57
|
};
|
|
65
|
-
const { collectCoverageFrom, moduleNameMapper,
|
|
58
|
+
const { collectCoverageFrom, moduleNameMapper, ...rest } = getJestConfigBase({
|
|
66
59
|
coveragePathIgnorePatterns,
|
|
67
60
|
setupFiles,
|
|
68
61
|
testPathIgnorePatterns,
|
|
@@ -71,7 +64,6 @@ const getJestConfigCLI = (args) => {
|
|
|
71
64
|
collectCoverageFrom: JSON.stringify(collectCoverageFrom),
|
|
72
65
|
globals: JSON.stringify(globals),
|
|
73
66
|
moduleNameMapper: JSON.stringify(moduleNameMapper),
|
|
74
|
-
transform: JSON.stringify(transform),
|
|
75
67
|
...rest,
|
|
76
68
|
...config,
|
|
77
69
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-jest-config.js","sourceRoot":"","sources":["../../src/utils/get-jest-config.ts"],"names":[],"mappings":";;;;;;AAAA,gDAAwB;AAExB,2DAA8E;AAC9E,uEAAkE;AAClE,yCAAqC;AAErC,MAAM,iBAAiB,GAAG,CAAC,EACvB,0BAA0B,GAAG,EAAE,EAC/B,UAAU,GAAG,EAAE,EACf,sBAAsB,GAAG,EAAE,GAK9B,EAAE,EAAE;IACD,MAAM,
|
|
1
|
+
{"version":3,"file":"get-jest-config.js","sourceRoot":"","sources":["../../src/utils/get-jest-config.ts"],"names":[],"mappings":";;;;;;AAAA,gDAAwB;AAExB,2DAA8E;AAC9E,uEAAkE;AAClE,yCAAqC;AAErC,MAAM,iBAAiB,GAAG,CAAC,EACvB,0BAA0B,GAAG,EAAE,EAC/B,UAAU,GAAG,EAAE,EACf,sBAAsB,GAAG,EAAE,GAK9B,EAAE,EAAE;IACD,MAAM,gBAAgB,GAAG;QACrB,iEAAiE,EAAE,oBAAoB;KAC1F,CAAC;IAEF,OAAO;QACH,OAAO,EAAE,IAAI;QACb,eAAe,EAAE,OAAO;QACxB,UAAU,EAAE,oBAAoB;QAChC,uBAAuB,EAAE,CAAC,4DAA4D,CAAC;QACvF,wBAAwB,EAAE,CAAC,wBAAwB,CAAC;QACpD,gBAAgB;QAChB,sBAAsB,EAAE;YACpB,SAAS;YACT,GAAG,IAAA,+CAAqB,GAAE;YAC1B,GAAG,IAAA,kBAAO,EAAC,sBAAsB,CAAC;SACrC;QACD,UAAU,EAAE,CAAC,cAAI,CAAC,IAAI,CAAC,SAAS,EAAE,qBAAqB,CAAC,EAAE,GAAG,IAAA,kBAAO,EAAC,UAAU,CAAC,CAAC;QACjF,0BAA0B,EAAE,CAAC,eAAe,EAAE,GAAG,0BAA0B,CAAC;QAC5E,iBAAiB,EAAE,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,CAAC;QACpE,mBAAmB,EAAE,CAAC,eAAe,CAAC;QACtC,MAAM,EAAE,cAAI,CAAC,IAAI,CAAC,SAAS,EAAE,YAAY,CAAC;KAC7C,CAAC;AACN,CAAC,CAAC;AAEF;;;GAGG;AACI,MAAM,aAAa,GAAG,GAAsB,EAAE;IACjD,MAAM,EAAE,0BAA0B,EAAE,UAAU,EAAE,sBAAsB,EAAE,GAAG,MAAM,EAAE,GAC/E,IAAA,wCAAoB,GAAyB,CAAC;IAClD,OAAO;QACH,GAAG,iBAAiB,CAAC;YACjB,0BAA0B;YAC1B,UAAU;YACV,sBAAsB;SACzB,CAAC;QACF,GAAG,MAAM;KACZ,CAAC;AACN,CAAC,CAAC;AAXW,QAAA,aAAa,iBAWxB;AAEF;;GAEG;AACI,MAAM,gBAAgB,GAAG,CAAC,IAAiB,EAAe,EAAE;IAC/D,MAAM,EAAE,0BAA0B,EAAE,UAAU,EAAE,sBAAsB,EAAE,OAAO,EAAE,GAAG,MAAM,EAAE,GAAG;QAC3F,GAAG,IAAA,wCAAoB,GAAE;QACzB,GAAG,IAAI;KACV,CAAC;IAEF,MAAM,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,GAAG,IAAI,EAAE,GAAG,iBAAiB,CAAC;QACzE,0BAA0B;QAC1B,UAAU;QACV,sBAAsB;KACzB,CAAC,CAAC;IAEH,OAAO;QACH,mBAAmB,EAAE,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC;QACxD,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;QAChC,gBAAgB,EAAE,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC;QAClD,GAAG,IAAI;QACP,GAAG,MAAM;KACZ,CAAC;AACN,CAAC,CAAC;AAnBW,QAAA,gBAAgB,oBAmB3B"}
|
package/dist/utils/index.d.ts
CHANGED
|
@@ -7,6 +7,7 @@ export * from './get-package-name';
|
|
|
7
7
|
export * from './get-packages';
|
|
8
8
|
export * from './get-startup-version';
|
|
9
9
|
export * from './get-tsconfig';
|
|
10
|
+
export * from './load-shared-dependencies';
|
|
10
11
|
export * from './log';
|
|
11
12
|
export * from './pick';
|
|
12
13
|
export * from './read-json';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC;AACpC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,eAAe,CAAC;AAC9B,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,uBAAuB,CAAC;AACtC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,OAAO,CAAC;AACtB,cAAc,QAAQ,CAAC;AACvB,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC;AACpC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,eAAe,CAAC;AAC9B,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,uBAAuB,CAAC;AACtC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,4BAA4B,CAAC;AAC3C,cAAc,OAAO,CAAC;AACtB,cAAc,QAAQ,CAAC;AACvB,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC"}
|
package/dist/utils/index.js
CHANGED
|
@@ -23,6 +23,7 @@ __exportStar(require("./get-package-name"), exports);
|
|
|
23
23
|
__exportStar(require("./get-packages"), exports);
|
|
24
24
|
__exportStar(require("./get-startup-version"), exports);
|
|
25
25
|
__exportStar(require("./get-tsconfig"), exports);
|
|
26
|
+
__exportStar(require("./load-shared-dependencies"), exports);
|
|
26
27
|
__exportStar(require("./log"), exports);
|
|
27
28
|
__exportStar(require("./pick"), exports);
|
|
28
29
|
__exportStar(require("./read-json"), exports);
|
package/dist/utils/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,sDAAoC;AACpC,4DAA0C;AAC1C,gDAA8B;AAC9B,oDAAkC;AAClC,qDAAmC;AACnC,qDAAmC;AACnC,iDAA+B;AAC/B,wDAAsC;AACtC,iDAA+B;AAC/B,wCAAsB;AACtB,yCAAuB;AACvB,8CAA4B;AAC5B,6CAA2B"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,sDAAoC;AACpC,4DAA0C;AAC1C,gDAA8B;AAC9B,oDAAkC;AAClC,qDAAmC;AACnC,qDAAmC;AACnC,iDAA+B;AAC/B,wDAAsC;AACtC,iDAA+B;AAC/B,6DAA2C;AAC3C,wCAAsB;AACtB,yCAAuB;AACvB,8CAA4B;AAC5B,6CAA2B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"load-shared-dependencies.d.ts","sourceRoot":"","sources":["../../src/utils/load-shared-dependencies.ts"],"names":[],"mappings":"AAaA,wBAAgB,sBAAsB,CAClC,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,SAAS,EAChD,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,SAAS,GACvD,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAqBxB"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.loadSharedDependencies = loadSharedDependencies;
|
|
4
|
+
const getDefaultSharedDependencies = () => ({
|
|
5
|
+
'@servicetitan/design-system': 'SharedDependencies.ServiceTitan.DesignSystem',
|
|
6
|
+
'@servicetitan/anvil2': 'SharedDependencies.ServiceTitan.Anvil2',
|
|
7
|
+
'classnames': 'SharedDependencies.ClassNames',
|
|
8
|
+
'formstate': 'SharedDependencies.FormState',
|
|
9
|
+
'mobx': 'SharedDependencies.MobX',
|
|
10
|
+
'mobx-react': 'SharedDependencies.MobXReact',
|
|
11
|
+
'mobx-utils': 'SharedDependencies.MobXUtils',
|
|
12
|
+
'react': 'SharedDependencies.React',
|
|
13
|
+
'react-dom': 'SharedDependencies.ReactDOM',
|
|
14
|
+
});
|
|
15
|
+
const defaultsKey = 'defaults';
|
|
16
|
+
function loadSharedDependencies(dependencies, sharedDependencies) {
|
|
17
|
+
if (!dependencies) {
|
|
18
|
+
return {};
|
|
19
|
+
}
|
|
20
|
+
const out = {
|
|
21
|
+
...(!sharedDependencies || sharedDependencies[defaultsKey] !== undefined
|
|
22
|
+
? getDefaultSharedDependencies()
|
|
23
|
+
: {}),
|
|
24
|
+
...(sharedDependencies !== null && sharedDependencies !== void 0 ? sharedDependencies : {}),
|
|
25
|
+
};
|
|
26
|
+
delete out[defaultsKey];
|
|
27
|
+
for (const [dependency, value] of Object.entries(out)) {
|
|
28
|
+
if (!value || !dependencies[dependency]) {
|
|
29
|
+
delete out[dependency];
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
return out;
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=load-shared-dependencies.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"load-shared-dependencies.js","sourceRoot":"","sources":["../../src/utils/load-shared-dependencies.ts"],"names":[],"mappings":";;AAaA,wDAwBC;AArCD,MAAM,4BAA4B,GAAG,GAAG,EAAE,CAAC,CAAC;IACxC,6BAA6B,EAAE,8CAA8C;IAC7E,sBAAsB,EAAE,wCAAwC;IAChE,YAAY,EAAE,+BAA+B;IAC7C,WAAW,EAAE,8BAA8B;IAC3C,MAAM,EAAE,yBAAyB;IACjC,YAAY,EAAE,8BAA8B;IAC5C,YAAY,EAAE,8BAA8B;IAC5C,OAAO,EAAE,0BAA0B;IACnC,WAAW,EAAE,6BAA6B;CAC7C,CAAC,CAAC;AACH,MAAM,WAAW,GAAG,UAAU,CAAC;AAE/B,SAAgB,sBAAsB,CAClC,YAAgD,EAChD,kBAAsD;IAEtD,IAAI,CAAC,YAAY,EAAE,CAAC;QAChB,OAAO,EAAE,CAAC;IACd,CAAC;IAED,MAAM,GAAG,GAA2B;QAChC,GAAG,CAAC,CAAC,kBAAkB,IAAI,kBAAkB,CAAC,WAAW,CAAC,KAAK,SAAS;YACpE,CAAC,CAAC,4BAA4B,EAAE;YAChC,CAAC,CAAC,EAAE,CAAC;QACT,GAAG,CAAC,kBAAkB,aAAlB,kBAAkB,cAAlB,kBAAkB,GAAI,EAAE,CAAC;KAChC,CAAC;IAEF,OAAO,GAAG,CAAC,WAAW,CAAC,CAAC;IAExB,KAAK,MAAM,CAAC,UAAU,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;QACpD,IAAI,CAAC,KAAK,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,EAAE,CAAC;YACtC,OAAO,GAAG,CAAC,UAAU,CAAC,CAAC;QAC3B,CAAC;IACL,CAAC;IAED,OAAO,GAAG,CAAC;AACf,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dev-server-config.d.ts","sourceRoot":"","sources":["../../../src/webpack/configs/dev-server-config.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"dev-server-config.d.ts","sourceRoot":"","sources":["../../../src/webpack/configs/dev-server-config.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAaxC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAI7C,KAAK,MAAM,GAAG,IAAI,CAAC,aAAa,EAAE,WAAW,GAAG,cAAc,CAAC,GAAG,SAAS,CAAC;AAE5E,wBAAgB,eAAe,CAAC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS,GAAG,MAAM,CAyB9E"}
|
|
@@ -61,7 +61,7 @@ function getDevServerConfig() {
|
|
|
61
61
|
function watchOptionsConfig() {
|
|
62
62
|
const ignored = (0, utils_1.getPackages)({ scope: (0, utils_1.getPackageName)() })
|
|
63
63
|
.filter(({ type }) => type === utils_1.PackageType.TSC)
|
|
64
|
-
.map(({ location }) => location);
|
|
64
|
+
.map(({ location }) => path_1.default.join(location, (0, utils_1.getFolders)(location).source));
|
|
65
65
|
/*
|
|
66
66
|
* NOTE: Don't return empty ignored array. It triggered a bug that caused
|
|
67
67
|
* webpack to ignore all files
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dev-server-config.js","sourceRoot":"","sources":["../../../src/webpack/configs/dev-server-config.ts"],"names":[],"mappings":";;;;;
|
|
1
|
+
{"version":3,"file":"dev-server-config.js","sourceRoot":"","sources":["../../../src/webpack/configs/dev-server-config.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"define-exposed-dependencies-plugin.d.ts","sourceRoot":"","sources":["../../../../src/webpack/configs/plugins/define-exposed-dependencies-plugin.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"define-exposed-dependencies-plugin.d.ts","sourceRoot":"","sources":["../../../../src/webpack/configs/plugins/define-exposed-dependencies-plugin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAEvC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAE9C,wBAAgB,+BAA+B,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,SAAS,4BAwB7E"}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.defineExposedDependenciesPlugin = defineExposedDependenciesPlugin;
|
|
4
|
-
const startup_utils_1 = require("@servicetitan/startup-utils");
|
|
5
4
|
const webpack_1 = require("webpack");
|
|
6
5
|
const utils_1 = require("../../../utils");
|
|
7
6
|
function defineExposedDependenciesPlugin(context, _) {
|
|
@@ -9,10 +8,17 @@ function defineExposedDependenciesPlugin(context, _) {
|
|
|
9
8
|
if (!isExposeSharedDependencies) {
|
|
10
9
|
return;
|
|
11
10
|
}
|
|
12
|
-
const exposedDependencies = (0, startup_utils_1.getExposedDependencies)(sharedDependencies, dependency => { var _a; return (0, utils_1.getPackageDependencyVersion)(dependency, (_a = packageData.dependencies) === null || _a === void 0 ? void 0 : _a[dependency]); });
|
|
13
11
|
return new webpack_1.DefinePlugin({
|
|
14
12
|
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
15
|
-
EXPOSED_DEPENDENCIES: JSON.stringify(
|
|
13
|
+
EXPOSED_DEPENDENCIES: JSON.stringify(Object.entries(sharedDependencies).reduce((result, [dependency, variable]) => {
|
|
14
|
+
var _a;
|
|
15
|
+
return Object.assign(result, {
|
|
16
|
+
[dependency]: {
|
|
17
|
+
version: (0, utils_1.getPackageDependencyVersion)(dependency, (_a = packageData.dependencies) === null || _a === void 0 ? void 0 : _a[dependency]),
|
|
18
|
+
variable,
|
|
19
|
+
},
|
|
20
|
+
});
|
|
21
|
+
}, {})),
|
|
16
22
|
});
|
|
17
23
|
}
|
|
18
24
|
//# sourceMappingURL=define-exposed-dependencies-plugin.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"define-exposed-dependencies-plugin.js","sourceRoot":"","sources":["../../../../src/webpack/configs/plugins/define-exposed-dependencies-plugin.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"define-exposed-dependencies-plugin.js","sourceRoot":"","sources":["../../../../src/webpack/configs/plugins/define-exposed-dependencies-plugin.ts"],"names":[],"mappings":";;AAIA,0EAwBC;AA5BD,qCAAuC;AACvC,0CAA6D;AAG7D,SAAgB,+BAA+B,CAAC,OAAgB,EAAE,CAAY;IAC1E,MAAM,EAAE,0BAA0B,EAAE,WAAW,EAAE,kBAAkB,EAAE,GAAG,OAAO,CAAC;IAChF,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAC9B,OAAO;IACX,CAAC;IAED,OAAO,IAAI,sBAAY,CAAC;QACpB,gEAAgE;QAChE,oBAAoB,EAAE,IAAI,CAAC,SAAS,CAChC,MAAM,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,MAAM,CACrC,CAAC,MAAM,EAAE,CAAC,UAAU,EAAE,QAAQ,CAAC,EAAE,EAAE;;YAC/B,OAAA,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE;gBAClB,CAAC,UAAU,CAAC,EAAE;oBACV,OAAO,EAAE,IAAA,mCAA2B,EAChC,UAAU,EACV,MAAA,WAAW,CAAC,YAAY,0CAAG,UAAU,CAAC,CACzC;oBACD,QAAQ;iBACX;aACJ,CAAC,CAAA;SAAA,EACN,EAAE,CACL,CACJ;KACJ,CAAC,CAAC;AACP,CAAC"}
|
|
@@ -9,7 +9,7 @@ const optionalAnvilPeerDependencies = ['@servicetitan/design-system', '@servicet
|
|
|
9
9
|
*/
|
|
10
10
|
function isOptionalAnvilPeerDependency({ context, packageContext, resource }) {
|
|
11
11
|
return (optionalAnvilPeerDependencies.includes(resource) &&
|
|
12
|
-
/(@servicetitan|packages)
|
|
12
|
+
/(@servicetitan|packages)[\\/](web-components)/.test(context) &&
|
|
13
13
|
!Object.keys(packageContext.packageData.dependencies).includes(resource));
|
|
14
14
|
}
|
|
15
15
|
//# sourceMappingURL=is-optional-anvil-peer-dependency.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"is-optional-anvil-peer-dependency.js","sourceRoot":"","sources":["../../../../../src/webpack/configs/plugins/ignore-plugin/is-optional-anvil-peer-dependency.ts"],"names":[],"mappings":";;AAeA,sEAMC;AAbD,MAAM,6BAA6B,GAAG,CAAC,6BAA6B,EAAE,sBAAsB,CAAC,CAAC;AAE9F;;;;GAIG;AACH,SAAgB,6BAA6B,CAAC,EAAE,OAAO,EAAE,cAAc,EAAE,QAAQ,EAAc;IAC3F,OAAO,CACH,6BAA6B,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAChD,
|
|
1
|
+
{"version":3,"file":"is-optional-anvil-peer-dependency.js","sourceRoot":"","sources":["../../../../../src/webpack/configs/plugins/ignore-plugin/is-optional-anvil-peer-dependency.ts"],"names":[],"mappings":";;AAeA,sEAMC;AAbD,MAAM,6BAA6B,GAAG,CAAC,6BAA6B,EAAE,sBAAsB,CAAC,CAAC;AAE9F;;;;GAIG;AACH,SAAgB,6BAA6B,CAAC,EAAE,OAAO,EAAE,cAAc,EAAE,QAAQ,EAAc;IAC3F,OAAO,CACH,6BAA6B,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAChD,+CAA+C,CAAC,IAAI,CAAC,OAAO,CAAC;QAC7D,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAC3E,CAAC;AACN,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/webpack/configs/plugins/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAC;AACzC,cAAc,0BAA0B,CAAC;AACzC,cAAc,sCAAsC,CAAC;AACrD,cAAc,oCAAoC,CAAC;AACnD,cAAc,0BAA0B,CAAC;AACzC,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,yBAAyB,CAAC;AACxC,cAAc,wBAAwB,CAAC;AACvC,cAAc,qBAAqB,CAAC;AACpC,cAAc,0BAA0B,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/webpack/configs/plugins/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAC;AACzC,cAAc,0BAA0B,CAAC;AACzC,cAAc,sCAAsC,CAAC;AACrD,cAAc,oCAAoC,CAAC;AACnD,cAAc,0BAA0B,CAAC;AACzC,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,yBAAyB,CAAC;AACxC,cAAc,wBAAwB,CAAC;AACvC,cAAc,qBAAqB,CAAC;AACpC,cAAc,0BAA0B,CAAC;AACzC,cAAc,oBAAoB,CAAC"}
|
|
@@ -26,4 +26,5 @@ __exportStar(require("./moment-locales-plugin"), exports);
|
|
|
26
26
|
__exportStar(require("./provide-react-plugin"), exports);
|
|
27
27
|
__exportStar(require("./ts-checker-plugin"), exports);
|
|
28
28
|
__exportStar(require("./virtual-modules-plugin"), exports);
|
|
29
|
+
__exportStar(require("./watch-run-plugin"), exports);
|
|
29
30
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/webpack/configs/plugins/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2DAAyC;AACzC,2DAAyC;AACzC,uEAAqD;AACrD,qEAAmD;AACnD,2DAAyC;AACzC,gDAA8B;AAC9B,kDAAgC;AAChC,4DAA0C;AAC1C,0DAAwC;AACxC,yDAAuC;AACvC,sDAAoC;AACpC,2DAAyC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/webpack/configs/plugins/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2DAAyC;AACzC,2DAAyC;AACzC,uEAAqD;AACrD,qEAAmD;AACnD,2DAAyC;AACzC,gDAA8B;AAC9B,kDAAgC;AAChC,4DAA0C;AAC1C,0DAAwC;AACxC,yDAAuC;AACvC,sDAAoC;AACpC,2DAAyC;AACzC,qDAAmC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Compiler } from 'webpack';
|
|
2
|
+
import { Context, Overrides } from '../types';
|
|
3
|
+
export declare function watchRunPlugin(_context: Context, _overrides: Overrides): WatchRunPlugin | undefined;
|
|
4
|
+
declare class WatchRunPlugin {
|
|
5
|
+
apply(compiler: Compiler): void;
|
|
6
|
+
}
|
|
7
|
+
export {};
|
|
8
|
+
//# sourceMappingURL=watch-run-plugin.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"watch-run-plugin.d.ts","sourceRoot":"","sources":["../../../../src/webpack/configs/plugins/watch-run-plugin.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAGnC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAE9C,wBAAgB,cAAc,CAAC,QAAQ,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,8BAKtE;AAED,cAAM,cAAc;IAEhB,KAAK,CAAC,QAAQ,EAAE,QAAQ;CAO3B"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.watchRunPlugin = watchRunPlugin;
|
|
7
|
+
const path_1 = __importDefault(require("path"));
|
|
8
|
+
const utils_1 = require("../../../utils");
|
|
9
|
+
function watchRunPlugin(_context, _overrides) {
|
|
10
|
+
/* istanbul ignore next: debug only */
|
|
11
|
+
if (utils_1.log.debug('modified-files').enabled) {
|
|
12
|
+
return new WatchRunPlugin();
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
class WatchRunPlugin {
|
|
16
|
+
/* istanbul ignore next: debug only */
|
|
17
|
+
apply(compiler) {
|
|
18
|
+
compiler.hooks.watchRun.tap('WatchRun', compilation => {
|
|
19
|
+
var _a;
|
|
20
|
+
(_a = compilation.modifiedFiles) === null || _a === void 0 ? void 0 : _a.forEach(file => {
|
|
21
|
+
utils_1.log.debug('modified-files', path_1.default.relative('', file));
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=watch-run-plugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"watch-run-plugin.js","sourceRoot":"","sources":["../../../../src/webpack/configs/plugins/watch-run-plugin.ts"],"names":[],"mappings":";;;;;AAMA,wCAKC;AAXD,gDAAwB;AAGxB,0CAAqC;AAGrC,SAAgB,cAAc,CAAC,QAAiB,EAAE,UAAqB;IACnE,sCAAsC;IACtC,IAAI,WAAG,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC,OAAO,EAAE,CAAC;QACtC,OAAO,IAAI,cAAc,EAAE,CAAC;IAChC,CAAC;AACL,CAAC;AAED,MAAM,cAAc;IAChB,sCAAsC;IACtC,KAAK,CAAC,QAAkB;QACpB,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,EAAE,WAAW,CAAC,EAAE;;YAClD,MAAA,WAAW,CAAC,aAAa,0CAAE,OAAO,CAAC,IAAI,CAAC,EAAE;gBACtC,WAAG,CAAC,KAAK,CAAC,gBAAgB,EAAE,cAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC,CAAC;YACzD,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;CACJ"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugins-config.d.ts","sourceRoot":"","sources":["../../../src/webpack/configs/plugins-config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"plugins-config.d.ts","sourceRoot":"","sources":["../../../src/webpack/configs/plugins-config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAgBxC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAG7C,KAAK,MAAM,GAAG,IAAI,CAAC,aAAa,EAAE,SAAS,CAAC,CAAC;AAE7C,wBAAgB,aAAa,CAAC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS,GAAG,MAAM,CAoB5E"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugins-config.js","sourceRoot":"","sources":["../../../src/webpack/configs/plugins-config.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"plugins-config.js","sourceRoot":"","sources":["../../../src/webpack/configs/plugins-config.ts"],"names":[],"mappings":";;AAqBA,sCAoBC;AAxCD,uCAcmB;AAMnB,SAAgB,aAAa,CAAC,OAAgB,EAAE,SAAoB;IAChE,MAAM,OAAO,GAAW;QACpB,8BAAoB;QACpB,8BAAoB;QACpB,yCAA+B;QAC/B,sCAA4B;QAC5B,8BAAoB;QACpB,oBAAU;QACV,sBAAY;QACZ,8BAAoB;QACpB,6BAAmB;QACnB,yBAAe;QACf,4BAAkB;QAClB,8BAAoB;QACpB,wBAAc;KACjB;SACI,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;SACjC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IAEhC,OAAO,EAAE,OAAO,EAAE,CAAC;AACvB,CAAC"}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import { loadSharedDependencies } from '
|
|
2
|
-
import { getPackageData, MinifyOptions } from '../../utils';
|
|
1
|
+
import { getPackageData, loadSharedDependencies, MinifyOptions } from '../../utils';
|
|
3
2
|
import { Options } from '../types';
|
|
4
3
|
export { Overrides } from '../types';
|
|
5
4
|
export interface Context extends Options {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/webpack/configs/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/webpack/configs/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,sBAAsB,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AACpF,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAErC,MAAM,WAAW,OAAQ,SAAQ,OAAO;IACpC,YAAY,EAAE,OAAO,CAAC;IACtB,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,EAAE,OAAO,CAAC;IACjB,oBAAoB,EAAE,OAAO,CAAC;IAC9B,kBAAkB,EAAE,OAAO,CAAC;IAC5B,0BAA0B,EAAE,OAAO,CAAC;IACpC,YAAY,EAAE,OAAO,CAAC;IACtB,YAAY,EAAE,OAAO,CAAC;IACtB,cAAc,EAAE,OAAO,CAAC;IACxB,MAAM,CAAC,EAAE,aAAa,CAAC;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;IAC/C,kBAAkB,EAAE,UAAU,CAAC,OAAO,sBAAsB,CAAC,CAAC;IAC9D,MAAM,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,UAAU;IACvB,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC;IACf,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC;CACjB;AAED,MAAM,WAAW,WAAW;IACxB,IAAI,CAAC,EAAE,UAAU,CAAC;IAClB,KAAK,CAAC,EAAE,UAAU,CAAC;CACtB;AAED,MAAM,WAAW,QAAQ;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACpC,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC3C,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACrC,WAAW,EAAE,WAAW,CAAC;CAC5B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-webpack-config.d.ts","sourceRoot":"","sources":["../../src/webpack/create-webpack-config.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"create-webpack-config.d.ts","sourceRoot":"","sources":["../../src/webpack/create-webpack-config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AA+BxC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAG7C,wBAAgB,mBAAmB,CAAC,SAAS,EAAE,SAAS,EAAE,OAAO,GAAE,OAAY,GAAG,aAAa,CAwD9F"}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.createWebpackConfig = createWebpackConfig;
|
|
4
|
-
const startup_utils_1 = require("@servicetitan/startup-utils");
|
|
5
4
|
const webpack_merge_1 = require("webpack-merge");
|
|
6
5
|
const yargs_1 = require("yargs");
|
|
7
6
|
const utils_1 = require("../cli/utils");
|
|
@@ -14,7 +13,7 @@ function createWebpackConfig(overrides, options = {}) {
|
|
|
14
13
|
const { source, destination } = (0, utils_2.getFolders)();
|
|
15
14
|
const { minify } = (0, utils_2.getWebpackConfiguration)();
|
|
16
15
|
const packageData = (0, utils_2.getPackageData)();
|
|
17
|
-
const sharedDependencies = (0,
|
|
16
|
+
const sharedDependencies = (0, utils_2.loadSharedDependencies)(packageData.dependencies, packageData.sharedDependencies);
|
|
18
17
|
const context = {
|
|
19
18
|
codeCoverage: (_a = options.codeCoverage) !== null && _a !== void 0 ? _a : !!yargs_1.argv['code-coverage'],
|
|
20
19
|
destination,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-webpack-config.js","sourceRoot":"","sources":["../../src/webpack/create-webpack-config.ts"],"names":[],"mappings":";;AAkCA,kDAwDC;
|
|
1
|
+
{"version":3,"file":"create-webpack-config.js","sourceRoot":"","sources":["../../src/webpack/create-webpack-config.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@servicetitan/startup",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "28.0.0",
|
|
4
4
|
"description": "",
|
|
5
5
|
"homepage": "https://docs.st.dev/docs/frontend/startup",
|
|
6
6
|
"repository": {
|
|
@@ -27,13 +27,12 @@
|
|
|
27
27
|
"@types/yargs": "~17.0.24"
|
|
28
28
|
},
|
|
29
29
|
"dependencies": {
|
|
30
|
-
"@babel/preset-env": "~7.
|
|
30
|
+
"@babel/preset-env": "~7.26.0",
|
|
31
31
|
"@jest/core": "~29.7.0",
|
|
32
32
|
"@jest/types": "~29.6.3",
|
|
33
33
|
"@jsdevtools/coverage-istanbul-loader": "^3.0.5",
|
|
34
|
-
"@servicetitan/eslint-config": "
|
|
35
|
-
"@servicetitan/
|
|
36
|
-
"@servicetitan/stylelint-config": "27.4.0",
|
|
34
|
+
"@servicetitan/eslint-config": "28.0.0",
|
|
35
|
+
"@servicetitan/stylelint-config": "28.0.0",
|
|
37
36
|
"@svgr/webpack": "^8.1.0",
|
|
38
37
|
"@swc/core": "1.7.26",
|
|
39
38
|
"@types/debug": "^4.1.12",
|
|
@@ -50,39 +49,39 @@
|
|
|
50
49
|
"execa": "~5.1.1",
|
|
51
50
|
"fork-ts-checker-webpack-plugin": "~9.0.2",
|
|
52
51
|
"glob": "~10.4.2",
|
|
53
|
-
"html-webpack-plugin": "~5.6.
|
|
52
|
+
"html-webpack-plugin": "~5.6.3",
|
|
54
53
|
"identity-obj-proxy": "~3.0.0",
|
|
55
54
|
"jest": "~29.7.0",
|
|
56
55
|
"jest-circus": "~29.7.0",
|
|
57
56
|
"jest-environment-jsdom": "^29.7.0",
|
|
58
57
|
"jest-fetch-mock": "~3.0.3",
|
|
59
|
-
"lerna": "~8.1.
|
|
58
|
+
"lerna": "~8.1.9",
|
|
60
59
|
"less": "~4.2.0",
|
|
61
60
|
"less-loader": "~12.2.0",
|
|
62
61
|
"less-plugin-npm-import": "~2.1.0",
|
|
63
62
|
"memfs": "~4.14.0",
|
|
64
|
-
"mini-css-extract-plugin": "~2.9.
|
|
63
|
+
"mini-css-extract-plugin": "~2.9.2",
|
|
65
64
|
"moment": "^2.30.1",
|
|
66
65
|
"moment-locales-webpack-plugin": "~1.2.0",
|
|
67
66
|
"multimatch": "~5.0.0",
|
|
68
67
|
"portfinder": "~1.0.32",
|
|
69
68
|
"postcss": "~8.4.47",
|
|
70
69
|
"prettier": "~3.3.3",
|
|
71
|
-
"sass": "~1.
|
|
72
|
-
"sass-loader": "~16.0.
|
|
70
|
+
"sass": "~1.80.6",
|
|
71
|
+
"sass-loader": "~16.0.3",
|
|
73
72
|
"source-map-loader": "~5.0.0",
|
|
74
73
|
"string-width": "<5.0.0",
|
|
75
74
|
"style-loader": "~4.0.0",
|
|
76
75
|
"stylelint": "~16.10.0",
|
|
77
76
|
"swc-loader": "0.2.6",
|
|
78
77
|
"terser-webpack-plugin": "^5.3.10",
|
|
79
|
-
"ts-jest": "
|
|
78
|
+
"ts-jest": "29.2.5",
|
|
80
79
|
"ts-loader": "~9.5.1",
|
|
81
80
|
"ts-node": "~10.9.2",
|
|
82
81
|
"typed-css-modules": "~0.9.1",
|
|
83
82
|
"typescript": "5.6.3",
|
|
84
83
|
"username": "~5.1.0",
|
|
85
|
-
"webpack": "~5.
|
|
84
|
+
"webpack": "~5.96.1",
|
|
86
85
|
"webpack-assets-manifest": "~5.2.1",
|
|
87
86
|
"webpack-bundle-analyzer": "^4.10.2",
|
|
88
87
|
"webpack-dev-server": "~5.1.0",
|
|
@@ -102,5 +101,6 @@
|
|
|
102
101
|
},
|
|
103
102
|
"cli": {
|
|
104
103
|
"webpack": false
|
|
105
|
-
}
|
|
104
|
+
},
|
|
105
|
+
"gitHead": "7b905cd6ecfd5bb4a748050a83ebd8ca4e185e09"
|
|
106
106
|
}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { loadSharedDependencies } from '@servicetitan/startup-utils';
|
|
2
1
|
import { fs, vol } from 'memfs';
|
|
3
2
|
import path from 'path';
|
|
4
3
|
import {
|
|
@@ -8,15 +7,12 @@ import {
|
|
|
8
7
|
isLegacy,
|
|
9
8
|
isStyleCheckDisabled,
|
|
10
9
|
isWebComponent,
|
|
10
|
+
loadSharedDependencies,
|
|
11
11
|
log,
|
|
12
12
|
} from '../../../utils';
|
|
13
13
|
|
|
14
14
|
import { StylesCheck } from '../styles-check';
|
|
15
15
|
|
|
16
|
-
jest.mock('@servicetitan/startup-utils', () => ({
|
|
17
|
-
...jest.requireActual('@servicetitan/startup-utils'),
|
|
18
|
-
loadSharedDependencies: jest.fn(),
|
|
19
|
-
}));
|
|
20
16
|
jest.mock('fs', () => fs);
|
|
21
17
|
jest.mock('../../../utils', () => ({
|
|
22
18
|
...jest.requireActual('../../../utils'),
|
|
@@ -30,10 +30,14 @@ describe(`[startup] ${Tests.name}`, () => {
|
|
|
30
30
|
});
|
|
31
31
|
|
|
32
32
|
describe('when the command fails', () => {
|
|
33
|
+
const exitCode = process.exitCode;
|
|
34
|
+
|
|
33
35
|
beforeEach(() => {
|
|
34
36
|
jest.mocked(runCLI).mockResolvedValue({ results: { success: false } } as any);
|
|
35
37
|
});
|
|
36
38
|
|
|
39
|
+
afterAll(() => (process.exitCode = exitCode));
|
|
40
|
+
|
|
37
41
|
test('sets process execCode to 1', async () => {
|
|
38
42
|
await subject();
|
|
39
43
|
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { loadSharedDependencies } from '@servicetitan/startup-utils';
|
|
2
1
|
import fs from 'fs';
|
|
3
2
|
import path from 'path';
|
|
4
3
|
import process from 'process';
|
|
@@ -9,6 +8,7 @@ import {
|
|
|
9
8
|
isLegacy,
|
|
10
9
|
isStyleCheckDisabled,
|
|
11
10
|
isWebComponent,
|
|
11
|
+
loadSharedDependencies,
|
|
12
12
|
log,
|
|
13
13
|
} from '../../utils';
|
|
14
14
|
import { Command } from './index';
|
|
@@ -1,9 +1,13 @@
|
|
|
1
|
-
import { loadSharedDependencies } from '@servicetitan/startup-utils';
|
|
2
1
|
import { fs, vol } from 'memfs';
|
|
3
2
|
import path from 'path';
|
|
4
3
|
import webpack from 'webpack';
|
|
5
4
|
import WebpackDevServer from 'webpack-dev-server';
|
|
6
|
-
import {
|
|
5
|
+
import {
|
|
6
|
+
getConfiguration,
|
|
7
|
+
getFolders,
|
|
8
|
+
getPackageData,
|
|
9
|
+
loadSharedDependencies,
|
|
10
|
+
} from '../../../utils';
|
|
7
11
|
import { createWebpackConfig } from '../../../webpack';
|
|
8
12
|
import { createPackage } from '../../../__mocks__';
|
|
9
13
|
|
|
@@ -14,10 +18,6 @@ import {
|
|
|
14
18
|
webpackProdConfigFileName,
|
|
15
19
|
} from '../bundle';
|
|
16
20
|
|
|
17
|
-
jest.mock('@servicetitan/startup-utils', () => ({
|
|
18
|
-
...jest.requireActual('@servicetitan/startup-utils'),
|
|
19
|
-
loadSharedDependencies: jest.fn(),
|
|
20
|
-
}));
|
|
21
21
|
jest.mock('fs', () => fs);
|
|
22
22
|
jest.mock('webpack', () => jest.fn());
|
|
23
23
|
jest.mock('webpack-dev-server');
|
|
@@ -25,6 +25,7 @@ jest.mock('../../../utils', () => ({
|
|
|
25
25
|
...jest.requireActual('../../../utils'),
|
|
26
26
|
getFolders: jest.fn(),
|
|
27
27
|
getPackageData: jest.fn(),
|
|
28
|
+
loadSharedDependencies: jest.fn(),
|
|
28
29
|
log: { info: jest.fn() }, // suppress test output
|
|
29
30
|
}));
|
|
30
31
|
jest.mock('../../../webpack', () => ({ createWebpackConfig: jest.fn() }));
|
|
@@ -63,8 +63,12 @@ describe(`[startup] utils:${eslint.name}`, () => {
|
|
|
63
63
|
});
|
|
64
64
|
|
|
65
65
|
describe('when there are errors', () => {
|
|
66
|
+
const exitCode = process.exitCode;
|
|
67
|
+
|
|
66
68
|
beforeEach(() => (eslintErrors = [mockResult]));
|
|
67
69
|
|
|
70
|
+
afterAll(() => (process.exitCode = exitCode));
|
|
71
|
+
|
|
68
72
|
test('sets process exitCode', async () => {
|
|
69
73
|
await subject();
|
|
70
74
|
|
|
@@ -19,13 +19,6 @@ describe('[startup] Utils', () => {
|
|
|
19
19
|
testRunner: 'jest-circus/runner',
|
|
20
20
|
transformIgnorePatterns: ['node_modules/(?!(@servicetitan|@react-hook|nanoid|axios)/)'],
|
|
21
21
|
modulePathIgnorePatterns: ['<rootDir>/.*/__mocks__'],
|
|
22
|
-
transform: {
|
|
23
|
-
'^.+\\.jsx?$': [
|
|
24
|
-
'babel-jest',
|
|
25
|
-
{ presets: [['@babel/preset-env', { targets: { node: 'current' } }]] },
|
|
26
|
-
],
|
|
27
|
-
'^.+\\.tsx?$': ['ts-jest', { tsconfig: './tsconfig.test.json' }],
|
|
28
|
-
},
|
|
29
22
|
moduleNameMapper: {
|
|
30
23
|
'\\.(css|scss|less|png|svg|jpg|jpeg|gif|woff|woff2|eot|ttf|otf)$': 'identity-obj-proxy',
|
|
31
24
|
},
|
|
@@ -34,6 +27,7 @@ describe('[startup] Utils', () => {
|
|
|
34
27
|
coveragePathIgnorePatterns: ['^.+\\.d\\.ts$'],
|
|
35
28
|
coverageReporters: ['html-spa', 'text', 'json', 'cobertura', 'lcov'],
|
|
36
29
|
collectCoverageFrom: ['**/*.{ts,tsx}'],
|
|
30
|
+
preset: expect.stringMatching(/startup[\\\/]+jest/),
|
|
37
31
|
};
|
|
38
32
|
|
|
39
33
|
beforeEach(() => {
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import { loadSharedDependencies } from '../load-shared-dependencies';
|
|
2
|
+
|
|
3
|
+
describe(`[startup] utils:${loadSharedDependencies.name}`, () => {
|
|
4
|
+
const defaultSharedDependencies = {
|
|
5
|
+
'@servicetitan/design-system': 'SharedDependencies.ServiceTitan.DesignSystem',
|
|
6
|
+
'@servicetitan/anvil2': 'SharedDependencies.ServiceTitan.Anvil2',
|
|
7
|
+
'classnames': 'SharedDependencies.ClassNames',
|
|
8
|
+
'formstate': 'SharedDependencies.FormState',
|
|
9
|
+
'mobx': 'SharedDependencies.MobX',
|
|
10
|
+
'mobx-react': 'SharedDependencies.MobXReact',
|
|
11
|
+
'mobx-utils': 'SharedDependencies.MobXUtils',
|
|
12
|
+
'react': 'SharedDependencies.React',
|
|
13
|
+
'react-dom': 'SharedDependencies.ReactDOM',
|
|
14
|
+
};
|
|
15
|
+
let packageDependencies: Record<string, string> | undefined;
|
|
16
|
+
let sharedDependencies: Record<string, string> | undefined;
|
|
17
|
+
|
|
18
|
+
beforeEach(() => {
|
|
19
|
+
packageDependencies = {
|
|
20
|
+
// Default shared dependencies
|
|
21
|
+
'@servicetitan/design-system': '^0.0.0',
|
|
22
|
+
'@servicetitan/anvil2': '^0.0.0',
|
|
23
|
+
'classnames': '^0.0.0',
|
|
24
|
+
'formstate': '^0.0.0',
|
|
25
|
+
'mobx': '^0.0.0',
|
|
26
|
+
'mobx-react': '^0.0.0',
|
|
27
|
+
'mobx-utils': '^0.0.0',
|
|
28
|
+
'react': '^0.0.0',
|
|
29
|
+
'react-dom': '^0.0.0',
|
|
30
|
+
// Other dependencies
|
|
31
|
+
'@servicetitan/confirm': '^0.0.0',
|
|
32
|
+
'react-input-mask': '^0.0.0',
|
|
33
|
+
};
|
|
34
|
+
sharedDependencies = undefined;
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
const subject = () => loadSharedDependencies(packageDependencies, sharedDependencies);
|
|
38
|
+
|
|
39
|
+
function omit(obj: Record<string, string>, ...exclude: string[]) {
|
|
40
|
+
return Object.fromEntries(Object.entries(obj).filter(([key]) => !exclude.includes(key)));
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
test('returns default shared dependencies', () => {
|
|
44
|
+
expect(subject()).toEqual(defaultSharedDependencies);
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
describe('when package does not depend on default shared dependency', () => {
|
|
48
|
+
beforeEach(() => delete packageDependencies!['@servicetitan/design-system']);
|
|
49
|
+
|
|
50
|
+
test('omits the default shared dependency', () => {
|
|
51
|
+
expect(subject()).toEqual(
|
|
52
|
+
omit(defaultSharedDependencies, '@servicetitan/design-system')
|
|
53
|
+
);
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
describe('with explicit shared dependencies', () => {
|
|
58
|
+
beforeEach(() => (sharedDependencies = {}));
|
|
59
|
+
|
|
60
|
+
test('returns specified dependencies', () => {
|
|
61
|
+
expect(subject()).toEqual(sharedDependencies);
|
|
62
|
+
});
|
|
63
|
+
|
|
64
|
+
describe('when explicit shared dependencies includes "defaults"', () => {
|
|
65
|
+
beforeEach(() => (sharedDependencies!.defaults = ''));
|
|
66
|
+
|
|
67
|
+
test('returns default shared dependencies', () => {
|
|
68
|
+
expect(subject()).toEqual(defaultSharedDependencies);
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
describe('when explicit shared dependency has falsy value', () => {
|
|
72
|
+
beforeEach(() => {
|
|
73
|
+
Object.assign(sharedDependencies!, { 'classnames': false, 'mobx-utils': '' });
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
test('omits the falsy dependency', () => {
|
|
77
|
+
expect(subject()).toEqual(
|
|
78
|
+
omit(defaultSharedDependencies, 'classnames', 'mobx-utils')
|
|
79
|
+
);
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
describe('when explicit shared dependency has non-default packages', () => {
|
|
84
|
+
beforeEach(() => {
|
|
85
|
+
Object.assign(sharedDependencies!, {
|
|
86
|
+
'@servicetitan/confirm': 'SharedDependencies.ServiceTitan.Confirm',
|
|
87
|
+
'react-input-mask': 'SharedDependencies.ReactInputMask',
|
|
88
|
+
});
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
test('adds the non-default packages', () => {
|
|
92
|
+
expect(subject()).toEqual({
|
|
93
|
+
...defaultSharedDependencies,
|
|
94
|
+
...omit(sharedDependencies!, 'defaults'),
|
|
95
|
+
});
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
});
|
|
100
|
+
|
|
101
|
+
describe('with no package dependencies', () => {
|
|
102
|
+
beforeEach(() => (packageDependencies = undefined));
|
|
103
|
+
|
|
104
|
+
test('returns empty object', () => {
|
|
105
|
+
expect(subject()).toEqual({});
|
|
106
|
+
});
|
|
107
|
+
});
|
|
108
|
+
});
|
|
@@ -13,13 +13,6 @@ const getJestConfigBase = ({
|
|
|
13
13
|
setupFiles?: string[];
|
|
14
14
|
testPathIgnorePatterns?: string[];
|
|
15
15
|
}) => {
|
|
16
|
-
const transform = {
|
|
17
|
-
'^.+\\.jsx?$': [
|
|
18
|
-
'babel-jest',
|
|
19
|
-
{ presets: [['@babel/preset-env', { targets: { node: 'current' } }]] },
|
|
20
|
-
],
|
|
21
|
-
'^.+\\.tsx?$': ['ts-jest', { tsconfig: './tsconfig.test.json' }],
|
|
22
|
-
};
|
|
23
16
|
const moduleNameMapper = {
|
|
24
17
|
'\\.(css|scss|less|png|svg|jpg|jpeg|gif|woff|woff2|eot|ttf|otf)$': 'identity-obj-proxy',
|
|
25
18
|
};
|
|
@@ -30,7 +23,6 @@ const getJestConfigBase = ({
|
|
|
30
23
|
testRunner: 'jest-circus/runner',
|
|
31
24
|
transformIgnorePatterns: ['node_modules/(?!(@servicetitan|@react-hook|nanoid|axios)/)'],
|
|
32
25
|
modulePathIgnorePatterns: ['<rootDir>/.*/__mocks__'],
|
|
33
|
-
transform,
|
|
34
26
|
moduleNameMapper,
|
|
35
27
|
testPathIgnorePatterns: [
|
|
36
28
|
'\\.yalc',
|
|
@@ -41,6 +33,7 @@ const getJestConfigBase = ({
|
|
|
41
33
|
coveragePathIgnorePatterns: ['^.+\\.d\\.ts$', ...coveragePathIgnorePatterns],
|
|
42
34
|
coverageReporters: ['html-spa', 'text', 'json', 'cobertura', 'lcov'],
|
|
43
35
|
collectCoverageFrom: ['**/*.{ts,tsx}'],
|
|
36
|
+
preset: path.join(__dirname, '../../jest'),
|
|
44
37
|
};
|
|
45
38
|
};
|
|
46
39
|
|
|
@@ -70,7 +63,7 @@ export const getJestConfigCLI = (args: Config.Argv): Config.Argv => {
|
|
|
70
63
|
...args,
|
|
71
64
|
};
|
|
72
65
|
|
|
73
|
-
const { collectCoverageFrom, moduleNameMapper,
|
|
66
|
+
const { collectCoverageFrom, moduleNameMapper, ...rest } = getJestConfigBase({
|
|
74
67
|
coveragePathIgnorePatterns,
|
|
75
68
|
setupFiles,
|
|
76
69
|
testPathIgnorePatterns,
|
|
@@ -80,7 +73,6 @@ export const getJestConfigCLI = (args: Config.Argv): Config.Argv => {
|
|
|
80
73
|
collectCoverageFrom: JSON.stringify(collectCoverageFrom),
|
|
81
74
|
globals: JSON.stringify(globals),
|
|
82
75
|
moduleNameMapper: JSON.stringify(moduleNameMapper),
|
|
83
|
-
transform: JSON.stringify(transform),
|
|
84
76
|
...rest,
|
|
85
77
|
...config,
|
|
86
78
|
};
|
package/src/utils/index.ts
CHANGED
|
@@ -7,6 +7,7 @@ export * from './get-package-name';
|
|
|
7
7
|
export * from './get-packages';
|
|
8
8
|
export * from './get-startup-version';
|
|
9
9
|
export * from './get-tsconfig';
|
|
10
|
+
export * from './load-shared-dependencies';
|
|
10
11
|
export * from './log';
|
|
11
12
|
export * from './pick';
|
|
12
13
|
export * from './read-json';
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
const getDefaultSharedDependencies = () => ({
|
|
2
|
+
'@servicetitan/design-system': 'SharedDependencies.ServiceTitan.DesignSystem',
|
|
3
|
+
'@servicetitan/anvil2': 'SharedDependencies.ServiceTitan.Anvil2',
|
|
4
|
+
'classnames': 'SharedDependencies.ClassNames',
|
|
5
|
+
'formstate': 'SharedDependencies.FormState',
|
|
6
|
+
'mobx': 'SharedDependencies.MobX',
|
|
7
|
+
'mobx-react': 'SharedDependencies.MobXReact',
|
|
8
|
+
'mobx-utils': 'SharedDependencies.MobXUtils',
|
|
9
|
+
'react': 'SharedDependencies.React',
|
|
10
|
+
'react-dom': 'SharedDependencies.ReactDOM',
|
|
11
|
+
});
|
|
12
|
+
const defaultsKey = 'defaults';
|
|
13
|
+
|
|
14
|
+
export function loadSharedDependencies(
|
|
15
|
+
dependencies: Record<string, string> | undefined,
|
|
16
|
+
sharedDependencies: Record<string, string> | undefined
|
|
17
|
+
): Record<string, string> {
|
|
18
|
+
if (!dependencies) {
|
|
19
|
+
return {};
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
const out: Record<string, string> = {
|
|
23
|
+
...(!sharedDependencies || sharedDependencies[defaultsKey] !== undefined
|
|
24
|
+
? getDefaultSharedDependencies()
|
|
25
|
+
: {}),
|
|
26
|
+
...(sharedDependencies ?? {}),
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
delete out[defaultsKey];
|
|
30
|
+
|
|
31
|
+
for (const [dependency, value] of Object.entries(out)) {
|
|
32
|
+
if (!value || !dependencies[dependency]) {
|
|
33
|
+
delete out[dependency];
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
return out;
|
|
38
|
+
}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { loadSharedDependencies } from '@servicetitan/startup-utils';
|
|
2
1
|
import MiniCssExtractPlugin from 'mini-css-extract-plugin';
|
|
3
2
|
import { DefinePlugin } from 'webpack';
|
|
4
3
|
import {
|
|
@@ -9,15 +8,12 @@ import {
|
|
|
9
8
|
getTsConfig,
|
|
10
9
|
isCustomStyleRules,
|
|
11
10
|
isExposeSharedDependencies,
|
|
11
|
+
loadSharedDependencies,
|
|
12
12
|
} from '../../utils';
|
|
13
13
|
import { getModuleEntryPath } from '../utils';
|
|
14
14
|
|
|
15
15
|
import { createWebpackConfig } from '../index';
|
|
16
16
|
|
|
17
|
-
jest.mock('@servicetitan/startup-utils', () => ({
|
|
18
|
-
...jest.requireActual('@servicetitan/startup-utils'),
|
|
19
|
-
loadSharedDependencies: jest.fn(),
|
|
20
|
-
}));
|
|
21
17
|
jest.mock('mini-css-extract-plugin', () =>
|
|
22
18
|
Object.assign(jest.fn(), { loader: 'MiniCssExtractPlugin.loader' })
|
|
23
19
|
);
|
|
@@ -37,7 +33,6 @@ jest.mock('../../utils', () => ({
|
|
|
37
33
|
isCustomStyleRules: jest.fn(),
|
|
38
34
|
isExposeSharedDependencies: jest.fn(),
|
|
39
35
|
loadSharedDependencies: jest.fn(),
|
|
40
|
-
log: { debug: jest.fn(), info: jest.fn() },
|
|
41
36
|
}));
|
|
42
37
|
jest.mock('../utils', () => ({
|
|
43
38
|
...jest.requireActual('../utils'),
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { loadSharedDependencies } from '@servicetitan/startup-utils';
|
|
2
1
|
import CssMinimizerWebpackPlugin from 'css-minimizer-webpack-plugin';
|
|
3
2
|
import ForkTsCheckerWebpackPlugin from 'fork-ts-checker-webpack-plugin';
|
|
4
3
|
import HtmlWebpackPlugin from 'html-webpack-plugin';
|
|
@@ -28,6 +27,7 @@ import {
|
|
|
28
27
|
isCustomStyleRules,
|
|
29
28
|
isDevServerDisabled,
|
|
30
29
|
isWebComponent,
|
|
30
|
+
loadSharedDependencies,
|
|
31
31
|
log,
|
|
32
32
|
} from '../../utils';
|
|
33
33
|
import { createPackage } from '../../__mocks__';
|
|
@@ -36,10 +36,6 @@ import { featureCohort, splitByEntry } from '../utils';
|
|
|
36
36
|
|
|
37
37
|
import { createWebpackConfig } from '../index';
|
|
38
38
|
|
|
39
|
-
jest.mock('@servicetitan/startup-utils', () => ({
|
|
40
|
-
...jest.requireActual('@servicetitan/startup-utils'),
|
|
41
|
-
loadSharedDependencies: jest.fn(),
|
|
42
|
-
}));
|
|
43
39
|
jest.mock('fs', () => fs);
|
|
44
40
|
jest.mock('css-minimizer-webpack-plugin', () => jest.fn());
|
|
45
41
|
jest.mock('fork-ts-checker-webpack-plugin', () => jest.fn());
|
|
@@ -72,6 +68,7 @@ jest.mock('../../utils', () => ({
|
|
|
72
68
|
isDevServerDisabled: jest.fn(),
|
|
73
69
|
isExposeSharedDependencies: jest.fn(),
|
|
74
70
|
isWebComponent: jest.fn(),
|
|
71
|
+
loadSharedDependencies: jest.fn(),
|
|
75
72
|
log: { debug: jest.fn(), info: jest.fn(), warning: jest.fn() },
|
|
76
73
|
}));
|
|
77
74
|
jest.mock('../utils', () => ({
|
|
@@ -121,6 +118,7 @@ describe(`[startup] ${createWebpackConfig.name}`, () => {
|
|
|
121
118
|
configuration = {};
|
|
122
119
|
|
|
123
120
|
jest.resetAllMocks();
|
|
121
|
+
jest.mocked(log.debug).mockReturnValue({ enabled: false } as any);
|
|
124
122
|
jest.mocked(CssMinimizerWebpackPlugin).mockImplementation(
|
|
125
123
|
mockPlugIn('CssMinimizerWebpackPlugin')
|
|
126
124
|
);
|
|
@@ -334,10 +332,10 @@ describe(`[startup] ${createWebpackConfig.name}`, () => {
|
|
|
334
332
|
];
|
|
335
333
|
});
|
|
336
334
|
|
|
337
|
-
test('configures "watchOptions" to ignore TSC
|
|
335
|
+
test('configures "watchOptions" to ignore TSC source files', () => {
|
|
338
336
|
const ignored = packages
|
|
339
337
|
.filter(({ type }) => type === PackageType.TSC)
|
|
340
|
-
.map(({ location }) => location);
|
|
338
|
+
.map(({ location }) => path.join(location, getFolders(location).source));
|
|
341
339
|
expect(subject().watchOptions).toEqual({ ignored });
|
|
342
340
|
});
|
|
343
341
|
});
|
|
@@ -4,6 +4,7 @@ import { Configuration } from 'webpack';
|
|
|
4
4
|
import {
|
|
5
5
|
PackageType,
|
|
6
6
|
allowedWebpackDevServerOptions,
|
|
7
|
+
getFolders,
|
|
7
8
|
getPackageName,
|
|
8
9
|
getPackages,
|
|
9
10
|
getWebpackConfiguration,
|
|
@@ -77,7 +78,7 @@ function getDevServerConfig() {
|
|
|
77
78
|
function watchOptionsConfig(): WatchOptionsConfig {
|
|
78
79
|
const ignored = getPackages({ scope: getPackageName() })
|
|
79
80
|
.filter(({ type }) => type === PackageType.TSC)
|
|
80
|
-
.map(({ location }) => location);
|
|
81
|
+
.map(({ location }) => path.join(location, getFolders(location).source));
|
|
81
82
|
|
|
82
83
|
/*
|
|
83
84
|
* NOTE: Don't return empty ignored array. It triggered a bug that caused
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { getExposedDependencies } from '@servicetitan/startup-utils';
|
|
2
1
|
import { DefinePlugin } from 'webpack';
|
|
3
2
|
import { getPackageDependencyVersion } from '../../../utils';
|
|
4
3
|
import { Context, Overrides } from '../types';
|
|
@@ -9,12 +8,22 @@ export function defineExposedDependenciesPlugin(context: Context, _: Overrides)
|
|
|
9
8
|
return;
|
|
10
9
|
}
|
|
11
10
|
|
|
12
|
-
const exposedDependencies = getExposedDependencies(sharedDependencies, dependency =>
|
|
13
|
-
getPackageDependencyVersion(dependency, packageData.dependencies?.[dependency])
|
|
14
|
-
);
|
|
15
|
-
|
|
16
11
|
return new DefinePlugin({
|
|
17
12
|
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
18
|
-
EXPOSED_DEPENDENCIES: JSON.stringify(
|
|
13
|
+
EXPOSED_DEPENDENCIES: JSON.stringify(
|
|
14
|
+
Object.entries(sharedDependencies).reduce(
|
|
15
|
+
(result, [dependency, variable]) =>
|
|
16
|
+
Object.assign(result, {
|
|
17
|
+
[dependency]: {
|
|
18
|
+
version: getPackageDependencyVersion(
|
|
19
|
+
dependency,
|
|
20
|
+
packageData.dependencies?.[dependency]
|
|
21
|
+
),
|
|
22
|
+
variable,
|
|
23
|
+
},
|
|
24
|
+
}),
|
|
25
|
+
{}
|
|
26
|
+
)
|
|
27
|
+
),
|
|
19
28
|
});
|
|
20
29
|
}
|
|
@@ -16,7 +16,7 @@ const optionalAnvilPeerDependencies = ['@servicetitan/design-system', '@servicet
|
|
|
16
16
|
export function isOptionalAnvilPeerDependency({ context, packageContext, resource }: Dependency) {
|
|
17
17
|
return (
|
|
18
18
|
optionalAnvilPeerDependencies.includes(resource) &&
|
|
19
|
-
/(@servicetitan|packages)
|
|
19
|
+
/(@servicetitan|packages)[\\/](web-components)/.test(context) &&
|
|
20
20
|
!Object.keys(packageContext.packageData.dependencies).includes(resource)
|
|
21
21
|
);
|
|
22
22
|
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import path from 'path';
|
|
2
|
+
import { Compiler } from 'webpack';
|
|
3
|
+
|
|
4
|
+
import { log } from '../../../utils';
|
|
5
|
+
import { Context, Overrides } from '../types';
|
|
6
|
+
|
|
7
|
+
export function watchRunPlugin(_context: Context, _overrides: Overrides) {
|
|
8
|
+
/* istanbul ignore next: debug only */
|
|
9
|
+
if (log.debug('modified-files').enabled) {
|
|
10
|
+
return new WatchRunPlugin();
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
class WatchRunPlugin {
|
|
15
|
+
/* istanbul ignore next: debug only */
|
|
16
|
+
apply(compiler: Compiler) {
|
|
17
|
+
compiler.hooks.watchRun.tap('WatchRun', compilation => {
|
|
18
|
+
compilation.modifiedFiles?.forEach(file => {
|
|
19
|
+
log.debug('modified-files', path.relative('', file));
|
|
20
|
+
});
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
}
|
|
@@ -12,6 +12,7 @@ import {
|
|
|
12
12
|
provideReactPlugin,
|
|
13
13
|
tsCheckerPlugin,
|
|
14
14
|
virtualModulesPlugin,
|
|
15
|
+
watchRunPlugin,
|
|
15
16
|
} from './plugins';
|
|
16
17
|
import { Context, Overrides } from './types';
|
|
17
18
|
|
|
@@ -32,6 +33,7 @@ export function pluginsConfig(context: Context, overrides: Overrides): Result {
|
|
|
32
33
|
tsCheckerPlugin,
|
|
33
34
|
provideReactPlugin,
|
|
34
35
|
virtualModulesPlugin,
|
|
36
|
+
watchRunPlugin,
|
|
35
37
|
]
|
|
36
38
|
.map(fn => fn(context, overrides))
|
|
37
39
|
.filter(plugin => !!plugin);
|
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import { loadSharedDependencies } from '
|
|
2
|
-
import { getPackageData, MinifyOptions } from '../../utils';
|
|
1
|
+
import { getPackageData, loadSharedDependencies, MinifyOptions } from '../../utils';
|
|
3
2
|
import { Options } from '../types';
|
|
4
3
|
export { Overrides } from '../types';
|
|
5
4
|
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { loadSharedDependencies } from '@servicetitan/startup-utils';
|
|
2
1
|
import { Configuration } from 'webpack';
|
|
3
2
|
import { merge } from 'webpack-merge';
|
|
4
3
|
import { argv, Arguments } from 'yargs';
|
|
@@ -12,6 +11,7 @@ import {
|
|
|
12
11
|
isExposeSharedDependencies,
|
|
13
12
|
isLegacyRoot,
|
|
14
13
|
isWebComponent,
|
|
14
|
+
loadSharedDependencies,
|
|
15
15
|
log,
|
|
16
16
|
} from '../utils';
|
|
17
17
|
import {
|