@gitlab/ui
Version:
GitLab UI Components
42 lines (36 loc) • 989 B
JavaScript
import { extend, mergeData } from '../../vue';
import { NAME_FORM } from '../../constants/components';
import { PROP_TYPE_STRING, PROP_TYPE_BOOLEAN } from '../../constants/props';
import { makePropsConfigurable, makeProp } from '../../utils/props';
// --- Props ---
const props = makePropsConfigurable({
id: makeProp(PROP_TYPE_STRING),
inline: makeProp(PROP_TYPE_BOOLEAN, false),
novalidate: makeProp(PROP_TYPE_BOOLEAN, false),
validated: makeProp(PROP_TYPE_BOOLEAN, false)
}, NAME_FORM);
// --- Main component ---
// @vue/component
const BForm = /*#__PURE__*/extend({
name: NAME_FORM,
functional: true,
props,
render(h, _ref) {
let {
props,
data,
children
} = _ref;
return h('form', mergeData(data, {
class: {
'form-inline': props.inline,
'was-validated': props.validated
},
attrs: {
id: props.id,
novalidate: props.novalidate
}
}), children);
}
});
export { BForm, props };