import { ref, computed, nextTick } from 'vue'; import { useStore } from 'vuex'; export default function useGetTasks() { const timeLine = ref(null); const store = useStore(); const tasks = computed(() => store.state.task.tasks); const showScrollTo = computed(() => store.state.task.showScrollTo); const roleId = computed(() => store.state.role.roleId); const timeNode = computed(() => store.state.task.timeNode); const timeUnit = computed(() => store.state.task.timeUnit); const projectId = computed(() => store.getters['project/projectId']); const timeGranularity = computed(() => store.getters['task/timeGranularity']); // 初始化 定期任务 async function initPlanTasks() { setPrevPlaceholderTasks(); // 向上加载空数据 setNextPlaceholderTasks(); // 向下加载空数据 await getInitTasks(); // 获取初始数据 // 滚动到对应位置 // let timer = null; // timer = setInterval(() => { // if (showScrollTo.value) { // clearInterval(timer); // console.log('timeLine',timeLine) // nextTick(() => timeLine.setScrollPosition()); // } // }, 500); } // 切换了 颗粒度 || 角色时候 获取初始定期任务 function getInitTasks() { // 预加载 上下的定期任务 // function preloadFn(that) { // const detailId = tasks.value.findIndex(task => task.detailId); // const arr = []; // tasks.value.forEach(task => { // if (task.detailId) { // arr.push(task); // } // }); // if (detailId !== -1) { // // 只要有1个真实的任务 就预加载上下周期的任务 // const { // pageCount // } = uni.$task; // nextTick(() => { // // 向上拿数据 // getTasks({ // timeNode: +tasks.value[detailId].planStart, // queryType: 0, // queryNum: pageCount // }); // // 向下拿数据 // const nextQueryTime = +uni.$time.add(+arr[arr.length - 1].planStart, 1, timeGranularity.value); // getTasks({ // timeNode: nextQueryTime, // queryType: 1, // queryNum: pageCount // }); // }); // } else { // // 没有任务 上下显示时间刻度 // // 向上加载 // setPrevPlaceholderTasks(); // // // 向下加载 // setNextPlaceholderTasks(); // } // } // 根据时间基准点和角色查找定期任务 getTasks({ queryType: 0 }); // 向上获取定期任务数据 // 根据项目id获取角色列表 // 向下获取定期任务数据 // getTasks({ // queryType: 1 // }, preloadFn); } /** * 生成getTasks所用的参数 * @param {object} query getTasks传递的参数 */ function generateGetTaskParam(query) { return { roleId: roleId.value, timeNode: query.timeNode || timeNode.value, timeUnit: query.timeUnit || timeUnit.value, queryNum: query.queryNum || 3, queryType: query.queryType, projectId: projectId.value, }; } /** * 根据时间基准点和角色查找定期任务 * @param {object} query * @param {string} query.roleId 角色id * @param {string} query.timeNode 时间基准点 默认当前 * @param {string} query.timeUnit 时间颗粒度 默认天 * @param {string} query.queryNum 查找颗粒度数量 默认3个 * @param {number} query.queryType 0向上查找 1向下查找(默认) 下查包含自己,上查不包含 */ function getTasks(query, fn) { // store.commit('task/setShowSkeleton', false); console.log('根据时间基准点和角色查找定期任务') const params = generateGetTaskParam(query); uni.$catchReq.getRegularTask(params, (err, data) => { store.commit('task/setShowSkeleton', false); if (err) { // TODO: 提示错误 console.error('err: ', err); } else { store.commit('task/setShowScrollTo', true); // 有数据用数据替换刻度 // 没有数据 继续加载刻度 if (data && data.length) { // replacePrevData(data, params.queryType); params.queryType === 0 ? store.commit('task/setTopEnd', false) : store.commit('task/setBottomEnd', false); } else { // TODO: 0 -> 向上 1 -> 向下 // params.queryType === 0 ? setPrevPlaceholderTasks() : setNextPlaceholderTasks(); } // if (tasks.value.length && fn) { // fn(this); // } } }); } // 设置时间轴向上的空数据 function setPrevPlaceholderTasks() { store.commit('task/setTopEnd', true); let startTime = ''; if (!tasks.value || !tasks.value.length) { startTime = Date.now(); // 没有任务就应该是时间基准点 } else { startTime = tasks[0].planStart - 0; // 有任务就是第一个任务的计划开始时间 } const placeholderTasks = uni.$task.setPlaceholderTasks(startTime, true, timeGranularity.value); store.commit('task/setUpTasks', placeholderTasks); } // 设置时间轴向下的空数据 function setNextPlaceholderTasks() { store.commit('task/setBottomEnd', true); let startTime = ''; if (!tasks.value || !tasks.value.length) { startTime = Date.now(); } else { startTime = +tasks.value[tasks.value.length - 1].planStart; } const initData = uni.$task.setPlaceholderTasks(startTime, false, timeGranularity.value); store.commit('task/setDownTasks', initData); } return { initPlanTasks } }