From af76a3b99bec09e0b40d82e515afe484755a08b5 Mon Sep 17 00:00:00 2001 From: Alexa Nguyen Date: Mon, 18 Oct 2021 21:28:50 +0800 Subject: [PATCH 1/2] Fix typos in README and formatting --- README.md | 79 +++++++++++++++++++++++++++++++++---------------------- 1 file changed, 47 insertions(+), 32 deletions(-) diff --git a/README.md b/README.md index e45f322e..1ed93175 100644 --- a/README.md +++ b/README.md @@ -30,7 +30,6 @@ [![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat-square)](http://makeapullrequest.com) [![Code of Conduct](https://img.shields.io/badge/code%20of-conduct-ff69b4.svg?style=flat-square)](https://github.com/express-labs/pure-react-carousel/blob/master/CODE_OF_CONDUCT.md) - ## Motivation My goal was to create a 100% ReactJS carousel that doesn't try to impose structure or styles that need to be defeated in order to match your site's design standards. Are you tired of fighting some other developer's CSS or DOM structure? If so, this carousel is for you. @@ -71,6 +70,7 @@ Carousels: Love them or hate them. However, if you are a React developer, and y * [Contributors](#contributors) ## 🛠 Tutorial + Let's make a simple carousel with three slides, a next button, and a back button. 1. Add the module to your project. @@ -92,7 +92,7 @@ Let's make a simple carousel with three slides, a next button, and a back button import 'pure-react-carousel/dist/react-carousel.es.css'; ``` -4. Put a CarouselProvider component in your code. This allows the other carousel components to communicate with each other. The only required properties are the orientation, naturalSlideWidth, and naturalSlideHeight. The naturalSlideWidth and naturalSlideHeight are used to create an aspect ratio for each slide. Since the carousel is responsive by default, it will stretch to fill in the width of it's parent container. The CarouselProvider must also have children. We'll add the children in the next step. +4. Put a CarouselProvider component in your code. This allows the other carousel components to communicate with each other. The only required properties are the totalSlides, naturalSlideWidth, and naturalSlideHeight. The naturalSlideWidth and naturalSlideHeight are used to create an aspect ratio for each slide. Since the carousel is responsive by default, it will stretch to fill in the width of its parent container. The CarouselProvider must also have children. We'll add the children in the next step. ```JSX import React from 'react'; @@ -166,49 +166,53 @@ Let's make a simple carousel with three slides, a next button, and a back button } ``` - That's it. You have a super basic Carousel. There are other components you can add, like ButtonFirst, ButtonLast, an Image component, and even an ImageWithZoom component that zooms on mouse hover or finger tap. -Obviously, you can customize the heck out of the layout. If you need to bury your Slider component in 18 parent divs, go for it. It will still do it's job. Feel free to add the className property to any of the Components to further customize your carousel. Or, hook into the many BEM named default CSS class names built into the carousel components. +Obviously, you can customize the heck out of the layout. If you need to bury your Slider component in 18 parent divs, go for it. It will still do its job. Feel free to add the className property to any of the Components to further customize your carousel. Or, hook into the many BEM named default CSS class names built into the carousel components. Some components have a ancestor / descendant relationship but they don't have to be direct descendants of the parent. For example, Slide needs to be a descendant of Slider, but you can put a bunch of div wrappers around slide if you need to. A good analogy are the html tags `table` and `tr`. The `tr` tag needs to be a descendant of `table`, but it doesn't have to be a direct descendant. You can have a `tbody` between them in the tree. ## Component Properties (props) #### classname + You can attach your own className property to each and every component in this library and it will be appended to the list of classes. It's appended so that it has more specificity in a tie, allowing your CSS to more easily override any internal styles without resorting to using !important. #### styles + You can attach your own styles property to each component in this library, however, any styles generated by the component take precedence over any styles you provide. Some components, like the ``, need their internal styles to function correctly. #### event props (onClick, onFocus, onBlur, etc) + You can supply your own event callbacks to any component. Your event callbacks are called after a component's internal event handling. Basically, your callback becomes a callback to our callback. Say that 10 times fast. :-) #### all other props + Any remaining props not consumed by the component are passed directly to the root element of a component unless otherwise noted in that component's documentation. This makes all the components in this library HIGHLY configurable. You can, for example, add your own event handlers, or change aria tags, etc. ## Components ### <CarouselProvider /> + | property | type | default | required | purpose | | -------- | ---- | ------- | -------- | ------- | | **children** | [string|node] | | **Yes** | Children is a special React property. Basically, the CarouselProvider needs to wrap other Carousel components and JSX | | className | [string|null] | null | No | Optional className string that will be appended to the component's className string | -| currentSlide | number | 0 | No | <Slide \> to display ONLY when CarouselProvider mounts. The indexing of <Slide /> components starts with 0. This is a poorly named variable and will be deprecated in a future version. | -| hasMasterSpinner | bool | false | No | When true, a spinner will cover <Slider /> component until all <Image \> and <ImageWithZoom \> are done loading images. If there are no <Image /> or <ImageWithZoom> components, the spinner will spin until this property is set to false | +| currentSlide | number | 0 | No | <Slide /> to display ONLY when CarouselProvider mounts. The indexing of <Slide /> components starts with 0. This is a poorly named variable and will be deprecated in a future version. | +| hasMasterSpinner | bool | false | No | When true, a spinner will cover <Slider /> component until all <Image /> and <ImageWithZoom /> are done loading images. If there are no <Image /> or <ImageWithZoom /> components, the spinner will spin until this property is set to false | | interval | number | 5000 | No | Number of milliseconds to wait when the auto slideshow is active | | isPlaying | bool | false | No | Setting this to true starts an auto slideshow. After "interval" milliseconds, the slider will move by "step" slides either forward or backwards depending on the value of "playDirection". | | lockOnWindowScroll | bool | false | No | When set to true, scrolling of the carousel slides are disabled while the browser window is scrolling | -| **naturalSlideHeight** | number | | **Yes** | The natural height of each <\Slide > component. ** | -| **naturalSlideWidth** | number | | **Yes** | The natural width of each <\Slide > component. ** | -| orientation | string | "horizontal" | No | Possible values are "horizontal" and "vertical". Let's you have a horizontal or vertical carousel. | -| playDirection | ['forward'|'backward' ] | 'forward' | No | The direction for the auto slideshow | +| **naturalSlideHeight** | number | | **Yes** | The natural height of each <Slide /> component. | +| **naturalSlideWidth** | number | | **Yes** | The natural width of each <Slide /> component. | +| orientation | string | 'horizontal' | No | Possible values are "horizontal" and "vertical". Lets you have a horizontal or vertical carousel. | +| playDirection | ['forward'|'backward'] | 'forward' | No | The direction for the auto slideshow | | step | number | 1 | No | The number of slides to move when pressing the <ButtonBack /> and <ButtonNext /> buttons.| | dragStep | number | 1 | No | The number of slides to move when performing a short touch drag.| | tag | string | 'div' | No | The HTML element to use for the provider. |` -| **totalSlides** | number | | **Yes** | Always set this to match the total number of <Slide > components in your carousel | +| **totalSlides** | number | | **Yes** | Always set this to match the total number of <Slide /> components in your carousel | | touchEnabled | boolean | true | No | Set to true to enable touch events | | dragEnabled | boolean | true | No | Set to true to enable mouse dragging events | | visibleSlides | number | 1 | No | The number of slides to show at once. This number should be <= totalSlides | @@ -224,9 +228,10 @@ Any remaining props not consumed by the component are passed directly to the roo ``` **__More about naturalSlideWidth and naturalSlideHeight__** -The carousel is responsive and by default will flex to the full width of the parent container. It's up to you to contain the carousel width via css. Each slide will be the same height to width ratio ([intrinsic ratio](https://alistapart.com/d/creating-intrinsic-ratios-for-video/example2.html)). CarouselProvider needs to know the default size of each <Slide />. Note: you can make the carousel non-responsive by setting the width of to a fixed css unit, like pixels. There are many other ways to make the carousel non-responsive. +The carousel is responsive and by default will flex to the full width of the <Slider /> parent container. It's up to you to contain the carousel width via css. Each slide will be the same height to width ratio ([intrinsic ratio](https://alistapart.github.io/code-samples/creating-intrinsic-ratios-for-video/example2.html)). CarouselProvider needs to know the default size of each <Slide />. Note: you can make the carousel non-responsive by setting the width of <Slider /> to a fixed css unit, like pixels. There are many other ways to make the carousel non-responsive. ### <Slider /> + A Slider is a viewport that masks slides. The Slider component must wrap one or more Slide components. | property | type | default | required | purpose | @@ -239,10 +244,10 @@ A Slider is a viewport that masks slides. The Slider component must wrap one or | classNameTrayWrap | [string|null] | null | No | Optional className string that is applied to a div that surrounds the Slider's tray | | moveThreshold | number | 0.1 | No | Threshold to control the drag distance that triggers a scroll to the next or previous slide. (slide width or height * moveThreshold = drag pixel distance required to scroll) | | onMasterSpinner | [function|null] | null | No | Optional callback function that is called when the Master Spinner is visible. Requires that <CarouselProvider /> set hasMasterSpinner to true | -| spinner | function | null | No | Optional inline JSX (aka "render props") to render your own custom spinner. Example `() => ` If left blank, the default spinner is used. | +| spinner | function | null | No | Optional inline JSX (aka "render props") to render your own custom spinner. Example `() => `. If left blank, the default spinner is used. | | style | object | {} | No | Optional css styles to add to the Slider. Note: internal css properties take precedence over any styles specified in the styles object | | trayProps | object | {} | No | Any props you want to attach to the slider tray with the exception of className and style. The className prop is handled via classNameTray prop above. Style is used internally. Any event handlers like onMouseDown or others are called after any of our internal event handlers. | -| trayTag | string | 'div' | No | The HTML tag to used for the tray (the thing that holds all the slides and moves the slides back and forth.) | +| trayTag | string | 'div' | No | The HTML tag to used for the tray (the thing that holds all the slides and moves the slides back and forth). | #### The Slider component creates the following pseudo HTML by default. @@ -267,15 +272,16 @@ A Slider is a viewport that masks slides. The Slider component must wrap one or - Pass the CSS class you create to the classNameAnimation property of Slider. ### <Slide /> + The Slide component is a container with an intrinsic ratio computed by the CarouselProvider naturalSlideWidth and naturalSlideHeight properties. By default, only one slide is visible in the Slider at a time. You can change this by altering the visibleSlides property of the CarouselProvider. Slide components also contain a div that acts as an aria compliant focus ring when the Slide receives focus either by using a keyboard tab, mouse click, or touch. | property | type | default | required | purpose | | -------- | ---- | ------- | -------- | ------- | | className | [string|null] | null | No | Optional className string that will be appended to the component's className string. | -| ariaLabel | string |'slide' | N | Optional sting that sets the "aria-label" attribute.| +| ariaLabel | string |'slide' | N | Optional string that sets the "aria-label" attribute.| | classNameHidden | [string|null] | null | No | Optional className string that will be appended to the component's className string when the slide is not visible. | | classNameVisible | [string|null] | null | No | Optional className string that will be appended to the component's className string when the slide is visible. | -| **index** | number | | **Yes** | You must consecutively number the <Slide > components in order starting with zero. | +| **index** | number | | **Yes** | You must consecutively number the <Slide /> components in order starting with zero. | | innerClassName | [string|null] | null | No | Optional className string that will be appended to an internal HTML element created by the Component. Best to just use Chrome Dev Tools to inspect the demo app or check the source code for <Slide /> | | innerTag | string | 'div' | No | The inner HTML element for each Slide. | | onBlur | [function|null] | null | No | Optional callback function that is called after the internal onBlur function is called. It is passed the React synthetic event | @@ -284,6 +290,7 @@ The Slide component is a container with an intrinsic ratio computed by the Carou | tag | string | 'div' | No | The root HTML element for each Slide. | #### The Slide component creates the following pseudo HTML by default: + ```HTML @@ -294,7 +301,8 @@ The Slide component is a container with an intrinsic ratio computed by the Carou ``` ### <Dot /> -A Dot component is a HTML button. Dots directly correlate to slides. Clicking on a dot causes it's correlating slide to scroll into the left-most visible slot of slider. The dots for currently visible slides cause are disabled. You can override the auto-disable feature by setting disabled to false (see table below) + +A Dot component is a HTML button. Dots directly correlate to slides. Clicking on a dot causes its correlating slide to scroll into the left-most visible slot of slider. The dots for currently visible slides cause are disabled. You can override the auto-disable feature by setting disabled to false (see table below) | property | type | default | required | purpose | | -------- | ---- | ------- | -------- | ------- | @@ -313,16 +321,17 @@ A Dot component is a HTML button. Dots directly correlate to slides. Clicking ``` ### <DotGroup /> -A compound component that creates a bunch of Dot's automatically for you. + +A compound component that creates a bunch of Dots automatically for you. | property | type | default | required | purpose | | -------- | ---- | ------- | -------- | ------- | | children | [string|node|null] | null | No | Any JSX wrapped by this component will appear AFTER the dots. | | className | [string|null] | null | No | Optional className string that will be appended to the component's className string. | | dotNumbers | boolean | false | No | Setting to true automatically adds text numbers the dot buttons starting at 1. | -| disableActiveDots | boolean | true | No | Setting to true make all dots, including active dots, enabled. | -| showAsSelectedForCurrentSlideOnly | boolean | false | No | Setting to true show only the current slide dot as selected. | -| renderDots | function| null | No | It accepts `props` and overrides renderDots() in . | +| disableActiveDots | boolean | true | No | Setting to true makes all dots, including active dots, enabled. | +| showAsSelectedForCurrentSlideOnly | boolean | false | No | Setting to true shows only the current slide dot as selected. | +| renderDots | function| null | No | It accepts `props` and overrides renderDots() in <DotGroup />. | #### The DotGroup component creates the following pseudo HTML by default: @@ -343,7 +352,7 @@ A compound component that creates a bunch of Dot's automatically for you. | alt | string | "" | No | Specifies an alternate text for an image, if the image cannot be displayed. | | children | [string|node|null] | null | Yes | Any optional JSX wrapped by the Image component | | className | [string|null] | null | No | Optional className string that will be appended to the component's className string. | -| **hasMasterSpinner** | **bool** | | **Yes** | **If set to true, a spinner will cover the entire slider viewport until all Image components with hasMasterSpinner set to true are finished loading images. It only takes one Image component with hasMasterSpinner to enable the master spinner. ** | +| **hasMasterSpinner** | **bool** | | **Yes** | **If set to true, a spinner will cover the entire slider viewport until all Image components with hasMasterSpinner set to true are finished loading images. It only takes one Image component with hasMasterSpinner to enable the master spinner.** | | isBgImage | bool | false | No | Setting this to true makes the image load as a background image. Any child JSX (see children property) will appear on top of the image. If set to false, no image will appear unless your child JSX displays the image via an image tag or some other means. | | onError | [func|null] | null | No | Callback function called if the image defined by the src property fails to load. This Callback is fired after the Image component's internal handleImageError method. | | onLoad | [func|null] | null | No | Callback function called if the image defined by the src property loads successfully. This Callback is fired after the Image component's internal renderSuccess method. | @@ -353,6 +362,7 @@ A compound component that creates a bunch of Dot's automatically for you. | tag | string | "img" | No | The element that will receive the image. Another option might be to set this to "div". Any tag besides "img" will result in the image being loaded as the css background-image for that tag. | ### <ButtonBack /> + A button for moving the slider backwards. Backwards on a horizontal carousel means "move to the left". Backwards on a vertical carousel means "move to the top". The slider will traverse an amount of slides determined by the step property of CarouselProvider. | property | type | default | required | purpose | @@ -371,6 +381,7 @@ A button for moving the slider backwards. Backwards on a horizontal carousel mea ``` ### <ButtonNext /> + A button for moving the slider forwards. Forwards on a horizontal carousel means "move to the right". Backwards on a vertical carousel means "move to the bottom". The slider will traverse an amount of slides determined by the step property of CarouselProvider. | property | type | default | required | purpose | @@ -389,6 +400,7 @@ A button for moving the slider forwards. Forwards on a horizontal carousel means ``` ### <ButtonFirst /> + Moves the slider to the beginning of the slides. | property | type | default | required | purpose | @@ -407,6 +419,7 @@ Moves the slider to the beginning of the slides. ``` ### <ButtonLast /> + Moves the slider to the end of the slides (totalSlides - visibleSlides). | property | type | default | required | purpose | @@ -425,13 +438,14 @@ Moves the slider to the end of the slides (totalSlides - visibleSlides). ``` ### <ButtonPlay /> + Pressing this button causes the slides to automatically advance by CarouselProvider's step property after an interval determined by CarouselProvider's interval property. | property | type | default | required | purpose | | -------- | ---- | ------- | -------- | ------- | | children | [string|node] | null | No | Children is a special React property. Content wrapped by ButtonPlay will appear AFTER the content of childrenPaused and childrenPlaying | | childrenPaused | [string|node] | null | No | Content to display when the slide show is paused. | -| childrenPlaying | [string|node] | null | No | Content to display when the slide show is playing | +| childrenPlaying | [string|node] | null | No | Content to display when the slide show is playing. | | className | [string|null] | null | No | Optional className string that will be appended to the component's className string. | | disabled | [boolean|null] | null | No | Null means ButtonPlay will automatically determine if this button is disabled. Setting this to true will force the button to be disabled. Setting this to false will prevent the button from ever being disabled. | | onClick | [function|null] | null | No | Optional callback function that is called after the internal onClick function is called. It is passed the React synthetic event | @@ -450,7 +464,7 @@ Pressing this button causes the slides to automatically advance by CarouselProvi __NOTE: ADVANCED USE ONLY.__ -Use this HOC to pass CarouselProvider state properties as props to a component. Basically, Your custom component must be an descendant of ``. It doesn't have to be a direct descendant, it just needs to be between some the opening and closing CarouselProvider tags somewhere. For example... +Use this HOC to pass CarouselProvider state properties as props to a component. Basically, your custom component must be an descendant of ``. It doesn't have to be a direct descendant, it just needs to be between some opening and closing CarouselProvider tags somewhere. For example... ```html // pseudocode example @@ -562,7 +576,8 @@ export function MyComponentUsingContext() { ``` ## TypeScript usage -The current bundled Typescript definitions are mostly complete. Certain edge case could have been not accounted for! Pull requests to improve them are welcome and appreciated. + +The current bundled Typescript definitions are mostly complete. Certain edge cases could have been not accounted for! Pull requests to improve them are welcome and appreciated. If you've never contributed to open source before, then you may find [this free video course](https://egghead.io/courses/how-to-contribute-to-an-open-source-project-on-github) helpful. @@ -605,10 +620,9 @@ export interface CarouselInjectedProps { **Also the first argument which is the component to wrap, needs to be a `React.ComponentClass` to render properly and therefore stateless component are not possible.** - ### Examples: -* Both with MapStateToProps and custom props +- Both with MapStateToProps and custom props ```TypeScript import { @@ -647,10 +661,9 @@ const DecoratedComponent = WithStore ``` -* No MapStateToProps +- No MapStateToProps ```TypeScript - interface UpdateCheckProps extends CarouselInjectedProps { readonly name: string, } @@ -670,13 +683,15 @@ const DecoratedComponent = WithStore(InjectedComponent) ``` ## More Documentation to Come + I promise to add docs for every component. In the meantime, feel free to download and run the demo app. Looking at the code might help you out. ## Dev Workflow -- `npm start` starts a local development server, opens the dev page with your default browser, and watches for changes via livereload

-- `npm run build` compiles commonjs and ES modules and places them in the dist directory

+ +- `npm start` starts a local development server, opens the dev page with your default browser, and watches for changes via livereload.

+- `npm run build` compiles commonjs and ES modules and places them in the dist directory.

- `npm test` runs unit and integration tests using Jest + Enzyme. Also does coverage reporting.

-- `npm lint` runs linting tests using eslint & airbnb linting.

+- `npm lint` runs linting tests using ESLint & Airbnb linting.

- `npm test:watch` same as `npm test` but it will watch for updates and auto-run tests. Does not do coverage reporting.

## Contributors From 2add050a6b3d895ab4df6b16de0a51ac9941142b Mon Sep 17 00:00:00 2001 From: Alexa Nguyen Date: Tue, 19 Oct 2021 10:49:06 +0800 Subject: [PATCH 2/2] fix: More typos --- README.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 1ed93175..d4bc8168 100644 --- a/README.md +++ b/README.md @@ -37,13 +37,13 @@ My goal was to create a 100% ReactJS carousel that doesn't try to impose structu Carousels: Love them or hate them. However, if you are a React developer, and you have to use a carousel, why not use one that was... - Developed from the ground-up in React. -- Is not a wrapper or port of some non-react carousel like Slick or Flickity. +- Is not a wrapper or port of some non-React carousel like Slick or Flickity. - Fully supports touch events. -- Is aria compliant. +- Is ARIA compliant. - Is responsive by default. - Lets you assemble the carousel components in the DOM in any order you desire so long as they are all children of a single <CarouselProvider /> component. - Lets you put any class names, properties, attributes, or styles on any of the components that you need. -- Supports ES6 and commonjs. +- Supports ES6 and CommonJS. - Has 100% test coverage. Solid! ## Table of contents @@ -689,7 +689,7 @@ I promise to add docs for every component. In the meantime, feel free to downlo ## Dev Workflow - `npm start` starts a local development server, opens the dev page with your default browser, and watches for changes via livereload.

-- `npm run build` compiles commonjs and ES modules and places them in the dist directory.

+- `npm run build` compiles CommonJS and ES modules and places them in the dist directory.

- `npm test` runs unit and integration tests using Jest + Enzyme. Also does coverage reporting.

- `npm lint` runs linting tests using ESLint & Airbnb linting.

- `npm test:watch` same as `npm test` but it will watch for updates and auto-run tests. Does not do coverage reporting.