flowbite-svelte 0.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +33 -0
- package/accordions/AccordionDefault.svelte +26 -0
- package/accordions/AccordionDefault.svelte.d.ts +35 -0
- package/accordions/AccordionItem.svelte +44 -0
- package/accordions/AccordionItem.svelte.d.ts +29 -0
- package/alerts/Alert.svelte +111 -0
- package/alerts/Alert.svelte.d.ts +31 -0
- package/alerts/BorderAlert.svelte +118 -0
- package/alerts/BorderAlert.svelte.d.ts +31 -0
- package/alerts/InfoAlert.svelte +125 -0
- package/alerts/InfoAlert.svelte.d.ts +35 -0
- package/badges/Badge.svelte +28 -0
- package/badges/Badge.svelte.d.ts +27 -0
- package/badges/BadgeIcon.svelte +31 -0
- package/badges/BadgeIcon.svelte.d.ts +31 -0
- package/badges/BadgeLink.svelte +29 -0
- package/badges/BadgeLink.svelte.d.ts +29 -0
- package/buttongroups/ButtonGroup.svelte +68 -0
- package/buttongroups/ButtonGroup.svelte.d.ts +33 -0
- package/buttongroups/ButtonGroupOutline.svelte +70 -0
- package/buttongroups/ButtonGroupOutline.svelte.d.ts +33 -0
- package/buttons/Button.svelte +60 -0
- package/buttons/Button.svelte.d.ts +33 -0
- package/buttons/ColorShadowButton.svelte +35 -0
- package/buttons/ColorShadowButton.svelte.d.ts +31 -0
- package/buttons/GradientDuotoneButton.svelte +33 -0
- package/buttons/GradientDuotoneButton.svelte.d.ts +31 -0
- package/buttons/GradientMonochromeButton.svelte +35 -0
- package/buttons/GradientMonochromeButton.svelte.d.ts +31 -0
- package/buttons/GradientOutlineButton.svelte +52 -0
- package/buttons/GradientOutlineButton.svelte.d.ts +31 -0
- package/cards/Card.svelte +86 -0
- package/cards/Card.svelte.d.ts +39 -0
- package/cards/CtaCard.svelte +63 -0
- package/cards/CtaCard.svelte.d.ts +45 -0
- package/cards/EcommerceCard.svelte +98 -0
- package/cards/EcommerceCard.svelte.d.ts +41 -0
- package/cards/HorizontalCard.svelte +29 -0
- package/cards/HorizontalCard.svelte.d.ts +35 -0
- package/cards/InteractiveCard.svelte +127 -0
- package/cards/InteractiveCard.svelte.d.ts +63 -0
- package/cards/ListCard.svelte +82 -0
- package/cards/ListCard.svelte.d.ts +51 -0
- package/cards/SignInCard.svelte +125 -0
- package/cards/SignInCard.svelte.d.ts +45 -0
- package/darkmode/DarkMode.svelte +78 -0
- package/darkmode/DarkMode.svelte.d.ts +23 -0
- package/dropdowns/DropdownDefault.svelte +117 -0
- package/dropdowns/DropdownDefault.svelte.d.ts +51 -0
- package/footer/SimpleFooter.svelte +32 -0
- package/footer/SimpleFooter.svelte.d.ts +45 -0
- package/index.d.ts +39 -0
- package/index.js +116 -0
- package/list-group/List.svelte +79 -0
- package/list-group/List.svelte.d.ts +33 -0
- package/modals/ExtraLargeModal.svelte +236 -0
- package/modals/ExtraLargeModal.svelte.d.ts +45 -0
- package/modals/LargeModal.svelte +236 -0
- package/modals/LargeModal.svelte.d.ts +45 -0
- package/modals/MediumModal.svelte +242 -0
- package/modals/MediumModal.svelte.d.ts +45 -0
- package/modals/ModalButton.svelte +48 -0
- package/modals/ModalButton.svelte.d.ts +29 -0
- package/modals/SignInModal.svelte +174 -0
- package/modals/SignInModal.svelte.d.ts +37 -0
- package/modals/SmallModal.svelte +236 -0
- package/modals/SmallModal.svelte.d.ts +45 -0
- package/modals/modalStores.d.ts +1 -0
- package/modals/modalStores.js +3 -0
- package/navbar/DropdownNavbar.svelte +210 -0
- package/navbar/DropdownNavbar.svelte.d.ts +65 -0
- package/navbar/Navbar.svelte +96 -0
- package/navbar/Navbar.svelte.d.ts +39 -0
- package/package.json +92 -0
- package/tabs/DefaultTabs.svelte +43 -0
- package/tabs/DefaultTabs.svelte.d.ts +33 -0
- package/tabs/InteractiveTabs.svelte +68 -0
- package/tabs/InteractiveTabs.svelte.d.ts +47 -0
- package/tabs/PillTabs.svelte +38 -0
- package/tabs/PillTabs.svelte.d.ts +31 -0
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
<script>
|
|
2
|
+
// import { createEventDispatcher } from "svelte";
|
|
3
|
+
import { modalIdStore } from "./modalStores.js";
|
|
4
|
+
// const dispatch = createEventDispatcher();
|
|
5
|
+
|
|
6
|
+
export let id = "signin-modal";
|
|
7
|
+
export let btnSignInColor = "blue";
|
|
8
|
+
export let titleSignIn = "Sign in to our platform";
|
|
9
|
+
export let lostPasswordLink;
|
|
10
|
+
export let rememberMe = false;
|
|
11
|
+
export let signUp;
|
|
12
|
+
export let action;
|
|
13
|
+
|
|
14
|
+
const closeModal = () => {
|
|
15
|
+
modalIdStore.update((value) => {
|
|
16
|
+
value = null;
|
|
17
|
+
});
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
export let showModalId;
|
|
21
|
+
modalIdStore.subscribe((value) => {
|
|
22
|
+
showModalId = value;
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
let submitClass;
|
|
26
|
+
|
|
27
|
+
if (btnSignInColor === "blue") {
|
|
28
|
+
submitClass =
|
|
29
|
+
"w-full text-white bg-blue-700 hover:bg-blue-800 focus:ring-4 focus:ring-blue-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-blue-600 dark:hover:bg-blue-700 dark:focus:ring-blue-800";
|
|
30
|
+
} else if (btnSignInColor === "gray") {
|
|
31
|
+
submitClass =
|
|
32
|
+
"w-full text-white bg-gray-700 hover:bg-gray-800 focus:ring-4 focus:ring-gray-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-gray-600 dark:hover:bg-gray-700 dark:focus:ring-gray-800";
|
|
33
|
+
} else if (btnSignInColor === "red") {
|
|
34
|
+
submitClass =
|
|
35
|
+
"w-full text-white bg-red-700 hover:bg-red-800 focus:ring-4 focus:ring-red-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-red-600 dark:hover:bg-red-700 dark:focus:ring-red-800";
|
|
36
|
+
} else if (btnSignInColor === "yellow") {
|
|
37
|
+
submitClass =
|
|
38
|
+
"w-full text-white bg-yellow-700 hover:bg-yellow-800 focus:ring-4 focus:ring-yellow-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-yellow-600 dark:hover:bg-yellow-700 dark:focus:ring-yellow-800";
|
|
39
|
+
} else if (btnSignInColor === "green") {
|
|
40
|
+
submitClass =
|
|
41
|
+
"w-full text-white bg-green-700 hover:bg-green-800 focus:ring-4 focus:ring-green-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-green-600 dark:hover:bg-green-700 dark:focus:ring-green-800";
|
|
42
|
+
} else if (btnSignInColor === "indigo") {
|
|
43
|
+
submitClass =
|
|
44
|
+
"w-full text-white bg-indigo-700 hover:bg-indigo-800 focus:ring-4 focus:ring-indigo-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-indigo-600 dark:hover:bg-indigo-700 dark:focus:ring-indigo-800";
|
|
45
|
+
} else if (btnSignInColor === "purple") {
|
|
46
|
+
submitClass =
|
|
47
|
+
"w-full text-white bg-purple-700 hover:bg-purple-800 focus:ring-4 focus:ring-purple-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-purple-600 dark:hover:bg-purple-700 dark:focus:ring-purple-800";
|
|
48
|
+
} else if (btnSignInColor === "pink") {
|
|
49
|
+
submitClass =
|
|
50
|
+
"w-full text-white bg-pink-700 hover:bg-pink-800 focus:ring-4 focus:ring-pink-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-pink-600 dark:hover:bg-pink-700 dark:focus:ring-pink-800";
|
|
51
|
+
} else {
|
|
52
|
+
submitClass =
|
|
53
|
+
"w-full text-white bg-blue-700 hover:bg-blue-800 focus:ring-4 focus:ring-blue-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-blue-600 dark:hover:bg-blue-700 dark:focus:ring-blue-800";
|
|
54
|
+
}
|
|
55
|
+
</script>
|
|
56
|
+
|
|
57
|
+
{#if showModalId === id}
|
|
58
|
+
<div
|
|
59
|
+
{id}
|
|
60
|
+
role="dialog"
|
|
61
|
+
aria-modal="true"
|
|
62
|
+
class="flex overflow-y-auto overflow-x-hidden fixed right-0 left-0 top-20 z-50 justify-center items-center"
|
|
63
|
+
>
|
|
64
|
+
<div class="relative px-4 w-full max-w-md h-full md:h-auto">
|
|
65
|
+
<div class="relative bg-white rounded-lg shadow dark:bg-gray-700">
|
|
66
|
+
<div class="flex justify-end p-2">
|
|
67
|
+
<button
|
|
68
|
+
type="button"
|
|
69
|
+
class="text-gray-400 bg-transparent hover:bg-gray-200 hover:text-gray-900 rounded-lg text-sm p-1.5 ml-auto inline-flex items-center dark:hover:bg-gray-800 dark:hover:text-white"
|
|
70
|
+
on:click={closeModal}
|
|
71
|
+
>
|
|
72
|
+
<svg
|
|
73
|
+
class="w-5 h-5"
|
|
74
|
+
fill="currentColor"
|
|
75
|
+
viewBox="0 0 20 20"
|
|
76
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
77
|
+
><path
|
|
78
|
+
fill-rule="evenodd"
|
|
79
|
+
d="M4.293 4.293a1 1 0 011.414 0L10 8.586l4.293-4.293a1 1 0 111.414 1.414L11.414 10l4.293 4.293a1 1 0 01-1.414 1.414L10 11.414l-4.293 4.293a1 1 0 01-1.414-1.414L8.586 10 4.293 5.707a1 1 0 010-1.414z"
|
|
80
|
+
clip-rule="evenodd"
|
|
81
|
+
/></svg
|
|
82
|
+
>
|
|
83
|
+
</button>
|
|
84
|
+
</div>
|
|
85
|
+
<form class="px-6 pb-4 space-y-6 lg:px-8 sm:pb-6 xl:pb-8" {action}>
|
|
86
|
+
<h3 class="text-xl font-medium text-gray-900 dark:text-white">
|
|
87
|
+
{titleSignIn}
|
|
88
|
+
</h3>
|
|
89
|
+
<div>
|
|
90
|
+
<label
|
|
91
|
+
for="email-{id}"
|
|
92
|
+
class="block mb-2 text-sm font-medium text-gray-900 dark:text-gray-300"
|
|
93
|
+
>Your email</label
|
|
94
|
+
>
|
|
95
|
+
<input
|
|
96
|
+
type="email"
|
|
97
|
+
name="email"
|
|
98
|
+
id="email-{id}"
|
|
99
|
+
class="bg-gray-50 border border-gray-300 text-gray-900 text-sm rounded-lg focus:ring-blue-500 focus:border-blue-500 block w-full p-2.5 dark:bg-gray-600 dark:border-gray-500 dark:placeholder-gray-400 dark:text-white"
|
|
100
|
+
placeholder="name@company.com"
|
|
101
|
+
required
|
|
102
|
+
/>
|
|
103
|
+
</div>
|
|
104
|
+
<div>
|
|
105
|
+
<label
|
|
106
|
+
for="password-{id}"
|
|
107
|
+
class="block mb-2 text-sm font-medium text-gray-900 dark:text-gray-300"
|
|
108
|
+
>Your password</label
|
|
109
|
+
>
|
|
110
|
+
<input
|
|
111
|
+
type="password"
|
|
112
|
+
name="password"
|
|
113
|
+
id="password-{id}"
|
|
114
|
+
placeholder="••••••••"
|
|
115
|
+
class="bg-gray-50 border border-gray-300 text-gray-900 text-sm rounded-lg focus:ring-blue-500 focus:border-blue-500 block w-full p-2.5 dark:bg-gray-600 dark:border-gray-500 dark:placeholder-gray-400 dark:text-white"
|
|
116
|
+
required
|
|
117
|
+
/>
|
|
118
|
+
</div>
|
|
119
|
+
<div class="flex justify-between">
|
|
120
|
+
{#if rememberMe}
|
|
121
|
+
<div class="flex items-start">
|
|
122
|
+
<div class="flex items-center h-5">
|
|
123
|
+
<input
|
|
124
|
+
id="remember-{id}"
|
|
125
|
+
aria-describedby="remember"
|
|
126
|
+
type="checkbox"
|
|
127
|
+
class="w-4 h-4 bg-gray-50 rounded border border-gray-300 focus:ring-3 focus:ring-blue-300 dark:bg-gray-700 dark:border-gray-600 dark:focus:ring-blue-600 dark:ring-offset-gray-800"
|
|
128
|
+
required=""
|
|
129
|
+
/>
|
|
130
|
+
</div>
|
|
131
|
+
<div class="ml-3 text-sm">
|
|
132
|
+
<label
|
|
133
|
+
for="remember"
|
|
134
|
+
class="font-medium text-gray-900 dark:text-gray-300"
|
|
135
|
+
>Remember me</label
|
|
136
|
+
>
|
|
137
|
+
</div>
|
|
138
|
+
</div>
|
|
139
|
+
{/if}
|
|
140
|
+
{#if lostPasswordLink}
|
|
141
|
+
<a
|
|
142
|
+
href={lostPasswordLink}
|
|
143
|
+
rel="external"
|
|
144
|
+
class="text-sm text-blue-700 hover:underline dark:text-blue-500"
|
|
145
|
+
><button type="button" on:click={closeModal}
|
|
146
|
+
>Lost Password?</button
|
|
147
|
+
></a
|
|
148
|
+
>
|
|
149
|
+
{/if}
|
|
150
|
+
</div>
|
|
151
|
+
<button type="submit" class={submitClass} on:click={closeModal}
|
|
152
|
+
>Login to your account</button
|
|
153
|
+
>
|
|
154
|
+
{#if signUp}
|
|
155
|
+
<div class="text-sm font-medium text-gray-500 dark:text-gray-300">
|
|
156
|
+
Not registered? <a
|
|
157
|
+
href={signUp}
|
|
158
|
+
rel="external"
|
|
159
|
+
class="text-blue-700 hover:underline dark:text-blue-500"
|
|
160
|
+
><button type="button" on:click={closeModal}
|
|
161
|
+
>Create account</button
|
|
162
|
+
></a
|
|
163
|
+
>
|
|
164
|
+
</div>
|
|
165
|
+
{/if}
|
|
166
|
+
</form>
|
|
167
|
+
</div>
|
|
168
|
+
</div>
|
|
169
|
+
</div>
|
|
170
|
+
<div
|
|
171
|
+
on:click={closeModal}
|
|
172
|
+
class="bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-40 w-full h-full"
|
|
173
|
+
/>
|
|
174
|
+
{/if}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
/** @typedef {typeof __propDef.props} SignInModalProps */
|
|
2
|
+
/** @typedef {typeof __propDef.events} SignInModalEvents */
|
|
3
|
+
/** @typedef {typeof __propDef.slots} SignInModalSlots */
|
|
4
|
+
export default class SignInModal extends SvelteComponentTyped<{
|
|
5
|
+
action: any;
|
|
6
|
+
lostPasswordLink: any;
|
|
7
|
+
showModalId: any;
|
|
8
|
+
signUp: any;
|
|
9
|
+
id?: string;
|
|
10
|
+
btnSignInColor?: string;
|
|
11
|
+
rememberMe?: boolean;
|
|
12
|
+
titleSignIn?: string;
|
|
13
|
+
}, {
|
|
14
|
+
[evt: string]: CustomEvent<any>;
|
|
15
|
+
}, {}> {
|
|
16
|
+
}
|
|
17
|
+
export type SignInModalProps = typeof __propDef.props;
|
|
18
|
+
export type SignInModalEvents = typeof __propDef.events;
|
|
19
|
+
export type SignInModalSlots = typeof __propDef.slots;
|
|
20
|
+
import { SvelteComponentTyped } from "svelte";
|
|
21
|
+
declare const __propDef: {
|
|
22
|
+
props: {
|
|
23
|
+
action: any;
|
|
24
|
+
lostPasswordLink: any;
|
|
25
|
+
showModalId: any;
|
|
26
|
+
signUp: any;
|
|
27
|
+
id?: string;
|
|
28
|
+
btnSignInColor?: string;
|
|
29
|
+
rememberMe?: boolean;
|
|
30
|
+
titleSignIn?: string;
|
|
31
|
+
};
|
|
32
|
+
events: {
|
|
33
|
+
[evt: string]: CustomEvent<any>;
|
|
34
|
+
};
|
|
35
|
+
slots: {};
|
|
36
|
+
};
|
|
37
|
+
export {};
|
|
@@ -0,0 +1,236 @@
|
|
|
1
|
+
<script>
|
|
2
|
+
import { createEventDispatcher } from "svelte";
|
|
3
|
+
import { modalIdStore } from "./modalStores.js";
|
|
4
|
+
const dispatch = createEventDispatcher();
|
|
5
|
+
export let id = "small-modal";
|
|
6
|
+
export let btnColor = "blue";
|
|
7
|
+
export let textColor = "gray";
|
|
8
|
+
export let title = "Terms of Service";
|
|
9
|
+
export let btn1;
|
|
10
|
+
export let btn2;
|
|
11
|
+
|
|
12
|
+
const closeModal = () => {
|
|
13
|
+
modalIdStore.update((value) => {
|
|
14
|
+
value = null;
|
|
15
|
+
});
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export let showModalId;
|
|
19
|
+
modalIdStore.subscribe((value) => {
|
|
20
|
+
showModalId = value;
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
const handlebtn1 = () => {
|
|
24
|
+
dispatch("handlebtn1");
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
const handlebtn2 = () => {
|
|
28
|
+
dispatch("handlebtn2");
|
|
29
|
+
// showModalId = null;
|
|
30
|
+
};
|
|
31
|
+
let divClass;
|
|
32
|
+
let headDivClass;
|
|
33
|
+
let h3Class;
|
|
34
|
+
let buttonClass;
|
|
35
|
+
let pClass;
|
|
36
|
+
let footerClass;
|
|
37
|
+
let btn2Class;
|
|
38
|
+
if (textColor === "blue") {
|
|
39
|
+
divClass = "relative bg-white rounded-lg shadow dark:bg-blue-700";
|
|
40
|
+
headDivClass =
|
|
41
|
+
"flex justify-between items-center p-5 rounded-t border-b dark:border-blue-600";
|
|
42
|
+
h3Class = "text-xl font-medium text-blue-900 dark:text-white";
|
|
43
|
+
buttonClass =
|
|
44
|
+
"text-blue-400 bg-transparent hover:bg-blue-200 hover:text-blue-900 rounded-lg text-sm p-1.5 ml-auto inline-flex items-center dark:hover:bg-blue-600 dark:hover:text-white";
|
|
45
|
+
pClass = "text-base leading-relaxed text-blue-500 dark:text-blue-400";
|
|
46
|
+
footerClass =
|
|
47
|
+
"flex items-center p-6 space-x-2 rounded-b border-t border-blue-200 dark:border-blue-600";
|
|
48
|
+
btn2Class =
|
|
49
|
+
"text-blue-500 bg-white hover:bg-blue-100 focus:ring-4 focus:ring-blue-300 rounded-lg border border-blue-200 text-sm font-medium px-5 py-2.5 hover:text-blue-900 focus:z-10 dark:bg-blue-700 dark:text-blue-300 dark:border-blue-500 dark:hover:text-white dark:hover:bg-blue-600";
|
|
50
|
+
} else if (textColor === "gray") {
|
|
51
|
+
divClass = "relative bg-white rounded-lg shadow dark:bg-gray-700";
|
|
52
|
+
headDivClass =
|
|
53
|
+
"flex justify-between items-center p-5 rounded-t border-b dark:border-gray-600";
|
|
54
|
+
h3Class = "text-xl font-medium text-gray-900 dark:text-white";
|
|
55
|
+
buttonClass =
|
|
56
|
+
"text-gray-400 bg-transparent hover:bg-gray-200 hover:text-gray-900 rounded-lg text-sm p-1.5 ml-auto inline-flex items-center dark:hover:bg-gray-600 dark:hover:text-white";
|
|
57
|
+
pClass = "text-base leading-relaxed text-gray-500 dark:text-gray-400";
|
|
58
|
+
footerClass =
|
|
59
|
+
"flex items-center p-6 space-x-2 rounded-b border-t border-gray-200 dark:border-gray-600";
|
|
60
|
+
btn2Class =
|
|
61
|
+
"text-gray-500 bg-white hover:bg-gray-100 focus:ring-4 focus:ring-gray-300 rounded-lg border border-gray-200 text-sm font-medium px-5 py-2.5 hover:text-gray-900 focus:z-10 dark:bg-gray-700 dark:text-gray-300 dark:border-gray-500 dark:hover:text-white dark:hover:bg-gray-600";
|
|
62
|
+
} else if (textColor === "red") {
|
|
63
|
+
divClass = "relative bg-white rounded-lg shadow dark:bg-red-700";
|
|
64
|
+
headDivClass =
|
|
65
|
+
"flex justify-between items-center p-5 rounded-t border-b dark:border-red-600";
|
|
66
|
+
h3Class = "text-xl font-medium text-red-900 dark:text-white";
|
|
67
|
+
buttonClass =
|
|
68
|
+
"text-red-400 bg-transparent hover:bg-red-200 hover:text-red-900 rounded-lg text-sm p-1.5 ml-auto inline-flex items-center dark:hover:bg-red-600 dark:hover:text-white";
|
|
69
|
+
pClass = "text-base leading-relaxed text-red-500 dark:text-red-400";
|
|
70
|
+
footerClass =
|
|
71
|
+
"flex items-center p-6 space-x-2 rounded-b border-t border-red-200 dark:border-red-600";
|
|
72
|
+
btn2Class =
|
|
73
|
+
"text-red-500 bg-white hover:bg-red-100 focus:ring-4 focus:ring-red-300 rounded-lg border border-red-200 text-sm font-medium px-5 py-2.5 hover:text-red-900 focus:z-10 dark:bg-red-700 dark:text-red-300 dark:border-red-500 dark:hover:text-white dark:hover:bg-red-600";
|
|
74
|
+
} else if (textColor === "yellow") {
|
|
75
|
+
divClass = "relative bg-white rounded-lg shadow dark:bg-yellow-700";
|
|
76
|
+
headDivClass =
|
|
77
|
+
"flex justify-between items-center p-5 rounded-t border-b dark:border-yellow-600";
|
|
78
|
+
h3Class = "text-xl font-medium text-yellow-900 dark:text-white";
|
|
79
|
+
buttonClass =
|
|
80
|
+
"text-yellow-400 bg-transparent hover:bg-yellow-200 hover:text-yellow-900 rounded-lg text-sm p-1.5 ml-auto inline-flex items-center dark:hover:bg-yellow-600 dark:hover:text-white";
|
|
81
|
+
pClass = "text-base leading-relaxed text-yellow-500 dark:text-yellow-400";
|
|
82
|
+
footerClass =
|
|
83
|
+
"flex items-center p-6 space-x-2 rounded-b border-t border-yellow-200 dark:border-yellow-600";
|
|
84
|
+
btn2Class =
|
|
85
|
+
"text-yellow-500 bg-white hover:bg-yellow-100 focus:ring-4 focus:ring-yellow-300 rounded-lg border border-yellow-200 text-sm font-medium px-5 py-2.5 hover:text-yellow-900 focus:z-10 dark:bg-yellow-700 dark:text-yellow-300 dark:border-yellow-500 dark:hover:text-white dark:hover:bg-yellow-600";
|
|
86
|
+
} else if (textColor === "green") {
|
|
87
|
+
divClass = "relative bg-white rounded-lg shadow dark:bg-green-700";
|
|
88
|
+
headDivClass =
|
|
89
|
+
"flex justify-between items-center p-5 rounded-t border-b dark:border-green-600";
|
|
90
|
+
h3Class = "text-xl font-medium text-green-900 dark:text-white";
|
|
91
|
+
buttonClass =
|
|
92
|
+
"text-green-400 bg-transparent hover:bg-green-200 hover:text-green-900 rounded-lg text-sm p-1.5 ml-auto inline-flex items-center dark:hover:bg-green-600 dark:hover:text-white";
|
|
93
|
+
pClass = "text-base leading-relaxed text-green-500 dark:text-green-400";
|
|
94
|
+
footerClass =
|
|
95
|
+
"flex items-center p-6 space-x-2 rounded-b border-t border-green-200 dark:border-green-600";
|
|
96
|
+
btn2Class =
|
|
97
|
+
"text-green-500 bg-white hover:bg-green-100 focus:ring-4 focus:ring-green-300 rounded-lg border border-green-200 text-sm font-medium px-5 py-2.5 hover:text-green-900 focus:z-10 dark:bg-green-700 dark:text-green-300 dark:border-green-500 dark:hover:text-white dark:hover:bg-green-600";
|
|
98
|
+
} else if (textColor === "indigo") {
|
|
99
|
+
divClass = "relative bg-white rounded-lg shadow dark:bg-indigo-700";
|
|
100
|
+
headDivClass =
|
|
101
|
+
"flex justify-between items-center p-5 rounded-t border-b dark:border-indigo-600";
|
|
102
|
+
h3Class = "text-xl font-medium text-indigo-900 dark:text-white";
|
|
103
|
+
buttonClass =
|
|
104
|
+
"text-indigo-400 bg-transparent hover:bg-indigo-200 hover:text-indigo-900 rounded-lg text-sm p-1.5 ml-auto inline-flex items-center dark:hover:bg-indigo-600 dark:hover:text-white";
|
|
105
|
+
pClass = "text-base leading-relaxed text-indigo-500 dark:text-indigo-400";
|
|
106
|
+
footerClass =
|
|
107
|
+
"flex items-center p-6 space-x-2 rounded-b border-t border-indigo-200 dark:border-indigo-600";
|
|
108
|
+
btn2Class =
|
|
109
|
+
"text-indigo-500 bg-white hover:bg-indigo-100 focus:ring-4 focus:ring-indigo-300 rounded-lg border border-indigo-200 text-sm font-medium px-5 py-2.5 hover:text-indigo-900 focus:z-10 dark:bg-indigo-700 dark:text-indigo-300 dark:border-indigo-500 dark:hover:text-white dark:hover:bg-indigo-600";
|
|
110
|
+
} else if (textColor === "purple") {
|
|
111
|
+
divClass = "relative bg-white rounded-lg shadow dark:bg-purple-700";
|
|
112
|
+
headDivClass =
|
|
113
|
+
"flex justify-between items-center p-5 rounded-t border-b dark:border-purple-600";
|
|
114
|
+
h3Class = "text-xl font-medium text-purple-900 dark:text-white";
|
|
115
|
+
buttonClass =
|
|
116
|
+
"text-purple-400 bg-transparent hover:bg-purple-200 hover:text-purple-900 rounded-lg text-sm p-1.5 ml-auto inline-flex items-center dark:hover:bg-purple-600 dark:hover:text-white";
|
|
117
|
+
pClass = "text-base leading-relaxed text-purple-500 dark:text-purple-400";
|
|
118
|
+
footerClass =
|
|
119
|
+
"flex items-center p-6 space-x-2 rounded-b border-t border-purple-200 dark:border-purple-600";
|
|
120
|
+
btn2Class =
|
|
121
|
+
"text-purple-500 bg-white hover:bg-purple-100 focus:ring-4 focus:ring-purple-300 rounded-lg border border-purple-200 text-sm font-medium px-5 py-2.5 hover:text-purple-900 focus:z-10 dark:bg-purple-700 dark:text-purple-300 dark:border-purple-500 dark:hover:text-white dark:hover:bg-purple-600";
|
|
122
|
+
} else if (textColor === "pink") {
|
|
123
|
+
divClass = "relative bg-white rounded-lg shadow dark:bg-pink-700";
|
|
124
|
+
headDivClass =
|
|
125
|
+
"flex justify-between items-center p-5 rounded-t border-b dark:border-pink-600";
|
|
126
|
+
h3Class = "text-xl font-medium text-pink-900 dark:text-white";
|
|
127
|
+
buttonClass =
|
|
128
|
+
"text-pink-400 bg-transparent hover:bg-pink-200 hover:text-pink-900 rounded-lg text-sm p-1.5 ml-auto inline-flex items-center dark:hover:bg-pink-600 dark:hover:text-white";
|
|
129
|
+
pClass = "text-base leading-relaxed text-pink-500 dark:text-pink-400";
|
|
130
|
+
footerClass =
|
|
131
|
+
"flex items-center p-6 space-x-2 rounded-b border-t border-pink-200 dark:border-pink-600";
|
|
132
|
+
btn2Class =
|
|
133
|
+
"text-pink-500 bg-white hover:bg-pink-100 focus:ring-4 focus:ring-pink-300 rounded-lg border border-pink-200 text-sm font-medium px-5 py-2.5 hover:text-pink-900 focus:z-10 dark:bg-pink-700 dark:text-pink-300 dark:border-pink-500 dark:hover:text-white dark:hover:bg-pink-600";
|
|
134
|
+
} else {
|
|
135
|
+
divClass = "relative bg-white rounded-lg shadow dark:bg-blue-700";
|
|
136
|
+
headDivClass =
|
|
137
|
+
"flex justify-between items-center p-5 rounded-t border-b dark:border-blue-600";
|
|
138
|
+
h3Class = "text-xl font-medium text-blue-900 dark:text-white";
|
|
139
|
+
buttonClass =
|
|
140
|
+
"text-blue-400 bg-transparent hover:bg-blue-200 hover:text-blue-900 rounded-lg text-sm p-1.5 ml-auto inline-flex items-center dark:hover:bg-blue-600 dark:hover:text-white";
|
|
141
|
+
pClass = "text-base leading-relaxed text-blue-500 dark:text-blue-400";
|
|
142
|
+
footerClass =
|
|
143
|
+
"flex items-center p-6 space-x-2 rounded-b border-t border-blue-200 dark:border-blue-600";
|
|
144
|
+
btn2Class =
|
|
145
|
+
"text-blue-500 bg-white hover:bg-blue-100 focus:ring-4 focus:ring-blue-300 rounded-lg border border-blue-200 text-sm font-medium px-5 py-2.5 hover:text-blue-900 focus:z-10 dark:bg-blue-700 dark:text-blue-300 dark:border-blue-500 dark:hover:text-white dark:hover:bg-blue-600";
|
|
146
|
+
}
|
|
147
|
+
let button1Class;
|
|
148
|
+
|
|
149
|
+
if (btnColor === "blue") {
|
|
150
|
+
button1Class =
|
|
151
|
+
"text-white bg-blue-700 hover:bg-blue-800 focus:ring-4 focus:ring-blue-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-blue-600 dark:hover:bg-blue-700 dark:focus:ring-blue-800";
|
|
152
|
+
} else if (btnColor === "gray") {
|
|
153
|
+
button1Class =
|
|
154
|
+
"text-white bg-gray-700 hover:bg-gray-800 focus:ring-4 focus:ring-gray-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-gray-600 dark:hover:bg-gray-700 dark:focus:ring-gray-800";
|
|
155
|
+
} else if (btnColor === "red") {
|
|
156
|
+
button1Class =
|
|
157
|
+
"text-white bg-red-700 hover:bg-red-800 focus:ring-4 focus:ring-red-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-red-600 dark:hover:bg-red-700 dark:focus:ring-red-800";
|
|
158
|
+
} else if (btnColor === "yellow") {
|
|
159
|
+
button1Class =
|
|
160
|
+
"text-white bg-yellow-700 hover:bg-yellow-800 focus:ring-4 focus:ring-yellow-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-yellow-600 dark:hover:bg-yellow-700 dark:focus:ring-yellow-800";
|
|
161
|
+
} else if (btnColor === "green") {
|
|
162
|
+
button1Class =
|
|
163
|
+
"text-white bg-green-700 hover:bg-green-800 focus:ring-4 focus:ring-green-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-green-600 dark:hover:bg-green-700 dark:focus:ring-green-800";
|
|
164
|
+
} else if (btnColor === "indigo") {
|
|
165
|
+
button1Class =
|
|
166
|
+
"text-white bg-indigo-700 hover:bg-indigo-800 focus:ring-4 focus:ring-indigo-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-indigo-600 dark:hover:bg-indigo-700 dark:focus:ring-indigo-800";
|
|
167
|
+
} else if (btnColor === "purple") {
|
|
168
|
+
button1Class =
|
|
169
|
+
"text-white bg-purple-700 hover:bg-purple-800 focus:ring-4 focus:ring-purple-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-purple-600 dark:hover:bg-purple-700 dark:focus:ring-purple-800";
|
|
170
|
+
} else if (btnColor === "pink") {
|
|
171
|
+
button1Class =
|
|
172
|
+
"text-white bg-pink-700 hover:bg-pink-800 focus:ring-4 focus:ring-pink-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-pink-600 dark:hover:bg-pink-700 dark:focus:ring-pink-800";
|
|
173
|
+
} else {
|
|
174
|
+
button1Class =
|
|
175
|
+
"text-white bg-blue-700 hover:bg-blue-800 focus:ring-4 focus:ring-blue-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-blue-600 dark:hover:bg-blue-700 dark:focus:ring-blue-800";
|
|
176
|
+
}
|
|
177
|
+
</script>
|
|
178
|
+
|
|
179
|
+
{#if showModalId === id}
|
|
180
|
+
<!-- Small Modal Component -->
|
|
181
|
+
<div
|
|
182
|
+
{id}
|
|
183
|
+
role="dialog"
|
|
184
|
+
aria-modal="true"
|
|
185
|
+
class="flex overflow-y-auto overflow-x-hidden fixed right-0 left-0 top-20 z-50 justify-center items-center"
|
|
186
|
+
>
|
|
187
|
+
<div class="relative px-4 w-full max-w-md h-full md:h-auto">
|
|
188
|
+
<!-- Modal content -->
|
|
189
|
+
<div class={divClass}>
|
|
190
|
+
<!-- Modal header -->
|
|
191
|
+
<div class={headDivClass}>
|
|
192
|
+
<h3 class={h3Class}>
|
|
193
|
+
{title}
|
|
194
|
+
</h3>
|
|
195
|
+
<button type="button" class={buttonClass} on:click={closeModal}>
|
|
196
|
+
<svg
|
|
197
|
+
class="w-5 h-5"
|
|
198
|
+
fill="currentColor"
|
|
199
|
+
viewBox="0 0 20 20"
|
|
200
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
201
|
+
><path
|
|
202
|
+
fill-rule="evenodd"
|
|
203
|
+
d="M4.293 4.293a1 1 0 011.414 0L10 8.586l4.293-4.293a1 1 0 111.414 1.414L11.414 10l4.293 4.293a1 1 0 01-1.414 1.414L10 11.414l-4.293 4.293a1 1 0 01-1.414-1.414L8.586 10 4.293 5.707a1 1 0 010-1.414z"
|
|
204
|
+
clip-rule="evenodd"
|
|
205
|
+
/></svg
|
|
206
|
+
>
|
|
207
|
+
</button>
|
|
208
|
+
</div>
|
|
209
|
+
<!-- Modal body -->
|
|
210
|
+
<div class="p-6 space-y-6">
|
|
211
|
+
<p class={pClass}>
|
|
212
|
+
<slot />
|
|
213
|
+
</p>
|
|
214
|
+
</div>
|
|
215
|
+
<!-- Modal footer -->
|
|
216
|
+
<div class={footerClass}>
|
|
217
|
+
{#if btn1}
|
|
218
|
+
<button type="button" class={button1Class} on:click={handlebtn1}
|
|
219
|
+
>{btn1}</button
|
|
220
|
+
>
|
|
221
|
+
{/if}
|
|
222
|
+
{#if btn2}
|
|
223
|
+
<button type="button" class={btn2Class} on:click={handlebtn2}
|
|
224
|
+
>{btn2}</button
|
|
225
|
+
>
|
|
226
|
+
{/if}
|
|
227
|
+
</div>
|
|
228
|
+
</div>
|
|
229
|
+
</div>
|
|
230
|
+
</div>
|
|
231
|
+
|
|
232
|
+
<div
|
|
233
|
+
on:click={closeModal}
|
|
234
|
+
class="bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-40 w-full h-full"
|
|
235
|
+
/>
|
|
236
|
+
{/if}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
/** @typedef {typeof __propDef.props} SmallModalProps */
|
|
2
|
+
/** @typedef {typeof __propDef.events} SmallModalEvents */
|
|
3
|
+
/** @typedef {typeof __propDef.slots} SmallModalSlots */
|
|
4
|
+
export default class SmallModal extends SvelteComponentTyped<{
|
|
5
|
+
btn1: any;
|
|
6
|
+
btn2: any;
|
|
7
|
+
showModalId: any;
|
|
8
|
+
id?: string;
|
|
9
|
+
btnColor?: string;
|
|
10
|
+
title?: string;
|
|
11
|
+
textColor?: string;
|
|
12
|
+
}, {
|
|
13
|
+
handlebtn1: CustomEvent<any>;
|
|
14
|
+
handlebtn2: CustomEvent<any>;
|
|
15
|
+
} & {
|
|
16
|
+
[evt: string]: CustomEvent<any>;
|
|
17
|
+
}, {
|
|
18
|
+
default: {};
|
|
19
|
+
}> {
|
|
20
|
+
}
|
|
21
|
+
export type SmallModalProps = typeof __propDef.props;
|
|
22
|
+
export type SmallModalEvents = typeof __propDef.events;
|
|
23
|
+
export type SmallModalSlots = typeof __propDef.slots;
|
|
24
|
+
import { SvelteComponentTyped } from "svelte";
|
|
25
|
+
declare const __propDef: {
|
|
26
|
+
props: {
|
|
27
|
+
btn1: any;
|
|
28
|
+
btn2: any;
|
|
29
|
+
showModalId: any;
|
|
30
|
+
id?: string;
|
|
31
|
+
btnColor?: string;
|
|
32
|
+
title?: string;
|
|
33
|
+
textColor?: string;
|
|
34
|
+
};
|
|
35
|
+
events: {
|
|
36
|
+
handlebtn1: CustomEvent<any>;
|
|
37
|
+
handlebtn2: CustomEvent<any>;
|
|
38
|
+
} & {
|
|
39
|
+
[evt: string]: CustomEvent<any>;
|
|
40
|
+
};
|
|
41
|
+
slots: {
|
|
42
|
+
default: {};
|
|
43
|
+
};
|
|
44
|
+
};
|
|
45
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const modalIdStore: import("svelte/store").Writable<number>;
|