@katlux/toolkit 0.1.0-beta.47 → 0.1.0-beta.48

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/dist/module.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@katlux/toolkit",
3
3
  "configKey": "katluxToolkit",
4
- "version": "0.1.0-beta.47",
4
+ "version": "0.1.0-beta.48",
5
5
  "builder": {
6
6
  "@nuxt/module-builder": "1.0.2",
7
7
  "unbuild": "3.6.1"
@@ -1,12 +1,17 @@
1
1
  <script setup>
2
2
  import { useKDropdownLogic, KDropdownDefaultProps } from "./KDropdown.logic";
3
3
  import { usePresetComponent } from "../../composables/usePresetComponent";
4
- import { computed } from "vue";
4
+ import { computed, watch } from "vue";
5
5
  import KDropdownDefault from "../../presets/default/components/KDropdown/KDropdown.vue";
6
6
  const props = defineProps(KDropdownDefaultProps);
7
7
  const emit = defineEmits(["update:isOpen"]);
8
- const { open, dropdownRect, clickoutside, teleportTarget, isInModal } = useKDropdownLogic(props, emit);
8
+ const { open, dropdownRect, clickoutside, teleportTarget, isInModal, updatePosition } = useKDropdownLogic(props, emit);
9
9
  const presetComponent = usePresetComponent("KDropdown", KDropdownDefault);
10
+ watch(presetComponent, () => {
11
+ if (open.value) {
12
+ updatePosition();
13
+ }
14
+ });
10
15
  const templateProps = computed(() => ({
11
16
  open: open.value,
12
17
  fullWidth: props.fullWidth,
@@ -1,4 +1,4 @@
1
- import { type PropType } from 'vue';
1
+ import { type PropType, type Ref } from 'vue';
2
2
  export interface KDropdownProps {
3
3
  isOpen: boolean;
4
4
  fullWidth: boolean;
@@ -27,8 +27,8 @@ export declare const KDropdownDefaultProps: {
27
27
  };
28
28
  };
29
29
  export declare function useKDropdownLogic(props: KDropdownProps, emit: KDropdownEmits): {
30
- open: import("vue").Ref<boolean, boolean>;
31
- dropdownRect: import("vue").Ref<{
30
+ open: Ref<boolean, boolean>;
31
+ dropdownRect: Ref<{
32
32
  top: number;
33
33
  left: number;
34
34
  width: number;
@@ -44,4 +44,5 @@ export declare function useKDropdownLogic(props: KDropdownProps, emit: KDropdown
44
44
  clickoutside: () => void;
45
45
  teleportTarget: import("vue").ComputedRef<string>;
46
46
  isInModal: import("vue").ComputedRef<boolean>;
47
+ updatePosition: () => void;
47
48
  };
@@ -20,10 +20,17 @@ export const KDropdownDefaultProps = {
20
20
  };
21
21
  export function useKDropdownLogic(props, emit) {
22
22
  const modalPortalId = inject(KMODAL_PORTAL_ID_KEY, null);
23
- const isInModal = computed(() => !!modalPortalId);
23
+ const isInModal = computed(() => !!modalPortalId?.value);
24
24
  const teleportTarget = computed(() => {
25
25
  if (props.teleportTo) return props.teleportTo;
26
- if (isInModal.value) return `#${modalPortalId}`;
26
+ if (isInModal.value && modalPortalId?.value) {
27
+ const targetId = `#${modalPortalId.value}`;
28
+ if (typeof document !== "undefined" && !document.querySelector(targetId)) {
29
+ const activePortal = document.querySelector(".modal-portal");
30
+ if (activePortal && activePortal.id) return `#${activePortal.id}`;
31
+ }
32
+ return targetId;
33
+ }
27
34
  return "body";
28
35
  });
29
36
  const open = ref(false);
@@ -87,12 +94,6 @@ export function useKDropdownLogic(props, emit) {
87
94
  }
88
95
  );
89
96
  onMounted(() => {
90
- if (props.isOpen) {
91
- updatePosition();
92
- nextTick(() => {
93
- open.value = true;
94
- });
95
- }
96
97
  window.addEventListener("scroll", onScrollResize, true);
97
98
  window.addEventListener("resize", onScrollResize);
98
99
  });
@@ -105,6 +106,7 @@ export function useKDropdownLogic(props, emit) {
105
106
  dropdownRect,
106
107
  clickoutside,
107
108
  teleportTarget,
108
- isInModal
109
+ isInModal,
110
+ updatePosition
109
111
  };
110
112
  }
@@ -4,7 +4,8 @@ import { usePresetComponent } from "../../composables/usePresetComponent";
4
4
  import { computed } from "vue";
5
5
  import KModalDefault from "../../presets/default/components/KModal/KModal.vue";
6
6
  const props = defineProps(KModalDefaultProps);
7
- const stableId = globalThis.useId ? globalThis.useId() : `k-modal-${Math.random().toString(36).slice(2, 9)}`;
7
+ const useId = globalThis.useId || (() => `k-modal-${Math.random().toString(36).slice(2, 9)}`);
8
+ const stableId = useId();
8
9
  const { modalId, opened, openModal, closeModal } = useKModalLogic(props, stableId);
9
10
  defineExpose({
10
11
  openModal,
@@ -12,7 +13,7 @@ defineExpose({
12
13
  });
13
14
  const presetComponent = usePresetComponent("KModal", KModalDefault);
14
15
  const templateProps = computed(() => ({
15
- modalId,
16
+ modalId: modalId.value,
16
17
  opened: opened.value,
17
18
  closeModal
18
19
  }));
@@ -3,7 +3,7 @@ export interface KModalProps {
3
3
  }
4
4
  export declare const KModalDefaultProps: {};
5
5
  export declare function useKModalLogic(props: KModalProps, stableId: string): {
6
- modalId: string;
6
+ modalId: import("vue").ComputedRef<string>;
7
7
  opened: import("vue").Ref<boolean, boolean>;
8
8
  openModal: () => void;
9
9
  closeModal: () => void;
@@ -1,8 +1,8 @@
1
- import { ref, provide } from "vue";
1
+ import { ref, provide, computed } from "vue";
2
2
  export const KMODAL_PORTAL_ID_KEY = "KMODAL_PORTAL_ID";
3
3
  export const KModalDefaultProps = {};
4
4
  export function useKModalLogic(props, stableId) {
5
- const modalId = stableId;
5
+ const modalId = computed(() => stableId);
6
6
  provide(KMODAL_PORTAL_ID_KEY, modalId);
7
7
  const opened = ref(false);
8
8
  function openModal() {
@@ -124,9 +124,11 @@
124
124
  --button-bg-dark: var(--neutral-900);
125
125
  --button-text-dark: var(--font-color-light);
126
126
  --button-hover-bg-dark: var(--neutral-700);
127
- --panel-bg-default: var(--yellow-300);
128
- --panel-header-bg-default: var(--yellow-500);
129
- --panel-footer-bg-default: var(--blue-100);
127
+ --panel-bg-opacity: 1;
128
+ --panel-blur: 0px;
129
+ --panel-bg-default: var(--neutral-50);
130
+ --panel-header-bg-default: var(--neutral-100);
131
+ --panel-footer-bg-default: var(--neutral-100);
130
132
  --panel-bg-primary: var(--blue-300);
131
133
  --panel-header-bg-primary: var(--blue-500);
132
134
  --panel-footer-bg-primary: var(--blue-100);
@@ -162,6 +164,7 @@
162
164
  --component-gap: var(--gap-sm);
163
165
  --layover: var(--neutral-600);
164
166
  --modal-overlay-bg: rgba(0, 0, 0, 0.5);
167
+ --modal-backdrop-blur: 0px;
165
168
  --layout-header-height: 60px;
166
169
  --layout-header-bg: var(--background-color);
167
170
  --layout-sidebar-width: 200px;
@@ -178,9 +178,11 @@
178
178
  --button-hover-bg-dark: var(--neutral-700);
179
179
 
180
180
  // Panel Colors - Default
181
- --panel-bg-default: var(--yellow-300);
182
- --panel-header-bg-default: var(--yellow-500);
183
- --panel-footer-bg-default: var(--blue-100);
181
+ --panel-bg-opacity: 1;
182
+ --panel-blur: 0px;
183
+ --panel-bg-default: var(--neutral-50);
184
+ --panel-header-bg-default: var(--neutral-100);
185
+ --panel-footer-bg-default: var(--neutral-100);
184
186
 
185
187
  // Panel Colors - Primary
186
188
  --panel-bg-primary: var(--blue-300);
@@ -236,6 +238,7 @@
236
238
  --component-gap: var(--gap-sm);
237
239
  --layover: var(--neutral-600);
238
240
  --modal-overlay-bg: rgba(0, 0, 0, 0.5);
241
+ --modal-backdrop-blur: 0px;
239
242
 
240
243
  // Layout Variables
241
244
  --layout-header-height: 60px;
@@ -141,9 +141,11 @@ li {
141
141
  --button-bg-dark: var(--neutral-900);
142
142
  --button-text-dark: var(--font-color-light);
143
143
  --button-hover-bg-dark: var(--neutral-700);
144
- --panel-bg-default: var(--yellow-300);
145
- --panel-header-bg-default: var(--yellow-500);
146
- --panel-footer-bg-default: var(--blue-100);
144
+ --panel-bg-opacity: 1;
145
+ --panel-blur: 0px;
146
+ --panel-bg-default: var(--neutral-50);
147
+ --panel-header-bg-default: var(--neutral-100);
148
+ --panel-footer-bg-default: var(--neutral-100);
147
149
  --panel-bg-primary: var(--blue-300);
148
150
  --panel-header-bg-primary: var(--blue-500);
149
151
  --panel-footer-bg-primary: var(--blue-100);
@@ -179,6 +181,7 @@ li {
179
181
  --component-gap: var(--gap-sm);
180
182
  --layover: var(--neutral-600);
181
183
  --modal-overlay-bg: rgba(0, 0, 0, 0.5);
184
+ --modal-backdrop-blur: 0px;
182
185
  --layout-header-height: 60px;
183
186
  --layout-header-bg: var(--background-color);
184
187
  --layout-sidebar-width: 200px;
@@ -1,6 +1,6 @@
1
1
  <template lang="pug">
2
2
  dialog.k-dialog(ref="dialogRef" @close="closeModal" @click="handleBackdropClick")
3
- .modal-portal(:id="modalId" style="position: absolute; top: 0; left: 0;")
3
+ .modal-portal(:id="modalId" style="position: absolute; top: 0; left: 0; z-index: 2000;")
4
4
  KPanel(no-gap flex-content scrollable).modal-container
5
5
  template(#header)
6
6
  slot(name="header")
@@ -57,6 +57,7 @@ const handleBackdropClick = (event: MouseEvent) => {
57
57
 
58
58
  &::backdrop {
59
59
  background-color: var(--modal-overlay-bg);
60
+ backdrop-filter: blur(var(--modal-backdrop-blur));
60
61
  }
61
62
 
62
63
  .modal-container {
@@ -33,8 +33,8 @@ const props = withDefaults(defineProps<{
33
33
  border-radius: var(--border-radius-lg);
34
34
  border: 1px solid var(--neutral-200);
35
35
  box-shadow: var(--shadow-md);
36
- background-color: color-mix(in srgb, var(--current-panel-bg), transparent 99%);
37
- backdrop-filter: blur(8px);
36
+ background-color: color-mix(in srgb, var(--current-panel-bg), transparent calc((1 - var(--panel-bg-opacity)) * 100%));
37
+ backdrop-filter: blur(var(--panel-blur));
38
38
  width: 100%;
39
39
  display: flex;
40
40
  flex-direction: column;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@katlux/toolkit",
3
- "version": "0.1.0-beta.47",
3
+ "version": "0.1.0-beta.48",
4
4
  "description": "Core UI toolkit and utilities for the Katlux ecosystem",
5
5
  "author": "Katlux",
6
6
  "license": "MIT",