4.1.1 • Published 2 years ago

bpk-react-utils-css v4.1.1

Weekly downloads
19
License
Apache-2.0
Repository
github
Last release
2 years ago

bpk-react-utils

Miscellaneous React based utilities for use in Backpack components.

Installation

npm install bpk-react-utils --save-dev

Portal.js

Render's children into a new component tree and appends it to document.body. Useful for Modals, Popovers, Tooltips etc where it's necessary in overcoming z-index issues when absolutely positioning elements.

Usage

import { Portal } from 'bpk-react-utils';
import BpkButton from 'bpk-component-button';
import { BpkCode } from 'bpk-component-code';
import React, { Component } from 'react';

class MyComponent extends Component {
  constructor() {
    super();

    this.state = {
      isOpen: false,
    };

  }

  onOpen = () => {
    this.setState({
      isOpen: true,
    });
  }

  onClose = () => {
    this.setState({
      isOpen: false,
    });
  }

  render() {
    return (
      <div>
        <BpkButton onClick={this.onOpen}>Open portal</BpkButton>
        <Portal
          isOpen={this.state.isOpen}
          onClose={this.onClose}
        >
          <div>I'm now appended to <BpkCode>document.body</BpkCode></div>
        </Portal>
      </div>
    );
  }
}

Props

PropertyPropTypeRequiredDefault Value
childrennodetrue-
isOpenbooltrue-
beforeClosefuncfalsenull
onClosefuncfalsenoop
onOpenfuncfalsenoop
onRenderfuncfalsenoop
renderTargetfuncfalsenull
targetoneOf(function, node)falsenull
closeOnEscPressedboolfalsetrue

cssModules.js

A helpful utility which permits backwards compatibility with hard coded classes and CSS modules.

Usage

import React from 'react';
import { cssModules } from 'bpk-react-utils';

import STYLES from './MyComponent.scss';

const getClassName = cssModules(STYLES);

const MyComponent = (props) => (
  <div className={getClassName('MyComponent')}>
    <div className={getClassName('MyComponent__inner')}>
      {props.children}
    </div>
  </div>
);

With CSS modules:

<div class="_35WloynrPDta8fhSfoHEgE">
  <div class="_1ghNYY7jOYzUneVCT4piQ9">
    Some text.
  </div>
</div>

Without CSS modules:

<div class="MyComponent">
  <div class="MyComponent__inner">
    Some text.
  </div>
</div>

The returned function accepts multiple class names and ignores values other than strings. e.g:

import { cssModules } from 'bpk-react-utils';

import STYLES from './MyComponent.scss';

const getClassNames = cssModules(STYLES);

const MyComponent = (props) => (
  <div className={getClassName('MyComponent', props.disabled && 'MyComponent--disabled')}>
   {props.children}
  </div>
);

Will result in MyComponent MyComponent--disabled if props.disabled is true or MyComponent otherwise.

TransitionInitialMount.js

A wrapper around react-transition-group which makes it easy to transition a components initial mount. All you need to provide is two class names and a timeout.

Usage

import React from 'react';
import { TransitionInitialMount } from 'bpk-react-utils';

const MyComponent = (props) => (
  <TransitionInitialMount
    appearClassName="my-transition-class--appear"
    appearActiveClassName="my-transition-class--appear-active"
    transitionTimeout={300}
  >
    <div>Some text.</div>
  </TransitionInitialMount>
);
@import '~bpk-mixins/index';

.my-transition-class {
  transition: opacity $bpk-duration-sm ease-in-out;
  opacity: 1;

  &--appear {
    opacity: 0;
  }

  &--appear-active {
    opacity: 1;
  }
}

Props

PropertyPropTypeRequiredDefault Value
childrennodetrue-
appearClassNamestringtrue-
appearActiveClassNamestringtrue-
transitionTimeoutnumbertrue-

isRTL

Returns true if the browser is showing content right-to-left.

Usage

import React from 'react';
import { isRTL } from 'bpk-react-utils';

if (isRTL()) {
  // do RTL stuff
} else {
  // do LTR stuff
}

isDeviceIphone

Returns true if the device is an iPhone.

Usage

import React from 'react';
import { isDeviceIphone } from 'bpk-react-utils';

if (isDeviceIphone()) {
  // do iPhone specific stuff
} else {
  // do other browser/device stuff
}

isDeviceIpad

Returns true if the device is an iPad.

Usage

import React from 'react';
import { isDeviceIpad } from 'bpk-react-utils';

if (isDeviceIpad()) {
  // do iPad specific stuff
} else {
  // do other browser/device stuff
}

isDeviceIos

Returns true if the platform is iOS (iPhone/iPad).

Usage

import React from 'react';
import { isDeviceIos } from 'bpk-react-utils';

if (isDeviceIos()) {
  // do iOS specific stuff
} else {
  // do other browser/device stuff
}
@infinitebrahmanuniverse/nolb-bp@everything-registry/sub-chunk-1259bpk-scrim-utils-cssbpk-storybook-utils-cssbpk-component-tooltip-cssbpk-component-table-cssbpk-component-text-cssbpk-component-textarea-cssbpk-component-theme-toggle-cssbpk-component-ticket-cssbpk-component-phone-input-cssbpk-component-popover-cssbpk-component-progress-cssbpk-component-radio-cssbpk-component-select-cssbpk-component-skip-link-cssbpk-component-slider-cssbpk-component-spinner-cssbpk-component-star-rating-cssbpk-component-switch-cssbpk-component-link-cssbpk-component-list-cssbpk-component-loading-button-cssbpk-component-map-cssbpk-component-nudger-cssbpk-component-overlay-cssbpk-component-pagination-cssbpk-component-panel-cssbpk-component-paragraph-cssbpk-component-mobile-scroll-container-cssbpk-component-modal-cssbpk-component-navigation-bar-cssbpk-component-rating-cssbpk-component-router-link-cssbpk-component-rtl-toggle-cssbpk-component-scrollable-calendar-cssbpk-component-section-list-cssbpk-component-navigation-stack-cssbpk-component-calendar-cssbpk-component-card-cssbpk-component-checkbox-cssbpk-component-chip-cssbpk-component-banner-alert-cssbpk-component-barchart-cssbpk-component-blockquote-cssbpk-component-breadcrumb-cssbpk-component-breakpoint-cssbpk-component-datepicker-cssbpk-component-description-list-cssbpk-component-dialog-cssbpk-component-drawer-cssbpk-component-fieldset-cssbpk-component-accordion-cssbpk-component-aria-live-cssbpk-component-autosuggest-cssbpk-component-badge-cssbpk-component-close-button-cssbpk-component-code-cssbpk-component-content-container-cssbpk-component-datatable-cssbpk-component-flare-cssbpk-component-form-validation-cssbpk-component-graphic-promotion-cssbpk-component-grid-cssbpk-component-grid-toggle-cssbpk-component-heading-cssbpk-component-horizontal-nav-cssbpk-component-icon-cssbpk-component-image-cssbpk-component-infinite-scroll-cssbpk-component-input-cssbpk-component-label-css@zalastax/nolb-bp
4.1.1

2 years ago

4.1.0

2 years ago

4.0.2

2 years ago

4.0.1

3 years ago

3.1.3

3 years ago

3.1.1

3 years ago

4.0.0

3 years ago

3.1.0

3 years ago

3.0.13

3 years ago

3.0.12

3 years ago

3.0.11

3 years ago

3.0.10

3 years ago

3.0.9

3 years ago

3.0.8

3 years ago

3.0.7

4 years ago

3.0.6

4 years ago

3.0.5

4 years ago

3.0.4

4 years ago

3.0.3

4 years ago

3.0.2

4 years ago