mirror of
https://github.com/dzeiocom/components.git
synced 2025-06-15 20:19:20 +00:00
Compare commits
16 Commits
v0.10.0
...
dependabot
Author | SHA1 | Date | |
---|---|---|---|
6f80618286 | |||
000de60c42
|
|||
60b7e187fe
|
|||
1d0108ac80
|
|||
a704e43fbf
|
|||
df06831c56
|
|||
52df94ed25
|
|||
ba0e70053b
|
|||
11dd18d8eb
|
|||
e24b31df10
|
|||
e38387534a | |||
ed49e9b961 | |||
be01f386d4 | |||
7e26c8d5aa | |||
a177e239c6 | |||
e5d8592186 |
12
.editorconfig
Normal file
12
.editorconfig
Normal file
@ -0,0 +1,12 @@
|
||||
# EditorConfig is awesome: https://EditorConfig.org
|
||||
|
||||
# top-most EditorConfig file
|
||||
root = true
|
||||
|
||||
[*]
|
||||
indent_style = tab
|
||||
indent_size = 4
|
||||
end_of_line = lf
|
||||
charset = utf-8
|
||||
trim_trailing_whitespace = true
|
||||
insert_final_newline = true
|
1
.gitignore
vendored
1
.gitignore
vendored
@ -9,4 +9,3 @@ types/
|
||||
!src/stylus.d.ts
|
||||
!.storybook/*.js
|
||||
style.css
|
||||
yarn-error.log
|
51592
package-lock.json
generated
Normal file
51592
package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load Diff
24
package.json
24
package.json
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@dzeio/components",
|
||||
"version": "0.10.0",
|
||||
"version": "0.11.3",
|
||||
"license": "MIT",
|
||||
"main": "./index.js",
|
||||
"types": "./types/index.d.ts",
|
||||
@ -11,15 +11,15 @@
|
||||
"@storybook/addon-essentials": "^6.1.14",
|
||||
"@storybook/cli": "^6.1.14",
|
||||
"@storybook/react": "^6.1.14",
|
||||
"@types/node": "^14.14.28",
|
||||
"@types/node": "^15.12.1",
|
||||
"@types/react": "^17.0.2",
|
||||
"@types/react-dom": "^17.0.1",
|
||||
"babel-loader": "^8.2.2",
|
||||
"css-loader": "^5.0.2",
|
||||
"next": "^10.0.5",
|
||||
"react": "^17.0.1",
|
||||
"react-dom": "^17.0.1",
|
||||
"react-feather": "^2.0.9",
|
||||
"lucide-react": "^0.15.19",
|
||||
"next": "^10.0.0",
|
||||
"react": "^16.0.0",
|
||||
"react-dom": "^16.0.0",
|
||||
"style-loader": "^2.0.0",
|
||||
"stylus": "^0.54.8",
|
||||
"stylus-loader": "^4.3.3",
|
||||
@ -28,17 +28,17 @@
|
||||
"webpack": "^4.44.2"
|
||||
},
|
||||
"peerDependencies": {
|
||||
"next": "^10.0.5",
|
||||
"react": "^17.0.1",
|
||||
"react-dom": "^17.0.1",
|
||||
"react-feather": "^2.0.9",
|
||||
"lucide-react": "^0.15.19",
|
||||
"next": "^10.0.0 || ^11.0.0",
|
||||
"react": "^16.0.0 || ^17.0.0",
|
||||
"react-dom": "^16.0.0 || ^17.0.0",
|
||||
"stylus": "^0.54.8",
|
||||
"typescript": "^4.2.3"
|
||||
"typescript": "^4.0.0"
|
||||
},
|
||||
"scripts": {
|
||||
"dev": "start-storybook -s ./.storybook/public -p 6006",
|
||||
"build": "rollup --config",
|
||||
"prepublishOnly": "yarn build",
|
||||
"prepublishOnly": "npm run build",
|
||||
"postinstall": "rollup --config"
|
||||
},
|
||||
"dependencies": {
|
||||
|
@ -1,6 +1,6 @@
|
||||
import { Meta } from '@storybook/react/types-6-0'
|
||||
import React from 'react'
|
||||
import { Zap } from 'react-feather'
|
||||
import { Zap } from 'lucide-react'
|
||||
import Component from '.'
|
||||
|
||||
export default {
|
||||
@ -25,3 +25,10 @@ WithImg.args = {
|
||||
href: '/pouet',
|
||||
block: true
|
||||
}
|
||||
|
||||
export const ExternalLinkButton = (args: any) => <Component {...args}>Button</Component>
|
||||
ExternalLinkButton.args = {
|
||||
nomargintop: true,
|
||||
href: 'https://example.com',
|
||||
block: true
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
import React, { FC } from 'react'
|
||||
import Link from 'next/link'
|
||||
import Link from '../Link'
|
||||
import { ColorType, IconProps } from '../interfaces'
|
||||
import { buildClassName } from '../Util'
|
||||
import Image from '../Image'
|
||||
@ -34,7 +34,7 @@ export default class Button extends React.Component<Props> {
|
||||
inner = (
|
||||
<>
|
||||
{typeof Icon === 'string' ? (
|
||||
<Image parentClassName={css.img} src={Icon} width={16} height={16} />
|
||||
<Image imageProps={{src: Icon, width: 16, height: 16}} />
|
||||
) : (
|
||||
<Icon size={this.props.size === 'large' ? 20 : this.props.size === 'small' ? 14 : 16} />
|
||||
)}
|
||||
@ -57,8 +57,8 @@ export default class Button extends React.Component<Props> {
|
||||
|
||||
if (this.props.href) {
|
||||
return (
|
||||
<Link href={this.props.href} as={this.props.as}>
|
||||
<a onClick={this.props.onClick} className={buildClassName([classes], [css.disabled, this.props.disabled])}>{inner}</a>
|
||||
<Link linkProps={{onClick: this.props.onClick}} hideIcon noStyle href={this.props.href} className={buildClassName([classes], [css.disabled, this.props.disabled])}>
|
||||
{inner}
|
||||
</Link>
|
||||
)
|
||||
}
|
||||
|
@ -1,8 +1,7 @@
|
||||
import React from 'react'
|
||||
import { Check } from 'react-feather'
|
||||
import { Check } from 'lucide-react'
|
||||
import { buildClassName } from '../Util'
|
||||
|
||||
import { ColorType } from '../interfaces'
|
||||
import css from './Checkbox.module.styl'
|
||||
import Text from '../Text'
|
||||
|
||||
|
@ -1,6 +1,6 @@
|
||||
import { Meta, Story } from '@storybook/react/types-6-0'
|
||||
import React from 'react'
|
||||
import { Zap } from 'react-feather'
|
||||
import { Zap } from 'lucide-react'
|
||||
import Component from '.'
|
||||
|
||||
export default {
|
||||
|
@ -1,7 +1,7 @@
|
||||
import React, { FC } from 'react'
|
||||
import { Heart } from 'react-feather'
|
||||
import { Heart } from 'lucide-react'
|
||||
import Link from '../Link'
|
||||
import { Icon } from 'react-feather'
|
||||
import { LucideProps } from 'lucide-react'
|
||||
import Text from '../Text'
|
||||
import css from './Footer.module.styl'
|
||||
import Image from 'next/image'
|
||||
@ -15,7 +15,7 @@ interface Props {
|
||||
}>
|
||||
socials?: Array<{
|
||||
href: string
|
||||
icon: Icon | string
|
||||
icon: FC<LucideProps> | string
|
||||
}>
|
||||
}
|
||||
|
||||
|
@ -6,7 +6,7 @@ $percent = 15%
|
||||
transition all $transition
|
||||
background $mainGradient
|
||||
|
||||
&.fullscreen
|
||||
&.fullscreen > :first-child
|
||||
min-height 100vh
|
||||
|
||||
.info
|
||||
@ -14,7 +14,6 @@ $percent = 15%
|
||||
@media (prefers-color-scheme dark)
|
||||
background linear-gradient(to right, $infoDark, darken($infoDark, $percent))
|
||||
|
||||
|
||||
.success
|
||||
background linear-gradient(to right, $successLight, lighten($successLight, $percent))
|
||||
@media (prefers-color-scheme dark)
|
||||
|
@ -14,7 +14,7 @@ interface Props {
|
||||
/**
|
||||
* Make the background a linear-gradient
|
||||
*
|
||||
* @version 1.0.1
|
||||
* @version 1.0.2
|
||||
*/
|
||||
export default class GradientBackground extends React.Component<Props> {
|
||||
|
||||
|
@ -2,7 +2,7 @@ import { Meta } from '@storybook/react/types-6-0'
|
||||
import { Story } from "@storybook/react"
|
||||
import React from 'react'
|
||||
import Component from '.'
|
||||
import { X } from 'react-feather'
|
||||
import { X } from 'lucide-react'
|
||||
|
||||
export default {
|
||||
title: 'DZEIO/Input',
|
||||
|
@ -1,11 +1,10 @@
|
||||
import React, { FC } from 'react'
|
||||
|
||||
import { ChevronDown } from 'react-feather'
|
||||
import { ChevronDown } from 'lucide-react'
|
||||
import Text from '../Text'
|
||||
import { IconProps } from '../interfaces'
|
||||
import { buildClassName } from '../Util'
|
||||
import css from './Input.module.styl'
|
||||
import Row from '../Row'
|
||||
|
||||
interface Props extends React.DetailedHTMLProps<React.InputHTMLAttributes<HTMLInputElement>, HTMLInputElement> {
|
||||
id?: string
|
||||
@ -98,7 +97,7 @@ export default class Input extends React.Component<Props, States> {
|
||||
baseProps.onWheel = (ev: React.WheelEvent<HTMLInputElement>) => ev.currentTarget.blur()
|
||||
}
|
||||
|
||||
if (this.props.type === 'select') {
|
||||
if (this.props.type === 'select' && !this.props.readOnly) {
|
||||
input = (
|
||||
<select
|
||||
ref={this.props.selectRef || this.inputRef}
|
||||
@ -113,6 +112,15 @@ export default class Input extends React.Component<Props, States> {
|
||||
{this.props.children}
|
||||
</select>
|
||||
)
|
||||
// select is readonly
|
||||
} else if (this.props.type === 'select') {
|
||||
input = (
|
||||
<input
|
||||
{...props}
|
||||
{...baseProps}
|
||||
type="text"
|
||||
/>
|
||||
)
|
||||
} else if (this.props.type === 'textarea') {
|
||||
delete baseProps.ref
|
||||
input = (
|
||||
@ -170,9 +178,9 @@ export default class Input extends React.Component<Props, States> {
|
||||
</div>
|
||||
)}
|
||||
|
||||
{this.props.autocomplete && this.props.autocomplete.indexOf(this.state?.value || '') === -1 && (
|
||||
{this.props.autocomplete && this.props.autocomplete.indexOf(this.state?.value ?? this.props.value?.toString() ?? '') === -1 && (
|
||||
<ul className={buildClassName(css.autocomplete, [css.reverse, !this.state.isInFirstPartOfScreen])}>
|
||||
{this.props.autocomplete.filter((item) => item.includes(this.state?.value || '')).map((item) => (<li key={item} onClick={this.onAutoCompleteClick(item)}><Text>{item}</Text></li>))}
|
||||
{this.props.autocomplete.filter((item) => item.toLowerCase().includes(this.state?.value?.toLowerCase() ?? this.props.value?.toString().toLowerCase() ?? '')).map((item) => (<li key={item} onClick={this.onAutoCompleteClick(item)}><Text>{item}</Text></li>))}
|
||||
</ul>
|
||||
)}
|
||||
</div>
|
||||
@ -183,7 +191,7 @@ export default class Input extends React.Component<Props, States> {
|
||||
const div = this.parentRef.current
|
||||
if (!div) {return}
|
||||
const result = !(div.offsetTop - window.scrollY >= window.innerHeight / 2)
|
||||
console.log(result, div, this.state.isInFirstPartOfScreen)
|
||||
// console.log(result, div, this.state.isInFirstPartOfScreen)
|
||||
if (this.state.isInFirstPartOfScreen !== result) {
|
||||
this.setState({isInFirstPartOfScreen: result})
|
||||
}
|
||||
@ -201,8 +209,8 @@ export default class Input extends React.Component<Props, States> {
|
||||
this.setState({textAreaHeight: this.inputRef.current.scrollHeight})
|
||||
})
|
||||
|
||||
private onAutoCompleteClick = (value: string) => () => {
|
||||
console.log('test')
|
||||
private onAutoCompleteClick = (value: string) => async () => {
|
||||
// console.log('test')
|
||||
const item = this.getElement()
|
||||
if (!item) {return}
|
||||
const valueSetter = Object.getOwnPropertyDescriptor(item, 'value')?.set
|
||||
@ -216,6 +224,9 @@ export default class Input extends React.Component<Props, States> {
|
||||
valueSetter.call(item, value)
|
||||
}
|
||||
item.dispatchEvent(new Event('input', {bubbles: true}))
|
||||
if (this.props.type === 'textarea') {
|
||||
await this.parentScroll()
|
||||
}
|
||||
}
|
||||
|
||||
private onChange = async (event?: React.FormEvent<HTMLDivElement>) => {
|
||||
|
@ -1,6 +1,6 @@
|
||||
import React from 'react'
|
||||
import NextLink from 'next/link'
|
||||
import { ExternalLink } from 'react-feather'
|
||||
import { ExternalLink } from 'lucide-react'
|
||||
|
||||
import css from './Link.module.styl'
|
||||
import { buildClassName } from '../Util'
|
||||
@ -30,7 +30,7 @@ export default class Link extends React.Component<Props> {
|
||||
|
||||
public render() {
|
||||
const isExternal = this.props.href.startsWith('http')
|
||||
const externalProps = this.props.external ? {
|
||||
const externalProps = this.props.external ?? isExternal ? {
|
||||
rel: 'noreferrer nofollow',
|
||||
target: '_blank'
|
||||
} : {}
|
||||
|
@ -48,8 +48,8 @@ export default class Loader extends React.Component<Props, State> {
|
||||
|
||||
public componentWillUnmount() {
|
||||
if (this.props.auto) {
|
||||
Router.events.off('routechangeComplete', this.routeChangeComplete)
|
||||
Router.events.off('routechangeStart', this.routeChangeStart)
|
||||
Router.events.off('routeChangeComplete', this.routeChangeComplete)
|
||||
Router.events.off('routeChangeStart', this.routeChangeStart)
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1,6 +1,6 @@
|
||||
import { Meta, Story } from '@storybook/react/types-6-0'
|
||||
import React from 'react'
|
||||
import { Zap, ZapOff } from 'react-feather'
|
||||
import { Zap, ZapOff } from 'lucide-react'
|
||||
import Component from '.'
|
||||
import Text from '../Text'
|
||||
|
||||
|
@ -2,7 +2,7 @@ import Router from 'next/router'
|
||||
|
||||
import Image, { ImageProps } from 'next/image'
|
||||
import React, { FC } from 'react'
|
||||
import { ChevronDown, ChevronsRight, Menu, X } from 'react-feather'
|
||||
import { ChevronDown, ChevronsRight, Menu, X } from 'lucide-react'
|
||||
import Text from '../Text'
|
||||
import Col from '../Col'
|
||||
import Row from '../Row'
|
||||
|
@ -1,6 +1,6 @@
|
||||
import { Meta } from '@storybook/react/types-6-0'
|
||||
import React from 'react'
|
||||
import { Zap } from 'react-feather'
|
||||
import { Zap } from 'lucide-react'
|
||||
import Component from '.'
|
||||
|
||||
export default {
|
||||
|
@ -5,7 +5,7 @@ import Col from '../Col'
|
||||
import Text from '../Text'
|
||||
import Router from 'next/router'
|
||||
import React from 'react'
|
||||
import { X } from 'react-feather'
|
||||
import { X } from 'lucide-react'
|
||||
|
||||
import css from './NotificationManager.module.styl'
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
import React from 'react'
|
||||
import { X } from 'react-feather'
|
||||
import { X } from 'lucide-react'
|
||||
import Text from '../Text'
|
||||
import Box from '../Box'
|
||||
import Row from '../Row'
|
||||
|
@ -17,3 +17,6 @@
|
||||
td
|
||||
padding 8px
|
||||
text-align left
|
||||
|
||||
.parent
|
||||
overflow-x auto
|
@ -1,15 +1,20 @@
|
||||
import React from 'react'
|
||||
import { buildClassName } from '../Util'
|
||||
|
||||
import css from './Table.module.styl'
|
||||
|
||||
interface Props {
|
||||
children: React.ReactNode
|
||||
parentClassName?: string
|
||||
className?: string
|
||||
}
|
||||
|
||||
export default class Table extends React.Component<Props> {
|
||||
|
||||
public render = () => (
|
||||
<table className={css.table}>{this.props.children}</table>
|
||||
<div className={buildClassName(css.parent, this.props.parentClassName)}>
|
||||
<table className={buildClassName(css.table, this.props.className)}>{this.props.children}</table>
|
||||
</div>
|
||||
)
|
||||
|
||||
}
|
||||
|
@ -51,4 +51,5 @@ $default = $main
|
||||
// See https://github.com/stylus/stylus/issues/1872#issuecomment-86553717
|
||||
use('stylusUtils.js')
|
||||
|
||||
// Import theme in the root folder of the project
|
||||
@import '../../../../../../theme' if file-exists('../../../../../../theme.styl')
|
||||
|
Reference in New Issue
Block a user