Skip to content

Commit

Permalink
feat(*): add css-prefix for wmf
Browse files Browse the repository at this point in the history
  • Loading branch information
Обмочевский Владислав Вячеславович authored and Обмочевский Владислав Вячеславович committed Sep 28, 2024
1 parent 9d1501b commit b96804d
Show file tree
Hide file tree
Showing 4 changed files with 55 additions and 5 deletions.
5 changes: 5 additions & 0 deletions .changeset/warm-terms-shave.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'arui-scripts': patch
---

Добавлена возможность задавать css префикс для MF модулей
30 changes: 27 additions & 3 deletions packages/arui-scripts/docs/modules.md
Original file line number Diff line number Diff line change
Expand Up @@ -338,10 +338,10 @@ export const MyAwesomeComponent = () => {
трудоемкой задачей, особенно если у вас уже есть большая кодовая база.

arui-scripts предоставляет два решения для этой проблемы:
- _compat_ модули
- _css-prefix_
- использование shadow dom

## compat модули
## css-prefix

Суть метода заключается в том, что ко всем стилям модуля будет добавляться префикс, который позволит изолировать
стили модуля от стилей приложения-потребителя.
Expand All @@ -354,7 +354,7 @@ arui-scripts предоставляет два решения для этой п
1. Изменить конфигурацию модуля в `arui-scripts.config.ts`:

```ts
// ./arui-scripts.config.ts
// ./arui-scripts.config.ts compatModules
import type { PackageSettings } from 'arui-scripts';

const aruiScriptsConfig: PackageSettings = {
Expand Down Expand Up @@ -384,6 +384,30 @@ const aruiScriptsConfig: PackageSettings = {
export default aruiScriptsConfig;
```

```ts
// ./arui-scripts.config.ts module federation
import type { PackageSettings } from 'arui-scripts';

const aruiScriptsConfig: PackageSettings = {
modules: {
shared: {
'react': '^17.0.0',
'react-dom': '^17.0.0',
},
exposes: {
'Module': './src/modules/module/index',
},
options: {
'Module': {
cssPrefix: '.my-module'
}
}
}
}

export default aruiScriptsConfig;
```

2. Изменить входную точку модуля:

```tsx
Expand Down
10 changes: 8 additions & 2 deletions packages/arui-scripts/src/configs/app-configs/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -89,13 +89,19 @@ export type AppConfigs = {
name?: string;
shared: any; // webpack don't expose this type
exposes?: Record<string, string>;
options?: {
[moduleId: string]: ModuleConfigBase;
};
} | null;
};

type CompatModuleConfigBase = {
export type ModuleConfigBase = {
cssPrefix?: false | string;
};

type CompatModuleConfigBase = ModuleConfigBase & {
entry: string;
externals?: Record<string, string>;
cssPrefix?: false | string;
};

export type CompatModuleConfig = CompatModuleConfigBase & {
Expand Down
15 changes: 15 additions & 0 deletions packages/arui-scripts/src/configs/modules.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,21 @@ export function patchMainWebpackConfigForModules(webpackConf: webpack.Configurat
return webpackConf;
}

const moduleOptions = configs.modules.options || {};

Object.keys(moduleOptions).forEach((moduleName) => {
const {cssPrefix} = moduleOptions[moduleName]

if (cssPrefix) {
// Добавляем префикс для css-классов, чтобы изолировать стили модуля от стилей основного приложения
const cssRule = findLoader(webpackConf, '/\\.css$/');
const cssModulesRule = findLoader(webpackConf, '/\\.module\\.css$/');

addPrefixCssRule(cssRule, cssPrefix);
addPrefixCssRule(cssModulesRule, `:global(${cssPrefix})`);
}
});

webpackConf.output.publicPath = haveExposedDefaultModules()
? 'auto' // Для того чтобы модули могли подключаться из разных мест, нам необходимо использовать auto. Для корректной работы в IE надо подключaть https://github.com/amiller-gh/currentScript-polyfill
: configs.publicPath;
Expand Down

0 comments on commit b96804d

Please sign in to comment.