reka-ui
Version:
Vue port for Radix UI Primitives.
86 lines (83 loc) • 2.98 kB
JavaScript
import { VisuallyHiddenInputBubble_default } from "./VisuallyHiddenInputBubble.js";
import { Fragment, computed, createBlock, createCommentVNode, createElementBlock, defineComponent, mergeProps, openBlock, renderList } from "vue";
//#region src/VisuallyHidden/VisuallyHiddenInput.vue?vue&type=script&setup=true&lang.ts
var VisuallyHiddenInput_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
inheritAttrs: false,
__name: "VisuallyHiddenInput",
props: {
name: {
type: String,
required: true
},
value: {
type: null,
required: true
},
checked: {
type: Boolean,
required: false,
default: void 0
},
required: {
type: Boolean,
required: false
},
disabled: {
type: Boolean,
required: false
},
feature: {
type: String,
required: false,
default: "fully-hidden"
}
},
setup(__props) {
const props = __props;
const isFormArrayEmptyAndRequired = computed(() => typeof props.value === "object" && Array.isArray(props.value) && props.value.length === 0 && props.required);
const parsedValue = computed(() => {
if (typeof props.value === "string" || typeof props.value === "number" || typeof props.value === "boolean" || props.value === null || props.value === void 0) return [{
name: props.name,
value: props.value
}];
else if (typeof props.value === "object" && Array.isArray(props.value)) return props.value.flatMap((obj, index) => {
if (typeof obj === "object") return Object.entries(obj).map(([key, value]) => ({
name: `${props.name}[${index}][${key}]`,
value
}));
else return {
name: `${props.name}[${index}]`,
value: obj
};
});
else if (props.value !== null && typeof props.value === "object" && !Array.isArray(props.value)) return Object.entries(props.value).map(([key, value]) => ({
name: `${props.name}[${key}]`,
value
}));
return [];
});
return (_ctx, _cache) => {
return openBlock(), createElementBlock(Fragment, null, [createCommentVNode(" We render single input if it's required "), isFormArrayEmptyAndRequired.value ? (openBlock(), createBlock(VisuallyHiddenInputBubble_default, mergeProps({ key: _ctx.name }, {
...props,
..._ctx.$attrs
}, {
name: _ctx.name,
value: _ctx.value
}), null, 16, ["name", "value"])) : (openBlock(true), createElementBlock(Fragment, { key: 1 }, renderList(parsedValue.value, (parsed) => {
return openBlock(), createBlock(VisuallyHiddenInputBubble_default, mergeProps({ key: parsed.name }, { ref_for: true }, {
...props,
..._ctx.$attrs
}, {
name: parsed.name,
value: parsed.value
}), null, 16, ["name", "value"]);
}), 128))], 2112);
};
}
});
//#endregion
//#region src/VisuallyHidden/VisuallyHiddenInput.vue
var VisuallyHiddenInput_default = VisuallyHiddenInput_vue_vue_type_script_setup_true_lang_default;
//#endregion
export { VisuallyHiddenInput_default };
//# sourceMappingURL=VisuallyHiddenInput.js.map