You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

36 lines
969 B

1 year ago
  1. import { useChildren } from '../common/relation';
  2. import { VantComponent } from '../common/component';
  3. VantComponent({
  4. field: true,
  5. relation: useChildren('checkbox', function (target) {
  6. this.updateChild(target);
  7. }),
  8. props: {
  9. max: Number,
  10. value: {
  11. type: Array,
  12. observer: 'updateChildren',
  13. },
  14. disabled: {
  15. type: Boolean,
  16. observer: 'updateChildren',
  17. },
  18. direction: {
  19. type: String,
  20. value: 'vertical',
  21. },
  22. },
  23. methods: {
  24. updateChildren() {
  25. this.children.forEach((child) => this.updateChild(child));
  26. },
  27. updateChild(child) {
  28. const { value, disabled, direction } = this.data;
  29. child.setData({
  30. value: value.indexOf(child.data.name) !== -1,
  31. parentDisabled: disabled,
  32. direction,
  33. });
  34. },
  35. },
  36. });