gvf3n4ygn-test
Version:
CLI for SIGMA-UI components.
24 lines • 3.97 kB
JSON
{
"name": "popover",
"dependencies": [],
"registryDependencies": [],
"files": [
{
"name": "Popover.vue",
"content": "<script setup lang=\"ts\">\nimport { PopoverRoot, useForwardPropsEmits } from 'radix-vue';\nimport type { PopoverRootEmits, PopoverRootProps } from 'radix-vue';\n\nconst props = defineProps<PopoverRootProps>();\nconst emits = defineEmits<PopoverRootEmits>();\n\nconst forwarded = useForwardPropsEmits(props, emits);\n</script>\n\n<template>\n <PopoverRoot v-bind=\"forwarded\">\n <slot />\n </PopoverRoot>\n</template>\n"
},
{
"name": "PopoverContent.vue",
"content": "<script setup lang=\"ts\">\nimport {\n PopoverContent,\n type PopoverContentEmits,\n type PopoverContentProps,\n PopoverPortal,\n useForwardPropsEmits,\n} from 'radix-vue';\n\ndefineOptions({\n inheritAttrs: false,\n});\n\nconst props = withDefaults(\n defineProps<PopoverContentProps>(),\n {\n align: 'center',\n sideOffset: 4,\n },\n);\nconst emits = defineEmits<PopoverContentEmits>();\n\nconst forwarded = useForwardPropsEmits(props, emits);\n</script>\n\n<template>\n <PopoverPortal>\n <PopoverContent\n v-bind=\"{ ...forwarded, ...$attrs }\"\n class=\"sigma-ui-popover-content\"\n :class=\"$attrs.class\"\n >\n <slot />\n </PopoverContent>\n </PopoverPortal>\n</template>\n\n<style>\n.sigma-ui-popover-content {\n z-index: 50;\n width: 18rem;\n border-radius: 0.375rem;\n border: 1px solid hsl(var(--border));\n background-color: hsl(var(--popover));\n color: hsl(var(--popover-foreground));\n padding: 1rem;\n box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);\n outline: none;\n transform-origin: var(--radix-popover-content-transform-origin);\n}\n\n.sigma-ui-popover-content[data-state=\"open\"][data-side=\"bottom\"] {\n animation: slideFromTop 150ms ease-out;\n}\n\n.sigma-ui-popover-content[data-state=\"open\"][data-side=\"top\"] {\n animation: slideFromBottom 150ms ease-out;\n}\n\n.sigma-ui-popover-content[data-state=\"open\"][data-side=\"left\"] {\n animation: slideFromRight 150ms ease-out;\n}\n\n.sigma-ui-popover-content[data-state=\"open\"][data-side=\"right\"] {\n animation: slideFromLeft 150ms ease-out;\n}\n\n.sigma-ui-popover-content[data-state=\"closed\"] {\n animation: popoverOut 150ms ease-in;\n}\n\n@keyframes popoverOut {\n from {\n opacity: 1;\n transform: scaleY(1);\n filter: blur(0px);\n }\n to {\n opacity: 0;\n transform: scaleY(0.98);\n filter: blur(4px);\n }\n}\n\n@keyframes slideFromTop {\n from {\n transform: translateY(-1rem) scaleY(0.98);\n filter: blur(4px);\n }\n to {\n transform: translateY(0) scaleY(1);\n filter: blur(0px);\n }\n}\n\n@keyframes slideFromBottom {\n from {\n transform: translateY(1rem) scaleY(0.98);\n filter: blur(4px);\n }\n to {\n transform: translateY(0) scaleY(1);\n filter: blur(0px);\n }\n}\n\n@keyframes slideFromLeft {\n from {\n transform: translateX(-1rem) scaleY(0.98);\n filter: blur(4px);\n }\n to {\n transform: translateX(0) scaleY(1);\n filter: blur(0px);\n }\n}\n\n@keyframes slideFromRight {\n from {\n transform: translateX(1rem) scaleY(0.98);\n filter: blur(4px);\n }\n to {\n transform: translateX(0) scaleY(1);\n filter: blur(0px);\n }\n}\n</style>\n"
},
{
"name": "PopoverTrigger.vue",
"content": "<script setup lang=\"ts\">\nimport { PopoverTrigger, type PopoverTriggerProps } from 'radix-vue';\n\nconst props = defineProps<PopoverTriggerProps>();\n</script>\n\n<template>\n <PopoverTrigger v-bind=\"props\">\n <slot />\n </PopoverTrigger>\n</template>\n"
},
{
"name": "index.ts",
"content": "export { default as Popover } from './Popover.vue';\nexport { default as PopoverTrigger } from './PopoverTrigger.vue';\nexport { default as PopoverContent } from './PopoverContent.vue';\n"
}
],
"type": "components:ui"
}