0e6146b4e81ef5e6766821c3727d4682f9c27a57b68c1248f88a7651741ff985af7bfbd9dd2cdbb2af14e0b6b8979668e62540c7b29f247befc42d7db5498e 837 B

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. import Picker from '../picker';
  2. import DatePanel from '../panel/date';
  3. import DateRangePanel from '../panel/date-range';
  4. import MonthRangePanel from '../panel/month-range';
  5. const getPanel = function(type) {
  6. if (type === 'daterange' || type === 'datetimerange') {
  7. return DateRangePanel;
  8. } else if (type === 'monthrange') {
  9. return MonthRangePanel;
  10. }
  11. return DatePanel;
  12. };
  13. export default {
  14. mixins: [Picker],
  15. name: 'ElDatePicker',
  16. props: {
  17. type: {
  18. type: String,
  19. default: 'date'
  20. },
  21. timeArrowControl: Boolean
  22. },
  23. watch: {
  24. type(type) {
  25. if (this.picker) {
  26. this.unmountPicker();
  27. this.panel = getPanel(type);
  28. this.mountPicker();
  29. } else {
  30. this.panel = getPanel(type);
  31. }
  32. }
  33. },
  34. created() {
  35. this.panel = getPanel(this.type);
  36. }
  37. };