lapikit 0.0.0-insiders.dcdfb82 → 0.0.0-insiders.de81aed

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.
Files changed (73) hide show
  1. package/LICENSE +21 -0
  2. package/bin/helper.js +41 -32
  3. package/bin/lapikit.js +9 -9
  4. package/bin/modules/adapter.js +3 -3
  5. package/dist/assets/icons/loading-fill.svelte +29 -0
  6. package/dist/assets/icons/loading-fill.svelte.d.ts +26 -0
  7. package/dist/components/app/app.svelte +14 -0
  8. package/dist/components/app/app.svelte.d.ts +7 -0
  9. package/dist/components/app/types.d.ts +4 -0
  10. package/dist/components/app/types.js +1 -0
  11. package/dist/components/button/button.css +276 -0
  12. package/dist/components/button/button.svelte +94 -0
  13. package/dist/components/button/button.svelte.d.ts +4 -0
  14. package/dist/components/button/types.d.ts +27 -0
  15. package/dist/components/button/types.js +1 -0
  16. package/dist/components/dialog/dialog.css +143 -0
  17. package/dist/components/dialog/dialog.svelte +67 -0
  18. package/dist/components/dialog/dialog.svelte.d.ts +4 -0
  19. package/dist/components/dialog/types.d.ts +21 -0
  20. package/dist/components/dialog/types.js +1 -0
  21. package/dist/components/dropdown/dropdown.css +22 -0
  22. package/dist/components/dropdown/dropdown.svelte +116 -0
  23. package/dist/components/dropdown/dropdown.svelte.d.ts +4 -0
  24. package/dist/components/dropdown/dropdown.svelte.js +148 -0
  25. package/dist/components/dropdown/types.d.ts +26 -0
  26. package/dist/components/dropdown/types.js +1 -0
  27. package/dist/components/icon/icon.css +76 -0
  28. package/dist/components/icon/icon.svelte +49 -0
  29. package/dist/components/icon/icon.svelte.d.ts +4 -0
  30. package/dist/components/icon/types.d.ts +16 -0
  31. package/dist/components/icon/types.js +1 -0
  32. package/dist/components/index.d.ts +9 -0
  33. package/dist/components/index.js +10 -0
  34. package/dist/components/modal/modal.css +19 -0
  35. package/dist/components/modal/modal.svelte +59 -0
  36. package/dist/components/modal/modal.svelte.d.ts +4 -0
  37. package/dist/components/modal/types.d.ts +21 -0
  38. package/dist/components/modal/types.js +1 -0
  39. package/dist/components/popover/popover.css +22 -0
  40. package/dist/components/popover/popover.svelte +73 -0
  41. package/dist/components/popover/popover.svelte.d.ts +4 -0
  42. package/dist/components/popover/popover.svelte.js +134 -0
  43. package/dist/components/popover/types.d.ts +20 -0
  44. package/dist/components/popover/types.js +1 -0
  45. package/dist/components/separator/separator.css +46 -0
  46. package/dist/components/separator/separator.svelte +37 -0
  47. package/dist/components/separator/separator.svelte.d.ts +4 -0
  48. package/dist/components/separator/types.d.ts +11 -0
  49. package/dist/components/separator/types.js +1 -0
  50. package/dist/components/tooltip/tooltip.css +124 -0
  51. package/dist/components/tooltip/tooltip.svelte +113 -0
  52. package/dist/components/tooltip/tooltip.svelte.d.ts +4 -0
  53. package/dist/components/tooltip/tooltip.svelte.js +131 -0
  54. package/dist/components/tooltip/types.d.ts +23 -0
  55. package/dist/components/tooltip/types.js +1 -0
  56. package/dist/internal/assets.svelte.d.ts +8 -0
  57. package/dist/internal/assets.svelte.js +52 -0
  58. package/dist/internal/clickOutside.d.ts +9 -0
  59. package/dist/internal/clickOutside.js +34 -0
  60. package/dist/internal/index.d.ts +2 -0
  61. package/dist/internal/index.js +2 -0
  62. package/dist/internal/scroll.d.ts +1 -0
  63. package/dist/internal/scroll.js +6 -0
  64. package/dist/internal/types.d.ts +13 -0
  65. package/dist/preset.js +14 -2
  66. package/dist/stores/index.d.ts +4 -0
  67. package/dist/stores/index.js +23 -0
  68. package/dist/style/animation.css +20 -0
  69. package/dist/style/css.js +6 -3
  70. package/dist/style/parser/color.js +13 -2
  71. package/dist/style/variable.css +7 -0
  72. package/dist/utils/x11.d.ts +1 -1
  73. package/package.json +12 -3
@@ -0,0 +1,16 @@
1
+ import type { Component } from '../../internal/types.js';
2
+ export interface IconProps extends Component {
3
+ ref?: HTMLElement | null;
4
+ is?: 'i' | 'div';
5
+ dark?: boolean;
6
+ light?: boolean;
7
+ error?: boolean;
8
+ info?: boolean;
9
+ warning?: boolean;
10
+ success?: boolean;
11
+ disabled?: boolean;
12
+ color?: string;
13
+ size?: string | {
14
+ [key: string]: string;
15
+ };
16
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,9 @@
1
+ export { default as App } from './app/app.svelte';
2
+ export { default as Btn } from './button/button.svelte';
3
+ export { default as Icon } from './icon/icon.svelte';
4
+ export { default as Dropdown } from './dropdown/dropdown.svelte';
5
+ export { default as Popover } from './popover/popover.svelte';
6
+ export { default as Tooltip } from './tooltip/tooltip.svelte';
7
+ export { default as Dialog } from './dialog/dialog.svelte';
8
+ export { default as Separator } from './separator/separator.svelte';
9
+ export { default as Modal } from './modal/modal.svelte';
@@ -0,0 +1,10 @@
1
+ // components
2
+ export { default as App } from './app/app.svelte';
3
+ export { default as Btn } from './button/button.svelte';
4
+ export { default as Icon } from './icon/icon.svelte';
5
+ export { default as Dropdown } from './dropdown/dropdown.svelte';
6
+ export { default as Popover } from './popover/popover.svelte';
7
+ export { default as Tooltip } from './tooltip/tooltip.svelte';
8
+ export { default as Dialog } from './dialog/dialog.svelte';
9
+ export { default as Separator } from './separator/separator.svelte';
10
+ export { default as Modal } from './modal/modal.svelte';
@@ -0,0 +1,19 @@
1
+ .kit-modal {
2
+ width: 100%;
3
+ height: 100%;
4
+ }
5
+
6
+ .kit-modal:not(.kit-modal--contain) .kit-modal-overlay {
7
+ top: 0;
8
+ left: 0;
9
+ }
10
+
11
+ .kit-modal-overlay {
12
+ background-color: var(--kit-shadow);
13
+ position: fixed;
14
+ }
15
+
16
+ .kit-modal-container {
17
+ background-color: aliceblue;
18
+ color: black;
19
+ }
@@ -0,0 +1,59 @@
1
+ <script lang="ts">
2
+ // import { disabledScroll } from '../../internal/index.js';
3
+ // import { getAssets } from '../../internal/index.js';
4
+ import type { ModalProps } from './types.js';
5
+
6
+ let {
7
+ children,
8
+ ref = $bindable(),
9
+ open = $bindable(),
10
+ contain,
11
+ // dark,
12
+ // light,
13
+ // classContent,
14
+ // color,
15
+ // background,
16
+ // size = 'md',
17
+ // persistent,
18
+ // position = 'center',
19
+ // rounded,
20
+ // density = 'default',
21
+ ...rest
22
+ }: ModalProps = $props();
23
+
24
+ // const assets = getAssets();
25
+
26
+ // $effect(() => {
27
+ // if (ref && open) ref.showModal();
28
+ // if (ref && !open) ref.close();
29
+ // disabledScroll(open ? true : false);
30
+ // });
31
+ </script>
32
+
33
+ {#if open}
34
+ <div class={['kit-modal', contain && 'kit-modal--contain', rest.class]}>
35
+ <div class="kit-modal-overlay">overlay</div>
36
+ <div class="kit-modal-container">
37
+ {@render children?.()}
38
+ </div>
39
+ <!-- surcharge-dialog autofocus-action-element -->
40
+ <!-- <button type="button" class="close-dialog">close</button>
41
+ <div
42
+ {...rest}
43
+ class={[
44
+ 'kit-modal-container',
45
+ light && 'light',
46
+ dark && 'dark',
47
+ classContent,
48
+ density && assets.className('dialog-container', 'density', density),
49
+ rest.class
50
+ ]}
51
+ onclick={(event: MouseEvent) => event.stopPropagation()}
52
+ style:--base={assets.color(background)}
53
+ style:--on={assets.color(color)}
54
+ style:--shape={assets.shape(rounded)}
55
+ >
56
+ {@render children?.()}
57
+ </div> -->
58
+ </div>
59
+ {/if}
@@ -0,0 +1,4 @@
1
+ import type { ModalProps } from './types.js';
2
+ declare const Modal: import("svelte").Component<ModalProps, {}, "ref" | "open">;
3
+ type Modal = ReturnType<typeof Modal>;
4
+ export default Modal;
@@ -0,0 +1,21 @@
1
+ import type { Component } from '../../internal/types.js';
2
+ type ModalSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl' | 'full';
3
+ type ModalPosition = 'bottom' | 'center' | 'top';
4
+ export interface ModalProps extends Component {
5
+ ref?: HTMLDivElement;
6
+ open?: boolean;
7
+ classContent?: string | string[] | undefined;
8
+ size?: ModalSize | {
9
+ [key: string]: ModalSize;
10
+ };
11
+ persistent?: boolean;
12
+ position?: ModalPosition | {
13
+ [key: string]: ModalPosition;
14
+ };
15
+ dark?: boolean;
16
+ light?: boolean;
17
+ color?: string;
18
+ background?: string;
19
+ density?: 'compact' | 'comfortable' | 'default';
20
+ }
21
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,22 @@
1
+ .kit-popover-content {
2
+ --popover-color: var(--on, var(--kit-on-neutral));
3
+ --popover-background: var(--base, var(--kit-neutral));
4
+ --popover-radius: var(--shape, var(--kit-radius-md));
5
+
6
+ inset: 0px auto auto 0px;
7
+ margin: 0px;
8
+ position: fixed;
9
+ z-index: 9999;
10
+ display: inline-block;
11
+ width: auto;
12
+ opacity: 1;
13
+ transition-property: opacity, transform;
14
+ transition:
15
+ color 0.5s,
16
+ background-color 0.5s;
17
+
18
+ /* theme */
19
+ background-color: var(--popover-background);
20
+ color: var(--popover-color);
21
+ border-radius: var(--popover-radius);
22
+ }
@@ -0,0 +1,73 @@
1
+ <script lang="ts">
2
+ import { getAssets } from '../../internal/assets.svelte.js';
3
+ import { clickOutside } from '../../internal/clickOutside.js';
4
+ import { getPositions } from './popover.svelte.js';
5
+ import type { PopoverProps, ModelPopoverProps } from './types.js';
6
+
7
+ let {
8
+ open = $bindable(),
9
+ children,
10
+ activator,
11
+ dark,
12
+ light,
13
+ rounded,
14
+ position,
15
+ color,
16
+ background,
17
+ ...rest
18
+ }: PopoverProps = $props();
19
+
20
+ const positionAxis = getPositions();
21
+ const assets = getAssets();
22
+
23
+ let ref: HTMLElement | null = $state(null);
24
+ let refActivator: HTMLElement | null = $state(null);
25
+ let axis = $state({ x: 0, y: 0 });
26
+ let innerHeight = $state(0);
27
+ let innerWidth = $state(0);
28
+ let scrollX = $state(0);
29
+ let scrollY = $state(0);
30
+
31
+ axis = positionAxis?.values;
32
+
33
+ let model: ModelPopoverProps = {
34
+ toggle: (element) => handleToggle(element)
35
+ };
36
+
37
+ const handleToggle = (element: HTMLElement | null) => {
38
+ if (element === null) return;
39
+ refActivator = element;
40
+ open = !open;
41
+ };
42
+
43
+ $effect(() => {
44
+ if (
45
+ open &&
46
+ ref &&
47
+ refActivator &&
48
+ (scrollX > 0 || scrollY > 0 || innerHeight > 0 || innerWidth > 0)
49
+ ) {
50
+ positionAxis.update(refActivator, ref, position);
51
+ }
52
+ });
53
+ </script>
54
+
55
+ <svelte:window bind:innerHeight bind:innerWidth bind:scrollX bind:scrollY />
56
+
57
+ {@render activator?.(model)}
58
+
59
+ {#if open}
60
+ <div
61
+ bind:this={ref}
62
+ {...rest}
63
+ role="menu"
64
+ class={['kit-popover-content', light && 'light', dark && 'dark', rest.class]}
65
+ style={`transform: translate(${axis.x}px, ${axis.y}px);`}
66
+ style:--base={assets.color(background)}
67
+ style:--on={assets.color(color)}
68
+ style:--shape={assets.shape(rounded)}
69
+ use:clickOutside={{ exclude: [ref, refActivator], onClose: () => (open = false) }}
70
+ >
71
+ {@render children?.()}
72
+ </div>
73
+ {/if}
@@ -0,0 +1,4 @@
1
+ import type { PopoverProps } from './types.js';
2
+ declare const Popover: import("svelte").Component<PopoverProps, {}, "open">;
3
+ type Popover = ReturnType<typeof Popover>;
4
+ export default Popover;
@@ -0,0 +1,134 @@
1
+ import { innerWidth, innerHeight } from 'svelte/reactivity/window';
2
+ export function getPositions() {
3
+ // state
4
+ const axis = $state({
5
+ x: 0,
6
+ y: 0,
7
+ location: null
8
+ });
9
+ return {
10
+ get values() {
11
+ return axis;
12
+ },
13
+ update(activator, element, location, centered, avoidCollisions) {
14
+ if (!activator || !element)
15
+ return;
16
+ const elementRect = element.getBoundingClientRect();
17
+ if (activator instanceof HTMLElement) {
18
+ const activatorRect = activator.getBoundingClientRect();
19
+ const spacing = 6;
20
+ const _activator = activatorRect.y + activatorRect.height;
21
+ const _element = elementRect.height + spacing;
22
+ if (location === 'top' || location === 'bottom') {
23
+ if (avoidCollisions) {
24
+ if (location === 'top') {
25
+ if (activatorRect.y - _element < 0) {
26
+ axis.y = activatorRect.bottom + spacing;
27
+ axis.location = 'bottom';
28
+ }
29
+ else {
30
+ axis.y = activatorRect.top - _element;
31
+ axis.location = 'top';
32
+ }
33
+ }
34
+ else {
35
+ if (_activator + _element > innerHeight.current) {
36
+ axis.y = activatorRect.top - _element;
37
+ axis.location = 'top';
38
+ }
39
+ else {
40
+ axis.y = activatorRect.bottom + spacing;
41
+ axis.location = 'bottom';
42
+ }
43
+ }
44
+ }
45
+ else {
46
+ if (location === 'top') {
47
+ axis.y = activatorRect.top - _element;
48
+ axis.location = 'top';
49
+ }
50
+ else {
51
+ axis.y = activatorRect.bottom + spacing;
52
+ axis.location = 'bottom';
53
+ }
54
+ }
55
+ if (centered &&
56
+ activatorRect.left - (elementRect.width - activatorRect.width) / 2 > 0 &&
57
+ activatorRect.left + elementRect.width < innerWidth.current) {
58
+ axis.x = activatorRect.left - (elementRect.width - activatorRect.width) / 2;
59
+ }
60
+ else if (activatorRect.left + elementRect.width > innerWidth.current) {
61
+ axis.x = activatorRect.left - (elementRect.width - activatorRect.width);
62
+ }
63
+ else {
64
+ axis.x = activatorRect.left;
65
+ }
66
+ }
67
+ else if (location === 'left' || location === 'right') {
68
+ if (avoidCollisions) {
69
+ if (location === 'left' && !(activatorRect.left - elementRect.width < 0)) {
70
+ axis.x = activatorRect.left - (elementRect.width + spacing);
71
+ axis.location = 'left';
72
+ }
73
+ else {
74
+ if (activatorRect.left + activatorRect.width + elementRect.width + spacing >
75
+ innerWidth.current) {
76
+ axis.x = activatorRect.left - (elementRect.width + spacing);
77
+ axis.location = 'left';
78
+ }
79
+ else {
80
+ axis.x = activatorRect.left + activatorRect.width + spacing;
81
+ axis.location = 'right';
82
+ }
83
+ }
84
+ }
85
+ else {
86
+ if (location === 'left') {
87
+ axis.x = activatorRect.left - (elementRect.width + spacing);
88
+ axis.location = 'left';
89
+ }
90
+ else {
91
+ axis.x = activatorRect.left + activatorRect.width + spacing;
92
+ axis.location = 'right';
93
+ }
94
+ }
95
+ if (centered &&
96
+ activatorRect.top - (elementRect.height - activatorRect.height) / 2 > 0 &&
97
+ activatorRect.top + elementRect.height < innerHeight.current) {
98
+ axis.y = activatorRect.top - (elementRect.height - activatorRect.height) / 2;
99
+ }
100
+ else if (activatorRect.y + elementRect.height > innerHeight.current) {
101
+ axis.y = activatorRect.y - elementRect.height + activatorRect.height;
102
+ }
103
+ else {
104
+ axis.y = activatorRect.y;
105
+ }
106
+ }
107
+ else {
108
+ if (centered &&
109
+ activatorRect.left - (elementRect.width - activatorRect.width) / 2 > 0 &&
110
+ activatorRect.left + elementRect.width < innerWidth.current) {
111
+ axis.x = activatorRect.left - (elementRect.width - activatorRect.width) / 2;
112
+ }
113
+ else if (activatorRect.left + elementRect.width > innerWidth.current) {
114
+ axis.x = activatorRect.left - (elementRect.width - activatorRect.width);
115
+ }
116
+ else {
117
+ axis.x = activatorRect.left;
118
+ }
119
+ if (centered &&
120
+ activatorRect.top - (elementRect.height - activatorRect.height) / 2 > 0 &&
121
+ activatorRect.top + elementRect.height < innerHeight.current) {
122
+ axis.y = activatorRect.top - (elementRect.height - activatorRect.height) / 2;
123
+ }
124
+ else if (activatorRect.bottom + elementRect.height > innerHeight.current) {
125
+ axis.y = activatorRect.top - elementRect.height;
126
+ }
127
+ else {
128
+ axis.y = activatorRect.bottom;
129
+ }
130
+ }
131
+ }
132
+ }
133
+ };
134
+ }
@@ -0,0 +1,20 @@
1
+ import type { Component } from '../../internal/types.js';
2
+ import type { Snippet } from 'svelte';
3
+ export type PositionElement = {
4
+ x: number;
5
+ y: number;
6
+ location: string | null;
7
+ };
8
+ export interface PopoverProps extends Component {
9
+ open?: boolean;
10
+ dark?: boolean;
11
+ light?: boolean;
12
+ rounded?: string;
13
+ position?: 'top' | 'bottom' | 'left' | 'right';
14
+ color?: string;
15
+ background?: string;
16
+ activator?: Snippet<[ModelPopoverProps]>;
17
+ }
18
+ export type ModelPopoverProps = {
19
+ toggle: (element: HTMLElement | null) => void;
20
+ };
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,46 @@
1
+ .kit-separator {
2
+ --separator-opacity: var(--opacity, 0.12);
3
+ --separator-color: var(--base, var(--kit-scrim));
4
+
5
+ display: block;
6
+ flex: 1 1 100%;
7
+ height: 0px;
8
+ max-height: 0px;
9
+ opacity: var(--separator-opacity);
10
+ transition: inherit;
11
+ border-color: var(--separator-color);
12
+ transition: border-color 0.5s;
13
+ border-style: solid;
14
+ }
15
+
16
+ .kit-separator:not(.kit-separator--orientation-vertical) {
17
+ border-width: var(--border-top-width, thin) 0 0 0;
18
+ }
19
+
20
+ .kit-separator--orientation-vertical {
21
+ align-self: stretch;
22
+ border-width: 0 thin 0 0;
23
+ display: inline-flex;
24
+ height: auto;
25
+ margin-left: 0px;
26
+ max-height: 100%;
27
+ max-width: 0px;
28
+ vertical-align: text-bottom;
29
+ width: 0px;
30
+ border-width: 0 var(--border-right-width, thin) 0 0;
31
+ }
32
+
33
+ .kit-separator--inset:not(.kit-separator--orientation-vertical) {
34
+ max-width: calc(100% - 4.5rem);
35
+ margin-inline-start: 4.5rem;
36
+ }
37
+
38
+ .kit-separator--inset.kit-separator--orientation-vertical {
39
+ margin-bottom: 0.5rem;
40
+ margin-top: 0.5rem;
41
+ max-height: calc(100% - 1rem);
42
+ }
43
+
44
+ .kit-separator:not(.kit-separator--orientation-vertical) {
45
+ width: 100%;
46
+ }
@@ -0,0 +1,37 @@
1
+ <script lang="ts">
2
+ import { getAssets } from '../../internal/index.js';
3
+ import type { SeparatorProps } from './types.js';
4
+
5
+ let {
6
+ is = 'hr',
7
+ light,
8
+ dark,
9
+ inset,
10
+ thickness,
11
+ orientation = 'horizontal',
12
+ opacity,
13
+ color,
14
+ ...rest
15
+ }: SeparatorProps = $props();
16
+
17
+ const assets = getAssets();
18
+ </script>
19
+
20
+ <svelte:element
21
+ this={is}
22
+ {...rest}
23
+ class={[
24
+ 'kit-separator',
25
+ light && 'light',
26
+ dark && 'dark',
27
+ inset && 'kit-separator--inset',
28
+ orientation && assets.className('separator', 'orientation', orientation),
29
+ rest.class
30
+ ]}
31
+ aria-orientation={orientation}
32
+ role="separator"
33
+ style:--base={assets.color(color)}
34
+ style:--opacity={opacity}
35
+ style:--border-top-width={orientation === 'horizontal' ? assets.unit(thickness) : undefined}
36
+ style:--border-right-width={orientation === 'vertical' ? assets.unit(thickness) : undefined}
37
+ />
@@ -0,0 +1,4 @@
1
+ import type { SeparatorProps } from './types.js';
2
+ declare const Separator: import("svelte").Component<SeparatorProps, {}, "">;
3
+ type Separator = ReturnType<typeof Separator>;
4
+ export default Separator;
@@ -0,0 +1,11 @@
1
+ import type { Base } from '../../internal/types.js';
2
+ export interface SeparatorProps extends Base {
3
+ is?: 'div' | 'hr';
4
+ light?: boolean;
5
+ dark?: boolean;
6
+ inset?: boolean;
7
+ thickness?: string;
8
+ opacity?: string | number;
9
+ color?: string;
10
+ orientation?: 'horizontal' | 'vertical';
11
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,124 @@
1
+ .kit-tooltip {
2
+ inset: 0px auto auto 0px;
3
+ margin: 0px;
4
+ position: fixed;
5
+ z-index: 2000;
6
+ }
7
+
8
+ .kit-tooltip-content {
9
+ --tooltip-color: var(--on, var(--kit-on-neutral));
10
+ --tooltip-background: var(--base, var(--kit-neutral));
11
+ --tooltip-radius: var(--shape, var(--kit-radius-md));
12
+
13
+ background-color: var(--tooltip-background);
14
+ color: var(--tooltip-color);
15
+ border-radius: var(--tooltip-radius);
16
+ border: 1px solid var(--tooltip-background);
17
+ font-size: 0.875rem;
18
+ display: inline-block;
19
+ width: auto;
20
+ pointer-events: none;
21
+ overflow-wrap: break-word;
22
+ transition:
23
+ color 0.5s,
24
+ border-color 0.5s,
25
+ background-color 0.5s;
26
+ box-shadow: 0px 16px 29px -10px color-mix(in oklab, var(--kit-scrim) 60%, transparent);
27
+ }
28
+
29
+ /* density */
30
+ .kit-tooltip-content[breakpoint]kit-tooltip-content--density-default {
31
+ padding: 0.15rem 0.625rem;
32
+ }
33
+
34
+ .kit-tooltip-content[breakpoint]kit-tooltip-content--density-compact {
35
+ padding: 0.125rem 0.5rem;
36
+ }
37
+
38
+ .kit-tooltip-content[breakpoint]kit-tooltip-content--density-comfortable {
39
+ padding: 0.35rem 0.75rem;
40
+ }
41
+
42
+ .kit-tooltip-content--arrow::after {
43
+ content: ' ';
44
+ position: absolute;
45
+ border-style: solid;
46
+ }
47
+
48
+ .kit-tooltip-content--arrow.kit-tooltip-content--bottom::after,
49
+ .kit-tooltip-content--arrow.kit-tooltip-content--top::after {
50
+ left: 50%;
51
+ margin-left: -0.35rem;
52
+ border-width: 0.35rem;
53
+ }
54
+
55
+ .kit-tooltip-content--arrow.kit-tooltip-content--bottom::after {
56
+ bottom: 100%;
57
+ border-color: transparent transparent var(--tooltip-background) transparent;
58
+ }
59
+
60
+ .kit-tooltip-content--arrow.kit-tooltip-content--top::after {
61
+ top: 100%;
62
+ border-color: var(--tooltip-background) transparent transparent transparent;
63
+ }
64
+
65
+ .kit-tooltip-content--arrow.kit-tooltip-content--left::after,
66
+ .kit-tooltip-content--arrow.kit-tooltip-content--right::after {
67
+ top: 50%;
68
+ margin-top: -0.35rem;
69
+ border-width: 0.35rem;
70
+ }
71
+
72
+ .kit-tooltip-content--arrow.kit-tooltip-content--right::after {
73
+ right: 100%;
74
+ border-color: transparent var(--tooltip-background) transparent transparent;
75
+ }
76
+
77
+ .kit-tooltip-content--arrow.kit-tooltip-content--left::after {
78
+ left: 100%;
79
+ border-color: transparent transparent transparent var(--tooltip-background);
80
+ }
81
+
82
+ .kit-tooltip-content--top,
83
+ .kit-tooltip-content--bottom,
84
+ .kit-tooltip-content--right,
85
+ .kit-tooltip-content--left {
86
+ animation-duration: 150ms;
87
+ animation-name: enter;
88
+ }
89
+
90
+ .kit-tooltip-content--top {
91
+ --animate-enter-pos1: 0;
92
+ --animate-enter-pos2: 0.5rem;
93
+ --animate-enter-pos3: 0;
94
+ }
95
+
96
+ .kit-tooltip-content--bottom {
97
+ --animate-enter-pos1: 0;
98
+ --animate-enter-pos2: -0.5rem;
99
+ --animate-enter-pos3: 0;
100
+ }
101
+
102
+ .kit-tooltip-content--right {
103
+ --animate-enter-pos1: -0.5rem;
104
+ --animate-enter-pos2: 0;
105
+ --animate-enter-pos3: 0;
106
+ }
107
+
108
+ .kit-tooltip-content--left {
109
+ --animate-enter-pos1: 0.5rem;
110
+ --animate-enter-pos2: 0;
111
+ --animate-enter-pos3: 0;
112
+ }
113
+
114
+ @keyframes enter {
115
+ 0% {
116
+ opacity: 0;
117
+ transform: translate3d(
118
+ var(--animate-enter-pos1),
119
+ var(--animate-enter-pos2),
120
+ var(--animate-enter-pos3)
121
+ )
122
+ scale3d(0.95, 0.95, 0.95) rotate(0);
123
+ }
124
+ }