| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- import { computed, watch } from 'vue';
- import { CHECKED_CHANGE_EVENT } from '../transfer-panel2.mjs';
- import { usePropsAlias } from './use-props-alias.mjs';
- import { isFunction } from '@vue/shared';
- const useCheck = (props, panelState, emit) => {
- const propsAlias = usePropsAlias(props);
- const filteredData = computed(() => {
- return props.data.filter((item) => {
- if (isFunction(props.filterMethod)) {
- return props.filterMethod(panelState.query, item);
- } else {
- const label = String(item[propsAlias.value.label] || item[propsAlias.value.key]);
- return label.toLowerCase().includes(panelState.query.toLowerCase());
- }
- });
- });
- const checkableData = computed(() => filteredData.value.filter((item) => !item[propsAlias.value.disabled]));
- const checkedSummary = computed(() => {
- const checkedLength = panelState.checked.length;
- const dataLength = props.data.length;
- const { noChecked, hasChecked } = props.format;
- if (noChecked && hasChecked) {
- return checkedLength > 0 ? hasChecked.replace(/\${checked}/g, checkedLength.toString()).replace(/\${total}/g, dataLength.toString()) : noChecked.replace(/\${total}/g, dataLength.toString());
- } else {
- return `${checkedLength}/${dataLength}`;
- }
- });
- const isIndeterminate = computed(() => {
- const checkedLength = panelState.checked.length;
- return checkedLength > 0 && checkedLength < checkableData.value.length;
- });
- const updateAllChecked = () => {
- const checkableDataKeys = checkableData.value.map((item) => item[propsAlias.value.key]);
- panelState.allChecked = checkableDataKeys.length > 0 && checkableDataKeys.every((item) => panelState.checked.includes(item));
- };
- const handleAllCheckedChange = (value) => {
- panelState.checked = value ? checkableData.value.map((item) => item[propsAlias.value.key]) : [];
- };
- watch(() => panelState.checked, (val, oldVal) => {
- updateAllChecked();
- if (panelState.checkChangeByUser) {
- const movedKeys = val.concat(oldVal).filter((v) => !val.includes(v) || !oldVal.includes(v));
- emit(CHECKED_CHANGE_EVENT, val, movedKeys);
- } else {
- emit(CHECKED_CHANGE_EVENT, val);
- panelState.checkChangeByUser = true;
- }
- });
- watch(checkableData, () => {
- updateAllChecked();
- });
- watch(() => props.data, () => {
- const checked = [];
- const filteredDataKeys = filteredData.value.map((item) => item[propsAlias.value.key]);
- panelState.checked.forEach((item) => {
- if (filteredDataKeys.includes(item)) {
- checked.push(item);
- }
- });
- panelState.checkChangeByUser = false;
- panelState.checked = checked;
- });
- watch(() => props.defaultChecked, (val, oldVal) => {
- if (oldVal && val.length === oldVal.length && val.every((item) => oldVal.includes(item)))
- return;
- const checked = [];
- const checkableDataKeys = checkableData.value.map((item) => item[propsAlias.value.key]);
- val.forEach((item) => {
- if (checkableDataKeys.includes(item)) {
- checked.push(item);
- }
- });
- panelState.checkChangeByUser = false;
- panelState.checked = checked;
- }, {
- immediate: true
- });
- return {
- filteredData,
- checkableData,
- checkedSummary,
- isIndeterminate,
- updateAllChecked,
- handleAllCheckedChange
- };
- };
- export { useCheck };
- //# sourceMappingURL=use-check.mjs.map
|