@servicetitan/startup 36.3.1 → 37.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/bin/analyze.js +3 -0
- package/bin/vite.js +3 -0
- package/dist/cli/commands/build.d.ts.map +1 -1
- package/dist/cli/commands/build.js +13 -9
- package/dist/cli/commands/build.js.map +1 -1
- package/dist/cli/commands/bundle-vite.d.ts +6 -0
- package/dist/cli/commands/bundle-vite.d.ts.map +1 -0
- package/dist/cli/commands/bundle-vite.js +127 -0
- package/dist/cli/commands/bundle-vite.js.map +1 -0
- package/dist/cli/commands/bundle-webpack.d.ts +6 -0
- package/dist/cli/commands/bundle-webpack.d.ts.map +1 -0
- package/dist/cli/commands/{bundle-package.js → bundle-webpack.js} +8 -6
- package/dist/cli/commands/bundle-webpack.js.map +1 -0
- package/dist/cli/commands/install.d.ts.map +1 -1
- package/dist/cli/commands/install.js +2 -1
- package/dist/cli/commands/install.js.map +1 -1
- package/dist/cli/commands/mfe-check.d.ts.map +1 -1
- package/dist/cli/commands/mfe-check.js +2 -2
- package/dist/cli/commands/mfe-check.js.map +1 -1
- package/dist/cli/commands/mfe-generate-metadata.js +2 -2
- package/dist/cli/commands/mfe-generate-metadata.js.map +1 -1
- package/dist/cli/commands/mfe-list.js +1 -1
- package/dist/cli/commands/mfe-list.js.map +1 -1
- package/dist/cli/commands/mfe-package-publish.js.map +1 -1
- package/dist/cli/commands/mfe-publish.js +1 -1
- package/dist/cli/commands/mfe-publish.js.map +1 -1
- package/dist/cli/commands/registry/build.d.ts +14 -0
- package/dist/cli/commands/registry/build.d.ts.map +1 -1
- package/dist/cli/commands/registry/build.js +17 -0
- package/dist/cli/commands/registry/build.js.map +1 -1
- package/dist/cli/commands/registry/bundle-vite.d.ts +33 -0
- package/dist/cli/commands/registry/bundle-vite.d.ts.map +1 -0
- package/dist/cli/commands/registry/bundle-vite.js +45 -0
- package/dist/cli/commands/registry/bundle-vite.js.map +1 -0
- package/dist/cli/commands/registry/{bundle-package.d.ts → bundle-webpack.d.ts} +1 -1
- package/dist/cli/commands/registry/bundle-webpack.d.ts.map +1 -0
- package/dist/cli/commands/registry/{bundle-package.js → bundle-webpack.js} +1 -1
- package/dist/cli/commands/registry/{bundle-package.js.map → bundle-webpack.js.map} +1 -1
- package/dist/cli/commands/registry/command-registry.d.ts +57 -1
- package/dist/cli/commands/registry/command-registry.d.ts.map +1 -1
- package/dist/cli/commands/registry/command-registry.js +4 -2
- package/dist/cli/commands/registry/command-registry.js.map +1 -1
- package/dist/cli/commands/registry/start.d.ts +10 -0
- package/dist/cli/commands/registry/start.d.ts.map +1 -1
- package/dist/cli/commands/registry/start.js +13 -0
- package/dist/cli/commands/registry/start.js.map +1 -1
- package/dist/cli/commands/review/rules/index.d.ts.map +1 -1
- package/dist/cli/commands/review/rules/index.js +2 -0
- package/dist/cli/commands/review/rules/index.js.map +1 -1
- package/dist/cli/commands/review/rules/require-compatible-typescript.d.ts +13 -0
- package/dist/cli/commands/review/rules/require-compatible-typescript.d.ts.map +1 -0
- package/dist/cli/commands/review/rules/require-compatible-typescript.js +72 -0
- package/dist/cli/commands/review/rules/require-compatible-typescript.js.map +1 -0
- package/dist/cli/commands/start.d.ts.map +1 -1
- package/dist/cli/commands/start.js +11 -22
- package/dist/cli/commands/start.js.map +1 -1
- package/dist/cli/index.js +3 -2
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/tasks/swc-compile-package/swc-compile-package.d.ts.map +1 -1
- package/dist/cli/tasks/swc-compile-package/swc-compile-package.js +8 -3
- package/dist/cli/tasks/swc-compile-package/swc-compile-package.js.map +1 -1
- package/dist/cli/tasks/tsc-compile/tsc-compile.js +1 -1
- package/dist/cli/tasks/tsc-compile/tsc-compile.js.map +1 -1
- package/dist/cli/utils/copy-files.js +1 -0
- package/dist/cli/utils/copy-files.js.map +1 -1
- package/dist/cli/utils/get-bundle-command.d.ts +3 -0
- package/dist/cli/utils/get-bundle-command.d.ts.map +1 -0
- package/dist/cli/utils/get-bundle-command.js +16 -0
- package/dist/cli/utils/get-bundle-command.js.map +1 -0
- package/dist/cli/utils/get-exit-code.d.ts +12 -0
- package/dist/cli/utils/get-exit-code.d.ts.map +1 -0
- package/dist/cli/utils/get-exit-code.js +26 -0
- package/dist/cli/utils/get-exit-code.js.map +1 -0
- package/dist/cli/utils/index.d.ts +3 -1
- package/dist/cli/utils/index.d.ts.map +1 -1
- package/dist/cli/utils/index.js +3 -1
- package/dist/cli/utils/index.js.map +1 -1
- package/dist/cli/utils/resolve-bundler.d.ts +8 -0
- package/dist/cli/utils/resolve-bundler.d.ts.map +1 -0
- package/dist/cli/utils/resolve-bundler.js +24 -0
- package/dist/cli/utils/resolve-bundler.js.map +1 -0
- package/dist/core/bundle-report.d.ts +4 -0
- package/dist/core/bundle-report.d.ts.map +1 -0
- package/dist/core/bundle-report.js +43 -0
- package/dist/core/bundle-report.js.map +1 -0
- package/dist/core/check-resource/check-resource.d.ts +4 -0
- package/dist/core/check-resource/check-resource.d.ts.map +1 -0
- package/dist/core/check-resource/check-resource.js +51 -0
- package/dist/core/check-resource/check-resource.js.map +1 -0
- package/dist/core/check-resource/get-package-json.d.ts +10 -0
- package/dist/core/check-resource/get-package-json.d.ts.map +1 -0
- package/dist/{webpack/configs/plugins/ignore-plugin → core/check-resource}/get-package-json.js +12 -10
- package/dist/core/check-resource/get-package-json.js.map +1 -0
- package/dist/core/check-resource/get-peer-dependency-meta.d.ts +17 -0
- package/dist/core/check-resource/get-peer-dependency-meta.d.ts.map +1 -0
- package/dist/core/check-resource/get-peer-dependency-meta.js +73 -0
- package/dist/core/check-resource/get-peer-dependency-meta.js.map +1 -0
- package/dist/core/check-resource/index.d.ts +3 -0
- package/dist/core/check-resource/index.d.ts.map +1 -0
- package/dist/core/check-resource/index.js +13 -0
- package/dist/core/check-resource/index.js.map +1 -0
- package/dist/core/check-resource/is-managed-react-dom-client-dependency.d.ts +8 -0
- package/dist/core/check-resource/is-managed-react-dom-client-dependency.d.ts.map +1 -0
- package/dist/core/check-resource/is-managed-react-dom-client-dependency.js +15 -0
- package/dist/core/check-resource/is-managed-react-dom-client-dependency.js.map +1 -0
- package/dist/core/check-resource/is-resolvable.d.ts +7 -0
- package/dist/core/check-resource/is-resolvable.d.ts.map +1 -0
- package/dist/core/check-resource/is-resolvable.js +31 -0
- package/dist/core/check-resource/is-resolvable.js.map +1 -0
- package/dist/core/check-resource/types.d.ts +6 -0
- package/dist/core/check-resource/types.d.ts.map +1 -0
- package/dist/core/check-resource/types.js.map +1 -0
- package/dist/core/chunk-patterns.d.ts +7 -0
- package/dist/core/chunk-patterns.d.ts.map +1 -0
- package/dist/core/chunk-patterns.js +37 -0
- package/dist/core/chunk-patterns.js.map +1 -0
- package/dist/core/constants.d.ts +17 -0
- package/dist/core/constants.d.ts.map +1 -0
- package/dist/core/constants.js +28 -0
- package/dist/core/constants.js.map +1 -0
- package/dist/core/create-build-context.d.ts +13 -0
- package/dist/core/create-build-context.d.ts.map +1 -0
- package/dist/core/create-build-context.js +54 -0
- package/dist/core/create-build-context.js.map +1 -0
- package/dist/core/create-extension-regexp.d.ts +5 -0
- package/dist/core/create-extension-regexp.d.ts.map +1 -0
- package/dist/core/create-extension-regexp.js +45 -0
- package/dist/core/create-extension-regexp.js.map +1 -0
- package/dist/core/defines/define-exposed-dependencies.d.ts +5 -0
- package/dist/core/defines/define-exposed-dependencies.d.ts.map +1 -0
- package/dist/core/defines/define-exposed-dependencies.js +32 -0
- package/dist/core/defines/define-exposed-dependencies.js.map +1 -0
- package/dist/core/defines/define-exposed-instance-dependencies.d.ts +5 -0
- package/dist/core/defines/define-exposed-instance-dependencies.d.ts.map +1 -0
- package/dist/core/defines/define-exposed-instance-dependencies.js +29 -0
- package/dist/core/defines/define-exposed-instance-dependencies.js.map +1 -0
- package/dist/core/defines/define-web-component-name.d.ts +5 -0
- package/dist/core/defines/define-web-component-name.d.ts.map +1 -0
- package/dist/core/defines/define-web-component-name.js +23 -0
- package/dist/core/defines/define-web-component-name.js.map +1 -0
- package/dist/core/defines/index.d.ts +4 -0
- package/dist/core/defines/index.d.ts.map +1 -0
- package/dist/core/defines/index.js +26 -0
- package/dist/core/defines/index.js.map +1 -0
- package/dist/core/externals.d.ts +3 -0
- package/dist/core/externals.d.ts.map +1 -0
- package/dist/core/externals.js +28 -0
- package/dist/core/externals.js.map +1 -0
- package/dist/core/get-build-name.d.ts +2 -0
- package/dist/core/get-build-name.d.ts.map +1 -0
- package/dist/core/get-build-name.js +24 -0
- package/dist/core/get-build-name.js.map +1 -0
- package/dist/core/get-bundle-type.d.ts +3 -0
- package/dist/core/get-bundle-type.d.ts.map +1 -0
- package/dist/{webpack/configs/utils → core}/get-bundle-type.js +4 -2
- package/dist/core/get-bundle-type.js.map +1 -0
- package/dist/core/get-cdn-path.d.ts +3 -0
- package/dist/core/get-cdn-path.d.ts.map +1 -0
- package/dist/core/get-cdn-path.js +15 -0
- package/dist/core/get-cdn-path.js.map +1 -0
- package/dist/core/get-exposed-dependencies.d.ts.map +1 -0
- package/dist/core/get-exposed-dependencies.js.map +1 -0
- package/dist/core/get-process-env.d.ts +3 -0
- package/dist/core/get-process-env.d.ts.map +1 -0
- package/dist/core/get-process-env.js +25 -0
- package/dist/core/get-process-env.js.map +1 -0
- package/dist/core/get-shared-entry-points.d.ts +11 -0
- package/dist/core/get-shared-entry-points.d.ts.map +1 -0
- package/dist/core/get-shared-entry-points.js +43 -0
- package/dist/core/get-shared-entry-points.js.map +1 -0
- package/dist/core/get-version/get-launchdarkly-sdk-version.d.ts.map +1 -0
- package/dist/core/get-version/get-launchdarkly-sdk-version.js.map +1 -0
- package/dist/core/get-version/get-startup-version.d.ts.map +1 -0
- package/dist/{utils → core/get-version}/get-startup-version.js +2 -2
- package/dist/core/get-version/get-startup-version.js.map +1 -0
- package/dist/core/get-version/get-web-components-version.d.ts.map +1 -0
- package/dist/core/get-version/get-web-components-version.js.map +1 -0
- package/dist/core/get-version/index.d.ts +4 -0
- package/dist/core/get-version/index.d.ts.map +1 -0
- package/dist/core/get-version/index.js +22 -0
- package/dist/core/get-version/index.js.map +1 -0
- package/dist/core/index.d.ts +24 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +41 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/metadata/build-metadata.d.ts.map +1 -0
- package/dist/{webpack/configs/utils → core/metadata}/build-metadata.js +5 -6
- package/dist/core/metadata/build-metadata.js.map +1 -0
- package/dist/core/metadata/generate-exposed-dependencies-metadata.d.ts +3 -0
- package/dist/core/metadata/generate-exposed-dependencies-metadata.d.ts.map +1 -0
- package/dist/core/metadata/generate-exposed-dependencies-metadata.js +42 -0
- package/dist/core/metadata/generate-exposed-dependencies-metadata.js.map +1 -0
- package/dist/core/metadata/generate-metadata.d.ts +3 -0
- package/dist/core/metadata/generate-metadata.d.ts.map +1 -0
- package/dist/{webpack/configs/utils → core/metadata}/generate-metadata.js +5 -4
- package/dist/core/metadata/generate-metadata.js.map +1 -0
- package/dist/core/metadata/index.d.ts +4 -0
- package/dist/core/metadata/index.d.ts.map +1 -0
- package/dist/{webpack/configs/utils → core/metadata}/index.js +2 -2
- package/dist/core/metadata/index.js.map +1 -0
- package/dist/core/moment-locales.d.ts +2 -0
- package/dist/core/moment-locales.d.ts.map +1 -0
- package/dist/core/moment-locales.js +21 -0
- package/dist/core/moment-locales.js.map +1 -0
- package/dist/core/resolve-output-path.d.ts +3 -0
- package/dist/core/resolve-output-path.d.ts.map +1 -0
- package/dist/core/resolve-output-path.js +25 -0
- package/dist/core/resolve-output-path.js.map +1 -0
- package/dist/core/resolve-output-root.d.ts +3 -0
- package/dist/core/resolve-output-root.d.ts.map +1 -0
- package/dist/core/resolve-output-root.js +23 -0
- package/dist/core/resolve-output-root.js.map +1 -0
- package/dist/core/sort-shared-css.d.ts +2 -0
- package/dist/core/sort-shared-css.d.ts.map +1 -0
- package/dist/core/sort-shared-css.js +20 -0
- package/dist/core/sort-shared-css.js.map +1 -0
- package/dist/core/stringify-config.d.ts.map +1 -0
- package/dist/core/stringify-config.js.map +1 -0
- package/dist/core/types.d.ts +50 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +6 -0
- package/dist/core/types.js.map +1 -0
- package/dist/core/virtual-modules.d.ts +8 -0
- package/dist/core/virtual-modules.d.ts.map +1 -0
- package/dist/core/virtual-modules.js +83 -0
- package/dist/core/virtual-modules.js.map +1 -0
- package/dist/cypress/config/index.d.ts +1 -0
- package/dist/cypress/config/index.d.ts.map +1 -1
- package/dist/cypress/config/index.js +1 -0
- package/dist/cypress/config/index.js.map +1 -1
- package/dist/cypress/config/vite-config.d.ts +3 -0
- package/dist/cypress/config/vite-config.d.ts.map +1 -0
- package/dist/cypress/config/vite-config.js +58 -0
- package/dist/cypress/config/vite-config.js.map +1 -0
- package/dist/cypress/config/webpack-config.d.ts +1 -1
- package/dist/cypress/config/webpack-config.d.ts.map +1 -1
- package/dist/cypress/config/webpack-config.js +20 -8
- package/dist/cypress/config/webpack-config.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/storybook-config/index.d.ts +1 -0
- package/dist/storybook-config/index.d.ts.map +1 -1
- package/dist/storybook-config/index.js +1 -0
- package/dist/storybook-config/index.js.map +1 -1
- package/dist/storybook-config/vite-final.d.ts +7 -0
- package/dist/storybook-config/vite-final.d.ts.map +1 -0
- package/dist/storybook-config/vite-final.js +86 -0
- package/dist/storybook-config/vite-final.js.map +1 -0
- package/dist/storybook-config/webpack-final.d.ts +1 -1
- package/dist/storybook-config/webpack-final.d.ts.map +1 -1
- package/dist/storybook-config/webpack-final.js +18 -13
- package/dist/storybook-config/webpack-final.js.map +1 -1
- package/dist/utils/get-configuration.d.ts +47 -11
- package/dist/utils/get-configuration.d.ts.map +1 -1
- package/dist/utils/get-configuration.js +43 -9
- package/dist/utils/get-configuration.js.map +1 -1
- package/dist/utils/get-package-data.d.ts.map +1 -1
- package/dist/utils/get-package-data.js +3 -2
- package/dist/utils/get-package-data.js.map +1 -1
- package/dist/utils/get-package-name.d.ts +2 -1
- package/dist/utils/get-package-name.d.ts.map +1 -1
- package/dist/utils/get-package-name.js +4 -2
- package/dist/utils/get-package-name.js.map +1 -1
- package/dist/utils/get-packages.d.ts +1 -1
- package/dist/utils/get-packages.d.ts.map +1 -1
- package/dist/utils/get-packages.js +1 -1
- package/dist/utils/get-packages.js.map +1 -1
- package/dist/utils/index.d.ts +2 -1
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +1 -1
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/types.d.ts +2 -0
- package/dist/utils/types.d.ts.map +1 -0
- package/dist/utils/types.js +6 -0
- package/dist/utils/types.js.map +1 -0
- package/dist/utils/validate-shared-dependencies.d.ts +2 -0
- package/dist/utils/validate-shared-dependencies.d.ts.map +1 -0
- package/dist/utils/validate-shared-dependencies.js +30 -0
- package/dist/utils/validate-shared-dependencies.js.map +1 -0
- package/dist/vite/build-shared-dependencies.d.ts +3 -0
- package/dist/vite/build-shared-dependencies.d.ts.map +1 -0
- package/dist/vite/build-shared-dependencies.js +60 -0
- package/dist/vite/build-shared-dependencies.js.map +1 -0
- package/dist/vite/config/asset-file-names.d.ts +4 -0
- package/dist/vite/config/asset-file-names.d.ts.map +1 -0
- package/dist/vite/config/asset-file-names.js +29 -0
- package/dist/vite/config/asset-file-names.js.map +1 -0
- package/dist/vite/config/base-config.d.ts +4 -0
- package/dist/vite/config/base-config.d.ts.map +1 -0
- package/dist/vite/config/base-config.js +176 -0
- package/dist/vite/config/base-config.js.map +1 -0
- package/dist/vite/config/code-splitting.d.ts +4 -0
- package/dist/vite/config/code-splitting.d.ts.map +1 -0
- package/dist/vite/config/code-splitting.js +48 -0
- package/dist/vite/config/code-splitting.js.map +1 -0
- package/dist/vite/config/create-css-config.d.ts +3 -0
- package/dist/vite/config/create-css-config.d.ts.map +1 -0
- package/dist/vite/config/create-css-config.js +26 -0
- package/dist/vite/config/create-css-config.js.map +1 -0
- package/dist/vite/config/create-filtering-logger.d.ts +3 -0
- package/dist/vite/config/create-filtering-logger.d.ts.map +1 -0
- package/dist/vite/config/create-filtering-logger.js +37 -0
- package/dist/vite/config/create-filtering-logger.js.map +1 -0
- package/dist/vite/config/create-vite-build-context.d.ts +6 -0
- package/dist/vite/config/create-vite-build-context.d.ts.map +1 -0
- package/dist/vite/config/create-vite-build-context.js +43 -0
- package/dist/vite/config/create-vite-build-context.js.map +1 -0
- package/dist/vite/config/create-vite-config.d.ts +3 -0
- package/dist/vite/config/create-vite-config.d.ts.map +1 -0
- package/dist/vite/config/create-vite-config.js +60 -0
- package/dist/vite/config/create-vite-config.js.map +1 -0
- package/dist/vite/config/define-config.d.ts +13 -0
- package/dist/vite/config/define-config.d.ts.map +1 -0
- package/dist/vite/config/define-config.js +15 -0
- package/dist/vite/config/define-config.js.map +1 -0
- package/dist/vite/config/get-warmup-client-files.d.ts +3 -0
- package/dist/vite/config/get-warmup-client-files.d.ts.map +1 -0
- package/dist/vite/config/get-warmup-client-files.js +26 -0
- package/dist/vite/config/get-warmup-client-files.js.map +1 -0
- package/dist/vite/config/index.d.ts +6 -0
- package/dist/vite/config/index.d.ts.map +1 -0
- package/dist/vite/config/index.js +24 -0
- package/dist/vite/config/index.js.map +1 -0
- package/dist/vite/config/load-config-file.d.ts +4 -0
- package/dist/vite/config/load-config-file.d.ts.map +1 -0
- package/dist/vite/config/load-config-file.js +103 -0
- package/dist/vite/config/load-config-file.js.map +1 -0
- package/dist/vite/config/merge-vite-configs.d.ts +5 -0
- package/dist/vite/config/merge-vite-configs.d.ts.map +1 -0
- package/dist/vite/config/merge-vite-configs.js +17 -0
- package/dist/vite/config/merge-vite-configs.js.map +1 -0
- package/dist/vite/index.d.ts +2 -0
- package/dist/vite/index.d.ts.map +1 -0
- package/dist/vite/index.html +33 -0
- package/dist/vite/index.js +20 -0
- package/dist/vite/index.js.map +1 -0
- package/dist/vite/plugins/bundle-stat-plugin.d.ts +4 -0
- package/dist/vite/plugins/bundle-stat-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/bundle-stat-plugin.js +32 -0
- package/dist/vite/plugins/bundle-stat-plugin.js.map +1 -0
- package/dist/vite/plugins/chain-source-maps-plugin.d.ts +3 -0
- package/dist/vite/plugins/chain-source-maps-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/chain-source-maps-plugin.js +37 -0
- package/dist/vite/plugins/chain-source-maps-plugin.js.map +1 -0
- package/dist/vite/plugins/clean-plugin.d.ts +4 -0
- package/dist/vite/plugins/clean-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/clean-plugin.js +63 -0
- package/dist/vite/plugins/clean-plugin.js.map +1 -0
- package/dist/vite/plugins/css-injector-plugin.d.ts +4 -0
- package/dist/vite/plugins/css-injector-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/css-injector-plugin.js +42 -0
- package/dist/vite/plugins/css-injector-plugin.js.map +1 -0
- package/dist/vite/plugins/design-system-guard-plugin.d.ts +4 -0
- package/dist/vite/plugins/design-system-guard-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/design-system-guard-plugin.js +35 -0
- package/dist/vite/plugins/design-system-guard-plugin.js.map +1 -0
- package/dist/vite/plugins/dev-server-routing-plugin.d.ts +24 -0
- package/dist/vite/plugins/dev-server-routing-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/dev-server-routing-plugin.js +85 -0
- package/dist/vite/plugins/dev-server-routing-plugin.js.map +1 -0
- package/dist/vite/plugins/externals-plugin.d.ts +4 -0
- package/dist/vite/plugins/externals-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/externals-plugin.js +60 -0
- package/dist/vite/plugins/externals-plugin.js.map +1 -0
- package/dist/vite/plugins/html-plugin.d.ts +4 -0
- package/dist/vite/plugins/html-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/html-plugin.js +118 -0
- package/dist/vite/plugins/html-plugin.js.map +1 -0
- package/dist/vite/plugins/ignore-modules-plugin.d.ts +21 -0
- package/dist/vite/plugins/ignore-modules-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/ignore-modules-plugin.js +58 -0
- package/dist/vite/plugins/ignore-modules-plugin.js.map +1 -0
- package/dist/vite/plugins/index.d.ts +17 -0
- package/dist/vite/plugins/index.d.ts.map +1 -0
- package/dist/vite/plugins/index.js +35 -0
- package/dist/vite/plugins/index.js.map +1 -0
- package/dist/vite/plugins/istanbul-plugin.d.ts +4 -0
- package/dist/vite/plugins/istanbul-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/istanbul-plugin.js +27 -0
- package/dist/vite/plugins/istanbul-plugin.js.map +1 -0
- package/dist/vite/plugins/magic-comments-plugin/index.d.ts +2 -0
- package/dist/vite/plugins/magic-comments-plugin/index.d.ts.map +1 -0
- package/dist/vite/plugins/magic-comments-plugin/index.js +20 -0
- package/dist/vite/plugins/magic-comments-plugin/index.js.map +1 -0
- package/dist/vite/plugins/magic-comments-plugin/magic-comments-plugin.d.ts +4 -0
- package/dist/vite/plugins/magic-comments-plugin/magic-comments-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/magic-comments-plugin/magic-comments-plugin.js +63 -0
- package/dist/vite/plugins/magic-comments-plugin/magic-comments-plugin.js.map +1 -0
- package/dist/vite/plugins/magic-comments-plugin/parse-magic-comments.d.ts +6 -0
- package/dist/vite/plugins/magic-comments-plugin/parse-magic-comments.d.ts.map +1 -0
- package/dist/vite/plugins/magic-comments-plugin/parse-magic-comments.js +40 -0
- package/dist/vite/plugins/magic-comments-plugin/parse-magic-comments.js.map +1 -0
- package/dist/vite/plugins/metadata-plugin.d.ts +4 -0
- package/dist/vite/plugins/metadata-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/metadata-plugin.js +76 -0
- package/dist/vite/plugins/metadata-plugin.js.map +1 -0
- package/dist/vite/plugins/moment-locales-plugin.d.ts +5 -0
- package/dist/vite/plugins/moment-locales-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/moment-locales-plugin.js +50 -0
- package/dist/vite/plugins/moment-locales-plugin.js.map +1 -0
- package/dist/vite/plugins/shared-dependencies-plugin/assemble-iife.d.ts +14 -0
- package/dist/vite/plugins/shared-dependencies-plugin/assemble-iife.d.ts.map +1 -0
- package/dist/vite/plugins/shared-dependencies-plugin/assemble-iife.js +100 -0
- package/dist/vite/plugins/shared-dependencies-plugin/assemble-iife.js.map +1 -0
- package/dist/vite/plugins/shared-dependencies-plugin/assert-no-dynamic-css.d.ts +3 -0
- package/dist/vite/plugins/shared-dependencies-plugin/assert-no-dynamic-css.d.ts.map +1 -0
- package/dist/vite/plugins/shared-dependencies-plugin/assert-no-dynamic-css.js +56 -0
- package/dist/vite/plugins/shared-dependencies-plugin/assert-no-dynamic-css.js.map +1 -0
- package/dist/vite/plugins/shared-dependencies-plugin/flatten.d.ts +2 -0
- package/dist/vite/plugins/shared-dependencies-plugin/flatten.d.ts.map +1 -0
- package/dist/vite/plugins/shared-dependencies-plugin/flatten.js +19 -0
- package/dist/vite/plugins/shared-dependencies-plugin/flatten.js.map +1 -0
- package/dist/vite/plugins/shared-dependencies-plugin/index.d.ts +2 -0
- package/dist/vite/plugins/shared-dependencies-plugin/index.d.ts.map +1 -0
- package/dist/vite/plugins/shared-dependencies-plugin/index.js +20 -0
- package/dist/vite/plugins/shared-dependencies-plugin/index.js.map +1 -0
- package/dist/vite/plugins/shared-dependencies-plugin/shared-dependencies-plugin.d.ts +8 -0
- package/dist/vite/plugins/shared-dependencies-plugin/shared-dependencies-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/shared-dependencies-plugin/shared-dependencies-plugin.js +174 -0
- package/dist/vite/plugins/shared-dependencies-plugin/shared-dependencies-plugin.js.map +1 -0
- package/dist/vite/plugins/style-urls-plugin.d.ts +4 -0
- package/dist/vite/plugins/style-urls-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/style-urls-plugin.js +31 -0
- package/dist/vite/plugins/style-urls-plugin.js.map +1 -0
- package/dist/vite/plugins/svgr-plugin.d.ts +4 -0
- package/dist/vite/plugins/svgr-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/svgr-plugin.js +33 -0
- package/dist/vite/plugins/svgr-plugin.js.map +1 -0
- package/dist/vite/plugins/utils/get-css-file-names.d.ts +5 -0
- package/dist/vite/plugins/utils/get-css-file-names.d.ts.map +1 -0
- package/dist/vite/plugins/utils/get-css-file-names.js +21 -0
- package/dist/vite/plugins/utils/get-css-file-names.js.map +1 -0
- package/dist/vite/plugins/utils/import-esm.d.ts +2 -0
- package/dist/vite/plugins/utils/import-esm.d.ts.map +1 -0
- package/dist/vite/plugins/utils/import-esm.js +22 -0
- package/dist/vite/plugins/utils/import-esm.js.map +1 -0
- package/dist/vite/plugins/utils/index.d.ts +3 -0
- package/dist/vite/plugins/utils/index.d.ts.map +1 -0
- package/dist/vite/plugins/utils/index.js +21 -0
- package/dist/vite/plugins/utils/index.js.map +1 -0
- package/dist/vite/plugins/virtual-modules-plugin.d.ts +4 -0
- package/dist/vite/plugins/virtual-modules-plugin.d.ts.map +1 -0
- package/dist/vite/plugins/virtual-modules-plugin.js +54 -0
- package/dist/vite/plugins/virtual-modules-plugin.js.map +1 -0
- package/dist/vite/types.d.ts +4 -0
- package/dist/vite/types.d.ts.map +1 -0
- package/dist/vite/types.js +6 -0
- package/dist/vite/types.js.map +1 -0
- package/dist/vite/validate-shared-dependencies.d.ts +2 -0
- package/dist/vite/validate-shared-dependencies.d.ts.map +1 -0
- package/dist/vite/validate-shared-dependencies.js +27 -0
- package/dist/vite/validate-shared-dependencies.js.map +1 -0
- package/dist/webpack/bundle-webpack.d.ts +11 -0
- package/dist/webpack/bundle-webpack.d.ts.map +1 -0
- package/dist/webpack/bundle-webpack.js +107 -0
- package/dist/webpack/bundle-webpack.js.map +1 -0
- package/dist/webpack/configs/amd-config.d.ts +3 -2
- package/dist/webpack/configs/amd-config.d.ts.map +1 -1
- package/dist/webpack/configs/amd-config.js.map +1 -1
- package/dist/webpack/configs/cache-config.d.ts +3 -2
- package/dist/webpack/configs/cache-config.d.ts.map +1 -1
- package/dist/webpack/configs/cache-config.js +5 -18
- package/dist/webpack/configs/cache-config.js.map +1 -1
- package/dist/webpack/configs/dev-server-config.d.ts +2 -2
- package/dist/webpack/configs/dev-server-config.d.ts.map +1 -1
- package/dist/webpack/configs/dev-server-config.js +8 -8
- package/dist/webpack/configs/dev-server-config.js.map +1 -1
- package/dist/webpack/configs/devtool-config.d.ts +3 -2
- package/dist/webpack/configs/devtool-config.d.ts.map +1 -1
- package/dist/webpack/configs/devtool-config.js +1 -1
- package/dist/webpack/configs/devtool-config.js.map +1 -1
- package/dist/webpack/configs/entry.config.d.ts +3 -2
- package/dist/webpack/configs/entry.config.d.ts.map +1 -1
- package/dist/webpack/configs/entry.config.js +6 -5
- package/dist/webpack/configs/entry.config.js.map +1 -1
- package/dist/webpack/configs/externals-config.d.ts +3 -2
- package/dist/webpack/configs/externals-config.d.ts.map +1 -1
- package/dist/webpack/configs/externals-config.js +4 -14
- package/dist/webpack/configs/externals-config.js.map +1 -1
- package/dist/webpack/configs/index.d.ts +0 -1
- package/dist/webpack/configs/index.d.ts.map +1 -1
- package/dist/webpack/configs/index.js.map +1 -1
- package/dist/webpack/configs/loaders/css-loader.d.ts +3 -3
- package/dist/webpack/configs/loaders/css-loader.d.ts.map +1 -1
- package/dist/webpack/configs/loaders/css-loader.js +5 -4
- package/dist/webpack/configs/loaders/css-loader.js.map +1 -1
- package/dist/webpack/configs/loaders/style-loader.d.ts +2 -2
- package/dist/webpack/configs/loaders/style-loader.d.ts.map +1 -1
- package/dist/webpack/configs/loaders/style-loader.js +3 -1
- package/dist/webpack/configs/loaders/style-loader.js.map +1 -1
- package/dist/webpack/configs/module-config.d.ts +2 -2
- package/dist/webpack/configs/module-config.d.ts.map +1 -1
- package/dist/webpack/configs/module-config.js.map +1 -1
- package/dist/webpack/configs/optimization-config.d.ts +2 -2
- package/dist/webpack/configs/optimization-config.d.ts.map +1 -1
- package/dist/webpack/configs/optimization-config.js +62 -31
- package/dist/webpack/configs/optimization-config.js.map +1 -1
- package/dist/webpack/configs/output-config.d.ts +3 -2
- package/dist/webpack/configs/output-config.d.ts.map +1 -1
- package/dist/webpack/configs/output-config.js +10 -25
- package/dist/webpack/configs/output-config.js.map +1 -1
- package/dist/webpack/configs/plugins/assets-manifest-plugin.d.ts +3 -8
- package/dist/webpack/configs/plugins/assets-manifest-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/assets-manifest-plugin.js +21 -50
- package/dist/webpack/configs/plugins/assets-manifest-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/bundle-analyser-plugin.d.ts +3 -2
- package/dist/webpack/configs/plugins/bundle-analyser-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/bundle-analyser-plugin.js +4 -23
- package/dist/webpack/configs/plugins/bundle-analyser-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/define-exposed-dependencies-plugin.d.ts +3 -2
- package/dist/webpack/configs/plugins/define-exposed-dependencies-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/define-exposed-dependencies-plugin.js +4 -17
- package/dist/webpack/configs/plugins/define-exposed-dependencies-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/define-exposed-instance-dependencies-plugin.d.ts +3 -2
- package/dist/webpack/configs/plugins/define-exposed-instance-dependencies-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/define-exposed-instance-dependencies-plugin.js +4 -12
- package/dist/webpack/configs/plugins/define-exposed-instance-dependencies-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/define-process-env-plugin.d.ts +5 -0
- package/dist/webpack/configs/plugins/define-process-env-plugin.d.ts.map +1 -0
- package/dist/webpack/configs/plugins/define-process-env-plugin.js +20 -0
- package/dist/webpack/configs/plugins/define-process-env-plugin.js.map +1 -0
- package/dist/webpack/configs/plugins/define-web-component-name-plugin.d.ts +3 -2
- package/dist/webpack/configs/plugins/define-web-component-name-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/define-web-component-name-plugin.js +4 -6
- package/dist/webpack/configs/plugins/define-web-component-name-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/filter-warnings-plugin.d.ts +3 -2
- package/dist/webpack/configs/plugins/filter-warnings-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/filter-warnings-plugin.js +2 -2
- package/dist/webpack/configs/plugins/filter-warnings-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/html-plugin.d.ts +3 -2
- package/dist/webpack/configs/plugins/html-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/html-plugin.js +4 -2
- package/dist/webpack/configs/plugins/html-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/html-tags-plugin.d.ts +3 -2
- package/dist/webpack/configs/plugins/html-tags-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/html-tags-plugin.js +16 -21
- package/dist/webpack/configs/plugins/html-tags-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/ignore-plugin/empty-module.d.ts +2 -0
- package/dist/webpack/configs/plugins/ignore-plugin/empty-module.d.ts.map +1 -0
- package/dist/webpack/configs/plugins/ignore-plugin/empty-module.js +11 -0
- package/dist/webpack/configs/plugins/ignore-plugin/empty-module.js.map +1 -0
- package/dist/webpack/configs/plugins/ignore-plugin/ignore-plugin.d.ts +27 -3
- package/dist/webpack/configs/plugins/ignore-plugin/ignore-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/ignore-plugin/ignore-plugin.js +42 -10
- package/dist/webpack/configs/plugins/ignore-plugin/ignore-plugin.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/mini-css-extract-plugin.d.ts +2 -2
- package/dist/webpack/configs/plugins/mini-css-extract-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/mini-css-extract-plugin.js +4 -2
- package/dist/webpack/configs/plugins/mini-css-extract-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/moment-locales-plugin.d.ts +3 -2
- package/dist/webpack/configs/plugins/moment-locales-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/moment-locales-plugin.js +2 -5
- package/dist/webpack/configs/plugins/moment-locales-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/remove-empty-scripts-plugin.d.ts +3 -2
- package/dist/webpack/configs/plugins/remove-empty-scripts-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/remove-empty-scripts-plugin.js +1 -1
- package/dist/webpack/configs/plugins/remove-empty-scripts-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/virtual-modules-plugin.d.ts +3 -3
- package/dist/webpack/configs/plugins/virtual-modules-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/virtual-modules-plugin.js +13 -56
- package/dist/webpack/configs/plugins/virtual-modules-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/watch-run-plugin.d.ts +3 -2
- package/dist/webpack/configs/plugins/watch-run-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/watch-run-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins-config.d.ts +3 -2
- 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/resolve-config.d.ts +3 -2
- package/dist/webpack/configs/resolve-config.d.ts.map +1 -1
- package/dist/webpack/configs/resolve-config.js +2 -1
- package/dist/webpack/configs/resolve-config.js.map +1 -1
- package/dist/webpack/configs/rules/css-rules.d.ts +2 -2
- package/dist/webpack/configs/rules/css-rules.d.ts.map +1 -1
- package/dist/webpack/configs/rules/css-rules.js +2 -1
- package/dist/webpack/configs/rules/css-rules.js.map +1 -1
- package/dist/webpack/configs/rules/font-rules.d.ts +2 -2
- package/dist/webpack/configs/rules/font-rules.d.ts.map +1 -1
- package/dist/webpack/configs/rules/font-rules.js +2 -1
- package/dist/webpack/configs/rules/font-rules.js.map +1 -1
- package/dist/webpack/configs/rules/image-rules.d.ts +2 -2
- package/dist/webpack/configs/rules/image-rules.d.ts.map +1 -1
- package/dist/webpack/configs/rules/image-rules.js +2 -1
- package/dist/webpack/configs/rules/image-rules.js.map +1 -1
- package/dist/webpack/configs/rules/js-rules.d.ts +2 -2
- package/dist/webpack/configs/rules/js-rules.d.ts.map +1 -1
- package/dist/webpack/configs/rules/js-rules.js +2 -1
- package/dist/webpack/configs/rules/js-rules.js.map +1 -1
- package/dist/webpack/configs/rules/less-rules.d.ts +2 -2
- package/dist/webpack/configs/rules/less-rules.d.ts.map +1 -1
- package/dist/webpack/configs/rules/less-rules.js.map +1 -1
- package/dist/webpack/configs/rules/scss-rules.d.ts +2 -2
- package/dist/webpack/configs/rules/scss-rules.d.ts.map +1 -1
- package/dist/webpack/configs/rules/scss-rules.js.map +1 -1
- package/dist/webpack/configs/rules/svg-rules.d.ts +2 -2
- package/dist/webpack/configs/rules/svg-rules.d.ts.map +1 -1
- package/dist/webpack/configs/rules/svg-rules.js.map +1 -1
- package/dist/webpack/configs/rules-config.d.ts +2 -2
- package/dist/webpack/configs/rules-config.d.ts.map +1 -1
- package/dist/webpack/configs/rules-config.js +2 -2
- package/dist/webpack/configs/rules-config.js.map +1 -1
- package/dist/webpack/configs/stats-config.d.ts +3 -2
- package/dist/webpack/configs/stats-config.d.ts.map +1 -1
- package/dist/webpack/configs/stats-config.js.map +1 -1
- package/dist/webpack/configs/watch-options-config.d.ts +2 -2
- package/dist/webpack/configs/watch-options-config.d.ts.map +1 -1
- package/dist/webpack/configs/watch-options-config.js +2 -2
- package/dist/webpack/configs/watch-options-config.js.map +1 -1
- package/dist/webpack/create-webpack-config.d.ts +2 -0
- package/dist/webpack/create-webpack-config.d.ts.map +1 -1
- package/dist/webpack/create-webpack-config.js +43 -49
- package/dist/webpack/create-webpack-config.js.map +1 -1
- package/dist/webpack/create-webpack-configs.d.ts +16 -0
- package/dist/webpack/create-webpack-configs.d.ts.map +1 -0
- package/dist/webpack/create-webpack-configs.js +80 -0
- package/dist/webpack/create-webpack-configs.js.map +1 -0
- package/dist/webpack/index.d.ts +2 -0
- package/dist/webpack/index.d.ts.map +1 -1
- package/dist/webpack/index.js +2 -0
- package/dist/webpack/index.js.map +1 -1
- package/dist/webpack/types.d.ts +4 -11
- package/dist/webpack/types.d.ts.map +1 -1
- package/dist/webpack/utils/create-webpack-build-context.d.ts +4 -0
- package/dist/webpack/utils/create-webpack-build-context.d.ts.map +1 -0
- package/dist/webpack/utils/create-webpack-build-context.js +20 -0
- package/dist/webpack/utils/create-webpack-build-context.js.map +1 -0
- package/dist/webpack/utils/index.d.ts +1 -1
- package/dist/webpack/utils/index.d.ts.map +1 -1
- package/dist/webpack/utils/index.js +1 -1
- package/dist/webpack/utils/index.js.map +1 -1
- package/jest/babel-plugin-import-meta-env.js +18 -0
- package/jest/jest-preset.js +5 -2
- package/package.json +40 -28
- package/src/cli/commands/__tests__/build.test.ts +35 -7
- package/src/cli/commands/__tests__/bundle-vite.test.ts +277 -0
- package/src/cli/commands/__tests__/{bundle-package.test.ts → bundle-webpack.test.ts} +26 -17
- package/src/cli/commands/__tests__/install.test.ts +6 -2
- package/src/cli/commands/__tests__/mfe-generate-metadata.test.ts +13 -10
- package/src/cli/commands/__tests__/mfe-publish.test.ts +4 -4
- package/src/cli/commands/__tests__/start.test.ts +18 -5
- package/src/cli/commands/build.ts +14 -12
- package/src/cli/commands/bundle-vite.ts +95 -0
- package/src/cli/commands/{bundle-package.ts → bundle-webpack.ts} +9 -6
- package/src/cli/commands/install.ts +2 -1
- package/src/cli/commands/mfe-check.ts +1 -2
- package/src/cli/commands/mfe-generate-metadata.ts +1 -1
- package/src/cli/commands/mfe-list.ts +1 -1
- package/src/cli/commands/mfe-package-publish.ts +1 -1
- package/src/cli/commands/mfe-publish.ts +1 -1
- package/src/cli/commands/registry/__tests__/command-registry.test.ts +1 -0
- package/src/cli/commands/registry/build.ts +7 -0
- package/src/cli/commands/registry/bundle-vite.ts +14 -0
- package/src/cli/commands/registry/command-registry.ts +4 -2
- package/src/cli/commands/registry/start.ts +6 -0
- package/src/cli/commands/review/rules/__tests__/require-compatible-typescript.test.ts +127 -0
- package/src/cli/commands/review/rules/index.ts +2 -0
- package/src/cli/commands/review/rules/require-compatible-typescript.ts +64 -0
- package/src/cli/commands/start.ts +15 -29
- package/src/cli/index.ts +4 -3
- package/src/cli/tasks/swc-compile-package/__tests__/swc-compile-package.test.ts +21 -1
- package/src/cli/tasks/swc-compile-package/swc-cli.d.ts +1 -1
- package/src/cli/tasks/swc-compile-package/swc-compile-package.ts +9 -3
- package/src/cli/tasks/tsc-compile/tsc-compile.ts +1 -1
- package/src/cli/utils/__tests__/get-bundle-command.test.ts +23 -0
- package/src/cli/utils/__tests__/get-exit-code.test.ts +41 -0
- package/src/cli/utils/__tests__/resolve-bundler.test.ts +64 -0
- package/src/cli/utils/copy-files.ts +1 -1
- package/src/cli/utils/get-bundle-command.ts +5 -0
- package/src/cli/utils/get-exit-code.ts +17 -0
- package/src/cli/utils/index.ts +3 -1
- package/src/cli/utils/resolve-bundler.ts +23 -0
- package/src/core/__tests__/bundle-report.test.ts +60 -0
- package/src/core/__tests__/create-extension-regexp.test.ts +32 -0
- package/src/core/__tests__/get-cdn-path.test.ts +27 -0
- package/src/core/__tests__/resolve-output-path.test.ts +45 -0
- package/src/core/__tests__/resolve-output-root.test.ts +37 -0
- package/src/core/__tests__/sort-shared-css.test.ts +39 -0
- package/src/core/bundle-report.ts +33 -0
- package/src/core/check-resource/__tests__/check-resource.test.ts +72 -0
- package/src/{webpack/configs/plugins/ignore-plugin → core/check-resource}/__tests__/get-package-json.test.ts +2 -1
- package/src/core/check-resource/__tests__/get-peer-dependency-meta.test.ts +108 -0
- package/src/core/check-resource/__tests__/is-managed-react-dom-client-dependency.test.ts +35 -0
- package/src/core/check-resource/__tests__/is-resolvable.test.ts +20 -0
- package/src/core/check-resource/check-resource.ts +31 -0
- package/src/core/check-resource/get-package-json.ts +33 -0
- package/src/core/check-resource/get-peer-dependency-meta.ts +78 -0
- package/src/core/check-resource/index.ts +2 -0
- package/src/core/check-resource/is-managed-react-dom-client-dependency.ts +13 -0
- package/src/core/check-resource/is-resolvable.ts +19 -0
- package/src/core/check-resource/types.ts +6 -0
- package/src/core/chunk-patterns.ts +30 -0
- package/src/core/constants.ts +16 -0
- package/src/core/create-build-context.ts +61 -0
- package/src/core/create-extension-regexp.ts +7 -0
- package/src/core/defines/define-exposed-dependencies.ts +25 -0
- package/src/core/defines/define-exposed-instance-dependencies.ts +19 -0
- package/src/core/defines/define-web-component-name.ts +15 -0
- package/src/core/defines/index.ts +3 -0
- package/src/core/externals.ts +22 -0
- package/src/core/get-build-name.ts +11 -0
- package/src/core/get-bundle-type.ts +19 -0
- package/src/core/get-cdn-path.ts +5 -0
- package/src/core/get-process-env.ts +17 -0
- package/src/core/get-shared-entry-points.ts +37 -0
- package/src/core/get-version/get-startup-version.ts +6 -0
- package/src/core/get-version/index.ts +3 -0
- package/src/core/index.ts +23 -0
- package/src/{webpack/configs/utils → core/metadata}/__tests__/build-metadata.test.ts +10 -6
- package/src/{webpack/configs/utils → core/metadata}/__tests__/generate-metadata.test.ts +25 -13
- package/src/{webpack/configs/utils → core/metadata}/build-metadata.ts +6 -3
- package/src/core/metadata/generate-exposed-dependencies-metadata.ts +20 -0
- package/src/{webpack/configs/utils → core/metadata}/generate-metadata.ts +8 -6
- package/src/core/metadata/index.ts +3 -0
- package/src/core/moment-locales.ts +6 -0
- package/src/core/resolve-output-path.ts +10 -0
- package/src/core/resolve-output-root.ts +8 -0
- package/src/core/sort-shared-css.ts +7 -0
- package/src/core/types.ts +54 -0
- package/src/core/virtual-modules.ts +74 -0
- package/src/cypress/config/__tests__/vite-config.test.ts +72 -0
- package/src/cypress/config/__tests__/webpack-config.test.ts +4 -3
- package/src/cypress/config/index.ts +1 -0
- package/src/cypress/config/vite-config.ts +37 -0
- package/src/cypress/config/webpack-config.ts +24 -11
- package/src/index.ts +1 -0
- package/src/storybook-config/__tests__/vite-final.test.ts +122 -0
- package/src/storybook-config/__tests__/webpack-final.test.ts +5 -27
- package/src/storybook-config/index.ts +1 -0
- package/src/storybook-config/vite-final.ts +65 -0
- package/src/storybook-config/webpack-final.ts +23 -15
- package/src/utils/__tests__/get-configuration.test.ts +109 -11
- package/src/utils/__tests__/get-package-data.test.ts +35 -1
- package/src/utils/__tests__/get-package-name.test.ts +57 -0
- package/src/utils/__tests__/get-packages.test.ts +4 -4
- package/src/utils/__tests__/validate-shared-dependencies.test.ts +70 -0
- package/src/utils/get-configuration.ts +96 -17
- package/src/utils/get-package-data.ts +3 -1
- package/src/utils/get-package-name.ts +8 -2
- package/src/utils/get-packages.ts +2 -2
- package/src/utils/index.ts +2 -1
- package/src/utils/types.ts +1 -0
- package/src/utils/validate-shared-dependencies.ts +46 -0
- package/src/vite/__tests__/build-shared-dependencies.test.ts +234 -0
- package/src/vite/__tests__/validate-shared-dependencies.test.ts +45 -0
- package/src/vite/build-shared-dependencies.ts +52 -0
- package/src/vite/config/__tests__/asset-file-names.test.ts +40 -0
- package/src/vite/config/__tests__/base-config.test.ts +377 -0
- package/src/vite/config/__tests__/code-splitting.test.ts +34 -0
- package/src/vite/config/__tests__/create-css-config.test.ts +58 -0
- package/src/vite/config/__tests__/create-filtering-logger.test.ts +51 -0
- package/src/vite/config/__tests__/create-vite-build-context.test.ts +89 -0
- package/src/vite/config/__tests__/create-vite-config.test.ts +219 -0
- package/src/vite/config/__tests__/define-config.test.ts +23 -0
- package/src/vite/config/__tests__/get-warmup-client-files.test.ts +20 -0
- package/src/vite/config/__tests__/load-config-file.test.ts +191 -0
- package/src/vite/config/__tests__/merge-vite-configs.test.ts +84 -0
- package/src/vite/config/asset-file-names.ts +20 -0
- package/src/vite/config/base-config.ts +145 -0
- package/src/vite/config/code-splitting.ts +23 -0
- package/src/vite/config/create-css-config.ts +16 -0
- package/src/vite/config/create-filtering-logger.ts +34 -0
- package/src/vite/config/create-vite-build-context.ts +43 -0
- package/src/vite/config/create-vite-config.ts +66 -0
- package/src/vite/config/define-config.ts +18 -0
- package/src/vite/config/get-warmup-client-files.ts +13 -0
- package/src/vite/config/index.ts +5 -0
- package/src/vite/config/load-config-file.ts +52 -0
- package/src/vite/config/merge-vite-configs.ts +15 -0
- package/src/vite/index.html +33 -0
- package/src/vite/index.ts +1 -0
- package/src/vite/plugins/__tests__/bundle-stat-plugin.test.ts +70 -0
- package/src/vite/plugins/__tests__/chain-source-maps-plugin.test.ts +58 -0
- package/src/vite/plugins/__tests__/clean-plugin.test.ts +121 -0
- package/src/vite/plugins/__tests__/css-injector-plugin.test.ts +119 -0
- package/src/vite/plugins/__tests__/design-system-guard-plugin.test.ts +83 -0
- package/src/vite/plugins/__tests__/dev-server-routing-plugin.test.ts +255 -0
- package/src/vite/plugins/__tests__/externals-plugin.test.ts +138 -0
- package/src/vite/plugins/__tests__/html-plugin.test.ts +360 -0
- package/src/vite/plugins/__tests__/html-template.test.ts +103 -0
- package/src/vite/plugins/__tests__/ignore-modules-plugin.test.ts +107 -0
- package/src/vite/plugins/__tests__/istanbul-plugin.test.ts +62 -0
- package/src/vite/plugins/__tests__/metadata-plugin.test.ts +163 -0
- package/src/vite/plugins/__tests__/moment-locales-plugin.test.ts +104 -0
- package/src/vite/plugins/__tests__/style-urls-plugin.test.ts +77 -0
- package/src/vite/plugins/__tests__/svgr-plugin.test.ts +67 -0
- package/src/vite/plugins/__tests__/virtual-modules-plugin.test.ts +101 -0
- package/src/vite/plugins/bundle-stat-plugin.ts +24 -0
- package/src/vite/plugins/chain-source-maps-plugin.ts +26 -0
- package/src/vite/plugins/clean-plugin.ts +46 -0
- package/src/vite/plugins/css-injector-plugin.ts +65 -0
- package/src/vite/plugins/design-system-guard-plugin.ts +34 -0
- package/src/vite/plugins/dev-server-routing-plugin.ts +96 -0
- package/src/vite/plugins/externals-plugin.ts +81 -0
- package/src/vite/plugins/html-plugin.ts +111 -0
- package/src/vite/plugins/ignore-modules-plugin.ts +51 -0
- package/src/vite/plugins/index.ts +16 -0
- package/src/vite/plugins/istanbul-plugin.ts +19 -0
- package/src/vite/plugins/magic-comments-plugin/__tests__/magic-comments-plugin.test.ts +105 -0
- package/src/vite/plugins/magic-comments-plugin/__tests__/parse-magic-comments.test.ts +40 -0
- package/src/vite/plugins/magic-comments-plugin/index.ts +1 -0
- package/src/vite/plugins/magic-comments-plugin/magic-comments-plugin.ts +63 -0
- package/src/vite/plugins/magic-comments-plugin/parse-magic-comments.ts +39 -0
- package/src/vite/plugins/metadata-plugin.ts +65 -0
- package/src/vite/plugins/moment-locales-plugin.ts +41 -0
- package/src/vite/plugins/shared-dependencies-plugin/__tests__/assemble-iife.test.ts +29 -0
- package/src/vite/plugins/shared-dependencies-plugin/__tests__/assert-no-dynamic-css.test.ts +113 -0
- package/src/vite/plugins/shared-dependencies-plugin/__tests__/flatten.test.ts +23 -0
- package/src/vite/plugins/shared-dependencies-plugin/__tests__/shared-dependencies-plugin.test.ts +461 -0
- package/src/vite/plugins/shared-dependencies-plugin/assemble-iife.ts +114 -0
- package/src/vite/plugins/shared-dependencies-plugin/assert-no-dynamic-css.ts +58 -0
- package/src/vite/plugins/shared-dependencies-plugin/flatten.ts +8 -0
- package/src/vite/plugins/shared-dependencies-plugin/index.ts +1 -0
- package/src/vite/plugins/shared-dependencies-plugin/shared-dependencies-plugin.ts +182 -0
- package/src/vite/plugins/style-urls-plugin.ts +21 -0
- package/src/vite/plugins/svgr-plugin.ts +17 -0
- package/src/vite/plugins/utils/get-css-file-names.ts +11 -0
- package/src/vite/plugins/utils/import-esm.ts +15 -0
- package/src/vite/plugins/utils/index.ts +2 -0
- package/src/vite/plugins/virtual-modules-plugin.ts +46 -0
- package/src/vite/rolldown-oxc.d.ts +20 -0
- package/src/vite/types.ts +6 -0
- package/src/vite/validate-shared-dependencies.ts +27 -0
- package/src/webpack/__mocks__/style-rules.ts +15 -3
- package/src/{cli/utils/__tests__/bundle.test.ts → webpack/__tests__/bundle-webpack.test.ts} +33 -26
- package/src/webpack/__tests__/create-webpack-config-shared-dependencies.test.ts +91 -16
- package/src/webpack/__tests__/create-webpack-config-web-component.test.ts +85 -26
- package/src/webpack/__tests__/create-webpack-config.test.ts +97 -13
- package/src/webpack/bundle-webpack.ts +107 -0
- package/src/webpack/configs/amd-config.ts +3 -2
- package/src/webpack/configs/cache-config.ts +7 -15
- package/src/webpack/configs/dev-server-config.ts +16 -17
- package/src/webpack/configs/devtool-config.ts +4 -3
- package/src/webpack/configs/entry.config.ts +8 -7
- package/src/webpack/configs/externals-config.ts +5 -21
- package/src/webpack/configs/index.ts +0 -1
- package/src/webpack/configs/loaders/css-loader.ts +7 -3
- package/src/webpack/configs/loaders/style-loader.ts +4 -5
- package/src/webpack/configs/module-config.ts +2 -2
- package/src/webpack/configs/optimization-config.ts +64 -36
- package/src/webpack/configs/output-config.ts +12 -24
- package/src/webpack/configs/plugins/assets-manifest-plugin.ts +24 -39
- package/src/webpack/configs/plugins/bundle-analyser-plugin.ts +6 -28
- package/src/webpack/configs/plugins/define-exposed-dependencies-plugin.ts +7 -18
- package/src/webpack/configs/plugins/define-exposed-instance-dependencies-plugin.ts +7 -13
- package/src/webpack/configs/plugins/define-process-env-plugin.ts +10 -0
- package/src/webpack/configs/plugins/define-web-component-name-plugin.ts +7 -8
- package/src/webpack/configs/plugins/filter-warnings-plugin.ts +4 -3
- package/src/webpack/configs/plugins/html-plugin.ts +6 -6
- package/src/webpack/configs/plugins/html-tags-plugin.ts +10 -17
- package/src/webpack/configs/plugins/ignore-plugin/__tests__/ignore-plugin.test.ts +119 -0
- package/src/webpack/configs/plugins/ignore-plugin/empty-module.ts +7 -0
- package/src/webpack/configs/plugins/ignore-plugin/ignore-plugin.ts +62 -12
- package/src/webpack/configs/plugins/index.ts +1 -0
- package/src/webpack/configs/plugins/mini-css-extract-plugin.ts +9 -5
- package/src/webpack/configs/plugins/moment-locales-plugin.ts +4 -3
- package/src/webpack/configs/plugins/remove-empty-scripts-plugin.ts +4 -3
- package/src/webpack/configs/plugins/virtual-modules-plugin.ts +11 -65
- package/src/webpack/configs/plugins/watch-run-plugin.ts +3 -2
- package/src/webpack/configs/plugins-config.ts +5 -2
- package/src/webpack/configs/resolve-config.ts +4 -2
- package/src/webpack/configs/rules/css-rules.ts +4 -3
- package/src/webpack/configs/rules/font-rules.ts +3 -3
- package/src/webpack/configs/rules/image-rules.ts +3 -3
- package/src/webpack/configs/rules/js-rules.ts +3 -2
- package/src/webpack/configs/rules/less-rules.ts +2 -2
- package/src/webpack/configs/rules/scss-rules.ts +2 -2
- package/src/webpack/configs/rules/svg-rules.ts +2 -2
- package/src/webpack/configs/rules-config.ts +6 -5
- package/src/webpack/configs/stats-config.ts +3 -2
- package/src/webpack/configs/watch-options-config.ts +3 -3
- package/src/webpack/create-webpack-config.ts +28 -53
- package/src/webpack/create-webpack-configs.ts +77 -0
- package/src/webpack/index.ts +2 -0
- package/src/webpack/types.ts +8 -11
- package/src/webpack/utils/__tests__/split-by-entry.test.ts +33 -0
- package/src/webpack/utils/create-webpack-build-context.ts +7 -0
- package/src/webpack/utils/index.ts +1 -1
- package/tsconfig/base.json +1 -1
- package/tsconfig/types.d.ts +10 -0
- package/dist/cli/commands/bundle-package.d.ts +0 -6
- package/dist/cli/commands/bundle-package.d.ts.map +0 -1
- package/dist/cli/commands/bundle-package.js.map +0 -1
- package/dist/cli/commands/registry/bundle-package.d.ts.map +0 -1
- package/dist/cli/utils/bundle.d.ts +0 -14
- package/dist/cli/utils/bundle.d.ts.map +0 -1
- package/dist/cli/utils/bundle.js +0 -187
- package/dist/cli/utils/bundle.js.map +0 -1
- package/dist/utils/get-startup-version.d.ts.map +0 -1
- package/dist/utils/get-startup-version.js.map +0 -1
- package/dist/webpack/configs/plugins/ignore-plugin/check-resource.d.ts +0 -3
- package/dist/webpack/configs/plugins/ignore-plugin/check-resource.d.ts.map +0 -1
- package/dist/webpack/configs/plugins/ignore-plugin/check-resource.js +0 -40
- package/dist/webpack/configs/plugins/ignore-plugin/check-resource.js.map +0 -1
- package/dist/webpack/configs/plugins/ignore-plugin/get-package-json.d.ts +0 -2
- package/dist/webpack/configs/plugins/ignore-plugin/get-package-json.d.ts.map +0 -1
- package/dist/webpack/configs/plugins/ignore-plugin/get-package-json.js.map +0 -1
- package/dist/webpack/configs/plugins/ignore-plugin/is-optional-peer-dependency.d.ts +0 -2
- package/dist/webpack/configs/plugins/ignore-plugin/is-optional-peer-dependency.d.ts.map +0 -1
- package/dist/webpack/configs/plugins/ignore-plugin/is-optional-peer-dependency.js +0 -27
- package/dist/webpack/configs/plugins/ignore-plugin/is-optional-peer-dependency.js.map +0 -1
- package/dist/webpack/configs/plugins/ignore-plugin/is-optional-react-dom-peer-dependency.d.ts +0 -7
- package/dist/webpack/configs/plugins/ignore-plugin/is-optional-react-dom-peer-dependency.d.ts.map +0 -1
- package/dist/webpack/configs/plugins/ignore-plugin/is-optional-react-dom-peer-dependency.js +0 -15
- package/dist/webpack/configs/plugins/ignore-plugin/is-optional-react-dom-peer-dependency.js.map +0 -1
- package/dist/webpack/configs/types.d.ts +0 -37
- package/dist/webpack/configs/types.d.ts.map +0 -1
- package/dist/webpack/configs/types.js.map +0 -1
- package/dist/webpack/configs/utils/build-metadata.d.ts.map +0 -1
- package/dist/webpack/configs/utils/build-metadata.js.map +0 -1
- package/dist/webpack/configs/utils/generate-metadata.d.ts +0 -3
- package/dist/webpack/configs/utils/generate-metadata.d.ts.map +0 -1
- package/dist/webpack/configs/utils/generate-metadata.js.map +0 -1
- package/dist/webpack/configs/utils/get-bundle-type.d.ts +0 -3
- package/dist/webpack/configs/utils/get-bundle-type.d.ts.map +0 -1
- package/dist/webpack/configs/utils/get-bundle-type.js.map +0 -1
- package/dist/webpack/configs/utils/get-exposed-dependencies.d.ts.map +0 -1
- package/dist/webpack/configs/utils/get-exposed-dependencies.js.map +0 -1
- package/dist/webpack/configs/utils/get-launchdarkly-sdk-version.d.ts.map +0 -1
- package/dist/webpack/configs/utils/get-launchdarkly-sdk-version.js.map +0 -1
- package/dist/webpack/configs/utils/get-web-components-version.d.ts.map +0 -1
- package/dist/webpack/configs/utils/get-web-components-version.js.map +0 -1
- package/dist/webpack/configs/utils/index.d.ts +0 -4
- package/dist/webpack/configs/utils/index.d.ts.map +0 -1
- package/dist/webpack/configs/utils/index.js.map +0 -1
- package/dist/webpack/utils/stringify-config.d.ts.map +0 -1
- package/dist/webpack/utils/stringify-config.js.map +0 -1
- package/src/cli/utils/bundle.ts +0 -191
- package/src/utils/get-startup-version.ts +0 -6
- package/src/webpack/configs/plugins/ignore-plugin/__tests__/check-resource.test.ts +0 -62
- package/src/webpack/configs/plugins/ignore-plugin/__tests__/is-optional-peer-dependency.test.ts +0 -47
- package/src/webpack/configs/plugins/ignore-plugin/__tests__/is-optional-react-dom-peer-dependency.test.ts +0 -35
- package/src/webpack/configs/plugins/ignore-plugin/check-resource.ts +0 -29
- package/src/webpack/configs/plugins/ignore-plugin/get-package-json.ts +0 -23
- package/src/webpack/configs/plugins/ignore-plugin/is-optional-peer-dependency.ts +0 -12
- package/src/webpack/configs/plugins/ignore-plugin/is-optional-react-dom-peer-dependency.ts +0 -11
- package/src/webpack/configs/types.ts +0 -40
- package/src/webpack/configs/utils/get-bundle-type.ts +0 -22
- package/src/webpack/configs/utils/index.ts +0 -3
- /package/dist/{webpack/configs → core/check-resource}/types.js +0 -0
- /package/dist/{webpack/configs/utils → core}/get-exposed-dependencies.d.ts +0 -0
- /package/dist/{webpack/configs/utils → core}/get-exposed-dependencies.js +0 -0
- /package/dist/{webpack/configs/utils → core/get-version}/get-launchdarkly-sdk-version.d.ts +0 -0
- /package/dist/{webpack/configs/utils → core/get-version}/get-launchdarkly-sdk-version.js +0 -0
- /package/dist/{utils → core/get-version}/get-startup-version.d.ts +0 -0
- /package/dist/{webpack/configs/utils → core/get-version}/get-web-components-version.d.ts +0 -0
- /package/dist/{webpack/configs/utils → core/get-version}/get-web-components-version.js +0 -0
- /package/dist/{webpack/configs/utils → core/metadata}/build-metadata.d.ts +0 -0
- /package/dist/{webpack/utils → core}/stringify-config.d.ts +0 -0
- /package/dist/{webpack/utils → core}/stringify-config.js +0 -0
- /package/src/cli/commands/registry/{bundle-package.ts → bundle-webpack.ts} +0 -0
- /package/src/{webpack/configs/utils → core}/__tests__/get-exposed-dependencies.test.ts +0 -0
- /package/src/{webpack/configs/utils → core}/get-exposed-dependencies.ts +0 -0
- /package/src/{webpack/configs/utils → core/get-version}/__tests__/get-launchdarkly-sdk-version.test.ts +0 -0
- /package/src/{utils → core/get-version}/__tests__/get-startup-version.test.ts +0 -0
- /package/src/{webpack/configs/utils → core/get-version}/__tests__/get-web-components-version.test.ts +0 -0
- /package/src/{webpack/configs/utils → core/get-version}/get-launchdarkly-sdk-version.ts +0 -0
- /package/src/{webpack/configs/utils → core/get-version}/get-web-components-version.ts +0 -0
- /package/src/{webpack/utils → core}/stringify-config.ts +0 -0
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { sortSharedCss } from '../sort-shared-css';
|
|
2
|
+
|
|
3
|
+
describe(`[startup] ${sortSharedCss.name}`, () => {
|
|
4
|
+
let cssFiles: string[];
|
|
5
|
+
|
|
6
|
+
beforeEach(() => {
|
|
7
|
+
cssFiles = ['foo.bundle.css', 'bar.bundle.css'];
|
|
8
|
+
});
|
|
9
|
+
|
|
10
|
+
const subject = () => sortSharedCss(cssFiles);
|
|
11
|
+
|
|
12
|
+
function itReturnsInput() {
|
|
13
|
+
test('returns input', () => {
|
|
14
|
+
expect(subject()).toBe(cssFiles);
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
itReturnsInput();
|
|
19
|
+
|
|
20
|
+
describe('when input contains design-system CSS', () => {
|
|
21
|
+
let otherCssFiles: string[];
|
|
22
|
+
const designSystemBundle = 'design-system.bundle.css';
|
|
23
|
+
|
|
24
|
+
beforeEach(() => {
|
|
25
|
+
otherCssFiles = [...cssFiles];
|
|
26
|
+
cssFiles = [...otherCssFiles, designSystemBundle];
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
test('moves design system to front', () => {
|
|
30
|
+
expect(subject()).toEqual([designSystemBundle, ...otherCssFiles]);
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
describe('when design-system CSS is already first', () => {
|
|
34
|
+
beforeEach(() => (cssFiles = [designSystemBundle, ...otherCssFiles]));
|
|
35
|
+
|
|
36
|
+
itReturnsInput();
|
|
37
|
+
});
|
|
38
|
+
});
|
|
39
|
+
});
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { getBundleType } from './get-bundle-type';
|
|
2
|
+
import { BuildContext } from './types';
|
|
3
|
+
|
|
4
|
+
/*
|
|
5
|
+
* Base name (no extension) and title for the bundle-size report, shared by the webpack and Vite
|
|
6
|
+
* builds so both bundlers label their reports identically. The timestamp keeps successive reports
|
|
7
|
+
* for the same package distinct.
|
|
8
|
+
*/
|
|
9
|
+
export function bundleReportFileName(context: BuildContext): string {
|
|
10
|
+
const type = getBundleType(context);
|
|
11
|
+
const qualifier = type ? `-${type}` : '';
|
|
12
|
+
return `${context.package.name}${qualifier}-bundle-${Date.now()}`;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export function bundleReportTitle(context: BuildContext): string {
|
|
16
|
+
const unscopedName = context.package.name.replace(/^@[^/]+\//, '');
|
|
17
|
+
const type = getBundleType(context);
|
|
18
|
+
const qualifier = type ? ` (${type})` : '';
|
|
19
|
+
return `${unscopedName}${qualifier} ${formatDate(new Date())}`;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
function formatDate(date: Date): string {
|
|
23
|
+
const yyyy = date.getFullYear();
|
|
24
|
+
const mm = zeroPad(date.getMonth() + 1);
|
|
25
|
+
const dd = zeroPad(date.getDate());
|
|
26
|
+
const HH = zeroPad(date.getHours());
|
|
27
|
+
const MM = zeroPad(date.getMinutes());
|
|
28
|
+
return `${yyyy}-${mm}-${dd} ${HH}:${MM}`;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
function zeroPad(value: number) {
|
|
32
|
+
return value.toString().padStart(2, '0');
|
|
33
|
+
}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { BuildContext } from '../../types';
|
|
2
|
+
import { checkResource } from '../check-resource';
|
|
3
|
+
import { getPeerDependencyMeta } from '../get-peer-dependency-meta';
|
|
4
|
+
import { isManagedReactDomClientDependency } from '../is-managed-react-dom-client-dependency';
|
|
5
|
+
import { isResolvable } from '../is-resolvable';
|
|
6
|
+
|
|
7
|
+
jest.mock('../is-managed-react-dom-client-dependency');
|
|
8
|
+
jest.mock('../get-peer-dependency-meta');
|
|
9
|
+
jest.mock('../is-resolvable');
|
|
10
|
+
|
|
11
|
+
describe(`${checkResource.name}`, () => {
|
|
12
|
+
const importer = 'node_modules/web-components/dist';
|
|
13
|
+
let context: BuildContext;
|
|
14
|
+
let resource: string;
|
|
15
|
+
let peerDependenciesMeta: ReturnType<typeof getPeerDependencyMeta>;
|
|
16
|
+
|
|
17
|
+
beforeEach(() => {
|
|
18
|
+
jest.resetAllMocks();
|
|
19
|
+
jest.mocked(getPeerDependencyMeta).mockImplementation(() => peerDependenciesMeta);
|
|
20
|
+
peerDependenciesMeta = undefined;
|
|
21
|
+
resource = '@servicetitan/foo';
|
|
22
|
+
context = { package: { dependencies: {} } } as BuildContext;
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
const subject = () => checkResource(context)({ resource, importer });
|
|
26
|
+
|
|
27
|
+
function itReturns(value: 'throw' | 'empty' | false) {
|
|
28
|
+
test(`returns ${JSON.stringify(value)}`, () => expect(subject()).toBe(value));
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
itReturns(false);
|
|
32
|
+
|
|
33
|
+
describe('when resource is optional peer dependency', () => {
|
|
34
|
+
beforeEach(() => (peerDependenciesMeta = { optional: true }));
|
|
35
|
+
|
|
36
|
+
itReturns('throw');
|
|
37
|
+
|
|
38
|
+
describe('when peer fallback is "empty"', () => {
|
|
39
|
+
beforeEach(() => (peerDependenciesMeta!.fallback = 'empty'));
|
|
40
|
+
|
|
41
|
+
itReturns('empty');
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
describe('when resource is resolvable', () => {
|
|
45
|
+
beforeEach(() => jest.mocked(isResolvable).mockReturnValue(true));
|
|
46
|
+
|
|
47
|
+
itReturns(false);
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
describe('when resource is package dependency', () => {
|
|
51
|
+
beforeEach(() => (context.package.dependencies[resource] = '*'));
|
|
52
|
+
|
|
53
|
+
itReturns(false);
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
describe('when resource is managed react-dom client dependency', () => {
|
|
58
|
+
beforeEach(() => jest.mocked(isManagedReactDomClientDependency).mockReturnValue(true));
|
|
59
|
+
|
|
60
|
+
describe('when resource is resolvable', () => {
|
|
61
|
+
beforeEach(() => jest.mocked(isResolvable).mockReturnValue(true));
|
|
62
|
+
|
|
63
|
+
itReturns(false);
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
describe('when resource is not resolvable', () => {
|
|
67
|
+
beforeEach(() => jest.mocked(isResolvable).mockReturnValue(false));
|
|
68
|
+
|
|
69
|
+
itReturns('empty');
|
|
70
|
+
});
|
|
71
|
+
});
|
|
72
|
+
});
|
|
@@ -8,6 +8,7 @@ describe(`[startup] ${getPackageJson.name}`, () => {
|
|
|
8
8
|
let context: string;
|
|
9
9
|
|
|
10
10
|
beforeEach(() => {
|
|
11
|
+
getPackageJson.cache.clear?.();
|
|
11
12
|
context = 'node_modules/foo/dist';
|
|
12
13
|
vol.fromNestedJSON({
|
|
13
14
|
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
@@ -39,7 +40,7 @@ describe(`[startup] ${getPackageJson.name}`, () => {
|
|
|
39
40
|
|
|
40
41
|
describe('when context is not in node_modules', () => {
|
|
41
42
|
beforeEach(() => {
|
|
42
|
-
context = 'foo/dist';
|
|
43
|
+
context = '/foo/dist';
|
|
43
44
|
vol.fromNestedJSON({
|
|
44
45
|
foo: { 'package.json': JSON.stringify(packageJson) },
|
|
45
46
|
});
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import { getPackageJson } from '../get-package-json';
|
|
2
|
+
import { getPeerDependencyMeta } from '../get-peer-dependency-meta';
|
|
3
|
+
|
|
4
|
+
jest.mock('../get-package-json');
|
|
5
|
+
|
|
6
|
+
describe(`[startup] ${getPeerDependencyMeta.name}`, () => {
|
|
7
|
+
let importer: string;
|
|
8
|
+
let resource: string;
|
|
9
|
+
let packageJson: ReturnType<typeof getPackageJson>;
|
|
10
|
+
|
|
11
|
+
beforeEach(() => {
|
|
12
|
+
jest.clearAllMocks();
|
|
13
|
+
importer = 'node_modules/pkg/dist';
|
|
14
|
+
resource = '@scope/a';
|
|
15
|
+
packageJson = undefined;
|
|
16
|
+
jest.mocked(getPackageJson).mockImplementation(() => packageJson);
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
const subject = () => getPeerDependencyMeta({ resource, importer });
|
|
20
|
+
|
|
21
|
+
function itReturnsUndefined() {
|
|
22
|
+
test('returns undefined', () => {
|
|
23
|
+
expect(subject()).toBeUndefined();
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
itReturnsUndefined();
|
|
28
|
+
|
|
29
|
+
describe('when resource is not a package name', () => {
|
|
30
|
+
beforeEach(() => (resource = './local'));
|
|
31
|
+
|
|
32
|
+
itReturnsUndefined();
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
describe('when package.json has no entry for resource', () => {
|
|
36
|
+
beforeEach(() => (packageJson = {}));
|
|
37
|
+
|
|
38
|
+
itReturnsUndefined();
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
describe('when peerDependenciesMeta includes resource', () => {
|
|
42
|
+
beforeEach(() => {
|
|
43
|
+
packageJson = { peerDependenciesMeta: { [resource]: { optional: true } } };
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
test('returns entry', () => {
|
|
47
|
+
expect(subject()).toEqual(packageJson!.peerDependenciesMeta[resource]);
|
|
48
|
+
});
|
|
49
|
+
});
|
|
50
|
+
|
|
51
|
+
describe('when cli.peerDependenciesMeta includes resource', () => {
|
|
52
|
+
beforeEach(() => {
|
|
53
|
+
packageJson = {
|
|
54
|
+
peerDependenciesMeta: { [resource]: { optional: true } },
|
|
55
|
+
cli: { peerDependenciesMeta: { [resource]: { fallback: 'empty' } } },
|
|
56
|
+
};
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
function itThrowsError(matcher: RegExp) {
|
|
60
|
+
test('throws', () => {
|
|
61
|
+
expect(subject).toThrow(matcher);
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
test('returns merged entry', () => {
|
|
66
|
+
expect(subject()).toEqual({
|
|
67
|
+
...packageJson!.peerDependenciesMeta[resource],
|
|
68
|
+
...packageJson!.cli.peerDependenciesMeta[resource],
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
describe('when peerDependenciesMeta.optional is missing', () => {
|
|
73
|
+
beforeEach(() => delete packageJson!.peerDependenciesMeta);
|
|
74
|
+
|
|
75
|
+
itThrowsError(/requires peerDependenciesMeta.*optional/);
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
describe('when entry is not an object', () => {
|
|
79
|
+
beforeEach(() => (packageJson!.cli.peerDependenciesMeta[resource] = ''));
|
|
80
|
+
|
|
81
|
+
itThrowsError(/must be an object/);
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
describe('when the malformed entry is for a different resource', () => {
|
|
85
|
+
beforeEach(() => {
|
|
86
|
+
packageJson!.cli.peerDependenciesMeta.foo = '';
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
itThrowsError(/must be an object/);
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
describe('when entry has an unexpected key', () => {
|
|
93
|
+
beforeEach(() => {
|
|
94
|
+
packageJson!.cli.peerDependenciesMeta[resource].optional = true;
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
itThrowsError(/unexpected key\(s\) \[optional\]/);
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
describe('when entry has invalid fallback', () => {
|
|
101
|
+
beforeEach(() => {
|
|
102
|
+
packageJson!.cli.peerDependenciesMeta[resource].fallback = 'foo';
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
itThrowsError(/must be one of \[throw, empty\]/);
|
|
106
|
+
});
|
|
107
|
+
});
|
|
108
|
+
});
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { isManagedReactDomClientDependency } from '../is-managed-react-dom-client-dependency';
|
|
2
|
+
|
|
3
|
+
describe(`[startup] ${isManagedReactDomClientDependency.name}`, () => {
|
|
4
|
+
const subject = (...args: Parameters<typeof isManagedReactDomClientDependency>) =>
|
|
5
|
+
isManagedReactDomClientDependency(...args);
|
|
6
|
+
|
|
7
|
+
describe.each([
|
|
8
|
+
{
|
|
9
|
+
resource: 'react-dom/client',
|
|
10
|
+
importers: [
|
|
11
|
+
'@servicetitan/web-components',
|
|
12
|
+
'uikit/packages/web-components/dist',
|
|
13
|
+
'@servicetitan/ko-bridge',
|
|
14
|
+
'uikit/packages/ko-bridge/dist',
|
|
15
|
+
],
|
|
16
|
+
},
|
|
17
|
+
])('with dependency "$resource"', ({ resource, importers }) => {
|
|
18
|
+
importers.forEach(importer => {
|
|
19
|
+
test(`with importer ${importer}, returns true`, () => {
|
|
20
|
+
expect(subject({ importer, resource })).toBe(true);
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
describe.each([
|
|
26
|
+
{ resource: 'react-dom', importers: ['@servicetitan/web-components'] },
|
|
27
|
+
{ resource: 'react-dom/client', importers: ['@servicetitan/foo'] },
|
|
28
|
+
])('with dependency "$resource"', ({ resource, importers }) => {
|
|
29
|
+
importers.forEach(importer => {
|
|
30
|
+
test(`with importer ${importer}, returns false`, () => {
|
|
31
|
+
expect(subject({ importer, resource })).toBe(false);
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
});
|
|
35
|
+
});
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { isResolvable } from '../is-resolvable';
|
|
2
|
+
|
|
3
|
+
describe('isResolvable', () => {
|
|
4
|
+
const importer = __filename;
|
|
5
|
+
let resource: string;
|
|
6
|
+
|
|
7
|
+
const subject = () => isResolvable({ resource, importer });
|
|
8
|
+
|
|
9
|
+
describe('when the resource resolves', () => {
|
|
10
|
+
beforeEach(() => (resource = 'lodash.memoize'));
|
|
11
|
+
|
|
12
|
+
test('returns true', () => expect(subject()).toBe(true));
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
describe('when the resource does not resolve', () => {
|
|
16
|
+
beforeEach(() => (resource = '@servicetitan/does-not-exist'));
|
|
17
|
+
|
|
18
|
+
test('returns false', () => expect(subject()).toBe(false));
|
|
19
|
+
});
|
|
20
|
+
});
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { log } from '../../utils';
|
|
2
|
+
import { BuildContext } from '../types';
|
|
3
|
+
import { getPeerDependencyMeta } from './get-peer-dependency-meta';
|
|
4
|
+
import { isManagedReactDomClientDependency } from './is-managed-react-dom-client-dependency';
|
|
5
|
+
import { isResolvable } from './is-resolvable';
|
|
6
|
+
import type { CheckerArgs, IgnoreMode } from './types';
|
|
7
|
+
|
|
8
|
+
export function checkResource(context: BuildContext) {
|
|
9
|
+
return function ({ resource, importer }: CheckerArgs): IgnoreMode | false {
|
|
10
|
+
if (!context.package.dependencies[resource]) {
|
|
11
|
+
const meta = getPeerDependencyMeta({ resource, importer });
|
|
12
|
+
if (meta?.optional && !isResolvable({ resource, importer })) {
|
|
13
|
+
const mode = meta.fallback ?? 'throw';
|
|
14
|
+
log.debug('check-resource', `${JSON.stringify({ resource, importer })} => ${mode}`);
|
|
15
|
+
return mode;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* react-dom/client isn't an explicit dependency, so the peerDependenciesMeta
|
|
21
|
+
* path above can't catch it.
|
|
22
|
+
*/
|
|
23
|
+
if (
|
|
24
|
+
isManagedReactDomClientDependency({ resource, importer }) &&
|
|
25
|
+
!isResolvable({ resource, importer })
|
|
26
|
+
) {
|
|
27
|
+
return 'empty';
|
|
28
|
+
}
|
|
29
|
+
return false;
|
|
30
|
+
};
|
|
31
|
+
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import fs from 'fs';
|
|
2
|
+
import memoize from 'lodash.memoize';
|
|
3
|
+
import path from 'path';
|
|
4
|
+
import { log, readJson } from '../../utils';
|
|
5
|
+
|
|
6
|
+
const containsExternalPackages = /[\\/](node_modules|\.yalc|ignore-plugin-test)([\\/]|$)/;
|
|
7
|
+
const isNodeModules = /(node_modules|\.yalc)/;
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Find the nearest package.json for a file path by walking up the directory tree.
|
|
11
|
+
* Only searches paths inside node_modules or .yalc because the ignore plugin only
|
|
12
|
+
* needs to suppress missing optional peer dependencies from third-party packages.
|
|
13
|
+
* ignore-plugin-test is for local integration tests.
|
|
14
|
+
*
|
|
15
|
+
* Memoized to avoid re-walking parent directories on every import resolution.
|
|
16
|
+
*/
|
|
17
|
+
export const getPackageJson = memoize(function getPackageJson(context: string) {
|
|
18
|
+
const fullPath = path.resolve(context);
|
|
19
|
+
if (!containsExternalPackages.test(fullPath)) {
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
for (let dir = path.dirname(fullPath); dir !== path.dirname(dir); dir = path.dirname(dir)) {
|
|
24
|
+
if (isNodeModules.test(path.basename(dir))) {
|
|
25
|
+
break;
|
|
26
|
+
}
|
|
27
|
+
const packageJsonFile = path.join(dir, 'package.json');
|
|
28
|
+
if (fs.existsSync(packageJsonFile)) {
|
|
29
|
+
log.debug('get-package-json', `${context} => ${packageJsonFile}`);
|
|
30
|
+
return readJson<Record<string, any>>(packageJsonFile);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
});
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import memoize from 'lodash.memoize';
|
|
2
|
+
import { getPackageJson } from './get-package-json';
|
|
3
|
+
import type { CheckerArgs, IgnoreMode } from './types';
|
|
4
|
+
|
|
5
|
+
interface PeerDependencyMeta {
|
|
6
|
+
optional?: boolean;
|
|
7
|
+
fallback?: IgnoreMode;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
const ALLOWED_KEYS: readonly string[] = ['fallback'];
|
|
11
|
+
const ALLOWED_FALLBACKS: readonly IgnoreMode[] = ['throw', 'empty'];
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Merged view of npm's `peerDependenciesMeta[resource]` (which carries
|
|
15
|
+
* `optional`) and our extension `cli.peerDependenciesMeta[resource]`. Returns
|
|
16
|
+
* undefined when no entry is declared for the resource.
|
|
17
|
+
*
|
|
18
|
+
* Validates the `cli.peerDependenciesMeta` map so a malformed entry (for
|
|
19
|
+
* example, `optional: true` written there by mistake, thinking it's npm's
|
|
20
|
+
* field) fails loudly.
|
|
21
|
+
*/
|
|
22
|
+
export function getPeerDependencyMeta({
|
|
23
|
+
resource,
|
|
24
|
+
importer,
|
|
25
|
+
}: CheckerArgs): PeerDependencyMeta | undefined {
|
|
26
|
+
if (!/^[@a-z]/.test(resource)) {
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
const pkg = getPackageJson(importer);
|
|
31
|
+
if (!pkg) {
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
const cliMap = pkg.cli?.peerDependenciesMeta;
|
|
36
|
+
if (cliMap && typeof cliMap === 'object') {
|
|
37
|
+
validate(cliMap);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
const npmEntry = pkg.peerDependenciesMeta?.[resource];
|
|
41
|
+
const cliEntry = cliMap?.[resource];
|
|
42
|
+
if (!npmEntry && !cliEntry) {
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
if (cliEntry?.fallback && !npmEntry?.optional) {
|
|
46
|
+
throw new Error(
|
|
47
|
+
`cli.peerDependenciesMeta["${resource}"].fallback requires peerDependenciesMeta["${resource}"].optional = true`
|
|
48
|
+
);
|
|
49
|
+
}
|
|
50
|
+
return { ...npmEntry, ...cliEntry };
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
/*
|
|
54
|
+
* cli.peerDependenciesMeta mirrors npm's peerDependenciesMeta shape. If a
|
|
55
|
+
* developer mistakenly puts npm fields (for example, `optional: true`) there
|
|
56
|
+
* thinking it's npm's config, this check causes it to fail loudly.
|
|
57
|
+
*
|
|
58
|
+
* Memoized by reference so each importer's map is validated once per build.
|
|
59
|
+
*/
|
|
60
|
+
const validate = memoize(function validate(meta: Record<string, unknown>) {
|
|
61
|
+
for (const [resource, entry] of Object.entries(meta)) {
|
|
62
|
+
if (entry === null || typeof entry !== 'object') {
|
|
63
|
+
throw new Error(`cli.peerDependenciesMeta["${resource}"] must be an object`);
|
|
64
|
+
}
|
|
65
|
+
const unknown = Object.keys(entry).filter(k => !ALLOWED_KEYS.includes(k));
|
|
66
|
+
if (unknown.length) {
|
|
67
|
+
throw new Error(
|
|
68
|
+
`cli.peerDependenciesMeta["${resource}"] has unexpected key(s) [${unknown.join(', ')}]; allowed: [${ALLOWED_KEYS.join(', ')}]`
|
|
69
|
+
);
|
|
70
|
+
}
|
|
71
|
+
const { fallback } = entry as { fallback?: unknown };
|
|
72
|
+
if (fallback !== undefined && !ALLOWED_FALLBACKS.includes(fallback as IgnoreMode)) {
|
|
73
|
+
throw new Error(
|
|
74
|
+
`cli.peerDependenciesMeta["${resource}"].fallback must be one of [${ALLOWED_FALLBACKS.join(', ')}], got ${JSON.stringify(fallback)}`
|
|
75
|
+
);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
});
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { CheckerArgs } from './types';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Matches both published paths (@servicetitan/ko-bridge, @servicetitan/web-components) and
|
|
5
|
+
* in-repo paths (packages/ko-bridge, packages/web-components) so the check works whether the
|
|
6
|
+
* importer is installed from npm/yalc or resolved locally during a uikit-internal build.
|
|
7
|
+
*/
|
|
8
|
+
export function isManagedReactDomClientDependency({ importer, resource }: CheckerArgs) {
|
|
9
|
+
return (
|
|
10
|
+
resource === 'react-dom/client' &&
|
|
11
|
+
/(@servicetitan|packages)\/(ko-bridge|web-components)/.test(importer)
|
|
12
|
+
);
|
|
13
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import memoize from 'lodash.memoize';
|
|
2
|
+
import path from 'path';
|
|
3
|
+
import type { CheckerArgs } from './types';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Whether a module resolves from the importer's location. Memoized so each unique
|
|
7
|
+
* (package, importer directory) pair is resolved once.
|
|
8
|
+
*/
|
|
9
|
+
export const isResolvable = memoize(
|
|
10
|
+
function isResolvable({ resource, importer }: CheckerArgs): boolean {
|
|
11
|
+
try {
|
|
12
|
+
require.resolve(resource, { paths: [path.dirname(importer)] });
|
|
13
|
+
return true;
|
|
14
|
+
} catch {
|
|
15
|
+
return false;
|
|
16
|
+
}
|
|
17
|
+
},
|
|
18
|
+
({ resource, importer }) => `${resource}\0${path.dirname(importer)}`
|
|
19
|
+
);
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Canonical module-path patterns for each code-splitting chunk, shared by the Vite
|
|
3
|
+
* and webpack configs. Using [\\/]? at the start matches both Vite module IDs (which
|
|
4
|
+
* begin with "node_modules/...") and webpack module paths (which begin with an
|
|
5
|
+
* absolute path separator before "node_modules/...").
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
const VENDOR_CORE_PACKAGES = [
|
|
9
|
+
'axios',
|
|
10
|
+
'classnames',
|
|
11
|
+
'formstate',
|
|
12
|
+
'inversify',
|
|
13
|
+
'mobx',
|
|
14
|
+
'mobx-react',
|
|
15
|
+
'mobx-utils',
|
|
16
|
+
'react',
|
|
17
|
+
'react-dom',
|
|
18
|
+
'react-router',
|
|
19
|
+
'react-router-dom',
|
|
20
|
+
'reflect-metadata',
|
|
21
|
+
];
|
|
22
|
+
|
|
23
|
+
export const CHUNK_PATTERNS = {
|
|
24
|
+
'servicetitan': /[\\/]?node_modules[\\/]@servicetitan[\\/]/,
|
|
25
|
+
'kendo': /[\\/]?node_modules[\\/](@progress|@telerik)[\\/]/,
|
|
26
|
+
'vendor-core': new RegExp(
|
|
27
|
+
`[\\\\/]?node_modules[\\\\/](${VENDOR_CORE_PACKAGES.join('|')})[\\\\/]`
|
|
28
|
+
),
|
|
29
|
+
'vendor': /[\\/]?node_modules[\\/]/,
|
|
30
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export const bundleConstants = {
|
|
2
|
+
cssModules: {
|
|
3
|
+
classnameTemplate: {
|
|
4
|
+
production: '[local]__[hash:base64:5]',
|
|
5
|
+
development: '[path][name]__[local]',
|
|
6
|
+
},
|
|
7
|
+
localsConvention: 'camelCaseOnly',
|
|
8
|
+
},
|
|
9
|
+
less: {
|
|
10
|
+
math: 'always',
|
|
11
|
+
},
|
|
12
|
+
mode: {
|
|
13
|
+
production: 'production',
|
|
14
|
+
development: 'development',
|
|
15
|
+
},
|
|
16
|
+
} as const;
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { getPackageManager } from '@servicetitan/install';
|
|
2
|
+
import yargs, { Arguments } from 'yargs';
|
|
3
|
+
import { hideBin } from 'yargs/helpers';
|
|
4
|
+
import {
|
|
5
|
+
getExposeProcessEnv,
|
|
6
|
+
getFolders,
|
|
7
|
+
getPackageData,
|
|
8
|
+
isExposeSharedDependencies,
|
|
9
|
+
isLegacyRoot,
|
|
10
|
+
isWebComponent,
|
|
11
|
+
loadSharedDependencies,
|
|
12
|
+
} from '../utils';
|
|
13
|
+
import { BuildContext, BuildIdentity } from './types';
|
|
14
|
+
export type { BuildContext } from './types';
|
|
15
|
+
|
|
16
|
+
export interface BuildContextOptions {
|
|
17
|
+
name: string;
|
|
18
|
+
isProduction: boolean;
|
|
19
|
+
light?: boolean;
|
|
20
|
+
headless?: boolean;
|
|
21
|
+
emitExposedDependencies?: BuildIdentity['emitExposedDependencies'];
|
|
22
|
+
codeCoverage?: boolean;
|
|
23
|
+
buildStat?: boolean;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export function createBuildContext(options: BuildContextOptions): BuildContext {
|
|
27
|
+
const args = yargs(hideBin(process.argv)).argv as Arguments;
|
|
28
|
+
const { source, destination } = getFolders();
|
|
29
|
+
const packageData = getPackageData();
|
|
30
|
+
const sharedDependencies = loadSharedDependencies(
|
|
31
|
+
packageData.dependencies,
|
|
32
|
+
packageData.sharedDependencies
|
|
33
|
+
);
|
|
34
|
+
|
|
35
|
+
return {
|
|
36
|
+
package: {
|
|
37
|
+
name: packageData.name,
|
|
38
|
+
version: packageData.version,
|
|
39
|
+
destination,
|
|
40
|
+
source,
|
|
41
|
+
dependencies: packageData.dependencies,
|
|
42
|
+
sharedDependencies,
|
|
43
|
+
isWebComponent: isWebComponent(),
|
|
44
|
+
isLegacyRoot: isLegacyRoot(),
|
|
45
|
+
isExposeSharedDependencies: isExposeSharedDependencies(),
|
|
46
|
+
exposeProcessEnv: getExposeProcessEnv(),
|
|
47
|
+
packageManager: getPackageManager(),
|
|
48
|
+
},
|
|
49
|
+
build: {
|
|
50
|
+
name: options.name,
|
|
51
|
+
isProduction: options.isProduction,
|
|
52
|
+
light: options.light,
|
|
53
|
+
headless: options.headless,
|
|
54
|
+
emitExposedDependencies: options.emitExposedDependencies,
|
|
55
|
+
},
|
|
56
|
+
options: {
|
|
57
|
+
codeCoverage: options.codeCoverage ?? !!args['code-coverage'],
|
|
58
|
+
buildStat: options.buildStat,
|
|
59
|
+
},
|
|
60
|
+
};
|
|
61
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export const FONT_EXTENSIONS = ['woff', 'woff2', 'eot', 'ttf', 'otf'];
|
|
2
|
+
export const IMAGE_EXTENSIONS = ['png', 'jpg', 'jpeg', 'gif'];
|
|
3
|
+
export const SVG_EXTENSIONS = ['svg'];
|
|
4
|
+
|
|
5
|
+
export function createExtensionRegExp(extensions: string[]): RegExp {
|
|
6
|
+
return new RegExp(`\\.(${extensions.join('|')})$`, 'i');
|
|
7
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { getExposedDependencies } from '../get-exposed-dependencies';
|
|
2
|
+
import { BuildContext } from '../types';
|
|
3
|
+
|
|
4
|
+
export function defineExposedDependencies(context: BuildContext) {
|
|
5
|
+
const { isExposeSharedDependencies, sharedDependencies, dependencies, packageManager } =
|
|
6
|
+
context.package;
|
|
7
|
+
const { emitExposedDependencies } = context.build;
|
|
8
|
+
|
|
9
|
+
if (!isExposeSharedDependencies || emitExposedDependencies) {
|
|
10
|
+
return;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
const workspacePackage = packageManager.getWorkspacePackage();
|
|
14
|
+
const exposedDependencies = getExposedDependencies(
|
|
15
|
+
sharedDependencies,
|
|
16
|
+
dependency =>
|
|
17
|
+
packageManager.getResolvedVersion({ workspacePackage, dependency }) ??
|
|
18
|
+
dependencies?.[dependency]
|
|
19
|
+
);
|
|
20
|
+
|
|
21
|
+
return {
|
|
22
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
23
|
+
EXPOSED_DEPENDENCIES: JSON.stringify(exposedDependencies),
|
|
24
|
+
};
|
|
25
|
+
}
|