@hashrytech/quick-components-kit 0.7.0 → 0.8.1

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/CHANGELOG.md CHANGED
@@ -1,5 +1,17 @@
1
1
  # @hashrytech/quick-components-kit
2
2
 
3
+ ## 0.8.1
4
+
5
+ ### Patch Changes
6
+
7
+ - fix: Adding close func property
8
+
9
+ ## 0.8.0
10
+
11
+ ### Minor Changes
12
+
13
+ - feat: Adding overlay component
14
+
3
15
  ## 0.7.0
4
16
 
5
17
  ### Minor Changes
@@ -6,6 +6,7 @@
6
6
  useCloseBtn?: boolean;
7
7
  ariaLabel: string;
8
8
  linesClasses?: string;
9
+ linesParentClasses?: string;
9
10
  onclick?: (event: MouseEvent) => void;
10
11
  class?: ClassNameValue;
11
12
  };
@@ -15,7 +16,7 @@
15
16
  <script lang="ts">
16
17
  import {twMerge} from 'tailwind-merge';
17
18
 
18
- let { open=$bindable(true), ariaLabel, linesClasses, useCloseBtn=true, onclick, ...props }: HamburgerProps = $props();
19
+ let { open=$bindable(true), ariaLabel, linesClasses, linesParentClasses, useCloseBtn=true, onclick, ...props }: HamburgerProps = $props();
19
20
 
20
21
  </script>
21
22
 
@@ -37,8 +38,8 @@
37
38
  </button>
38
39
  -->
39
40
 
40
- <button aria-label={ariaLabel} class={twMerge("p-2 rounded focus:outline-none focus:ring-2 focus:ring-focus-primary cursor-pointer w-fit", props.class)} {onclick}>
41
- <div class="flex flex-col items-center justify-center size-7 transition-all gap-2">
41
+ <button aria-label={ariaLabel} class={twMerge("px-1 py-0.5 rounded focus:outline-none focus:ring-2 focus:ring-focus-primary cursor-pointer w-fit", props.class)} {onclick}>
42
+ <div class={twMerge("flex flex-col items-center justify-center size-7 transition-all gap-2", linesParentClasses)}>
42
43
  <!-- Top bar -->
43
44
  <span class={twMerge("h-0.5 w-7 bg-button-primary transition-transform duration-300 origin-center", open && useCloseBtn ? "rotate-45 translate-y-2.5" : "", linesClasses)}></span>
44
45
 
@@ -4,6 +4,7 @@ export type HamburgerProps = {
4
4
  useCloseBtn?: boolean;
5
5
  ariaLabel: string;
6
6
  linesClasses?: string;
7
+ linesParentClasses?: string;
7
8
  onclick?: (event: MouseEvent) => void;
8
9
  class?: ClassNameValue;
9
10
  };
package/dist/index.d.ts CHANGED
@@ -4,3 +4,4 @@ export * from './link-button/index.js';
4
4
  export * from './hamburger-menu/index.js';
5
5
  export * from './drawer/index.js';
6
6
  export * from './modal/index.js';
7
+ export * from './overlay/index.js';
package/dist/index.js CHANGED
@@ -6,4 +6,5 @@ export * from './link-button/index.js';
6
6
  export * from './hamburger-menu/index.js';
7
7
  export * from './drawer/index.js';
8
8
  export * from './modal/index.js';
9
+ export * from './overlay/index.js';
9
10
  // Add more components here...
@@ -40,13 +40,13 @@
40
40
  }
41
41
  });
42
42
 
43
- export function closeDrawer() {
43
+ export function closeModal() {
44
44
  open = false;
45
45
  };
46
46
 
47
47
  function handleKeydown (event: { key: string; }) {
48
48
  if(open && escapeKeyClose && event.key === "Escape") {
49
- closeDrawer();
49
+ closeModal();
50
50
  }
51
51
  };
52
52
 
@@ -11,7 +11,7 @@ export type ModalProps = {
11
11
  class?: ClassNameValue;
12
12
  };
13
13
  declare const Modal: import("svelte").Component<ModalProps, {
14
- closeDrawer: () => void;
14
+ closeModal: () => void;
15
15
  }, "open">;
16
16
  type Modal = ReturnType<typeof Modal>;
17
17
  export default Modal;
@@ -0,0 +1,58 @@
1
+ <script lang="ts" module>
2
+ import { onDestroy, onMount, type Snippet } from 'svelte';
3
+ import type { ClassNameValue } from 'tailwind-merge';
4
+ import { fade } from 'svelte/transition';
5
+ import {twMerge} from 'tailwind-merge';
6
+ import { browser } from '$app/environment';
7
+
8
+ export type OverlayProps = {
9
+ open?: boolean;
10
+ escapeKeyClose?: boolean;
11
+ disableBodyScroll?: boolean;
12
+ ariaLabel?: string;
13
+ overlayTransitionDuration?: number;
14
+ overlayClasses?: string;
15
+ children?: Snippet;
16
+ class?: ClassNameValue;
17
+ };
18
+
19
+ </script>
20
+
21
+ <script lang="ts">
22
+ let {open=$bindable(false), escapeKeyClose=true, disableBodyScroll=true, overlayTransitionDuration=0, ariaLabel="Modal", overlayClasses="", onclick, children, ...props}: OverlayProps = $props();
23
+
24
+ const lockScroll = () => document.body.style.overflow = 'hidden';
25
+ const unlockScroll = () => document.body.style.overflow = '';
26
+
27
+ $effect(() => {
28
+ if (open && disableBodyScroll) lockScroll(); else unlockScroll();
29
+ });
30
+
31
+ onMount(() => {
32
+ if(browser){
33
+ window.addEventListener('keydown', handleKeydown);
34
+ }
35
+ });
36
+
37
+ onDestroy(() => {
38
+ if(browser){
39
+ window.removeEventListener('keydown', handleKeydown);
40
+ }
41
+ });
42
+
43
+ export function closeOverlay() {
44
+ open = false;
45
+ };
46
+
47
+ function handleKeydown (event: { key: string; }) {
48
+ if(open && escapeKeyClose && event.key === "Escape") {
49
+ closeOverlay();
50
+ }
51
+ };
52
+
53
+ </script>
54
+
55
+ {#if open}
56
+ <div transition:fade={{duration: overlayTransitionDuration}} class={twMerge("fixed inset-0 bg-overlay-primary", overlayClasses)} role="presentation" {onclick}></div>
57
+ {/if}
58
+
@@ -0,0 +1,17 @@
1
+ import { type Snippet } from 'svelte';
2
+ import type { ClassNameValue } from 'tailwind-merge';
3
+ export type OverlayProps = {
4
+ open?: boolean;
5
+ escapeKeyClose?: boolean;
6
+ disableBodyScroll?: boolean;
7
+ ariaLabel?: string;
8
+ overlayTransitionDuration?: number;
9
+ overlayClasses?: string;
10
+ children?: Snippet;
11
+ class?: ClassNameValue;
12
+ };
13
+ declare const Overlay: import("svelte").Component<OverlayProps, {
14
+ closeOverlay: () => void;
15
+ }, "open">;
16
+ type Overlay = ReturnType<typeof Overlay>;
17
+ export default Overlay;
@@ -0,0 +1 @@
1
+ export { default as Overlay } from './Overlay.svelte';
@@ -0,0 +1 @@
1
+ export { default as Overlay } from './Overlay.svelte';
package/package.json CHANGED
@@ -5,7 +5,7 @@
5
5
  "type": "git",
6
6
  "url": "git+https://github.com/hashrytech/quick-components-kit.git"
7
7
  },
8
- "version": "0.7.0",
8
+ "version": "0.8.1",
9
9
  "license": "MIT",
10
10
  "author": "Hashry Tech",
11
11
  "files": [