Add arrow component
This commit is contained in:
19
src/Arrow/Arrow.stories.js
Normal file
19
src/Arrow/Arrow.stories.js
Normal file
@@ -0,0 +1,19 @@
|
||||
import Arrow from './Arrow.svelte';
|
||||
|
||||
export default {
|
||||
title: 'Arrow',
|
||||
component: Arrow,
|
||||
argTypes: {
|
||||
onClick: { action: 'onClick' }
|
||||
}
|
||||
};
|
||||
|
||||
const Template = ({ onClick, ...args }) => ({
|
||||
Component: Arrow,
|
||||
props: args,
|
||||
on: {
|
||||
click: onClick,
|
||||
},
|
||||
});
|
||||
|
||||
export const Primary = Template.bind({});
|
||||
50
src/Arrow/Arrow.svelte
Normal file
50
src/Arrow/Arrow.svelte
Normal file
@@ -0,0 +1,50 @@
|
||||
<script>
|
||||
/**
|
||||
* Indicates direction of the arrow ('next', 'prev')
|
||||
*/
|
||||
export let direction = 'next'
|
||||
</script>
|
||||
|
||||
<div
|
||||
class="circle"
|
||||
on:click
|
||||
>
|
||||
<i
|
||||
class="arrow"
|
||||
class:next={direction === 'next'}
|
||||
class:prev={direction === 'prev'}
|
||||
></i>
|
||||
</div>
|
||||
|
||||
<style>
|
||||
:root {
|
||||
--size: 2px
|
||||
}
|
||||
.circle {
|
||||
width: 20px;
|
||||
height: 20px;
|
||||
border-radius: 50%;
|
||||
background-color: rgba(93, 93, 93, 0.5); /* #5d5d5d */
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
transition: opacity 100ms ease;
|
||||
}
|
||||
.circle:hover {
|
||||
opacity: 0.9;
|
||||
}
|
||||
.arrow {
|
||||
border: solid #1e1e1e;
|
||||
border-width: 0 var(--size) var(--size) 0;
|
||||
padding: var(--size);
|
||||
position: relative;
|
||||
}
|
||||
.next {
|
||||
transform: rotate(-45deg);
|
||||
left: calc(var(--size) / -2);
|
||||
}
|
||||
.prev {
|
||||
transform: rotate(135deg);
|
||||
right: calc(var(--size) / -2);
|
||||
}
|
||||
</style>
|
||||
@@ -1,11 +1,14 @@
|
||||
<script>
|
||||
import { tweened } from 'svelte/motion';
|
||||
import { cubicInOut } from 'svelte/easing';
|
||||
import { tweened } from 'svelte/motion';
|
||||
import { cubicInOut } from 'svelte/easing';
|
||||
|
||||
const size = tweened(10, {
|
||||
duration: 100,
|
||||
easing: cubicInOut
|
||||
});
|
||||
const sizePx = 5
|
||||
const sizeCurrentPx = 8
|
||||
|
||||
const size = tweened(sizePx, {
|
||||
duration: 250,
|
||||
easing: cubicInOut
|
||||
});
|
||||
|
||||
/**
|
||||
* Indicates if dot is active
|
||||
@@ -13,7 +16,7 @@
|
||||
export let active = false
|
||||
|
||||
$: {
|
||||
size.set(active ? 13 : 10)
|
||||
size.set(active ? sizeCurrentPx : sizePx)
|
||||
}
|
||||
</script>
|
||||
|
||||
|
||||
@@ -13,6 +13,7 @@
|
||||
getIsNotCompletePage
|
||||
} from '../utils/size'
|
||||
import Dots from '../Dots/Dots.svelte'
|
||||
import Arrow from '../Arrow/Arrow.svelte'
|
||||
|
||||
/**
|
||||
* Enable Next/Prev arrows
|
||||
@@ -139,12 +140,11 @@
|
||||
<div class="main-container">
|
||||
<div class="carousel-container">
|
||||
{#if arrows}
|
||||
<div class="side-container">
|
||||
<span
|
||||
class="clickable"
|
||||
on:click={showPrevPage}
|
||||
><</span>
|
||||
</div>
|
||||
<slot name="prev">
|
||||
<div class="side-container">
|
||||
<Arrow direction="prev" on:click={showPrevPage} />
|
||||
</div>
|
||||
</slot>
|
||||
{/if}
|
||||
<div
|
||||
class="content-container"
|
||||
@@ -161,12 +161,11 @@
|
||||
</div>
|
||||
</div>
|
||||
{#if arrows}
|
||||
<div class="side-container">
|
||||
<span
|
||||
class="clickable"
|
||||
on:click={showNextPage}
|
||||
>></span>
|
||||
</div>
|
||||
<slot name="next">
|
||||
<div class="side-container">
|
||||
<Arrow direction="next" on:click={showNextPage} />
|
||||
</div>
|
||||
</slot>
|
||||
{/if}
|
||||
</div>
|
||||
{#if dots}
|
||||
@@ -209,7 +208,6 @@
|
||||
transition-property: transform;
|
||||
}
|
||||
.side-container {
|
||||
background-color: cornflowerblue;
|
||||
height: 100%;
|
||||
padding: 5px;
|
||||
box-sizing: border-box;
|
||||
@@ -217,7 +215,4 @@
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
}
|
||||
.clickable {
|
||||
cursor: pointer;
|
||||
}
|
||||
</style>
|
||||
Reference in New Issue
Block a user