Super early implementation

pull/146/head
Cory LaViska 2020-07-27 16:20:15 -04:00
rodzic 5d9608b6bc
commit c32581678a
5 zmienionych plików z 117 dodań i 0 usunięć

Wyświetl plik

@ -33,6 +33,7 @@
- [Range](/components/range.md)
- [Rating](/components/rating.md)
- [Select](/components/select.md)
- [Skeleton](/components/skeleton.md)
- [Spinner](/components/spinner.md)
- [Switch](/components/switch.md)
- [Tab Group](/components/tab-group.md)

Wyświetl plik

@ -0,0 +1,29 @@
# Skeleton
[component-header:sl-skeleton]
Skeletons are used to show where content will eventually be drawn.
```html preview
<div class="skeleton-overview">
<sl-skeleton loading></sl-skeleton>
<sl-skeleton loading></sl-skeleton>
<sl-skeleton loading></sl-skeleton>
</div>
<style>
.skeleton-overview sl-skeleton {
margin-bottom: 1rem;
}
.skeleton-overview sl-skeleton:nth-child(2) {
width: 95%;
}
.skeleton-overview sl-skeleton:last-child {
width: 60%;
}
</style>
```
[component-metadata:sl-skeleton]

21
src/components.d.ts vendored
Wyświetl plik

@ -667,6 +667,12 @@ export namespace Components {
*/
"value": string | Array<string>;
}
interface SlSkeleton {
/**
* When enabled, the skeleton will be animated to indicate that content is loading.
*/
"loading": boolean;
}
interface SlSpinner {
}
interface SlSwitch {
@ -1050,6 +1056,12 @@ declare global {
prototype: HTMLSlSelectElement;
new (): HTMLSlSelectElement;
};
interface HTMLSlSkeletonElement extends Components.SlSkeleton, HTMLStencilElement {
}
var HTMLSlSkeletonElement: {
prototype: HTMLSlSkeletonElement;
new (): HTMLSlSkeletonElement;
};
interface HTMLSlSpinnerElement extends Components.SlSpinner, HTMLStencilElement {
}
var HTMLSlSpinnerElement: {
@ -1124,6 +1136,7 @@ declare global {
"sl-range": HTMLSlRangeElement;
"sl-rating": HTMLSlRatingElement;
"sl-select": HTMLSlSelectElement;
"sl-skeleton": HTMLSlSkeletonElement;
"sl-spinner": HTMLSlSpinnerElement;
"sl-switch": HTMLSlSwitchElement;
"sl-tab": HTMLSlTabElement;
@ -1880,6 +1893,12 @@ declare namespace LocalJSX {
*/
"value"?: string | Array<string>;
}
interface SlSkeleton {
/**
* When enabled, the skeleton will be animated to indicate that content is loading.
*/
"loading"?: boolean;
}
interface SlSpinner {
}
interface SlSwitch {
@ -2145,6 +2164,7 @@ declare namespace LocalJSX {
"sl-range": SlRange;
"sl-rating": SlRating;
"sl-select": SlSelect;
"sl-skeleton": SlSkeleton;
"sl-spinner": SlSpinner;
"sl-switch": SlSwitch;
"sl-tab": SlTab;
@ -2184,6 +2204,7 @@ declare module "@stencil/core" {
"sl-range": LocalJSX.SlRange & JSXBase.HTMLAttributes<HTMLSlRangeElement>;
"sl-rating": LocalJSX.SlRating & JSXBase.HTMLAttributes<HTMLSlRatingElement>;
"sl-select": LocalJSX.SlSelect & JSXBase.HTMLAttributes<HTMLSlSelectElement>;
"sl-skeleton": LocalJSX.SlSkeleton & JSXBase.HTMLAttributes<HTMLSlSkeletonElement>;
"sl-spinner": LocalJSX.SlSpinner & JSXBase.HTMLAttributes<HTMLSlSpinnerElement>;
"sl-switch": LocalJSX.SlSwitch & JSXBase.HTMLAttributes<HTMLSlSwitchElement>;
"sl-tab": LocalJSX.SlTab & JSXBase.HTMLAttributes<HTMLSlTabElement>;

Wyświetl plik

@ -0,0 +1,34 @@
@import 'component';
/**
* @prop --color: The color of the skeleton.
* @prop --sheen-color: The sheen color when the skeleton is in its loading state.
*/
:host {
--color: var(--sl-color-gray-90);
--sheen-color: var(--sl-color-gray-95);
display: flex;
height: 1em;
}
.skeleton {
flex: 1 1 auto;
background: var(--color);
border-radius: var(--sl-border-radius-pill);
}
.skeleton--loading {
background: linear-gradient(90deg, var(--sheen-color) 20%, var(--color) 40%, var(--sheen-color) 60%);
background-size: 400% 100%;
animation: loading 1.5s ease infinite;
}
@keyframes loading {
0% {
background-position: 100% 50%;
}
100% {
background-position: 0 50%;
}
}

Wyświetl plik

@ -0,0 +1,32 @@
import { Component, Prop, h } from '@stencil/core';
/**
* @since 2.0
* @status stable
*
* @part base - The component's base wrapper.
*/
@Component({
tag: 'sl-skeleton',
styleUrl: 'skeleton.scss',
shadow: true
})
export class Skeleton {
/** When enabled, the skeleton will be animated to indicate that content is loading. */
@Prop() loading = false;
render() {
return (
<div
part="base"
class={{
skeleton: true,
'skeleton--loading': this.loading
}}
aria-busy={this.loading}
aria-live="polite"
/>
);
}
}