UNPKG

naive-ui

Version:

A Vue 3 Component Library. Fairly Complete, Theme Customizable, Uses TypeScript, Fast

83 lines 2.6 kB
import { defineComponent, h, inject } from 'vue'; import { useLocale } from "../../_mixins/index.mjs"; import { NButton } from "../../button/index.mjs"; import { transferInjectionKey } from "./interface.mjs"; export default defineComponent({ name: 'TransferHeader', props: { size: { type: String, required: true }, selectAllText: String, clearText: String, source: Boolean, onCheckedAll: Function, onClearAll: Function, title: [String, Function] }, setup(props) { const { targetOptionsRef, canNotSelectAnythingRef, canBeClearedRef, allCheckedRef, mergedThemeRef, disabledRef, mergedClsPrefixRef, srcOptionsLengthRef } = inject(transferInjectionKey); const { localeRef } = useLocale('Transfer'); return () => { const { source, onClearAll, onCheckedAll, selectAllText, clearText } = props; const { value: mergedTheme } = mergedThemeRef; const { value: mergedClsPrefix } = mergedClsPrefixRef; const { value: locale } = localeRef; const buttonSize = props.size === 'large' ? 'small' : 'tiny'; const { title } = props; return h("div", { class: `${mergedClsPrefix}-transfer-list-header` }, title && h("div", { class: `${mergedClsPrefix}-transfer-list-header__title` }, typeof title === 'function' ? title() : title), source && h(NButton, { class: `${mergedClsPrefix}-transfer-list-header__button`, theme: mergedTheme.peers.Button, themeOverrides: mergedTheme.peerOverrides.Button, size: buttonSize, tertiary: true, onClick: allCheckedRef.value ? onClearAll : onCheckedAll, disabled: canNotSelectAnythingRef.value || disabledRef.value }, { default: () => allCheckedRef.value ? clearText || locale.unselectAll : selectAllText || locale.selectAll }), !source && canBeClearedRef.value && h(NButton, { class: `${mergedClsPrefix}-transfer-list-header__button`, theme: mergedTheme.peers.Button, themeOverrides: mergedTheme.peerOverrides.Button, size: buttonSize, tertiary: true, onClick: onClearAll, disabled: disabledRef.value }, { default: () => locale.clearAll }), h("div", { class: `${mergedClsPrefix}-transfer-list-header__extra` }, source ? locale.total(srcOptionsLengthRef.value) : locale.selected(targetOptionsRef.value.length))); }; } });