4.22.4 • Published 5 days ago

@skbkontur/react-ui v4.22.4

Weekly downloads
1,590
License
MIT
Repository
github
Last release
5 days ago

React UI

Build Status

Как использовать

yarn add @skbkontur/react-ui
import { Button, Toast } from '@skbkontur/react-ui';

const MyApp = () => (
  <div>
    Click this button <Button onClick={() => Toast.push('Hey!')}>Click me</Button>
  </div>
);

Хотим другой цвет кнопки!

Нужно использовать ThemeContext. Список переменных можно глянуть в ThemeShowcase

StrictMode

Начиная с версий @skbkontur/react-ui@3.10.0 и @skbkontur/react-ui-validations@1.7.0, библиотека поддерживает работу в React.StrictMode.

Некоторым компонентам библиотеки необходимо иметь доступ до корневой DOM-ноды своих children. Ранее для этого использовался метод findDomNode, который в StrictMode запрещён. Теперь получение DOM-ноды реализовано в библиотеке через ref, из-за чего появились некоторые требования к компонентам, передаваемым в Hint, Tooltip, Popup или Tab:

  • при передаче функциональных компонентов, они должны использовать React.ForwardRef:
import { Hint } from '@skbkontur/react-ui';

const CustomFunctionComponent = React.forwardRef(
  (props, ref) => <div ref={ref}>children text</div>
);

export const WithFunctionChildren = () => (
  <React.StrictMode>
    <Hint pos="top" text="Something will never be changed" manual opened>
      <CustomFunctionComponent />
    </Hint>
  </React.StrictMode>
);
  • при использовании хука useImperativeHandle, возвращаемый объект должен реализовывать метод getRootNode, возвращающий DOM-ноду:
import { Hint } from '@skbkontur/react-ui';

const ImperativeHandleComponent = React.forwardRef(function FN(_, ref) {
  const rootNode = React.useRef<HTMLDivElement>(null);
  React.useImperativeHandle(ref, () => ({
    foo: 'bar',
    getRootNode: () => rootNode.current,
  }));
  return <div ref={rootNode}>children text</div>;
});

export const WithImperativeHandleChildren = () => (
  <React.StrictMode>
    <Hint pos="top" text="Something will never be changed" manual opened>
      <ImperativeHandleComponent />
    </Hint>
  </React.StrictMode>
);
  • при передаче классовых компонентов, их инстанс должен реализовывать метод getRootNode, возвращающий DOM-ноду:
import { Hint } from '@skbkontur/react-ui';

class CustomClassComponent extends React.Component {
  rootNode = React.createRef();

  render() {
    return <div ref={this.rootNode}>children text</div>;
  }

  getRootNode() {
    return this.rootNode.current;
  }
}

export const WithClassChildren = () => (
  <React.StrictMode>
    <Hint pos="top" text="Something will never be changed" manual opened>
      <CustomClassComponent />
    </Hint>
  </React.StrictMode>
);

В случае несоблюдения требования, будет использоваться старый метод findDomNode, который не совместим с StrictMode.

Подробнее в пулл-реквесте

FAQ

Отключение анимаций во время тестирования

Анимации в компонентах отключаются любой из следующих глобальных переменных:

REACT_UI_TEST
process.env.NODE_ENV === 'test'
process.env.REACT_UI_TEST
process.env.REACT_APP_REACT_UI_TEST
process.env.STORYBOOK_REACT_UI_TEST

Прокидывание className и style компонентам

Начиная с версии 2.14.0, стало возможным передавать в компоненты свои css-классы для дополнительной стилизации. Однако, не стоит пользоваться этой возможностью для вмешательства во внутренние стили компонентов. Верстка компонентов может быть изменена в любой момент без предупреждения, что приведет к поломке ваших переопределенных стилей.

Мобильная верстка

С версии 4.0 многие компоненты умеют адаптироваться под мобильные устройства. Подробнее об управлении этим поведением в MOBILES.md.

Помощь в развитии

Мы рады любой сторонней помощи. Не стесняйтесь писать в issues баги и идеи для развития библиотеки.

4.22.4

5 days ago

0.0.0-48840c3b9c

15 days ago

0.0.0-ea6161656e

15 days ago

0.0.0-95a1dbe516

16 days ago

0.0.0-6fbd9fadb2

16 days ago

4.22.3-next.0

17 days ago

4.22.3

17 days ago

4.22.2

23 days ago

0.0.0-1da9bba033

23 days ago

4.21.4

26 days ago

4.22.1

26 days ago

4.21.3

1 month ago

4.22.0

1 month ago

4.22.0-next.5

1 month ago

0.0.0-f5a3ad3862

1 month ago

4.22.0-next.4

1 month ago

0.0.0-a2ba201dd3

1 month ago

0.0.0-9216939ede

1 month ago

0.0.0-2d059f9369

1 month ago

4.22.0-next.2

2 months ago

4.22.0-next.3

2 months ago

4.21.1

2 months ago

4.21.2

2 months ago

4.22.0-next.1

2 months ago

0.0.0-2309bff2d3

2 months ago

0.0.0-53ccdcbfcc

2 months ago

0.0.0-a2ba583fb2

2 months ago

0.0.0-444dd4e7b3

2 months ago

4.21.0-next.3

3 months ago

4.21.0

3 months ago

4.20.3

3 months ago

4.22.0-next.0

3 months ago

4.21.0-next.2

3 months ago

4.20.2

3 months ago

4.21.0-next.1

3 months ago

4.20.1

3 months ago

4.21.0-next.0

3 months ago

4.20.0

3 months ago

4.20.0-next.2

3 months ago

4.19.1

4 months ago

4.20.0-next.1

4 months ago

4.20.0-next.0

4 months ago

0.0.0-b821a2f064

5 months ago

4.19.0-next.0

5 months ago

4.19.0

5 months ago

0.0.0-1c6f0751ba

9 months ago

0.0.0-5188be76c1

7 months ago

0.0.0-308773c7f8

8 months ago

4.16.0

8 months ago

4.16.1

7 months ago

4.16.2

7 months ago

4.16.0-next.8

9 months ago

4.16.0-next.7

9 months ago

4.16.0-next.9

9 months ago

0.0.0-ae6d10f363

6 months ago

4.16.0-next.2

10 months ago

4.16.0-next.1

10 months ago

4.16.0-next.4

10 months ago

4.16.0-next.6

9 months ago

4.16.0-next.5

9 months ago

0.0.0-0b3ae9e05b

9 months ago

4.15.4

10 months ago

4.15.5

9 months ago

4.15.6

9 months ago

4.15.7

9 months ago

4.15.1

10 months ago

4.15.2

10 months ago

4.15.3

10 months ago

0.0.0-ccbe7cf017

10 months ago

0.0.0-7b43e31fde

9 months ago

4.17.0-minimodal.0

6 months ago

4.17.0-minimodal.1

6 months ago

4.17.0-minimodal.2

6 months ago

0.0.0-0ffbe8b468

7 months ago

0.0.0-a25347e958

7 months ago

0.0.0-80c5917afc

9 months ago

0.0.0-4c5579465d

9 months ago

0.0.0-60bf3b9da8

9 months ago

4.15.3-fixed

10 months ago

4.16.0-next.10

8 months ago

0.0.0-8431409396

9 months ago

4.18.0-next.0

5 months ago

4.18.0

5 months ago

0.0.0-942b5aade9

9 months ago

0.0.0-f6524ddda7

8 months ago

4.17.0-next.0

8 months ago

4.17.0-next.1

7 months ago

4.17.0-next.2

7 months ago

4.17.0-next.3

7 months ago

4.17.0-next.4

6 months ago

4.17.2

6 months ago

4.17.3

6 months ago

4.17.4

5 months ago

4.17.0

6 months ago

4.17.1

6 months ago

0.0.0-1b188ff0e7

11 months ago

0.0.0-b4292e4d5b

8 months ago

0.0.0-bc0c053ae7

7 months ago

0.0.0-1ee663e1d9

11 months ago

0.0.0-0dca6f33be

11 months ago

4.14.1

11 months ago

4.14.2

11 months ago

4.14.0

12 months ago

4.16.0-next.0

11 months ago

4.14.0-next.1

12 months ago

4.14.0-next.0

12 months ago

4.15.0

11 months ago

0.0.0-ee57da3e1e

11 months ago

0.0.0-b5a1896fa9

11 months ago

4.14.2-next.1

11 months ago

4.14.2-next.0

11 months ago

0.0.0-bd4276284d

11 months ago

0.0.0-7feb61cdde

11 months ago

4.13.2

1 year ago

4.13.3

1 year ago

4.13.4

1 year ago

4.13.0

1 year ago

4.13.1

1 year ago

4.12.0

1 year ago

4.10.0

1 year ago

4.11.0

1 year ago

4.9.2

1 year ago

4.9.1

1 year ago

4.9.0

1 year ago

4.8.0

2 years ago

4.7.0

2 years ago

4.6.1

2 years ago

4.6.0

2 years ago

3.12.9

1 year ago

3.12.8

2 years ago

4.5.3

2 years ago

4.5.0

2 years ago

4.5.2

2 years ago

4.5.1

2 years ago

0.0.0-f270e66c62

2 years ago

0.0.0-0fe669bb2d

2 years ago

0.0.0-ce2a893b1a

2 years ago

4.4.0

2 years ago

0.0.0-7b63c63db3

2 years ago

4.3.1

2 years ago

4.3.0

2 years ago

0.0.0-757d1fac56

2 years ago

4.2.2

2 years ago

4.2.1

2 years ago

4.2.0

2 years ago

4.1.2

2 years ago

4.1.1

2 years ago

0.0.0-8ea1692541

2 years ago

0.0.0-aca98a1591

2 years ago

0.0.0-2ac4c133dd

2 years ago

0.0.0-b08da15166

2 years ago

0.0.0-4bd3603e53

2 years ago

3.12.5

2 years ago

3.12.7

2 years ago

3.12.6

2 years ago

4.1.2-fix-zindex

2 years ago

0.0.0-6739d0c9d2

2 years ago

0.0.0-151f385a39

2 years ago

0.0.0-69a6fa606f

2 years ago

0.0.0-8824ede9eb

2 years ago

0.0.0-fed57d84fb

2 years ago

4.1.0

2 years ago

4.0.5

2 years ago

4.0.4

2 years ago

4.0.6

2 years ago

3.12.3-popup-fix

2 years ago

3.12.3

2 years ago

3.12.4

2 years ago

0.0.0-8339c75a54

2 years ago

0.0.0-627b6e869c

2 years ago

4.0.1

2 years ago

4.0.3

2 years ago

4.0.2

2 years ago

2.17.9

2 years ago

3.12.2

2 years ago

3.12.1

2 years ago

4.0.0

2 years ago

3.12.0

2 years ago

0.0.0-cb270e7a13

2 years ago

2.17.8

2 years ago

0.0.0-f50cd2db6e

2 years ago

3.10.0

2 years ago

2.17.7-csi.0

2 years ago

4.0.0-beta.5

2 years ago

3.11.0

2 years ago

4.0.0-beta.4

2 years ago

4.0.0-beta.3

2 years ago

4.0.0-beta.2

2 years ago

4.0.0-beta.1

2 years ago

3.11.0-csi.2

2 years ago

3.11.0-csi.1

2 years ago

0.0.0-bb4cbfe9c6

2 years ago

0.0.0-a18e664e8f

2 years ago

1.6.11

2 years ago

0.0.0-ecefada396

2 years ago

3.11.0-latest

2 years ago

1.12.2

2 years ago

3.9.3

2 years ago

3.9.2

2 years ago

3.9.1

2 years ago

3.9.0

2 years ago

3.9.4

2 years ago

2.17.6

3 years ago

2.17.7

2 years ago

3.8.5

2 years ago

3.8.4-adaptive.1

3 years ago

3.10.0-beta.1

2 years ago

2.17.5

3 years ago

3.8.4

3 years ago

3.8.3

3 years ago

3.8.0

3 years ago

3.8.2

3 years ago

3.8.1

3 years ago

3.7.2

3 years ago

3.7.1

3 years ago

2.17.4

3 years ago

3.7.0

3 years ago

1.12.1

3 years ago

3.6.0

3 years ago

3.5.0

3 years ago

2.17.3

3 years ago

3.4.0

3 years ago

0.0.0-acc8bd836b

3 years ago

2.17.2

3 years ago

3.3.1

3 years ago

3.3.0

3 years ago

0.0.0-6a047cca2c

3 years ago

3.2.1

3 years ago

3.2.0

3 years ago

0.0.0-34314258fc

3 years ago

0.0.0-599274d651

3 years ago

0.0.0-13d2191267

3 years ago

2.17.1

3 years ago

3.1.0

3 years ago

1.12.0

3 years ago

0.0.0-fbd8ffdb58

3 years ago

1.12.0-beta.0

3 years ago

3.0.0-beta.1

3 years ago

3.0.0

3 years ago

2.17.0

3 years ago

1.11.8

3 years ago

0.0.0-0b8a8f7a39

3 years ago

0.0.0-243b88a6d4

3 years ago

0.0.0-4bf82bc3f4

3 years ago

2.16.2

3 years ago

2.16.1

3 years ago

0.53.15

3 years ago

3.0.0-beta.0

3 years ago

0.0.0-c91b3db3f4

3 years ago

2.16.0

3 years ago

0.0.0-db49e83900

3 years ago

0.0.0-5a76463ffc

3 years ago

0.0.0-031e4bb3f9

3 years ago

0.0.0-4cd450ed1e

3 years ago

0.0.0-80ce75eca6

3 years ago

0.53.14

3 years ago

0.0.0-2d05d1e54b

3 years ago

0.0.0-b203c99d11

3 years ago

2.15.0

3 years ago

0.0.0-edbe8cfc5c

3 years ago

0.0.0-77c9412271

3 years ago

0.0.0-05ffc1aa54

3 years ago

0.0.0-d09e1235b2

3 years ago

2.14.1

3 years ago

0.0.0-a56ed1062c

3 years ago

2.14.0

3 years ago

0.0.0-a39f3fcd24

3 years ago

0.0.0-e39f3359cc

3 years ago

0.0.0-f6c5e6ce66

3 years ago

0.0.0-a8072451c2

3 years ago

2.13.0

3 years ago

2.12.1

3 years ago

2.12.0

3 years ago

0.0.0-4ef0a955cc

3 years ago

0.0.0-375e096002

3 years ago

2.11.0

3 years ago

0.0.0-73eeccf6c9

3 years ago

2.10.0

3 years ago

2.9.0

3 years ago

0.53.13

3 years ago

1.11.7

4 years ago

2.8.0

4 years ago

2.7.0

4 years ago

2.7.0-beta.0

4 years ago

0.0.0-d911b322a7

4 years ago

0.0.0-5faffefa15

4 years ago

2.6.0

4 years ago

2.5.0

4 years ago

2.4.3

4 years ago

1.11.6

4 years ago

0.0.0-38b6d1ada0

4 years ago

2.4.2

4 years ago

1.11.5

4 years ago

0.53.12

4 years ago

0.0.0-587d5220be

4 years ago

2.4.1

4 years ago

1.11.4

4 years ago

0.0.0-cb54865bf2

4 years ago

0.53.11

4 years ago

1.6.10

4 years ago

2.4.0

4 years ago

0.0.0-e55f22da73

4 years ago

0.0.0-1215609799

4 years ago

2.3.2

4 years ago

0.0.0-9a66eda8b5

4 years ago

1.11.3

4 years ago

2.3.1

4 years ago

1.9.1

4 years ago

0.0.0-001618ff8c

4 years ago

2.3.0

4 years ago

0.0.0-50f666af0e

4 years ago

0.0.0-aaf2aabecb

4 years ago

1.11.2

4 years ago

0.53.10

4 years ago

2.2.0

4 years ago

0.0.0-80951ea125

4 years ago

2.1.1

4 years ago

0.53.9

4 years ago

2.1.0

4 years ago

0.53.8

4 years ago

1.11.1

4 years ago

2.0.0

4 years ago

1.11.0

4 years ago

0.0.0-4eeec901d8

4 years ago

0.0.0-8fc80072ce

4 years ago

1.10.0

4 years ago

0.0.0-57f703b950

4 years ago

0.0.0-b0853da840

4 years ago

1.9.0

4 years ago

0.0.0-71afabf463

4 years ago

0.0.0-2eafa74fd6

4 years ago

1.8.1

4 years ago

0.53.7

4 years ago

1.8.0

4 years ago

1.7.0

4 years ago

1.6.9

4 years ago

1.6.8

4 years ago

1.6.7

4 years ago

1.6.6

4 years ago

0.53.6

4 years ago

1.6.5

4 years ago

1.6.4

4 years ago

1.6.3

4 years ago

0.53.5

5 years ago

1.6.2

5 years ago

1.6.1

5 years ago

1.6.0

5 years ago

1.5.0

5 years ago

0.53.4

5 years ago

1.4.0

5 years ago

0.53.3

5 years ago

0.30.1

5 years ago

1.3.1

5 years ago

1.3.0

5 years ago

0.53.2

5 years ago

1.2.0

5 years ago

0.53.1

5 years ago

1.1.2

5 years ago

0.33.4

5 years ago

1.1.1

5 years ago

1.1.0

5 years ago

0.51.2

5 years ago

1.0.1

5 years ago

1.0.0

5 years ago

0.53.0

5 years ago

0.0.0-dd8159fe6c

5 years ago

0.0.0-75af0d4d53

5 years ago

0.52.1

5 years ago

0.0.0-1e20264c71

5 years ago

0.0.0-c425bc6234

5 years ago

0.0.0-e66a3400ba

5 years ago

0.52.0

5 years ago

0.40.2

5 years ago

0.18.17

5 years ago

0.18.16

5 years ago

0.51.1

5 years ago

0.51.0

5 years ago

0.50.0

5 years ago

0.49.1

5 years ago

0.49.0

5 years ago

0.48.0

5 years ago

0.47.0

5 years ago

0.46.2

5 years ago

0.46.1

5 years ago

0.46.0

5 years ago

0.45.0

5 years ago

0.44.3

5 years ago

0.44.2

5 years ago

0.44.1

5 years ago

0.44.0

5 years ago

0.33.3

5 years ago

0.43.0

5 years ago

0.28.1

5 years ago

0.42.0

5 years ago

0.41.1

5 years ago

0.33.2

5 years ago

0.41.0

5 years ago

0.40.1

5 years ago

0.40.0

5 years ago

0.39.0

5 years ago

0.38.0

5 years ago

0.37.0

5 years ago

0.36.0

5 years ago

0.35.0

5 years ago

0.33.1

5 years ago

0.34.0

5 years ago

0.33.0

5 years ago

0.32.1

5 years ago

0.33.0-beta.0

5 years ago

0.32.0

5 years ago

0.32.0-beta.0

5 years ago

0.31.0

5 years ago

0.31.0-beta.2

5 years ago

0.31.0-beta.1

5 years ago

0.31.0-beta.0

5 years ago

0.30.0

5 years ago

0.30.0-beta.0

5 years ago

0.29.0

5 years ago

0.28.0

6 years ago

0.27.0

6 years ago

0.27.0-beta.2

6 years ago

0.26.3

6 years ago

0.26.2

6 years ago

0.26.1

6 years ago

0.27.0-beta.1

6 years ago

0.26.0

6 years ago

0.26.0-beta.0

6 years ago

0.25.0

6 years ago

0.24.3

6 years ago

0.24.2

6 years ago

0.24.1

6 years ago

0.24.0

6 years ago

0.24.0-beta.0

6 years ago

0.23.3

6 years ago

0.23.2

6 years ago

0.17.13

6 years ago

0.23.1

6 years ago

0.23.0

6 years ago

0.22.0

6 years ago

0.21.2

6 years ago

0.21.0

6 years ago

0.20.2

6 years ago

0.20.1

6 years ago

0.20.0

6 years ago

0.19.1

6 years ago

0.19.0

6 years ago

0.18.14

6 years ago

0.18.13

6 years ago

0.18.12

6 years ago

0.16.6

6 years ago

0.18.11

6 years ago

0.18.10

6 years ago

0.18.9

6 years ago

0.18.8

6 years ago

0.18.7

6 years ago

0.18.6

6 years ago

0.18.5

6 years ago

0.18.4

6 years ago

0.18.3

6 years ago

0.18.2

6 years ago

0.18.1

6 years ago

0.18.0

6 years ago

0.17.12

6 years ago

0.17.11

6 years ago

0.17.10

6 years ago

0.17.9

6 years ago

0.17.7

6 years ago

0.17.6

6 years ago

0.17.4

6 years ago

0.17.3

6 years ago

0.17.2

6 years ago

0.17.1

6 years ago

0.16.5

6 years ago

0.16.4-alpha.9

6 years ago

0.16.4-alpha.8

6 years ago

0.16.4-alpha.2

6 years ago

0.16.4-alpha.1

6 years ago

0.16.3

6 years ago

0.16.2

6 years ago

0.16.1

6 years ago

0.16.0

6 years ago

0.15.1

6 years ago

0.15.0

6 years ago

0.14.4

6 years ago

0.14.3

6 years ago

0.14.2

6 years ago

0.14.1

6 years ago

0.14.0

6 years ago

0.13.2

6 years ago

0.13.1

6 years ago

0.13.0

6 years ago

0.12.2

6 years ago

0.12.1

6 years ago

0.12.0

6 years ago

0.11.0

6 years ago

0.10.9

6 years ago

0.10.8

6 years ago

0.10.7

6 years ago

0.10.6

6 years ago

0.10.5

6 years ago

0.10.4

6 years ago

0.10.3

6 years ago

0.10.2

6 years ago

0.10.1

6 years ago

0.10.0

6 years ago

0.9.10

7 years ago

0.9.9

7 years ago

0.9.8

7 years ago

0.9.7

7 years ago

0.9.6

7 years ago

0.9.5

7 years ago

0.9.4

7 years ago

0.9.3

7 years ago

0.9.2

7 years ago

0.9.1

7 years ago

0.9.0

7 years ago

0.8.15

7 years ago

0.8.14

7 years ago

0.8.11

7 years ago

0.8.10

7 years ago

0.8.8

7 years ago

0.8.7

7 years ago

0.8.6

7 years ago

0.8.5

7 years ago

0.8.4

7 years ago

0.8.3

7 years ago

0.8.1

7 years ago

0.8.0

7 years ago

0.8.0-beta.20

7 years ago

0.8.0-beta.19

7 years ago

0.8.0-beta.5

7 years ago

0.8.0-beta.4

7 years ago