revotech-ui-kit 0.0.6-beta → 0.0.7-beta
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/index.ts +1 -1
- package/dist/rollup-plugin-html-noop.js +1 -0
- package/dist/sw.js +1 -1
- package/dist/sw.js.map +1 -1
- package/package.json +3 -3
- package/.editorconfig +0 -29
- package/.eslintrc +0 -10
- package/.github/workflows/deploy-storybook.yml +0 -107
- package/.storybook/main.ts +0 -17
- package/.storybook/preview-head.html +0 -1
- package/.storybook/preview.ts +0 -17
- package/assets/fonts/Geist/Geist-Black.otf +0 -0
- package/assets/fonts/Geist/Geist-Black.woff2 +0 -0
- package/assets/fonts/Geist/Geist-Bold.otf +0 -0
- package/assets/fonts/Geist/Geist-Bold.woff2 +0 -0
- package/assets/fonts/Geist/Geist-Light.otf +0 -0
- package/assets/fonts/Geist/Geist-Light.woff2 +0 -0
- package/assets/fonts/Geist/Geist-Medium.otf +0 -0
- package/assets/fonts/Geist/Geist-Medium.woff2 +0 -0
- package/assets/fonts/Geist/Geist-Regular.otf +0 -0
- package/assets/fonts/Geist/Geist-Regular.woff2 +0 -0
- package/assets/fonts/Geist/Geist-SemiBold.otf +0 -0
- package/assets/fonts/Geist/Geist-SemiBold.woff2 +0 -0
- package/assets/fonts/Geist/Geist-Thin.otf +0 -0
- package/assets/fonts/Geist/Geist-Thin.woff2 +0 -0
- package/assets/fonts/Geist/Geist-UltraBlack.otf +0 -0
- package/assets/fonts/Geist/Geist-UltraBlack.woff2 +0 -0
- package/assets/fonts/Geist/Geist-UltraLight.otf +0 -0
- package/assets/fonts/Geist/Geist-UltraLight.woff2 +0 -0
- package/assets/fonts/Geist/GeistVariableVF.ttf +0 -0
- package/assets/fonts/Geist/GeistVariableVF.woff2 +0 -0
- package/assets/fonts/Geist/LICENSE.TXT +0 -92
- package/assets/open-wc-logo.svg +0 -29
- package/assume_role.sh +0 -18
- package/index.html +0 -314
- package/rollup.config.js +0 -83
- package/src/assets/icons/arrows.icon.ts +0 -20
- package/src/assets/icons/index.ts +0 -3
- package/src/assets/icons/search.icon.ts +0 -19
- package/src/assets/icons/tick.icon.ts +0 -20
- package/src/chai-custom.d.ts +0 -0
- package/src/components/atoms/alert/alert-description.ts +0 -15
- package/src/components/atoms/alert/alert-title.ts +0 -17
- package/src/components/atoms/alert/alert.atom.ts +0 -55
- package/src/components/atoms/alert/alert.stories.ts +0 -71
- package/src/components/atoms/alert/alert.styles.ts +0 -21
- package/src/components/atoms/alert/alert.types.ts +0 -1
- package/src/components/atoms/badge/badge.atom.ts +0 -40
- package/src/components/atoms/badge/badge.stories.ts +0 -118
- package/src/components/atoms/badge/badge.style.ts +0 -24
- package/src/components/atoms/badge/badge.type.ts +0 -7
- package/src/components/atoms/button/button.atom.ts +0 -59
- package/src/components/atoms/button/button.stories.ts +0 -224
- package/src/components/atoms/button/button.style.ts +0 -31
- package/src/components/atoms/button/button.type.ts +0 -10
- package/src/components/atoms/card/card-content.ts +0 -15
- package/src/components/atoms/card/card-description.ts +0 -15
- package/src/components/atoms/card/card-footer.ts +0 -15
- package/src/components/atoms/card/card-header.ts +0 -15
- package/src/components/atoms/card/card-title.ts +0 -15
- package/src/components/atoms/card/card.atom.ts +0 -31
- package/src/components/atoms/card/card.stories.ts +0 -149
- package/src/components/atoms/checkbox/checkbox.atom.ts +0 -76
- package/src/components/atoms/checkbox/checkbox.stories.ts +0 -309
- package/src/components/atoms/checkbox/checkbox.style.ts +0 -5
- package/src/components/atoms/checkbox/checkbox.type.ts +0 -24
- package/src/components/atoms/combo-box/combo-box-input.ts +0 -33
- package/src/components/atoms/combo-box/combo-box-item.ts +0 -59
- package/src/components/atoms/combo-box/combo-box-list.ts +0 -57
- package/src/components/atoms/combo-box/combo-box.atom.ts +0 -187
- package/src/components/atoms/combo-box/combo-box.stories.ts +0 -95
- package/src/components/atoms/command-empty/command-empty.atom.ts +0 -44
- package/src/components/atoms/command-group/command-group.atom.ts +0 -60
- package/src/components/atoms/command-item/command-item.atom.ts +0 -74
- package/src/components/atoms/command-list/command-list.atom.ts +0 -37
- package/src/components/atoms/command-separator/command-separator.atom.ts +0 -42
- package/src/components/atoms/dialog/dialog-close.ts +0 -50
- package/src/components/atoms/dialog/dialog-content.ts +0 -71
- package/src/components/atoms/dialog/dialog-footer.ts +0 -22
- package/src/components/atoms/dialog/dialog-header.ts +0 -36
- package/src/components/atoms/dialog/dialog-overly.ts +0 -20
- package/src/components/atoms/dialog/dialog-trigger.ts +0 -54
- package/src/components/atoms/dialog/dialog.atom.ts +0 -78
- package/src/components/atoms/dialog/dialog.stories.ts +0 -93
- package/src/components/atoms/dropdownMenu/dropdown-menu-checkbox-Item.ts +0 -106
- package/src/components/atoms/dropdownMenu/dropdown-menu-content.ts +0 -79
- package/src/components/atoms/dropdownMenu/dropdown-menu-group.ts +0 -60
- package/src/components/atoms/dropdownMenu/dropdown-menu-item.ts +0 -74
- package/src/components/atoms/dropdownMenu/dropdown-menu-radio-item.ts +0 -107
- package/src/components/atoms/dropdownMenu/dropdown-menu-seperator.ts +0 -44
- package/src/components/atoms/dropdownMenu/dropdown-menu-shortcut.ts +0 -17
- package/src/components/atoms/dropdownMenu/dropdown-menu.atom.ts +0 -84
- package/src/components/atoms/dropdownMenu/dropdownMenu.stories.ts +0 -220
- package/src/components/atoms/dropdownMenu/dropdownMenu.style.ts +0 -7
- package/src/components/atoms/index.ts +0 -13
- package/src/components/atoms/input/input.atom.ts +0 -88
- package/src/components/atoms/input/input.stories.ts +0 -451
- package/src/components/atoms/input/input.styles.ts +0 -2
- package/src/components/atoms/input/input.type.ts +0 -58
- package/src/components/atoms/label/label.atom.ts +0 -64
- package/src/components/atoms/label/label.stories.ts +0 -102
- package/src/components/atoms/label/label.style.ts +0 -5
- package/src/components/atoms/popover/popover-content.ts +0 -58
- package/src/components/atoms/popover/popover-trigger.ts +0 -50
- package/src/components/atoms/popover/popover.atom.ts +0 -34
- package/src/components/atoms/popover/popover.stories.ts +0 -79
- package/src/components/atoms/popover/popover.style.ts +0 -25
- package/src/components/atoms/popover/popover.types.ts +0 -3
- package/src/components/atoms/toggle/defs.ts +0 -29
- package/src/components/atoms/toggle/toggle.atom.ts +0 -58
- package/src/components/atoms/toggle/toggle.stories.ts +0 -204
- package/src/components/atoms/toggle/toggle.style.ts +0 -22
- package/src/components/command/command.stories.ts +0 -154
- package/src/components/command/command.ts +0 -391
- package/src/components/index.ts +0 -2
- package/src/components/molecules/command/command.molecules.ts +0 -31
- package/src/components/molecules/command-input/command-input.atom.ts +0 -130
- package/src/components/molecules/dropdownMenu/dropdownMenu.molecules.ts +0 -0
- package/src/components/molecules/index.ts +0 -1
- package/src/globals.css +0 -2215
- package/src/helpers/base-element.ts +0 -79
- package/src/helpers/index.ts +0 -3
- package/src/helpers/mouse-conroller.helper.ts +0 -42
- package/src/helpers/style.helpers.ts +0 -6
- package/src/index.d.ts +0 -1
- package/src/index.ts +0 -1
- package/src/interfaces/actionable.interface.ts +0 -6
- package/src/interfaces/atomic.interface.ts +0 -6
- package/src/interfaces/changeable.interface.ts +0 -14
- package/src/interfaces/child-support-atomic.interface.ts +0 -5
- package/src/interfaces/index.ts +0 -6
- package/src/interfaces/intractable.interface.ts +0 -6
- package/src/interfaces/variant.interface.ts +0 -3
- package/src/lib/index.ts +0 -0
- package/src/lib/next/next.lib.ts +0 -0
- package/src/lib/react/react.lib.ts +0 -18
- package/src/lib/tw-styles.ts +0 -1957
- package/src/styles/index.ts +0 -1
- package/src/styles/tw.styles.ts +0 -2219
- package/src/tailwind-lib.css +0 -115
- package/src/wc-ui-app.ts +0 -81
- package/tailwind.config.js +0 -217
- package/test/wc-ui-app.test.ts +0 -22
- package/tsconfig.json +0 -30
- package/web-dev-server.config.mjs +0 -26
- package/web-test-runner.config.mjs +0 -41
@@ -1,71 +0,0 @@
|
|
1
|
-
import { TWStyles } from '../../../styles';
|
2
|
-
import { cn } from '../../../helpers';
|
3
|
-
import { css, html, LitElement, nothing } from 'lit';
|
4
|
-
import { customElement, property } from 'lit/decorators.js';
|
5
|
-
import { Dialog } from './dialog.atom';
|
6
|
-
|
7
|
-
const STATE_OPEN = 'open';
|
8
|
-
const STATE_CLOSED = 'closed';
|
9
|
-
|
10
|
-
@customElement('rtg-dialog-content')
|
11
|
-
export class DialogContent extends LitElement {
|
12
|
-
static styles = [css``, TWStyles];
|
13
|
-
|
14
|
-
@property({ attribute: 'data-state', type: String }) state = STATE_CLOSED;
|
15
|
-
|
16
|
-
private get _dialog(): Dialog | null {
|
17
|
-
let parent = this.parentElement;
|
18
|
-
|
19
|
-
while (parent) {
|
20
|
-
if (parent instanceof Dialog) {
|
21
|
-
return parent;
|
22
|
-
}
|
23
|
-
parent = parent.parentElement;
|
24
|
-
}
|
25
|
-
return parent;
|
26
|
-
}
|
27
|
-
|
28
|
-
private handleCloseButtonClick = () => {
|
29
|
-
const dialog = this._dialog;
|
30
|
-
if (dialog) {
|
31
|
-
dialog.dataset.state = STATE_CLOSED;
|
32
|
-
}
|
33
|
-
};
|
34
|
-
|
35
|
-
render() {
|
36
|
-
return html`${this.state === STATE_OPEN
|
37
|
-
? html`
|
38
|
-
<div
|
39
|
-
class="${cn(
|
40
|
-
'fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg',
|
41
|
-
this.className
|
42
|
-
)}"
|
43
|
-
rtgdlg-content
|
44
|
-
>
|
45
|
-
<slot></slot>
|
46
|
-
<button
|
47
|
-
type="button"
|
48
|
-
@click="${this.handleCloseButtonClick}"
|
49
|
-
class="absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground"
|
50
|
-
>
|
51
|
-
<svg
|
52
|
-
xmlns="http://www.w3.org/2000/svg"
|
53
|
-
width="24"
|
54
|
-
height="24"
|
55
|
-
viewBox="0 0 24 24"
|
56
|
-
fill="none"
|
57
|
-
stroke="currentColor"
|
58
|
-
stroke-width="2"
|
59
|
-
stroke-linecap="round"
|
60
|
-
stroke-linejoin="round"
|
61
|
-
class="h-4 w-4"
|
62
|
-
>
|
63
|
-
<path d="M18 6 6 18"></path>
|
64
|
-
<path d="m6 6 12 12"></path></svg
|
65
|
-
><span class="sr-only">Close</span>
|
66
|
-
</button>
|
67
|
-
</div>
|
68
|
-
`
|
69
|
-
: nothing}`;
|
70
|
-
}
|
71
|
-
}
|
@@ -1,22 +0,0 @@
|
|
1
|
-
import { cn } from '../../../helpers';
|
2
|
-
import { TWStyles } from '../../../styles';
|
3
|
-
import { css, html, LitElement } from 'lit';
|
4
|
-
import { customElement } from 'lit/decorators.js';
|
5
|
-
|
6
|
-
@customElement('rtg-dialog-footer')
|
7
|
-
export class DialogFooter extends LitElement {
|
8
|
-
static styles = [css``, TWStyles];
|
9
|
-
|
10
|
-
render() {
|
11
|
-
return html`
|
12
|
-
<div
|
13
|
-
class="${cn(
|
14
|
-
'flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2',
|
15
|
-
this.className
|
16
|
-
)}"
|
17
|
-
>
|
18
|
-
<slot></slot>
|
19
|
-
</div>
|
20
|
-
`;
|
21
|
-
}
|
22
|
-
}
|
@@ -1,36 +0,0 @@
|
|
1
|
-
import { cn } from '../../../helpers';
|
2
|
-
import { TWStyles } from '../../../styles';
|
3
|
-
import { css, html, LitElement } from 'lit';
|
4
|
-
import { customElement, property } from 'lit/decorators.js';
|
5
|
-
|
6
|
-
@customElement('rtg-dialog-header')
|
7
|
-
export class DialogHeader extends LitElement {
|
8
|
-
static styles = [css``, TWStyles];
|
9
|
-
|
10
|
-
@property({ attribute: 'title', type: String }) _title = '';
|
11
|
-
|
12
|
-
@property({ type: String }) description = '';
|
13
|
-
|
14
|
-
render() {
|
15
|
-
return html`
|
16
|
-
<div
|
17
|
-
class="${cn(
|
18
|
-
'flex flex-col space-y-1.5 text-center sm:text-left',
|
19
|
-
this.className
|
20
|
-
)}"
|
21
|
-
>
|
22
|
-
<h2
|
23
|
-
class="${cn(
|
24
|
-
'text-lg font-semibold leading-none tracking-tight',
|
25
|
-
this.className
|
26
|
-
)}"
|
27
|
-
>
|
28
|
-
${this._title}
|
29
|
-
</h2>
|
30
|
-
<p class="${cn('text-sm text-muted-foreground', this.className)}">
|
31
|
-
${this.description}
|
32
|
-
</p>
|
33
|
-
</div>
|
34
|
-
`;
|
35
|
-
}
|
36
|
-
}
|
@@ -1,20 +0,0 @@
|
|
1
|
-
import { cn } from '../../../helpers';
|
2
|
-
import { TWStyles } from '../../../styles';
|
3
|
-
import { css, html, LitElement } from 'lit';
|
4
|
-
import { customElement, property } from 'lit/decorators.js';
|
5
|
-
|
6
|
-
@customElement('rtg-dialog-overlay')
|
7
|
-
export class DialogOverlay extends LitElement {
|
8
|
-
static styles = [css``, TWStyles];
|
9
|
-
|
10
|
-
render() {
|
11
|
-
return html`
|
12
|
-
<div
|
13
|
-
class="${cn(
|
14
|
-
'fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0',
|
15
|
-
this.className
|
16
|
-
)}"
|
17
|
-
></div>
|
18
|
-
`;
|
19
|
-
}
|
20
|
-
}
|
@@ -1,54 +0,0 @@
|
|
1
|
-
import { TWStyles } from '../../../styles';
|
2
|
-
import { css, html, LitElement, PropertyValueMap } from 'lit';
|
3
|
-
import { customElement } from 'lit/decorators.js';
|
4
|
-
import { Dialog } from './dialog.atom';
|
5
|
-
|
6
|
-
const STATE_OPEN = 'open';
|
7
|
-
const STATE_CLOSED = 'closed';
|
8
|
-
|
9
|
-
@customElement('rtg-dialog-trigger')
|
10
|
-
export class DialogTrigger extends LitElement {
|
11
|
-
static styles = [css``, TWStyles];
|
12
|
-
|
13
|
-
private get _dialog(): Dialog | null {
|
14
|
-
let parent = this.parentElement;
|
15
|
-
|
16
|
-
while (parent) {
|
17
|
-
if (parent instanceof Dialog) {
|
18
|
-
return parent;
|
19
|
-
}
|
20
|
-
parent = parent.parentElement;
|
21
|
-
}
|
22
|
-
return parent;
|
23
|
-
}
|
24
|
-
|
25
|
-
handleClick = () => {
|
26
|
-
const dialog = this._dialog;
|
27
|
-
if (dialog) {
|
28
|
-
dialog.dataset.state = STATE_OPEN;
|
29
|
-
}
|
30
|
-
};
|
31
|
-
protected firstUpdated(
|
32
|
-
_changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>
|
33
|
-
): void {
|
34
|
-
super.firstUpdated(_changedProperties);
|
35
|
-
const slots = this.shadowRoot?.querySelector('slot') as HTMLSlotElement;
|
36
|
-
const assignedElements = slots?.assignedElements({ flatten: true });
|
37
|
-
if (assignedElements && assignedElements.length > 0) {
|
38
|
-
//@ts-ignore
|
39
|
-
assignedElements[0].click = this.handleClick;
|
40
|
-
}
|
41
|
-
|
42
|
-
this.shadowRoot?.addEventListener('click', e => {
|
43
|
-
e.stopPropagation();
|
44
|
-
});
|
45
|
-
}
|
46
|
-
|
47
|
-
render() {
|
48
|
-
return html`
|
49
|
-
<div>
|
50
|
-
<slot></slot>
|
51
|
-
</div>
|
52
|
-
`;
|
53
|
-
}
|
54
|
-
}
|
@@ -1,78 +0,0 @@
|
|
1
|
-
import { LitElement, html, css, nothing, PropertyValues } from 'lit';
|
2
|
-
import { customElement, property } from 'lit/decorators.js';
|
3
|
-
import { TWStyles } from '../../../styles';
|
4
|
-
import { DialogContent } from './dialog-content';
|
5
|
-
|
6
|
-
const STATE_OPEN = 'open';
|
7
|
-
const STATE_CLOSED = 'closed';
|
8
|
-
|
9
|
-
@customElement('rtg-dialog')
|
10
|
-
export class Dialog extends LitElement {
|
11
|
-
static styles = [css``, TWStyles];
|
12
|
-
|
13
|
-
@property({ attribute: 'data-state', type: String }) state = STATE_CLOSED;
|
14
|
-
|
15
|
-
private get _content(): DialogContent | null {
|
16
|
-
const slot = this.shadowRoot?.querySelector('slot');
|
17
|
-
const children = slot?.assignedElements();
|
18
|
-
if (children) {
|
19
|
-
for (let index = 0; index < children.length; index++) {
|
20
|
-
if (children[index] instanceof DialogContent) {
|
21
|
-
return children[index] as DialogContent;
|
22
|
-
}
|
23
|
-
}
|
24
|
-
}
|
25
|
-
|
26
|
-
return null;
|
27
|
-
}
|
28
|
-
|
29
|
-
protected updated(_changedProperties: PropertyValues): void {
|
30
|
-
super.updated(_changedProperties);
|
31
|
-
const content = this._content;
|
32
|
-
if (content) {
|
33
|
-
content.dataset.state = this.state;
|
34
|
-
}
|
35
|
-
}
|
36
|
-
|
37
|
-
render() {
|
38
|
-
return html`
|
39
|
-
<div rtgdlg-root>
|
40
|
-
${this.state === STATE_OPEN
|
41
|
-
? html` <rtg-dialog-overlay></rtg-dialog-overlay>`
|
42
|
-
: nothing}
|
43
|
-
<slot></slot>
|
44
|
-
</div>
|
45
|
-
`;
|
46
|
-
}
|
47
|
-
}
|
48
|
-
|
49
|
-
// @customElement('rtg-dialog-title')
|
50
|
-
// export class DialogTitle extends LitElement {
|
51
|
-
// static styles = [css``, TWStyles];
|
52
|
-
|
53
|
-
// render() {
|
54
|
-
// return html`
|
55
|
-
// <h2
|
56
|
-
// class="${cn(
|
57
|
-
// 'text-lg font-semibold leading-none tracking-tight',
|
58
|
-
// this.className
|
59
|
-
// )}"
|
60
|
-
// >
|
61
|
-
// <slot></slot>
|
62
|
-
// </h2>
|
63
|
-
// `;
|
64
|
-
// }
|
65
|
-
// }
|
66
|
-
|
67
|
-
// @customElement('rtg-dialog-description')
|
68
|
-
// export class DialogDescription extends LitElement {
|
69
|
-
// static styles = [css``, TWStyles];
|
70
|
-
|
71
|
-
// render() {
|
72
|
-
// return html`
|
73
|
-
// <p class="${cn('text-sm text-muted-foreground', this.className)}">
|
74
|
-
// <slot></slot>
|
75
|
-
// </p>
|
76
|
-
// `;
|
77
|
-
// }
|
78
|
-
// }
|
@@ -1,93 +0,0 @@
|
|
1
|
-
import { html } from 'lit';
|
2
|
-
import { Meta, StoryObj } from '@storybook/web-components';
|
3
|
-
import '../input/input.atom';
|
4
|
-
import './dialog.atom';
|
5
|
-
import './dialog-close';
|
6
|
-
import './dialog-content';
|
7
|
-
import './dialog-footer';
|
8
|
-
import './dialog-header';
|
9
|
-
import './dialog-overly';
|
10
|
-
import './dialog-trigger';
|
11
|
-
import '../input/input.atom';
|
12
|
-
import '../button/button.atom';
|
13
|
-
const meta: Meta = {
|
14
|
-
component: 'components/dialog',
|
15
|
-
};
|
16
|
-
|
17
|
-
export default meta;
|
18
|
-
type Story = StoryObj;
|
19
|
-
|
20
|
-
export const ConfirmationDialog: Story = {
|
21
|
-
render: () =>
|
22
|
-
html`<div class="flex flex-nowrap">
|
23
|
-
<div class="flex flex-wrap space-x-4 gap-5 mx-3">
|
24
|
-
<rtg-dialog>
|
25
|
-
<rtg-dialog-trigger>
|
26
|
-
<rtg-button>Open Dialog</rtg-button>
|
27
|
-
</rtg-dialog-trigger>
|
28
|
-
<rtg-dialog-content>
|
29
|
-
<rtg-dialog-header title="Are you absolutely sure?" description="This action cannot be undone. This will permanently delete your
|
30
|
-
content.">
|
31
|
-
<rtg-dialog-title>Are you absolutely sure?</rtg-dialog-title>
|
32
|
-
<rtg-dialog-description>
|
33
|
-
This action cannot be undone. This will permanently delete your
|
34
|
-
content.</rtg-dialog-description
|
35
|
-
>
|
36
|
-
</rtg-dialog-header>
|
37
|
-
<rtg-dialog-footer>
|
38
|
-
<div class="flex w-full justify-between space-x-1">
|
39
|
-
<rtg-dialog-close><rtg-button variant="secondary">Close</rtg-button></rtg-dialog-close>
|
40
|
-
<div class="justify-end">
|
41
|
-
<rtg-button variant="destructive">Delete</rtg-button>
|
42
|
-
<rtg-button>Cancel</rtg-button>
|
43
|
-
</div>
|
44
|
-
</div>
|
45
|
-
</rtg-dialog-content>
|
46
|
-
</rtg-dialog>
|
47
|
-
</div>
|
48
|
-
</div>`,
|
49
|
-
};
|
50
|
-
|
51
|
-
export const ModalForm: Story = {
|
52
|
-
render: () => html`
|
53
|
-
<rtg-dialog>
|
54
|
-
<rtg-dialog-trigger>
|
55
|
-
<rtg-button variant="outline">Edit Profile</rtg-button>
|
56
|
-
</rtg-dialog-trigger>
|
57
|
-
<rtg-dialog-content class="sm:max-w-[425px]">
|
58
|
-
<rtg-dialog-header title="Edit Profile" description="Make changes to your profile here. Click save when you're done.">
|
59
|
-
<!-- <rtg-dialog-title>Edit Profile</rtg-dialog-title>
|
60
|
-
<rtg-dialog-description>
|
61
|
-
Make changes to your profile here. Click save when you're done.</rtg-dialog-description
|
62
|
-
> -->
|
63
|
-
</rtg-dialog-header>
|
64
|
-
<div class="grid gap-4 py-4">
|
65
|
-
<div class="grid grid-cols-4 items-center gap-4">
|
66
|
-
<rtg-label for="name" class="text-right">
|
67
|
-
Name
|
68
|
-
</rtg-label>
|
69
|
-
<rtg-input
|
70
|
-
id="name"
|
71
|
-
defaultValue="Pedro Duarte"
|
72
|
-
style="width:280px"
|
73
|
-
>
|
74
|
-
</rtg-input>
|
75
|
-
</div>
|
76
|
-
<div class="grid grid-cols-4 items-center gap-4">
|
77
|
-
<rtg-label for="username" class="text-right">
|
78
|
-
Username
|
79
|
-
</rtg-label>
|
80
|
-
<rtg-input
|
81
|
-
id="username"
|
82
|
-
defaultValue="@peduarte"
|
83
|
-
style="width:280px"
|
84
|
-
>
|
85
|
-
</rtg-input>
|
86
|
-
</div>
|
87
|
-
</div>
|
88
|
-
<rtg-dialog-footer>
|
89
|
-
<rtg-button>Save changes</rtg-button>
|
90
|
-
</rtg-dialog-content>
|
91
|
-
</rtg-dialog>
|
92
|
-
`,
|
93
|
-
};
|
@@ -1,106 +0,0 @@
|
|
1
|
-
import { LitElement, html, css, nothing } from 'lit';
|
2
|
-
import { property, customElement } from 'lit/decorators.js';
|
3
|
-
import { cn } from '../../../helpers';
|
4
|
-
import { TWStyles } from '../../../styles';
|
5
|
-
|
6
|
-
@customElement('rtg-dropdown-menu-checkbox-item')
|
7
|
-
export class DropdownMenuCheckboxItem extends LitElement {
|
8
|
-
@property({ type: String }) _id = '';
|
9
|
-
|
10
|
-
@property({ attribute: 'aria-hidden', type: String }) _hidden = '';
|
11
|
-
|
12
|
-
private static _counter = 0;
|
13
|
-
|
14
|
-
static styles = [
|
15
|
-
css`
|
16
|
-
.icon-space {
|
17
|
-
width: 16px; /* Fixed width to reserve space for the check icon */
|
18
|
-
height: 16px;
|
19
|
-
display: inline-block;
|
20
|
-
}
|
21
|
-
`,
|
22
|
-
TWStyles,
|
23
|
-
];
|
24
|
-
|
25
|
-
private get identifier() {
|
26
|
-
if (this._id !== '') {
|
27
|
-
return this._id;
|
28
|
-
}
|
29
|
-
const parent =
|
30
|
-
this.parentElement?.shadowRoot?.querySelector('div[rtgcmd-group]');
|
31
|
-
if (parent) {
|
32
|
-
this._id = `${parent.getAttribute(
|
33
|
-
'id'
|
34
|
-
)}li${DropdownMenuCheckboxItem._counter++}`;
|
35
|
-
} else {
|
36
|
-
this._id = `rtgcmdrxgxli${DropdownMenuCheckboxItem._counter++}`;
|
37
|
-
}
|
38
|
-
return this._id;
|
39
|
-
}
|
40
|
-
|
41
|
-
@property({ attribute: 'data-value', type: String })
|
42
|
-
public get value() {
|
43
|
-
return this.textContent?.trim() || '';
|
44
|
-
}
|
45
|
-
|
46
|
-
@property({ type: Boolean }) selected = false;
|
47
|
-
|
48
|
-
private handleMouseEvent(e: Event) {
|
49
|
-
if (e.type === 'mouseover' || e.type === 'focus') {
|
50
|
-
this.selected = true;
|
51
|
-
}
|
52
|
-
if (e.type === 'mouseleave') {
|
53
|
-
this.selected = false;
|
54
|
-
}
|
55
|
-
}
|
56
|
-
|
57
|
-
@property({ type: Boolean }) checked = false;
|
58
|
-
@property({ type: Boolean }) disabled = false;
|
59
|
-
|
60
|
-
toggleChecked() {
|
61
|
-
this.checked = !this.checked;
|
62
|
-
}
|
63
|
-
|
64
|
-
render() {
|
65
|
-
return html`
|
66
|
-
<div
|
67
|
-
class="${cn(
|
68
|
-
'relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none aria-selected:bg-accent aria-selected:text-accent-foreground',
|
69
|
-
this.disabled ? 'pointer-events-none opacity-50' : '',
|
70
|
-
this.className
|
71
|
-
)}"
|
72
|
-
@click=${this.toggleChecked}
|
73
|
-
@mouseover="${this.handleMouseEvent}"
|
74
|
-
@mouseleave="${this.handleMouseEvent}"
|
75
|
-
@focus="${this.handleMouseEvent}"
|
76
|
-
rtgcmd-item
|
77
|
-
role="option"
|
78
|
-
aria-selected="${this.selected}"
|
79
|
-
data-selected="${this.selected}"
|
80
|
-
data-value="${this.value}"
|
81
|
-
id="${this.identifier}"
|
82
|
-
aria-hidden="${this.hidden}"
|
83
|
-
>
|
84
|
-
<span
|
85
|
-
class="icon-space absolute left-2 flex items-center justify-center"
|
86
|
-
>
|
87
|
-
${this.checked
|
88
|
-
? html`
|
89
|
-
<svg
|
90
|
-
xmlns="http://www.w3.org/2000/svg"
|
91
|
-
viewBox="0 0 24 24"
|
92
|
-
width="16px"
|
93
|
-
height="16px"
|
94
|
-
>
|
95
|
-
<path
|
96
|
-
d="M 19.28125 5.28125 L 9 15.5625 L 4.71875 11.28125 L 3.28125 12.71875 L 8.28125 17.71875 L 9 18.40625 L 9.71875 17.71875 L 20.71875 6.71875 Z"
|
97
|
-
/>
|
98
|
-
</svg>
|
99
|
-
`
|
100
|
-
: nothing}
|
101
|
-
</span>
|
102
|
-
<slot></slot>
|
103
|
-
</div>
|
104
|
-
`;
|
105
|
-
}
|
106
|
-
}
|
@@ -1,79 +0,0 @@
|
|
1
|
-
import { LitElement, html, css, PropertyValues, nothing } from 'lit';
|
2
|
-
import { customElement, property, state } from 'lit/decorators.js';
|
3
|
-
import { cn } from '../../../helpers';
|
4
|
-
import { TWStyles } from '../../../styles';
|
5
|
-
import { DropdownMenu } from './dropdown-menu.atom';
|
6
|
-
import { dropdownMenuContentStyle } from './dropdownMenu.style';
|
7
|
-
import { STATE_CLOSED, STATE_OPEN } from '../popover/popover.types';
|
8
|
-
|
9
|
-
@customElement('rtg-dropdown-menu-content')
|
10
|
-
export class DropdownMenuContent extends LitElement {
|
11
|
-
static styles = [css``, TWStyles];
|
12
|
-
@property({ attribute: 'data-state', type: String }) state = STATE_CLOSED;
|
13
|
-
@state() isOpen = false;
|
14
|
-
|
15
|
-
get _dropdownMenu(): DropdownMenu | null {
|
16
|
-
let parent = this.parentElement;
|
17
|
-
// Traverse up the DOM tree to find the parent `Popover`
|
18
|
-
while (parent && !(parent instanceof DropdownMenu)) {
|
19
|
-
parent = parent.parentElement;
|
20
|
-
}
|
21
|
-
return parent;
|
22
|
-
}
|
23
|
-
|
24
|
-
connectedCallback() {
|
25
|
-
super.connectedCallback();
|
26
|
-
if (this.isOpen) {
|
27
|
-
document.addEventListener('mousedown', this.handleClickOutside);
|
28
|
-
}
|
29
|
-
}
|
30
|
-
|
31
|
-
disconnectedCallback() {
|
32
|
-
document.removeEventListener('mousedown', this.handleClickOutside);
|
33
|
-
super.disconnectedCallback();
|
34
|
-
}
|
35
|
-
|
36
|
-
updated(changedProps: PropertyValues) {
|
37
|
-
super.updated(changedProps);
|
38
|
-
// Check if the state is 'open'
|
39
|
-
if (this.state === 'open') {
|
40
|
-
this.isOpen = true;
|
41
|
-
} else {
|
42
|
-
this.isOpen = false;
|
43
|
-
}
|
44
|
-
|
45
|
-
if (changedProps.has('isOpen')) {
|
46
|
-
if (this.isOpen) {
|
47
|
-
document.addEventListener('mousedown', this.handleClickOutside);
|
48
|
-
} else {
|
49
|
-
document.removeEventListener('mousedown', this.handleClickOutside);
|
50
|
-
}
|
51
|
-
}
|
52
|
-
}
|
53
|
-
|
54
|
-
handleClickOutside(event: MouseEvent) {
|
55
|
-
const dropdownMenu = this.shadowRoot?.querySelector(
|
56
|
-
'rtg-dropdown-menu-content'
|
57
|
-
);
|
58
|
-
const dropdownButton = this.shadowRoot?.querySelector('button'); // Ensure this targets your open button
|
59
|
-
|
60
|
-
if (
|
61
|
-
dropdownMenu &&
|
62
|
-
!dropdownMenu.contains(event.target as Node) &&
|
63
|
-
!dropdownButton?.contains(event.target as Node)
|
64
|
-
) {
|
65
|
-
this.isOpen = false; // Only close if the click is outside both the menu and button
|
66
|
-
}
|
67
|
-
}
|
68
|
-
|
69
|
-
render() {
|
70
|
-
return html`
|
71
|
-
<div
|
72
|
-
class="max-h-[300px] overflow-y-auto overflow-x-hidden"
|
73
|
-
style="display: ${this.isOpen ? 'block' : 'none'}"
|
74
|
-
>
|
75
|
-
<slot></slot>
|
76
|
-
</div>
|
77
|
-
`;
|
78
|
-
}
|
79
|
-
}
|
@@ -1,60 +0,0 @@
|
|
1
|
-
import { LitElement, html, css, nothing } from 'lit';
|
2
|
-
import { property, customElement } from 'lit/decorators.js';
|
3
|
-
import { TWStyles } from '../../../styles';
|
4
|
-
|
5
|
-
@customElement('rtg-dropdown-menu-group')
|
6
|
-
export class DropdownMenuGroup extends LitElement {
|
7
|
-
@property({ type: String }) heading = '';
|
8
|
-
|
9
|
-
@property({ attribute: 'id', type: String }) _id = '';
|
10
|
-
|
11
|
-
@property({ attribute: 'aria-hidden', type: String }) _hidden = '';
|
12
|
-
|
13
|
-
private static _counter = 0;
|
14
|
-
|
15
|
-
static styles = [css``, TWStyles];
|
16
|
-
|
17
|
-
private get identifier() {
|
18
|
-
if (this._id !== '') {
|
19
|
-
return this._id;
|
20
|
-
}
|
21
|
-
const parent =
|
22
|
-
this.parentElement?.shadowRoot?.querySelector('div[rtgcmd-list]');
|
23
|
-
if (parent) {
|
24
|
-
this._id = `${parent.getAttribute('id')}g${DropdownMenuGroup._counter++}`;
|
25
|
-
} else {
|
26
|
-
this._id = `rtgcmdrxlxg${DropdownMenuGroup._counter++}`;
|
27
|
-
}
|
28
|
-
return this._id;
|
29
|
-
}
|
30
|
-
|
31
|
-
render() {
|
32
|
-
const className =
|
33
|
-
'overflow-hidden p-1 text-foreground [&_[rtgcmd-group-heading]]:px-2 [&_[rtgcmd-group-heading]]:py-1.5 [&_[rtgcmd-group-heading]]:text-xs [&_[rtgcmd-group-heading]]:font-medium [&_[rtgcmd-group-heading]]:text-muted-foreground';
|
34
|
-
return html`${this._hidden === 'true'
|
35
|
-
? nothing
|
36
|
-
: html`
|
37
|
-
<div
|
38
|
-
class="${className}"
|
39
|
-
rtgcmd-group
|
40
|
-
role="presentation"
|
41
|
-
id="${this.identifier}"
|
42
|
-
>
|
43
|
-
<div
|
44
|
-
rtgcmd-group-heading
|
45
|
-
aria-hidden="true"
|
46
|
-
id="${this.identifier}h"
|
47
|
-
>
|
48
|
-
${this.heading}
|
49
|
-
</div>
|
50
|
-
<div
|
51
|
-
rtgcmd-group-items
|
52
|
-
role="group"
|
53
|
-
aria-labelledby="${this.identifier}h"
|
54
|
-
>
|
55
|
-
<slot></slot>
|
56
|
-
</div>
|
57
|
-
</div>
|
58
|
-
`}`;
|
59
|
-
}
|
60
|
-
}
|