mirror of
https://github.com/dzeiocom/components.git
synced 2025-06-07 16:49:55 +00:00
Merge branch 'master' of github.com:dzeiocom/components
This commit is contained in:
commit
1488386e1d
@ -1,8 +1,8 @@
|
|||||||
{
|
{
|
||||||
"name": "@dzeio/components",
|
"name": "@dzeio/components",
|
||||||
"version": "0.7.0",
|
"version": "0.8.0",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"main": "./index.mjs",
|
"main": "./index.js",
|
||||||
"types": "./types/index.d.ts",
|
"types": "./types/index.d.ts",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@babel/core": "^7.12.16",
|
"@babel/core": "^7.12.16",
|
||||||
|
@ -12,14 +12,16 @@ export default [
|
|||||||
url: false,
|
url: false,
|
||||||
autoModules: true,
|
autoModules: true,
|
||||||
mode: 'extract',
|
mode: 'extract',
|
||||||
|
modules: {
|
||||||
|
generateScopedName: '[local][hash:5]'
|
||||||
|
}
|
||||||
}),
|
}),
|
||||||
typescript({useTsconfigDeclarationDir: true}), // so Rollup can convert TypeScript to JavaScript
|
typescript({useTsconfigDeclarationDir: true}), // so Rollup can convert TypeScript to JavaScript
|
||||||
],
|
],
|
||||||
output: [
|
output: [
|
||||||
{
|
{
|
||||||
file: pkg.main,
|
file: pkg.main,
|
||||||
format: 'es',
|
format: 'cjs',
|
||||||
assetFileNames: 'style.css'
|
assetFileNames: 'style.css'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
@ -1,34 +1,29 @@
|
|||||||
@import "../config"
|
@import "../config"
|
||||||
|
|
||||||
$transparent = 75%
|
$transparent = 15%
|
||||||
|
|
||||||
.back
|
.back
|
||||||
transition all $transition
|
transition all $transition
|
||||||
background linear-gradient(to left, $default, transparentify($default, $transparent))
|
background $mainGradient
|
||||||
|
|
||||||
.primary
|
&.fullscreen
|
||||||
$color = $primary
|
min-height 100vh
|
||||||
background linear-gradient(to left, $color, transparentify($color, $transparent))
|
|
||||||
|
|
||||||
.secondary
|
|
||||||
$color = $secondary
|
|
||||||
background linear-gradient(to left, $color, transparentify($color, $transparent))
|
|
||||||
|
|
||||||
.info
|
.info
|
||||||
$color = $info
|
$color = $info
|
||||||
background linear-gradient(to left, $color, transparentify($color, $transparent))
|
background linear-gradient(to left, $color, lighten($color, $transparent))
|
||||||
|
|
||||||
.success
|
.success
|
||||||
$color = $success
|
$color = $success
|
||||||
background linear-gradient(to left, $color, transparentify($color, $transparent))
|
background linear-gradient(to left, $color, lighten($color, $transparent))
|
||||||
|
|
||||||
.danger
|
.danger
|
||||||
$color = $danger
|
$color = $danger
|
||||||
background linear-gradient(to left, $color, transparentify($color, $transparent))
|
background linear-gradient(to left, $color, lighten($color, $transparent))
|
||||||
|
|
||||||
.warning
|
.warning
|
||||||
$color = $warning
|
$color = $warning
|
||||||
background linear-gradient(to left, $color, transparentify($color, $transparent))
|
background linear-gradient(to left, $color, lighten($color, $transparent))
|
||||||
|
|
||||||
@media (prefers-color-scheme dark)
|
@media (prefers-color-scheme dark)
|
||||||
.back
|
.back
|
||||||
|
@ -8,12 +8,18 @@ interface Props {
|
|||||||
color?: ColorType
|
color?: ColorType
|
||||||
className?: string
|
className?: string
|
||||||
children: React.ReactNode
|
children: React.ReactNode
|
||||||
|
fullscreen?: boolean
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make the background a linear-gradient
|
||||||
|
*
|
||||||
|
* @version 1.0.0
|
||||||
|
*/
|
||||||
export default class GradientBackground extends React.Component<Props> {
|
export default class GradientBackground extends React.Component<Props> {
|
||||||
|
|
||||||
public render = () => (
|
public render = () => (
|
||||||
<div className={buildClassName([css.back], [css[this.props.color as string], this.props.color], [this.props.className])}>
|
<div className={buildClassName(css.back, [css[this.props.color as string], this.props.color], this.props.className)}>
|
||||||
{this.props.children}
|
{this.props.children}
|
||||||
</div>
|
</div>
|
||||||
)
|
)
|
||||||
|
@ -24,7 +24,7 @@ interface Props {
|
|||||||
export default class Link extends React.Component<Props> {
|
export default class Link extends React.Component<Props> {
|
||||||
|
|
||||||
public render() {
|
public render() {
|
||||||
const external = this.props.external ?? !this.props.href.startsWith('/')
|
const external = this.props.external ?? this.props.href.startsWith('http')
|
||||||
if (external) {
|
if (external) {
|
||||||
// external link
|
// external link
|
||||||
return (
|
return (
|
||||||
|
@ -4,9 +4,22 @@ import { buildClassName } from '../Util'
|
|||||||
import css from './Loader.module.styl'
|
import css from './Loader.module.styl'
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
|
/**
|
||||||
|
* The new Percentage (if you calculate it yourself)
|
||||||
|
*/
|
||||||
percent?: number
|
percent?: number
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Auto random loader
|
||||||
|
*/
|
||||||
auto?: {
|
auto?: {
|
||||||
|
/**
|
||||||
|
* the minimum and maximum interval between two increment
|
||||||
|
*/
|
||||||
interval: [number, number]
|
interval: [number, number]
|
||||||
|
/**
|
||||||
|
* the minimum and maximum incrementation (MUST be an integer)
|
||||||
|
*/
|
||||||
increment: [number, number]
|
increment: [number, number]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -15,6 +28,11 @@ interface State {
|
|||||||
percent?: number
|
percent?: number
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Display a simple loading animation at the top of the page
|
||||||
|
*
|
||||||
|
* @version 1.0.0
|
||||||
|
*/
|
||||||
export default class Loader extends React.Component<Props, State> {
|
export default class Loader extends React.Component<Props, State> {
|
||||||
|
|
||||||
public state: State = {}
|
public state: State = {}
|
||||||
|
@ -21,7 +21,7 @@ interface Props {
|
|||||||
/**
|
/**
|
||||||
* Logo to display
|
* Logo to display
|
||||||
*/
|
*/
|
||||||
logo: ImageProps & {height: number, width: number}
|
logo?: ImageProps & {height: number, width: number}
|
||||||
/**
|
/**
|
||||||
* Login URL
|
* Login URL
|
||||||
*/
|
*/
|
||||||
@ -82,7 +82,7 @@ interface State {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Navbar/Sidebar Component
|
* Navbar/Sidebar Component
|
||||||
* @version 1.0.0
|
* @version 1.0.1
|
||||||
*/
|
*/
|
||||||
export default class Navbar extends React.Component<Props, State> {
|
export default class Navbar extends React.Component<Props, State> {
|
||||||
|
|
||||||
@ -164,11 +164,13 @@ export default class Navbar extends React.Component<Props, State> {
|
|||||||
<>
|
<>
|
||||||
<nav className={buildClassName(css[this.getType()], [css.short, this.state.short && !this.props.mobileMenu], [css.mobile, this.props.mobileMenu])}>
|
<nav className={buildClassName(css[this.getType()], [css.short, this.state.short && !this.props.mobileMenu], [css.mobile, this.props.mobileMenu])}>
|
||||||
<Row nowrap className={css.header} align="center">
|
<Row nowrap className={css.header} align="center">
|
||||||
<Col className={css.imgContainer}>
|
{this.props.logo && (
|
||||||
<Link href="/">
|
<Col className={css.imgContainer}>
|
||||||
<Image {...this.props.logo} height={34} width={this.props.logo.width*34/this.props.logo.height} />
|
<Link href="/">
|
||||||
</Link>
|
<Image {...this.props.logo} height={34} width={this.props.logo.width*34/this.props.logo.height} />
|
||||||
</Col>
|
</Link>
|
||||||
|
</Col>
|
||||||
|
)}
|
||||||
{this.getType() === 'sidebar' && (
|
{this.getType() === 'sidebar' && (
|
||||||
<Col nogrow><Text><div onClick={this.onSidebarButton}>
|
<Col nogrow><Text><div onClick={this.onSidebarButton}>
|
||||||
{this.state.short ? (
|
{this.state.short ? (
|
||||||
|
@ -12,7 +12,6 @@ interface Props {
|
|||||||
|
|
||||||
export default class Text extends React.Component<Props> {
|
export default class Text extends React.Component<Props> {
|
||||||
|
|
||||||
|
|
||||||
public render() {
|
public render() {
|
||||||
const classes = buildClassName(
|
const classes = buildClassName(
|
||||||
css.text,
|
css.text,
|
||||||
@ -23,16 +22,10 @@ export default class Text extends React.Component<Props> {
|
|||||||
this.props.className
|
this.props.className
|
||||||
)
|
)
|
||||||
|
|
||||||
switch (this.props.type || 'p') {
|
if (this.props.type === 'em') {
|
||||||
case 'h1': return (<h1 className={classes}>{this.props.children}</h1>)
|
return (<p className={classes}><em>{this.props.children}</em></p>)
|
||||||
case 'h2': return (<h2 className={classes}>{this.props.children}</h2>)
|
|
||||||
case 'h3': return (<h3 className={classes}>{this.props.children}</h3>)
|
|
||||||
case 'h4': return (<h4 className={classes}>{this.props.children}</h4>)
|
|
||||||
case 'h5': return (<h5 className={classes}>{this.props.children}</h5>)
|
|
||||||
case 'h6': return (<h6 className={classes}>{this.props.children}</h6>)
|
|
||||||
case 'em': return (<p className={classes}><em>{this.props.children}</em></p>)
|
|
||||||
case 'span': return (<span className={classes}>{this.props.children}</span>)
|
|
||||||
default: return (<p className={classes}>{this.props.children}</p>)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return React.createElement(this.props.type || 'p', {className: classes, children: this.props.children})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import { SVGAttributes } from 'react'
|
import { SVGAttributes } from 'react'
|
||||||
|
|
||||||
export type ColorType = 'primary' | 'info' | 'success' | 'error' | 'warning'
|
export type ColorType = 'info' | 'success' | 'error' | 'warning'
|
||||||
|
|
||||||
export interface IconProps extends SVGAttributes<SVGElement> {
|
export interface IconProps extends SVGAttributes<SVGElement> {
|
||||||
color?: string
|
color?: string
|
||||||
|
@ -4,6 +4,8 @@
|
|||||||
* @summary DZEIO Component Library
|
* @summary DZEIO Component Library
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import './dzeio/general.styl'
|
||||||
|
|
||||||
import Box from './dzeio/Box'
|
import Box from './dzeio/Box'
|
||||||
import Button from './dzeio/Button'
|
import Button from './dzeio/Button'
|
||||||
import Checkbox from './dzeio/Checkbox'
|
import Checkbox from './dzeio/Checkbox'
|
||||||
|
Loading…
x
Reference in New Issue
Block a user