1.0.0 • Published 22 days ago

@f1stnpm2/reprehenderit-libero-similique v1.0.0

Weekly downloads
-
License
MIT
Repository
github
Last release
22 days ago

React Spinners

npm version downloads license

Coverage Status Dependency Count Types Included Tree Shaking Supported

A collection of loading spinners with React.js based on Halogen.

This package is bootstraped using react-npm-boilerplate

Demo

Demo Page

Storybook

Installation

With Yarn:

yarn add @f1stnpm2/reprehenderit-libero-similique

With npm:

npm install --save @f1stnpm2/reprehenderit-libero-similique

Usage

Each loader has their own default properties. You can overwrite the defaults by passing props into the loaders.

Each loader accepts a loading prop as a boolean. The loader will render null if loading is false.

Example

import { useState, CSSProperties } from "react";
import ClipLoader from "@f1stnpm2/reprehenderit-libero-similique/ClipLoader";

const override: CSSProperties = {
  display: "block",
  margin: "0 auto",
  borderColor: "red",
};

function App() {
  let [loading, setLoading] = useState(true);
  let [color, setColor] = useState("#ffffff");

  return (
    <div className="sweet-loading">
      <button onClick={() => setLoading(!loading)}>Toggle Loader</button>
      <input value={color} onChange={(input) => setColor(input.target.value)} placeholder="Color of the loader" />

      <ClipLoader
        color={color}
        loading={loading}
        cssOverride={override}
        size={150}
        aria-label="Loading Spinner"
        data-testid="loader"
      />
    </div>
  );
}

export default App;
import React from "react";
import ClipLoader from "@f1stnpm2/reprehenderit-libero-similique/ClipLoader";

const override: React.CSSProperties = {
  display: "block",
  margin: "0 auto",
  borderColor: "red",
};

class AwesomeComponent extends React.Component {
  constructor(props) {
    super(props);
    this.state = {
      loading: true,
    };
  }

  render() {
    return (
      <div className="sweet-loading">
        <ClipLoader
          cssOverride={override}
          size={150}
          color={"#123abc"}
          loading={this.state.loading}
          speedMultiplier={1.5}
          aria-label="Loading Spinner"
          data-testid="loader"
        />
      </div>
    );
  }
}

Available Loaders, PropTypes, and Default Values

Common default props for all loaders:

loading: true;
color: "#000000";
cssOverride: {}
speedMultiplier: 1;

All valid HTML props such as aria-* and data-* props are fully supported.

color prop

color prop accepts a color hash in the format of #XXXXXX or #XXX. It also accepts basic colors listed below:

maroon, red, orange, yellow, olive, green, purple, white, fuchsia, lime, teal, aqua, blue, navy, black, gray, silver

cssOverride prop

The cssOverride prop is an object of camelCase styles used to create inline styles on the loaders. Any html css property is valid here.

size, height, width, and radius props

The input to these props can be number or string.

  • If value is number, the loader will default to css unit px.
  • If value is string, the loader will verify the unit against valid css units.
    • If unit is valid, return the original value
    • If unit is invalid, output warning console log and default to px.

The table below has the default values for each loader.

Loadersizeheightwidthradiusmargin
BarLoader4100
BeatLoader152
BounceLoader60
CircleLoader50
ClimbingBoxLoader15
ClipLoader35
ClockLoader50
DotLoader602
FadeLoader15522
GridLoader15
HashLoader502
MoonLoader602
PacmanLoader252
PropagateLoader15
PuffLoader60
PulseLoader152
RingLoader602
RiseLoader152
RotateLoader152
ScaleLoader35422
SyncLoader152
tapeio-tsTypeScriptarraylinuxbluebirdfile systemcolumnthrottleprotoutilsettingslesscssgrouplazyInt32ArraychromiumES2022rfc4122valuesomitdatastructurecryptomruserializerviewInt8ArrayES2020taskES6shrinkwrapes2016deep-copychinesetc39ansibrowsermapexitsharedarraybufferES8mapreduceminimales2015prunedirectoryArray.prototype.includessetImmediatedynamodbbrowserlistecmascriptttybundlingjshinttypedarrayObject.entriesi18nfigletcloudwatchkarmachannelfastmatchAllfullwidthbindwebcontainslistenersInt16Arrayschemestringifierpackage.jsonstreamspackageclassnamesextraconsumepushObject.fromEntriesdependencieshas-owncomparedroplimitdeepclonedataViewidavaoperating-systemwhichiamerrordatefolderfetchreduceres8toolkitrequesthelpersArrayBufferbatchsafereact-hook-formtypanionECMAScript 6regexpaccessibilityrecursiveinspectasciiwatchconcatMapES7proxyreplaysetsqsreadablestreamcomputed-typespreprocessorObservablesECMAScript 3restfulvarsstreamuuidfunctionurles-shim APIjoiStreamssesflatzerologfast-clonemkdirpstyleguidegdprUnderscoreformatperformancees7unicodeuninstallWeakMapsetPrototypeOfpipeestreeupframeworkshimelmglobalkoreanArray.prototype.flatMapbootstrap lesshooksbrowserslistqseast-asian-widthBigUint64ArraystringifyqueueMicrotaskmacoscallboundECMAScript 5.envcharacterworkflowtypesafeRxJSfindLastObservableWeakSetURLSearchParamsECMAScript 2015awaittypeofoutputkinesisvariablescloudsearchhttpredactinternalencryptiongroupBydescriptorfixed-widthES2019cssObjectfindupnameelasticachephonestoragegatewayexpressjwtpositiveserializationfull-widthownwatchFilelivesomeWebSocketcolourutilitiesESnextnegativestyled-componentsreact-testing-librarypromisesstylesheetconfigurablewgetUint8ArrayhotargumentflatMapenvironmentinstallerrminstallmatchsigtermjsonl10nfunctionalintrinsichasOwnProperty_.extendparsemovefluxcss variablesetterauthemojixhreslintregulartimeiterateES5requireassertwaitconcurrencyhashRFC-6455optimistformattingIteratorgetwordwrapcircularstringwhatwgmochaflattenECMAScript 2023entriesbreaka11yprivateUint8ClampedArrayregular expressionsform-validationhasOwnformscloneiteratortrimLeftdatatslibnodeagentReactiveExtensionsquerystringReactiveXelbreduxredux-toolkitvalidHyBishellgradients cssnegative zeroendpointArraytypesPushstatuss3dom-testing-librarychaicurltapvpcECMAScript 2021domenvironmentsloggingjsonpathstatelessreal-timergbglobflagstddgradients css3__proto__getOwnPropertyDescriptorfastifycloudformationworkerexit-codemetadataES2016scheme-validationmoduletelephoneslotECMAScript 2018package managerpredictablelessec2pluginterminallimitedcommanderdiffdebuggerTypeBoxURLpromisees5css lessbyteOffsetfastcloneresolvebyteLengthsnsSetvalidationnopefilterstylesextensionmobileapiwrapparentsfindLastIndextoStringTagmonorepoinvariantcss nestingstyleelectronefficientserializetrimStarttrimEndeslintpluginprettyeslintconfigspinnersFloat32ArrayECMAScript 2019speed[[Prototype]]picomatcharktypegetPrototypeOftraversecolorfpsdeterministicpnpm9ECMAScript 7StyleSheetstylingcloudfrontreadableutilityprototypecompilersearchassertsoptimizerprefixECMAScript 2016
1.0.0

22 days ago