index.jsx 1.2 KB

123456789101112131415161718192021222324252627282930
  1. import { computed, ref } from 'vue'
  2. import { layoutProps } from '../layout-props'
  3. import { ElCollapse, ElCollapseItem } from 'element-plus'
  4. import { useFormLayoutOptions } from '@cip/components/hooks/use-form-layout'
  5. export default {
  6. name: 'BasicCollapse',
  7. props: layoutProps,
  8. setup (props, { slots, emit }) {
  9. const { options, updateConfig, ...handler } = useFormLayoutOptions({ props, emit })
  10. const grid = computed(() => {
  11. return props.config._isGrid
  12. })
  13. const active = ref('')
  14. if (props.config.active) {
  15. // eslint-disable-next-line vue/no-setup-props-destructure
  16. active.value = props.config.active
  17. }
  18. return () => (<ElCollapse v-model={active.value}>
  19. {options.value.map((option, optionIndex) => {
  20. const { children, ...itemConfig } = option
  21. return <ElCollapseItem key={itemConfig.name || optionIndex} name={itemConfig.name} title={itemConfig.title}>
  22. <div class={{ 'cip-form--grid': grid.value }}
  23. style={{ gridTemplateColumns: `repeat(${typeof grid.value === 'number' ? grid.value : 3},1fr)` }}>
  24. {slots.item?.({ children, optionIndex, isShow: props.config._isShow, ...handler })}
  25. </div>
  26. </ElCollapseItem>
  27. })}
  28. </ElCollapse>)
  29. }
  30. }