Skip to content

Commit

Permalink
feat: add showIndicators and showNavigators properties to carousel co… (
Browse files Browse the repository at this point in the history
#3231)

* feat: add showIndicators and showNavigators properties to carousel component.

* Add new carousel attributes to the api-generator.

Co-authored-by: Ulaş Turan <[email protected]>
  • Loading branch information
ulasturann and Ulaş Turan authored Sep 6, 2022
1 parent 7362e5c commit 8178dcc
Show file tree
Hide file tree
Showing 4 changed files with 38 additions and 4 deletions.
12 changes: 12 additions & 0 deletions api-generator/components/carousel.js
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,18 @@ const CarouselProps = [
default: 'false',
description: 'Defines if scrolling would be infinite.'
},
{
name: 'showIndicators',
type: 'boolean',
default: 'false',
description: 'Whether to display indicator container.'
},
{
name: 'showNavigators',
type: 'boolean',
default: 'true',
description: 'Whether to display navigation buttons in container.'
},
{
name: 'autoplayInterval',
type: 'number',
Expand Down
18 changes: 18 additions & 0 deletions components/doc/carousel/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -549,6 +549,24 @@ const responsiveOptions = [
<td>false</td>
<td>Defines if scrolling would be infinite.</td>
</tr>
<tr>
<td>showIndicators</td>
<td>boolean</td>
<td>false</td>
<td>Whether to display indicator container.</td>
</tr>
<tr>
<td>showNavigators</td>
<td>boolean</td>
<td>true</td>
<td>Whether to display navigation buttons in container.</td>
</tr>
<tr>
<td>circular</td>
<td>boolean</td>
<td>false</td>
<td>Defines if scrolling would be infinite.</td>
</tr>
<tr>
<td>autoplayInterval</td>
<td>number</td>
Expand Down
10 changes: 6 additions & 4 deletions components/lib/carousel/Carousel.js
Original file line number Diff line number Diff line change
Expand Up @@ -449,13 +449,13 @@ export const Carousel = React.memo(

return (
<div className={className}>
{backwardNavigator}
{props.showNavigators ? backwardNavigator : null}
<div className="p-carousel-items-content" style={{ height: height }} onTouchStart={onTouchStart} onTouchMove={onTouchMove} onTouchEnd={onTouchEnd}>
<div ref={itemsContainerRef} className="p-carousel-items-container" onTransitionEnd={onTransitionEnd}>
{items}
</div>
</div>
{forwardNavigator}
{props.showNavigators ? forwardNavigator : null}
</div>
);
};
Expand Down Expand Up @@ -531,7 +531,7 @@ export const Carousel = React.memo(
{header}
<div className={contentClassName}>
{content}
{indicators}
{!props.showIndicators ? indicators : null}
</div>
{footer}
</div>
Expand Down Expand Up @@ -562,5 +562,7 @@ Carousel.defaultProps = {
contentClassName: null,
containerClassName: null,
indicatorsContentClassName: null,
onPageChange: null
onPageChange: null,
showIndicators: false,
showNavigators: true
};
2 changes: 2 additions & 0 deletions components/lib/carousel/carousel.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,8 @@ export interface CarouselProps extends Omit<React.DetailedHTMLProps<React.HTMLAt
indicatorsContentClassName?: string;
onPageChange?(e: CarouselPageChangeParams): void;
children?: React.ReactNode;
showNavigators: boolean;
showIndicators: boolean;
}

export declare class Carousel extends React.Component<CarouselProps, any> {
Expand Down

0 comments on commit 8178dcc

Please sign in to comment.