5365d02a13304ccdcc4ebfd9c056961e2c6c22bdba5602b07db5a3deef6e0d6c5df506a63dc505bc9a9b37a940c56db49231ca6080a97fc7d2c785cc8294d6 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. 'use strict';
  2. Object.defineProperty(exports, '__esModule', { value: true });
  3. var usePropsAlias = require('./use-props-alias.js');
  4. var event = require('../../../../constants/event.js');
  5. const useMove = (props, checkedState, emit) => {
  6. const propsAlias = usePropsAlias.usePropsAlias(props);
  7. const _emit = (value, direction, movedKeys) => {
  8. emit(event.UPDATE_MODEL_EVENT, value);
  9. emit(event.CHANGE_EVENT, value, direction, movedKeys);
  10. };
  11. const addToLeft = () => {
  12. const currentValue = props.modelValue.slice();
  13. checkedState.rightChecked.forEach((item) => {
  14. const index = currentValue.indexOf(item);
  15. if (index > -1) {
  16. currentValue.splice(index, 1);
  17. }
  18. });
  19. _emit(currentValue, "left", checkedState.rightChecked);
  20. };
  21. const addToRight = () => {
  22. let currentValue = props.modelValue.slice();
  23. const itemsToBeMoved = props.data.filter((item) => {
  24. const itemKey = item[propsAlias.value.key];
  25. return checkedState.leftChecked.includes(itemKey) && !props.modelValue.includes(itemKey);
  26. }).map((item) => item[propsAlias.value.key]);
  27. currentValue = props.targetOrder === "unshift" ? itemsToBeMoved.concat(currentValue) : currentValue.concat(itemsToBeMoved);
  28. if (props.targetOrder === "original") {
  29. currentValue = props.data.filter((item) => currentValue.includes(item[propsAlias.value.key])).map((item) => item[propsAlias.value.key]);
  30. }
  31. _emit(currentValue, "right", checkedState.leftChecked);
  32. };
  33. return {
  34. addToLeft,
  35. addToRight
  36. };
  37. };
  38. exports.useMove = useMove;
  39. //# sourceMappingURL=use-move.js.map