Skip to content

Commit 29af7fe

Browse files
authored
feat: modal (#154)
* fix: styling of modal * fix: modal props * fix: conflicting styles * fix: styles of drawer * fix: hide scrollbar in drawer * fix: padding * fix: used native method for dismissing of drawer
1 parent 76e861c commit 29af7fe

File tree

11 files changed

+299
-123
lines changed

11 files changed

+299
-123
lines changed

platforms/metagram/src/app.css

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -27,6 +27,14 @@
2727
.subtext {
2828
@apply font-geist text-xs/[1] font-normal;
2929
}
30+
.hide-scrollbar {
31+
-ms-overflow-style: none;
32+
scrollbar-width: none;
33+
}
34+
35+
.hide-scrollbar::-webkit-scrollbar {
36+
display: none;
37+
}
3038
}
3139

3240
@theme {
Lines changed: 80 additions & 32 deletions
Original file line numberDiff line numberDiff line change
@@ -1,36 +1,84 @@
11
<script module>
2-
export {DrawerContent};
2+
export { DrawerContent };
33
</script>
44

55
{#snippet DrawerContent()}
6-
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Vero dolore, necessitatibus quam expedita repudiandae cum nulla totam officiis itaque earum explicabo vel soluta libero ea exercitationem iusto velit incidunt quibusdam.
7-
Incidunt maiores sed, voluptas magnam magni reiciendis ipsa. Totam molestias commodi incidunt obcaecati fugiat temporibus voluptatum ea excepturi cumque, nostrum quod quae aperiam, nemo asperiores consectetur doloremque repellat, alias consequatur.
8-
Inventore deleniti aliquam sapiente, vel ipsam tempore veritatis explicabo minus harum hic itaque dolorem nostrum tenetur dicta dolores delectus eveniet nisi accusantium aperiam cumque iure culpa, eos adipisci! Vel, iusto.
9-
Repellendus unde incidunt a saepe reiciendis? Nam, esse voluptas aliquam repellendus cupiditate placeat quis autem minima reiciendis ex unde eveniet neque qui dolorum. Dignissimos inventore quidem ipsum sequi non vel?
10-
Nemo aspernatur incidunt veniam quia animi vel asperiores quidem, expedita eum in qui provident, consequuntur officiis veritatis quisquam quo, necessitatibus similique autem odit officia numquam cum dolore pariatur eius! Cupiditate.
11-
Facilis aliquid nihil doloremque officiis fugit in minus dicta et, omnis nesciunt suscipit sequi atque perferendis alias exercitationem eaque aliquam provident praesentium quae sunt quas magni consequatur. Praesentium, dolor ipsa?
12-
Et, veritatis saepe animi harum eligendi fugit accusamus tempore, reiciendis eveniet, dolores rerum optio earum magnam nam laudantium necessitatibus incidunt minima labore laboriosam voluptatum mollitia quia? Consectetur, reprehenderit! Mollitia, neque.
13-
Optio nam eius voluptatem. Facilis hic cum non est quod modi sapiente ex asperiores earum, temporibus ipsum dolore optio aut mollitia fuga ducimus ipsam deleniti et adipisci maxime in velit.
14-
Praesentium doloribus earum sunt quasi voluptas quo expedita tempora consequatur ratione maiores accusantium dolorem sit corporis quibusdam esse molestias facilis nemo, non quam? Dolores recusandae neque ex consequatur in atque?
15-
Animi recusandae minus eaque nisi dicta earum sit tempore neque porro vero assumenda tempora alias, quis sunt iste illo fuga in inventore quaerat? Magnam cum vero fugiat quaerat provident necessitatibus.
16-
Consequatur iusto est sint doloribus quis porro quibusdam inventore numquam nisi nam ullam consectetur mollitia molestiae molestias necessitatibus recusandae voluptate cum aut pariatur, asperiores nobis et perspiciatis ipsam labore. Delectus.
17-
Laborum quisquam ea eligendi ut nesciunt aut minima iusto sint esse laboriosam! Doloremque deserunt enim et recusandae quo, nobis expedita maxime error inventore, officiis nulla ipsa tempora eos commodi beatae!
18-
Atque vel vitae perspiciatis quam soluta eaque sed illo autem ea ut, exercitationem sit ad quidem eius modi alias facilis labore porro esse. Vel nihil expedita reprehenderit culpa facilis omnis!
19-
Non eum minima eius sapiente quo nulla culpa maiores laudantium quos! Consequatur adipisci ad neque nemo! Iste aperiam, tenetur nisi distinctio saepe, reiciendis sed reprehenderit, eum assumenda vel provident in.
20-
Magni ex commodi soluta quod ipsum repellendus laborum assumenda velit, aperiam praesentium nemo, dolor aut similique libero tenetur eum! Atque maxime laborum tenetur similique nam ipsam possimus eos officia voluptates.
21-
Deleniti quas amet corporis enim possimus nostrum laboriosam nisi. Quisquam, perspiciatis. Quidem unde ut sequi maxime omnis inventore sed qui minima neque, accusamus officia, labore delectus et itaque repellendus. Quia.
22-
Quod unde id ipsum labore ex. Non quam, provident, excepturi expedita in, fuga repellendus quibusdam qui numquam similique eaque corrupti exercitationem dolorem mollitia quas! Eius facere nihil natus rerum saepe.
23-
Quos atque dolorem, eaque explicabo vel sequi, nam debitis nihil velit adipisci libero praesentium. Modi blanditiis odio, quis explicabo minus vel sunt eius! Odit, libero exercitationem dolore sequi odio assumenda.
24-
Cum nostrum iusto ratione excepturi mollitia reiciendis illo eius quisquam veniam non sunt ullam, porro suscipit beatae nesciunt temporibus optio quam tempora possimus. Facere, officia quasi tempora repudiandae quo rem!
25-
Explicabo cum ratione sapiente. Obcaecati at enim delectus aperiam iure ex, dolore, quae, id cupiditate quam facere similique perferendis voluptates vel ut. Dolorum delectus, officiis placeat amet rerum inventore nesciunt!
26-
Qui voluptas dolor similique id ratione magnam quas dolore ipsum dolores consectetur, error consequuntur nemo veniam tempora temporibus modi fugiat, quam officia exercitationem iusto veritatis dicta magni. Doloribus, harum provident.
27-
Veniam tempora quasi, pariatur omnis temporibus ipsam modi mollitia eum fuga tempore quia? Vel aliquam odit aut a! Perspiciatis sint nisi quidem, fuga eligendi architecto porro quos nemo ex provident!
28-
Modi nesciunt, aspernatur iure accusamus laborum incidunt? Suscipit amet dolor nihil odio id blanditiis beatae quos harum. Quasi dolorum voluptatum eaque sed vero cum. Impedit, esse. Voluptates tempora saepe repellendus!
29-
Quaerat quod animi suscipit error. Similique quae eaque accusantium fugit sint vero voluptas alias quidem? Animi cumque repudiandae quas deleniti ea repellat provident, esse, voluptatum nam dolore consequatur non blanditiis?
30-
Qui reiciendis quidem dicta iusto minima aliquam, iste itaque illo dolor earum eligendi, harum sed doloremque quo voluptatum amet consectetur at quod a officiis perspiciatis! Debitis perferendis pariatur cum odio!
31-
Est eveniet commodi dolorem numquam voluptatibus aliquid, unde accusamus, tempora laudantium consequatur autem repudiandae, quaerat magnam ducimus atque hic facilis officiis aspernatur. Ducimus necessitatibus, labore praesentium consectetur libero at voluptatibus.
32-
Consequatur repudiandae magnam sit blanditiis impedit fugiat totam reiciendis facilis porro sapiente harum veniam in, quos excepturi commodi perspiciatis ad voluptas! Perferendis cum nulla soluta ipsa at? Fugit, dignissimos mollitia!
33-
Adipisci voluptatem molestiae doloribus alias quisquam neque commodi incidunt libero maiores aut consequatur error corrupti, modi illo veritatis itaque numquam facere eveniet? Tenetur consectetur ipsum excepturi quaerat, facilis labore modi?
34-
Alias harum dolor tempora voluptatibus nam? Incidunt laborum debitis consequuntur, blanditiis laudantium ad facilis laboriosam, cupiditate optio similique saepe a, praesentium veniam dignissimos modi placeat reiciendis! Quia doloribus blanditiis labore.
35-
Suscipit dolorum nobis incidunt voluptatibus fugiat minima nostrum natus cum, quas magni obcaecati qui perspiciatis maxime, eligendi aperiam doloribus doloremque totam asperiores a labore! Explicabo quaerat doloremque labore harum vitae!</p>
36-
{/snippet}
6+
<p>
7+
Lorem ipsum dolor sit amet consectetur adipisicing elit. Vero dolore, necessitatibus quam
8+
expedita repudiandae cum nulla totam officiis itaque earum explicabo vel soluta libero ea
9+
exercitationem iusto velit incidunt quibusdam. Incidunt maiores sed, voluptas magnam magni
10+
reiciendis ipsa. Totam molestias commodi incidunt obcaecati fugiat temporibus voluptatum ea
11+
excepturi cumque, nostrum quod quae aperiam, nemo asperiores consectetur doloremque
12+
repellat, alias consequatur. Inventore deleniti aliquam sapiente, vel ipsam tempore
13+
veritatis explicabo minus harum hic itaque dolorem nostrum tenetur dicta dolores delectus
14+
eveniet nisi accusantium aperiam cumque iure culpa, eos adipisci! Vel, iusto. Repellendus
15+
unde incidunt a saepe reiciendis? Nam, esse voluptas aliquam repellendus cupiditate placeat
16+
quis autem minima reiciendis ex unde eveniet neque qui dolorum. Dignissimos inventore quidem
17+
ipsum sequi non vel? Nemo aspernatur incidunt veniam quia animi vel asperiores quidem,
18+
expedita eum in qui provident, consequuntur officiis veritatis quisquam quo, necessitatibus
19+
similique autem odit officia numquam cum dolore pariatur eius! Cupiditate. Facilis aliquid
20+
nihil doloremque officiis fugit in minus dicta et, omnis nesciunt suscipit sequi atque
21+
perferendis alias exercitationem eaque aliquam provident praesentium quae sunt quas magni
22+
consequatur. Praesentium, dolor ipsa? Et, veritatis saepe animi harum eligendi fugit
23+
accusamus tempore, reiciendis eveniet, dolores rerum optio earum magnam nam laudantium
24+
necessitatibus incidunt minima labore laboriosam voluptatum mollitia quia? Consectetur,
25+
reprehenderit! Mollitia, neque. Optio nam eius voluptatem. Facilis hic cum non est quod modi
26+
sapiente ex asperiores earum, temporibus ipsum dolore optio aut mollitia fuga ducimus ipsam
27+
deleniti et adipisci maxime in velit. Praesentium doloribus earum sunt quasi voluptas quo
28+
expedita tempora consequatur ratione maiores accusantium dolorem sit corporis quibusdam esse
29+
molestias facilis nemo, non quam? Dolores recusandae neque ex consequatur in atque? Animi
30+
recusandae minus eaque nisi dicta earum sit tempore neque porro vero assumenda tempora
31+
alias, quis sunt iste illo fuga in inventore quaerat? Magnam cum vero fugiat quaerat
32+
provident necessitatibus. Consequatur iusto est sint doloribus quis porro quibusdam
33+
inventore numquam nisi nam ullam consectetur mollitia molestiae molestias necessitatibus
34+
recusandae voluptate cum aut pariatur, asperiores nobis et perspiciatis ipsam labore.
35+
Delectus. Laborum quisquam ea eligendi ut nesciunt aut minima iusto sint esse laboriosam!
36+
Doloremque deserunt enim et recusandae quo, nobis expedita maxime error inventore, officiis
37+
nulla ipsa tempora eos commodi beatae! Atque vel vitae perspiciatis quam soluta eaque sed
38+
illo autem ea ut, exercitationem sit ad quidem eius modi alias facilis labore porro esse.
39+
Vel nihil expedita reprehenderit culpa facilis omnis! Non eum minima eius sapiente quo nulla
40+
culpa maiores laudantium quos! Consequatur adipisci ad neque nemo! Iste aperiam, tenetur
41+
nisi distinctio saepe, reiciendis sed reprehenderit, eum assumenda vel provident in. Magni
42+
ex commodi soluta quod ipsum repellendus laborum assumenda velit, aperiam praesentium nemo,
43+
dolor aut similique libero tenetur eum! Atque maxime laborum tenetur similique nam ipsam
44+
possimus eos officia voluptates. Deleniti quas amet corporis enim possimus nostrum
45+
laboriosam nisi. Quisquam, perspiciatis. Quidem unde ut sequi maxime omnis inventore sed qui
46+
minima neque, accusamus officia, labore delectus et itaque repellendus. Quia. Quod unde id
47+
ipsum labore ex. Non quam, provident, excepturi expedita in, fuga repellendus quibusdam qui
48+
numquam similique eaque corrupti exercitationem dolorem mollitia quas! Eius facere nihil
49+
natus rerum saepe. Quos atque dolorem, eaque explicabo vel sequi, nam debitis nihil velit
50+
adipisci libero praesentium. Modi blanditiis odio, quis explicabo minus vel sunt eius! Odit,
51+
libero exercitationem dolore sequi odio assumenda. Cum nostrum iusto ratione excepturi
52+
mollitia reiciendis illo eius quisquam veniam non sunt ullam, porro suscipit beatae nesciunt
53+
temporibus optio quam tempora possimus. Facere, officia quasi tempora repudiandae quo rem!
54+
Explicabo cum ratione sapiente. Obcaecati at enim delectus aperiam iure ex, dolore, quae, id
55+
cupiditate quam facere similique perferendis voluptates vel ut. Dolorum delectus, officiis
56+
placeat amet rerum inventore nesciunt! Qui voluptas dolor similique id ratione magnam quas
57+
dolore ipsum dolores consectetur, error consequuntur nemo veniam tempora temporibus modi
58+
fugiat, quam officia exercitationem iusto veritatis dicta magni. Doloribus, harum provident.
59+
Veniam tempora quasi, pariatur omnis temporibus ipsam modi mollitia eum fuga tempore quia?
60+
Vel aliquam odit aut a! Perspiciatis sint nisi quidem, fuga eligendi architecto porro quos
61+
nemo ex provident! Modi nesciunt, aspernatur iure accusamus laborum incidunt? Suscipit amet
62+
dolor nihil odio id blanditiis beatae quos harum. Quasi dolorum voluptatum eaque sed vero
63+
cum. Impedit, esse. Voluptates tempora saepe repellendus! Quaerat quod animi suscipit error.
64+
Similique quae eaque accusantium fugit sint vero voluptas alias quidem? Animi cumque
65+
repudiandae quas deleniti ea repellat provident, esse, voluptatum nam dolore consequatur non
66+
blanditiis? Qui reiciendis quidem dicta iusto minima aliquam, iste itaque illo dolor earum
67+
eligendi, harum sed doloremque quo voluptatum amet consectetur at quod a officiis
68+
perspiciatis! Debitis perferendis pariatur cum odio! Est eveniet commodi dolorem numquam
69+
voluptatibus aliquid, unde accusamus, tempora laudantium consequatur autem repudiandae,
70+
quaerat magnam ducimus atque hic facilis officiis aspernatur. Ducimus necessitatibus, labore
71+
praesentium consectetur libero at voluptatibus. Consequatur repudiandae magnam sit
72+
blanditiis impedit fugiat totam reiciendis facilis porro sapiente harum veniam in, quos
73+
excepturi commodi perspiciatis ad voluptas! Perferendis cum nulla soluta ipsa at? Fugit,
74+
dignissimos mollitia! Adipisci voluptatem molestiae doloribus alias quisquam neque commodi
75+
incidunt libero maiores aut consequatur error corrupti, modi illo veritatis itaque numquam
76+
facere eveniet? Tenetur consectetur ipsum excepturi quaerat, facilis labore modi? Alias
77+
harum dolor tempora voluptatibus nam? Incidunt laborum debitis consequuntur, blanditiis
78+
laudantium ad facilis laboriosam, cupiditate optio similique saepe a, praesentium veniam
79+
dignissimos modi placeat reiciendis! Quia doloribus blanditiis labore. Suscipit dolorum
80+
nobis incidunt voluptatibus fugiat minima nostrum natus cum, quas magni obcaecati qui
81+
perspiciatis maxime, eligendi aperiam doloribus doloremque totam asperiores a labore!
82+
Explicabo quaerat doloremque labore harum vitae!
83+
</p>
84+
{/snippet}

platforms/metagram/src/lib/fragments/Drawer/Drawer.stories.ts

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,6 @@ export default {
1414

1515
export const Main = {
1616
args: {
17-
children: DrawerContent
18-
}
17+
children: DrawerContent
18+
}
1919
};

platforms/metagram/src/lib/fragments/Drawer/Drawer.svelte

Lines changed: 30 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -2,9 +2,9 @@
22
import { onMount, type Snippet } from 'svelte';
33
import { CupertinoPane } from 'cupertino-pane';
44
import type { HTMLAttributes } from 'svelte/elements';
5-
import { clickOutside, cn } from '$lib/utils';
5+
import { cn } from '$lib/utils';
66
import { swipe } from 'svelte-gestures';
7-
import type { SwipeCustomEvent } from 'svelte-gestures';
7+
import type { SwipeCustomEvent } from 'svelte-gestures';
88
99
interface IDrawerProps extends HTMLAttributes<HTMLDivElement> {
1010
isPaneOpen?: boolean;
@@ -22,18 +22,17 @@
2222
let drawerElement: HTMLElement;
2323
let drawer: CupertinoPane;
2424
25-
const handleClickOutside = () => {
26-
drawer?.destroy({ animate: true });
27-
isPaneOpen = false;
28-
};
25+
function dismiss() {
26+
if (drawer) drawer.destroy({ animate: true });
27+
}
2928
30-
const handleDrawerSwipe = (event: SwipeCustomEvent) => {
31-
if (event.detail.direction === 'down' as string) {
32-
handleSwipe?.(false);
33-
drawer?.destroy({ animate: true });
34-
isPaneOpen = false;
35-
}
36-
};
29+
const handleDrawerSwipe = (event: SwipeCustomEvent) => {
30+
if (event.detail.direction === ('down' as string)) {
31+
handleSwipe?.(false);
32+
drawer?.destroy({ animate: true });
33+
isPaneOpen = false;
34+
}
35+
};
3736
3837
onMount(() => {
3938
if (!drawerElement) return;
@@ -47,7 +46,10 @@
4746
bottomClose: true,
4847
buttonDestroy: false,
4948
cssClass: '',
50-
initialBreak: 'middle'
49+
initialBreak: 'middle',
50+
events: {
51+
onBackdropTap: () => dismiss()
52+
}
5153
});
5254
if (isPaneOpen) {
5355
drawer.present({ animate: true });
@@ -67,8 +69,20 @@
6769
minSwipeDistance: 60
6870
})}
6971
onswipe={handleDrawerSwipe}
70-
use:clickOutside={handleClickOutside}
7172
class={cn(restProps.class)}
7273
>
73-
{@render children?.()}
74+
{@render children?.()}
7475
</div>
76+
77+
<style>
78+
:global(.pane) {
79+
border-top-left-radius: 32px !important;
80+
border-top-right-radius: 32px !important;
81+
padding: 20px !important;
82+
scrollbar-width: none !important;
83+
-ms-overflow-style: none !important;
84+
::-webkit-scrollbar {
85+
display: none !important;
86+
}
87+
}
88+
</style>
Lines changed: 31 additions & 34 deletions
Original file line numberDiff line numberDiff line change
@@ -1,52 +1,49 @@
1-
import type { ComponentProps } from "svelte";
2-
import Header from "./Header.svelte";
1+
import type { ComponentProps } from 'svelte';
2+
import Header from './Header.svelte';
33

44
export default {
5-
title: "Fragments/Header",
6-
component: Header,
7-
tags: ["autodocs"],
8-
render: (args: {
9-
Component: Header;
10-
props: ComponentProps<typeof Header>;
11-
}) => ({
12-
Component: Header,
13-
props: args,
14-
}),
5+
title: 'UI/Header',
6+
component: Header,
7+
tags: ['autodocs'],
8+
render: (args: { Component: Header; props: ComponentProps<typeof Header> }) => ({
9+
Component: Header,
10+
props: args
11+
})
1512
};
1613

1714
export const Primary = {
18-
args: {
19-
variant: "primary",
20-
heading: "metagram",
21-
callback: () => alert("clicked"),
22-
},
15+
args: {
16+
variant: 'primary',
17+
heading: 'metagram',
18+
callback: () => alert('clicked')
19+
}
2320
};
2421

2522
export const PrimaryWithNoFlash = {
26-
args: {
27-
variant: "primary",
28-
heading: "messages",
29-
},
23+
args: {
24+
variant: 'primary',
25+
heading: 'messages'
26+
}
3027
};
3128

3229
export const Secondary = {
33-
args: {
34-
variant: "secondary",
35-
heading: "Account",
36-
},
30+
args: {
31+
variant: 'secondary',
32+
heading: 'Account'
33+
}
3734
};
3835

3936
export const SecondaryWithMenu = {
40-
args: {
41-
variant: "secondary",
42-
heading: "Account",
43-
callback: () => alert("menu clicked"),
44-
},
37+
args: {
38+
variant: 'secondary',
39+
heading: 'Account',
40+
callback: () => alert('menu clicked')
41+
}
4542
};
4643

4744
export const Tertiary = {
48-
args: {
49-
variant: "tertiary",
50-
callback: () => alert("clicked"),
51-
},
45+
args: {
46+
variant: 'tertiary',
47+
callback: () => alert('clicked')
48+
}
5249
};
Lines changed: 23 additions & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -1,35 +1,32 @@
1-
import type { ComponentProps } from "svelte";
2-
import Message from "./Message.svelte";
1+
import type { ComponentProps } from 'svelte';
2+
import Message from './Message.svelte';
33

44
export default {
5-
title: "UI/Message",
6-
component: Message,
7-
tags: ["autodocs"],
8-
render: (args: {
9-
Component: Message;
10-
props: ComponentProps<typeof Message>;
11-
}) => ({
12-
Component: Message,
13-
props: args,
14-
}),
5+
title: 'UI/Message',
6+
component: Message,
7+
tags: ['autodocs'],
8+
render: (args: { Component: Message; props: ComponentProps<typeof Message> }) => ({
9+
Component: Message,
10+
props: args
11+
})
1512
};
1613

1714
export const Primary = {
18-
args: {
19-
avatar: "https://www.gravatar.com/avatar/2c7d99fe281ecd3bcd65ab915bac6dd5?s=250",
20-
username: "donaldthefirstt",
21-
text: "i was thinking of making it to the conference so we could take some more fire pictures like last time",
22-
unread: false,
23-
callback: () => alert("Message clicked"),
24-
},
15+
args: {
16+
avatar: 'https://www.gravatar.com/avatar/2c7d99fe281ecd3bcd65ab915bac6dd5?s=250',
17+
username: 'donaldthefirstt',
18+
text: 'i was thinking of making it to the conference so we could take some more fire pictures like last time',
19+
unread: false,
20+
callback: () => alert('Message clicked')
21+
}
2522
};
2623

2724
export const Unread = {
28-
args: {
29-
avatar: "https://www.gravatar.com/avatar/2c7d99fe281ecd3bcd65ab915bac6dd5?s=250",
30-
username: "donaldthefirstt",
31-
text: "i was thinking of making it to the conference so we could take some more fire pictures like last time",
32-
unread: true,
33-
callback: () => alert("Message clicked"),
34-
},
25+
args: {
26+
avatar: 'https://www.gravatar.com/avatar/2c7d99fe281ecd3bcd65ab915bac6dd5?s=250',
27+
username: 'donaldthefirstt',
28+
text: 'i was thinking of making it to the conference so we could take some more fire pictures like last time',
29+
unread: true,
30+
callback: () => alert('Message clicked')
31+
}
3532
};

0 commit comments

Comments
 (0)