UNPKG

@gitlab/ui

Version:
112 lines (92 loc) 3.31 kB
import _uniqueId from 'lodash/uniqueId'; import { BCollapse } from 'bootstrap-vue/esm/index.js'; import { GlCollapseToggleDirective } from '../../../directives/collapse_toggle'; import GlButton from '../button/button'; import __vue_normalize__ from 'vue-runtime-helpers/dist/normalize-component.js'; var script = { name: 'GlAccordionItem', components: { BCollapse, GlButton }, directives: { GlCollapseToggle: GlCollapseToggleDirective }, inject: ['accordionSetId', 'defaultHeaderLevel'], inheritAttrs: false, props: { /* Used to set the title of accordion link */ title: { type: String, required: true }, /* When set, it will ensure the accordion item is initially visible */ visible: { type: Boolean, default: false, required: false }, /* The header tag used in the accordion (h1/h2/h3/h4/h5/h6). This overrides the value provided by GlAccordion. For accessibility this should be set to an appropriate value in the context where the accordion is used., */ headerLevel: { type: Number, required: false, default: null, validator(value) { return value > 0 && value <= 6; } } }, data() { return { accordionItemId: _uniqueId('accordion-item-'), isVisible: this.visible }; }, computed: { headerComponent() { const level = this.headerLevel || this.defaultHeaderLevel; return `h${level}`; }, accordion() { return this.accordionSetId || undefined; }, icon() { return this.isVisible ? 'chevron-down' : 'chevron-right'; } } }; /* script */ const __vue_script__ = script; /* template */ var __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"gl-accordion-item"},[_c(_vm.headerComponent,{tag:"component",staticClass:"gl-accordion-item-header"},[_c('gl-button',{directives:[{name:"gl-collapse-toggle",rawName:"v-gl-collapse-toggle",value:(_vm.accordionItemId),expression:"accordionItemId"}],attrs:{"variant":"link","button-text-classes":"gl-display-flex","icon":_vm.icon}},[_vm._v("\n "+_vm._s(_vm.title)+"\n ")])],1),_vm._v(" "),_c('b-collapse',{staticClass:"gl-mt-3 gl-font-base",attrs:{"id":_vm.accordionItemId,"visible":_vm.isVisible,"accordion":_vm.accordion,"data-testid":("accordion-item-collapse-" + _vm.accordionItemId)},model:{value:(_vm.isVisible),callback:function ($$v) {_vm.isVisible=$$v;},expression:"isVisible"}},[_vm._t("default")],2)],1)}; var __vue_staticRenderFns__ = []; /* style */ const __vue_inject_styles__ = undefined; /* scoped */ const __vue_scope_id__ = undefined; /* module identifier */ const __vue_module_identifier__ = undefined; /* functional template */ const __vue_is_functional_template__ = false; /* style inject */ /* style inject SSR */ /* style inject shadow dom */ const __vue_component__ = __vue_normalize__( { render: __vue_render__, staticRenderFns: __vue_staticRenderFns__ }, __vue_inject_styles__, __vue_script__, __vue_scope_id__, __vue_is_functional_template__, __vue_module_identifier__, false, undefined, undefined, undefined ); export default __vue_component__;