dateRang.ts 976 B

12345678910111213141516171819202122232425262728293031323334353637383940
  1. import { dateFormat } from "@/util";
  2. import { ElMessage } from "element-plus";
  3. import { ref, watchEffect } from "vue";
  4. type SyncProps = {
  5. start: string;
  6. end: string;
  7. };
  8. export const useDateRange = <T extends SyncProps>(syncProps: T) => {
  9. const timeRang = ref<[number, number]>();
  10. watchEffect(() => {
  11. if (!timeRang.value?.length) {
  12. return;
  13. }
  14. const start = new Date(timeRang.value[0]);
  15. const end = new Date(timeRang.value[1]);
  16. if (end.getTime() - start.getTime() < 0) {
  17. ElMessage.error("结束日期必须大于开始日期");
  18. } else {
  19. syncProps.start = dateFormat(start, "yyyy-MM-dd");
  20. syncProps.end = dateFormat(end, "yyyy-MM-dd");
  21. }
  22. });
  23. watchEffect(
  24. () => {
  25. console.log(syncProps.start, syncProps.end);
  26. if (!syncProps.start || !syncProps.end) {
  27. timeRang.value = undefined;
  28. console.log("???", timeRang.value);
  29. }
  30. },
  31. { flush: "post" }
  32. );
  33. return timeRang;
  34. };