From e25218be7538206ac46e2178571c888a472f0eb4 Mon Sep 17 00:00:00 2001
From: xuesinan <1404152492@qq.com>
Date: Thu, 17 Feb 2022 10:40:53 +0800
Subject: [PATCH] =?UTF-8?q?feat:=20=E6=97=B6=E9=97=B4=E8=BD=B4=E6=96=B0?=
=?UTF-8?q?=E7=AD=96=E7=95=A5?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
CHANGELOG.md | 3 +-
components/Plugin/Plugin.vue | 10 +-
components/TimeLine/TimeLine.vue | 20 +-
hooks/project/useGetTasks - 副本.js | 263 ++++++++++++++++++++++
hooks/project/useGetTasks.js | 269 +++++++++++------------
hooks/project/useInit.js | 2 +-
pages/project/project.vue | 14 ++
plugins/p-deliver/p-deliver.vue | 2 +-
plugins/p-finance/p-finance.vue | 2 +-
store/task/mutations - 副本.js | 325 ++++++++++++++++++++++++++++
store/task/mutations.js | 77 ++++---
store/task/state - 副本.js | 36 +++
store/task/state.js | 13 +-
13 files changed, 836 insertions(+), 200 deletions(-)
create mode 100644 hooks/project/useGetTasks - 副本.js
create mode 100644 store/task/mutations - 副本.js
create mode 100644 store/task/state - 副本.js
diff --git a/CHANGELOG.md b/CHANGELOG.md
index b320afe..20f0075 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,4 +1,4 @@
-# 1.0.0 (2022-02-16)
+# 1.0.0 (2022-02-17)
### 🌟 新功能
范围|描述|commitId
@@ -31,6 +31,7 @@
- | 获取手机唯一码 | [3f60cf8](https://101.201.226.163:50022/TALL/TALL-MUI-4/commits/3f60cf8)
- | 将时间轴改成swiper滑动 | [12384f9](https://101.201.226.163:50022/TALL/TALL-MUI-4/commits/12384f9)
- | 解决时间轴日常任务不显示问题 | [c532a93](https://101.201.226.163:50022/TALL/TALL-MUI-4/commits/c532a93)
+ - | 刻度模式时间轴 | [a9bc53a](https://101.201.226.163:50022/TALL/TALL-MUI-4/commits/a9bc53a)
- | 日历页首页 | [561c8e6](https://101.201.226.163:50022/TALL/TALL-MUI-4/commits/561c8e6)
- | 日历页添加 | [1b46a91](https://101.201.226.163:50022/TALL/TALL-MUI-4/commits/1b46a91)
- | 设置项目域名 | [1a835f1](https://101.201.226.163:50022/TALL/TALL-MUI-4/commits/1a835f1)
diff --git a/components/Plugin/Plugin.vue b/components/Plugin/Plugin.vue
index e933ebe..25c6e8a 100644
--- a/components/Plugin/Plugin.vue
+++ b/components/Plugin/Plugin.vue
@@ -28,7 +28,7 @@
-
+ /> -->
@@ -70,9 +70,9 @@ const isMine = computed(() => store.getters['role/isMine']);
// return target.component;
// });
-if (props.pluginId === '5') {
- store.dispatch('role/getAllMembers', { projectId: projectId.value });
-}
+// if (props.pluginId === '5') {
+// store.dispatch('role/getAllMembers', { projectId: projectId.value });
+// }
// 点击时存储 storage
async function setStorage() {
diff --git a/components/TimeLine/TimeLine.vue b/components/TimeLine/TimeLine.vue
index 16a658c..837addd 100644
--- a/components/TimeLine/TimeLine.vue
+++ b/components/TimeLine/TimeLine.vue
@@ -13,19 +13,13 @@
@scrolltoupper="handleScrollTop"
id="scroll"
>
-
-
-
-
-
diff --git a/hooks/project/useGetTasks - 副本.js b/hooks/project/useGetTasks - 副本.js
new file mode 100644
index 0000000..032d147
--- /dev/null
+++ b/hooks/project/useGetTasks - 副本.js
@@ -0,0 +1,263 @@
+import { computed, nextTick, watch } from 'vue';
+import { useStore } from 'vuex';
+import { flatten } from 'lodash';
+import dayjs from 'dayjs';
+export default function useGetTasks() {
+ const store = useStore();
+ const tasks = computed(() => store.state.task.tasks);
+ const basicTasks = computed(() => store.state.task.basicTasks);
+ const upBasicTasks = computed(() => store.state.task.upBasicTasks);
+ const nextPage = computed(() => store.state.task.nextPage); // 下一页
+ const upNextPage = computed(() => store.state.task.upNextPage); // 下一页
+ // const lastPage = computed(() => store.state.task.lastPage); // 最后一页
+ const roleId = computed(() => store.state.role.roleId);
+ const timeNode = computed(() => store.state.task.timeNode);
+ const timeUnit = computed(() => store.state.task.timeUnit);
+ const visibleRoles = computed(() => store.state.role.visibleRoles);
+ const allTasks = computed(() => store.state.task.allTasks);
+ const roleIndex = computed(() => store.state.role.roleIndex);
+
+ const projectId = computed(() => store.getters['project/projectId']);
+ const timeGranularity = computed(() => store.getters['task/timeGranularity']);
+
+ // 初始化 定期任务
+ async function initPlanTasks() {
+ await getTasks({}); // 获取初始数据
+ }
+
+ /**
+ * 根据时间基准点和角色查找定期任务
+ * @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) {
+ store.commit('task/setShowSkeleton', false);
+
+ const params = {
+ roleId: roleId.value,
+ timeUnit: query.timeUnit || timeUnit.value,
+ queryType: query.queryType === 0 ? 0 : 1,
+ pageNum: query.pageNum || 1,
+ pageSize: query.pageSize || uni.$taskConfig.pageCount
+ }
+
+ uni.$catchReq.getTaskByNum(params, (err, data) => {
+ store.commit('task/setShowSkeleton', false);
+ if (err) {
+ // TODO: 提示错误
+ console.error('err: ', err);
+ } else {
+ store.commit('task/setShowScrollTo', true);
+
+ if (params.queryType === 0) {
+ // 将接口返回的数据存储到store
+ let lists = [...upBasicTasks.value, ...data.list];
+ store.commit('task/setUpBasicTask', lists);
+ store.commit('task/setUpNextPage', data.nextPage); // 下一页
+ } else {
+ let lists = [...basicTasks.value, ...data.list];
+ store.commit('task/setBasicTask', lists);
+ store.commit('task/setNextPage', data.nextPage); // 下一页
+ }
+
+ // 刻度模式数据处理
+ renderTask(params);
+ }
+ });
+ }
+
+ // 刻度模式数据处理
+ function renderTask(params) {
+ params.queryType === 0 ? setPrevPlaceholderTasks() : setNextPlaceholderTasks();
+ tasksData(params);
+ }
+
+ /**
+ * 刻度模式数据处理
+ * 大于等于15天,真实数据的时间跨度
+ * 或大于等于15条,真实数据的数量
+ * 不用重新加载数据
+ * @param {Object} params
+ */
+ function tasksData(params) {
+ let oldTasks = tasks.value;
+ let realTasks = params.queryType === 0 ? upBasicTasks.value : basicTasks.value;
+ // 下一页的值
+ let next = params.queryType === 0 ? upNextPage.value : nextPage.value;
+
+ // 真实数据是否>=15条 || 是否>=15天
+ let term = tremFilter(params);
+
+ if (term || next === 0) {
+ // 过滤真实数据中在tasks时间段中的数据,并将最后的数据存储到tasksArr数组中
+ let tasksArr = [], taskLen = 0, lastIndex = 0;
+ oldTasks.forEach((task, index) => {
+ const oldArr = oldTasks.filter(item => dayjs(+item.planStart).isSame(+task.planStart, timeGranularity.value));
+ const arr = realTasks.filter(item => dayjs(+item.planStart).isSame(+task.planStart, timeGranularity.value));
+
+ if (arr && arr.length) {
+ if (task.detailId) {
+ tasksArr = [...arr];
+ lastIndex = index;
+ } else {
+ taskLen += arr.length; // 在时间刻度内的数据量
+ oldTasks.splice(index, 1, [...arr]); // 这里加入的数据是array类型的, [{},{},[],[],{}]
+ }
+ }
+ })
+
+ // 数据与上一页最后一个数据时间节点相同
+ if (lastIndex) {
+ taskLen += tasksArr.length;
+ oldTasks.splice(lastIndex, 0, [...tasksArr]);
+ }
+
+ oldTasks = flatten(oldTasks); // 1维拍平
+
+ if (taskLen === params.pageSize) {
+ // 如果真实任务所有数据都在tasks时间段中,则将所有任务显示,并且从最后一个真实任务的时间截止,存储到tasks中
+ let len = 0;
+ oldTasks.forEach((item, index) => {
+ if (item.id === realTasks[realTasks.length - 1].id) {
+ len = index;
+ }
+ })
+
+ oldTasks = oldTasks.slice(0, len + 1);
+ params.queryType === 0 ? store.commit('task/setUpBasicTask', []) : store.commit('task/setBasicTask', []);
+ } else {
+ // 只有一部分真实数据展示,展示tasks时间段加时间段内的真实数据
+ params.queryType === 0 ? store.commit('task/setUpBasicTask', realTasks.slice(taskLen)) : store.commit('task/setBasicTask', realTasks.slice(taskLen));
+ }
+
+ store.commit('task/clearTasks');
+ params.queryType === 0 ? store.commit('task/setUpTasks', oldTasks) : store.commit('task/setDownTasks', oldTasks);
+ } else {
+ if (next > 0) {
+ getTasks({pageNum: params.pageNum, queryType: params.queryType});
+ }
+ }
+ }
+
+ /**
+ * 数据筛选条件
+ * 大于等于15天,真实数据的时间跨度,且大于等于15条,真实数据的数量,不用重新加载数据
+ */
+ function tremFilter(params) {
+ let time1 = 0, time2 = 0;
+ let realTasks = basicTasks.value;
+
+ if (realTasks.length > 0) {
+ // 真实数据第一条数据加上15天后的时间
+ time1 = dayjs(+realTasks[0].planStart).add(params.pageSize, timeGranularity.value);
+ // 真实数据最后一条数据的时间
+ time2 = dayjs(realTasks[realTasks.length - 1].planStart, timeGranularity.value);
+ }
+
+ let result1 = false, result2 = false;
+ // 判断真实任务的时间跨度是否在15天之内
+ if (time1 > 0 && time2 > 0) {
+ // 两个时间是否相等
+ result1 = dayjs(time1).isSame(time2, timeGranularity.value);
+ // time1是否大于time2
+ result2 = dayjs(time1).isAfter(time2, timeGranularity.value);
+ }
+
+ let term1 = realTasks.length >= params.pageSize; // 大于等于15条,真实数据的数量
+ // 大于等于15天,真实数据的时间跨度
+ let term2 = result1 || result2;
+
+ return term1 || term2;
+ }
+
+ /**
+ * 用拿到的新数据 替换 时间刻度/旧数据
+ * 先对比 新旧数据的 始末时间 补齐刻度
+ * 再遍历对比 用任务替换刻度
+ * @param {array} data 服务端返回的新数据 上边已经处理过空值
+ * @param {number} type 0 -> 向上 1->向下
+ */
+ // function replacePrevData(data, type) {
+ // const obj = { tasks: tasks.value, data, timeGranularity: timeGranularity.value };
+ // let oldTasks = fillPlaceholderTask(obj); // 已经上下补齐时间刻度的
+ // console.log('oldTasks', oldTasks)
+ // // 遍历对比 用任务替换刻度
+ // // TODO: tasks越来越多 遍历越来越多 需要优化
+ // oldTasks.forEach((taskItem, index) => {
+ // const arr = data.filter(dataItem => dayjs(+dataItem.planStart).isSame(+taskItem.planStart, timeGranularity.value));
+ // if (arr && arr.length) {
+ // oldTasks.splice(index, 1, [...arr]); // 这里加入的数据是array类型的, [{},{},[],[],{}]
+ // }
+ // });
+
+ // oldTasks = flatten(oldTasks); // 1维拍平
+
+ // store.commit('task/clearTasks');
+ // type === 0 ? store.commit('task/setUpTasks', oldTasks) : store.commit('task/setDownTasks', oldTasks);
+ // }
+
+ /**
+ * 超出旧数据上、下限 补齐时间刻度到新数据的起始时间颗粒度
+ */
+ // function fillPlaceholderTask(obj) {
+ // const { prev, next } = uni.$task.computeFillPlaceholderTaskCount(obj);
+ // if (prev) {
+ // const newTasks = uni.$task.setPlaceholderTasks(+obj.tasks[0].planStart, true, obj.timeGranularity, prev);
+ // store.commit('task/setUpTasks', newTasks);
+ // }
+ // if (next) {
+ // const newTasks = uni.$task.setPlaceholderTasks(+obj.tasks[obj.tasks.length - 1].planStart, false, obj.timeGranularity, next);
+ // store.commit('task/setDownTasks', newTasks);
+ // }
+ // return tasks.value;
+ // }
+
+ // 设置时间轴向上的空数据
+ function setPrevPlaceholderTasks() {
+ store.commit('task/setTopEnd', true);
+ let startTime = '';
+ if (!tasks.value || !tasks.value.length) {
+ startTime = Date.now(); // 没有任务就应该是时间基准点
+ } else {
+ startTime = tasks.value[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 = dayjs(+tasks.value[tasks.value.length - 1].planStart).add(1, timeGranularity.value);
+ }
+ const initData = uni.$task.setPlaceholderTasks(startTime, false, timeGranularity.value);
+ store.commit('task/setDownTasks', initData);
+ }
+
+ /**
+ * 当日常任务发生变化时
+ * 将新获取到的日常任务放在allTasks里
+ */
+ watch(tasks, newValue => {
+ // console.log('newValue----->tasks: ', tasks.value);
+ // 添加到allTasks里
+ const index = visibleRoles.value.findIndex(role => role.id === roleId.value);
+ const arr = [...allTasks.value];
+ arr[index].task = [...newValue];
+ store.commit('task/setAllTasks', arr);
+ });
+
+ return {
+ initPlanTasks,
+ getTasks,
+ renderTask
+ };
+}
diff --git a/hooks/project/useGetTasks.js b/hooks/project/useGetTasks.js
index 45bd8d2..71613da 100644
--- a/hooks/project/useGetTasks.js
+++ b/hooks/project/useGetTasks.js
@@ -5,11 +5,12 @@ import dayjs from 'dayjs';
export default function useGetTasks() {
const store = useStore();
const tasks = computed(() => store.state.task.tasks);
- const basicTasks = computed(() => store.state.task.basicTasks);
- const upBasicTasks = computed(() => store.state.task.upBasicTasks);
- const nextPage = computed(() => store.state.task.nextPage); // 下一页
+ const timeLineType = computed(() => store.state.task.timeLineType); // 时间轴模式
+ const realTasks = computed(() => store.state.task.realTasks); // 真实任务
+ const downNextPage = computed(() => store.state.task.downNextPage); // 下一页
const upNextPage = computed(() => store.state.task.upNextPage); // 下一页
- // const lastPage = computed(() => store.state.task.lastPage); // 最后一页
+ const currUpTimeNode = computed(() => store.state.task.currUpTimeNode); // 当前查询的时间
+ const currDownTimeNode = computed(() => store.state.task.currDownTimeNode); // 当前查询的时间
const roleId = computed(() => store.state.role.roleId);
const timeNode = computed(() => store.state.task.timeNode);
const timeUnit = computed(() => store.state.task.timeUnit);
@@ -32,11 +33,10 @@ export default function useGetTasks() {
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,
+ queryType: query.queryType === 0 ? 0 : 1,
+ pageNum: query.pageNum || 1,
+ pageSize: query.pageSize || uni.$taskConfig.pageCount
};
}
@@ -51,15 +51,8 @@ export default function useGetTasks() {
*/
function getTasks(query) {
store.commit('task/setShowSkeleton', false);
- // const params = generateGetTaskParam(query);
- const params = {
- roleId: roleId.value,
- timeUnit: query.timeUnit || timeUnit.value,
- queryType: query.queryType === 0 ? 0 : 1,
- pageNum: query.pageNum || 1,
- pageSize: query.pageSize || uni.$taskConfig.pageCount
- }
+ const params = generateGetTaskParam(query);
uni.$catchReq.getTaskByNum(params, (err, data) => {
store.commit('task/setShowSkeleton', false);
if (err) {
@@ -68,27 +61,70 @@ export default function useGetTasks() {
} else {
store.commit('task/setShowScrollTo', true);
- if (params.queryType === 0) {
- // 将接口返回的数据存储到store
- let lists = [...upBasicTasks.value, ...data.list];
- store.commit('task/setUpBasicTask', lists);
- store.commit('task/setUpNextPage', data.nextPage); // 下一页
- } else {
- let lists = [...basicTasks.value, ...data.list];
- store.commit('task/setBasicTask', lists);
- store.commit('task/setNextPage', data.nextPage); // 下一页
- }
+ params.queryType === 0 ? store.commit('task/setUpRealTasks', data.list) : store.commit('task/setDownRealTasks', data.list);
+ params.queryType === 0 ? store.commit('task/setUpNextPage', data.nextPage) : store.commit('task/setDownNextPage', data.nextPage); // 下一页
- // 刻度模式数据处理
- renderTask(params);
+ // 数据处理
+ dataRender(params);
}
});
}
+ function dataRender(params) {
+ timeLineType.value === 1 ? renderScaleTask(params) : renderConTask(params);
+ }
+
+ async function renderConTask(params) {
+ let nextPage = params.queryType === 0 ? upNextPage.value : downNextPage.value; // 下一页的值
+ let showTasks = tasks.value;
+ let centerData = await showTaskId(params, showTasks, realTasks.value) || [];
+
+ if (centerData.length < 15 && nextPage > 0) {
+ getTasks({pageNum: nextPage, queryType: params.queryType});
+ } else {
+ if (params.queryType === 0) {
+ showTasks = [...centerData, ...showTasks];
+ } else {
+ showTasks = [...showTasks, ...centerData];
+ }
+ }
+
+ if (showTasks.length < 15 && nextPage === 0 && params.queryType === 1) {
+ getTasks({pageNum: 1, queryType: 0});
+ }
+
+ store.commit('task/clearTasks');
+ params.queryType === 0 ? store.commit('task/setUpTasks', showTasks) : store.commit('task/setDownTasks', showTasks);
+ }
+
// 刻度模式数据处理
- function renderTask(params) {
+ async function renderScaleTask(params) {
params.queryType === 0 ? setPrevPlaceholderTasks() : setNextPlaceholderTasks();
- tasksData(params);
+ let centerData = await showTaskId(params, tasks.value, realTasks.value) || [];
+ tasksData(params, centerData, realTasks.value);
+ }
+
+ // 已显示的任务第一个id和最后一个id
+ function showTaskId(params, showTasks, realTasks) {
+ const firstDetailIndex = showTasks.findIndex(task => task.detailId);
+ const firstId = firstDetailIndex === -1 ? 0 : showTasks[firstDetailIndex].id;
+ let lastDetailIndex = -1;
+ showTasks.forEach((item, index) => {
+ if (item.detailId) {
+ lastDetailIndex = index;
+ }
+ })
+ const lastId = lastDetailIndex === -1 ? 0 : showTasks[lastDetailIndex].id;
+
+ let centerData = params.queryType === 0 ? [] : realTasks.slice(0, params.pageSize);
+ realTasks.forEach((item, index) => {
+ if (params.queryType === 1 && item.id === lastId) {
+ centerData = realTasks.slice(index + 1, index + 1 + params.pageSize) || [];
+ } else if (params.queryType === 0 && item.id === firstId) {
+ centerData = realTasks.slice(index - params.pageSize, index) || [];
+ }
+ })
+ return centerData;
}
/**
@@ -98,139 +134,90 @@ export default function useGetTasks() {
* 不用重新加载数据
* @param {Object} params
*/
- function tasksData(params) {
- let oldTasks = tasks.value;
- let realTasks = params.queryType === 0 ? upBasicTasks.value : basicTasks.value;
- // 下一页的值
- let next = params.queryType === 0 ? upNextPage.value : nextPage.value;
+ function tasksData(params, centerData, realTasks) {
+ let param = generateGetTaskParam(params);
+ let showTasks = tasks.value; // 显示的数据
+ let nextPage = param.queryType === 0 ? upNextPage.value : downNextPage.value; // 下一页的值
- // 真实数据是否>=15条 || 是否>=15天
- let term = tremFilter(params);
+ // 判断条件
+ let isAccordTerm1 = false, isAccordTerm2 = false;
+ if (centerData.length > 0) {
+ // 1.数据数量>=15条
+ isAccordTerm1 = centerData.length >= param.pageSize;
- if (term || next === 0) {
- // 过滤真实数据中在tasks时间段中的数据,并将最后的数据存储到tasksArr数组中
- let tasksArr = [], taskLen = 0, lastIndex = 0;
- oldTasks.forEach((task, index) => {
- const oldArr = oldTasks.filter(item => dayjs(+item.planStart).isSame(+task.planStart, timeGranularity.value));
- const arr = realTasks.filter(item => dayjs(+item.planStart).isSame(+task.planStart, timeGranularity.value));
+ // 2.数据最后一条数据时间>=当前查询的时间
+ if (param.queryType === 0) {
+ let firstData = dayjs(centerData[0].planStart).add(param.pageSize, timeGranularity.value);
+ isAccordTerm2 = dayjs(+firstData).isBefore(+currUpTimeNode.value, timeGranularity.value) || dayjs(+firstData).isSame(+currUpTimeNode.value, timeGranularity.value);
+ } else {
+ let lastData = dayjs(centerData[centerData.length - 1].planStart).subtract(param.pageSize, timeGranularity.value);
+ isAccordTerm2 = dayjs(+lastData).isAfter(+currDownTimeNode.value, timeGranularity.value) || dayjs(+lastData).isSame(+currDownTimeNode.value, timeGranularity.value);
+ }
+ }
+ // 3.下一页===0
+ // 不需要添加新数据
+ if (!isAccordTerm1 && !isAccordTerm2 && nextPage > 0) {
+ getTasks({pageNum: nextPage, queryType: param.queryType});
+ } else {
+ let tasksArr = [], isReplace = false, firstIndex = -1, selctedIndex = -1, replaceTime = 0;
+ showTasks.forEach((task, index) => {
+ const arr = centerData.filter(item => dayjs(+item.planStart).isSame(+task.planStart, timeGranularity.value));
if (arr && arr.length) {
if (task.detailId) {
- tasksArr = [...arr];
- lastIndex = index;
+ // 新数据与旧数据时间有重叠
+ if (param.queryType === 1) {
+ selctedIndex = index;
+ tasksArr = [...arr];
+ } else {
+ firstIndex = showTasks.findIndex(data => dayjs(+data.planStart).isSame(+task.planStart, timeGranularity.value));
+ }
} else {
- taskLen += arr.length; // 在时间刻度内的数据量
- oldTasks.splice(index, 1, [...arr]); // 这里加入的数据是array类型的, [{},{},[],[],{}]
+ showTasks.splice(index, 1, [...arr]);
}
}
})
- // 数据与上一页最后一个数据时间节点相同
- if (lastIndex) {
- taskLen += tasksArr.length;
- oldTasks.splice(lastIndex, 0, [...tasksArr]);
+ if (selctedIndex) {
+ showTasks.splice(selctedIndex + 1, 0, [...tasksArr])
+ }
+
+ if (firstIndex) {
+ showTasks.splice(firstIndex, 0, [...tasksArr])
}
- oldTasks = flatten(oldTasks); // 1维拍平
+ showTasks.forEach((task, index) => {
+ const arr = centerData.filter(item => dayjs(+item.planStart).isSame(+task.planStart, timeGranularity.value));
+ if (arr && arr.length) {
+ if (!task.detailId) { // 新数据与旧数据时间有重叠
+ showTasks.splice(index, 1, [...arr]); // 这里加入的数据是array类型的, [{},{},[],[],{}]
+ }
+ }
+ })
+
+ showTasks = flatten(showTasks); // 1维拍平
- if (taskLen === params.pageSize) {
- // 如果真实任务所有数据都在tasks时间段中,则将所有任务显示,并且从最后一个真实任务的时间截止,存储到tasks中
+ if (isAccordTerm1 && !isAccordTerm2) {
let len = 0;
- oldTasks.forEach((item, index) => {
- if (item.id === realTasks[realTasks.length - 1].id) {
+ let data = param.queryType === 0 ? centerData[0] : centerData[centerData.length - 1];
+ showTasks.forEach((item, index) => {
+ if (item.id === data.id) {
len = index;
}
})
- oldTasks = oldTasks.slice(0, len + 1);
- params.queryType === 0 ? store.commit('task/setUpBasicTask', []) : store.commit('task/setBasicTask', []);
- } else {
- // 只有一部分真实数据展示,展示tasks时间段加时间段内的真实数据
- params.queryType === 0 ? store.commit('task/setUpBasicTask', realTasks.slice(taskLen)) : store.commit('task/setBasicTask', realTasks.slice(taskLen));
+ showTasks = param.queryType === 0 ? showTasks.slice(len) : showTasks.slice(0, len + 1);
}
- store.commit('task/clearTasks');
- params.queryType === 0 ? store.commit('task/setUpTasks', oldTasks) : store.commit('task/setDownTasks', oldTasks);
- } else {
- if (next > 0) {
- getTasks({pageNum: params.pageNum, queryType: params.queryType});
+ if (showTasks.length > 80) {
+ showTasks = param.queryType === 0 ? showTasks.slice(0, 80) : showTasks.slice(showTasks.length - 80);
}
}
- }
-
- /**
- * 数据筛选条件
- * 大于等于15天,真实数据的时间跨度,且大于等于15条,真实数据的数量,不用重新加载数据
- */
- function tremFilter(params) {
- let time1 = 0, time2 = 0;
- let realTasks = basicTasks.value;
- if (realTasks.length > 0) {
- // 真实数据第一条数据加上15天后的时间
- time1 = dayjs(+realTasks[0].planStart).add(params.pageSize, timeGranularity.value);
- // 真实数据最后一条数据的时间
- time2 = dayjs(realTasks[realTasks.length - 1].planStart, timeGranularity.value);
- }
-
- let result1 = false, result2 = false;
- // 判断真实任务的时间跨度是否在15天之内
- if (time1 > 0 && time2 > 0) {
- // 两个时间是否相等
- result1 = dayjs(time1).isSame(time2, timeGranularity.value);
- // time1是否大于time2
- result2 = dayjs(time1).isAfter(time2, timeGranularity.value);
- }
-
- let term1 = realTasks.length >= params.pageSize; // 大于等于15条,真实数据的数量
- // 大于等于15天,真实数据的时间跨度
- let term2 = result1 || result2;
-
- return term1 || term2;
+ store.commit('task/clearTasks');
+ param.queryType === 0 ? store.commit('task/setUpTasks', showTasks) : store.commit('task/setDownTasks', showTasks);
}
- /**
- * 用拿到的新数据 替换 时间刻度/旧数据
- * 先对比 新旧数据的 始末时间 补齐刻度
- * 再遍历对比 用任务替换刻度
- * @param {array} data 服务端返回的新数据 上边已经处理过空值
- * @param {number} type 0 -> 向上 1->向下
- */
- // function replacePrevData(data, type) {
- // const obj = { tasks: tasks.value, data, timeGranularity: timeGranularity.value };
- // let oldTasks = fillPlaceholderTask(obj); // 已经上下补齐时间刻度的
- // console.log('oldTasks', oldTasks)
- // // 遍历对比 用任务替换刻度
- // // TODO: tasks越来越多 遍历越来越多 需要优化
- // oldTasks.forEach((taskItem, index) => {
- // const arr = data.filter(dataItem => dayjs(+dataItem.planStart).isSame(+taskItem.planStart, timeGranularity.value));
- // if (arr && arr.length) {
- // oldTasks.splice(index, 1, [...arr]); // 这里加入的数据是array类型的, [{},{},[],[],{}]
- // }
- // });
-
- // oldTasks = flatten(oldTasks); // 1维拍平
-
- // store.commit('task/clearTasks');
- // type === 0 ? store.commit('task/setUpTasks', oldTasks) : store.commit('task/setDownTasks', oldTasks);
- // }
-
- /**
- * 超出旧数据上、下限 补齐时间刻度到新数据的起始时间颗粒度
- */
- // function fillPlaceholderTask(obj) {
- // const { prev, next } = uni.$task.computeFillPlaceholderTaskCount(obj);
- // if (prev) {
- // const newTasks = uni.$task.setPlaceholderTasks(+obj.tasks[0].planStart, true, obj.timeGranularity, prev);
- // store.commit('task/setUpTasks', newTasks);
- // }
- // if (next) {
- // const newTasks = uni.$task.setPlaceholderTasks(+obj.tasks[obj.tasks.length - 1].planStart, false, obj.timeGranularity, next);
- // store.commit('task/setDownTasks', newTasks);
- // }
- // return tasks.value;
- // }
-
// 设置时间轴向上的空数据
function setPrevPlaceholderTasks() {
store.commit('task/setTopEnd', true);
@@ -241,6 +228,7 @@ export default function useGetTasks() {
startTime = tasks.value[0].planStart - 0; // 有任务就是第一个任务的计划开始时间
}
const placeholderTasks = uni.$task.setPlaceholderTasks(startTime, true, timeGranularity.value);
+ store.commit('task/setCurrUpTimeNode', startTime);
store.commit('task/setUpTasks', placeholderTasks);
}
@@ -251,9 +239,10 @@ export default function useGetTasks() {
if (!tasks.value || !tasks.value.length) {
startTime = Date.now();
} else {
- startTime = dayjs(+tasks.value[tasks.value.length - 1].planStart).add(1, timeGranularity.value);
+ startTime = dayjs(+tasks.value[tasks.value.length - 1].planStart).add(1, timeGranularity.value).valueOf();
}
const initData = uni.$task.setPlaceholderTasks(startTime, false, timeGranularity.value);
+ store.commit('task/setCurrDownTimeNode', startTime);
store.commit('task/setDownTasks', initData);
}
@@ -273,6 +262,6 @@ export default function useGetTasks() {
return {
initPlanTasks,
getTasks,
- renderTask
+ dataRender
};
}
diff --git a/hooks/project/useInit.js b/hooks/project/useInit.js
index 0239ab9..bb6d913 100644
--- a/hooks/project/useInit.js
+++ b/hooks/project/useInit.js
@@ -94,7 +94,7 @@ export default function useInit() {
// 根据项目id获取角色列表
getRoles(params);
// 根据项目id获取成员列表
- store.dispatch('role/getAllMembers', { projectId: options.p });
+ // store.dispatch('role/getAllMembers', { projectId: options.p });
}
}
diff --git a/pages/project/project.vue b/pages/project/project.vue
index ea26fd8..be8b8ac 100644
--- a/pages/project/project.vue
+++ b/pages/project/project.vue
@@ -27,6 +27,8 @@
+
+ {{timeLineType === 1 ? '切换到任务模式' : '切换到时间轴模式'}}
@@ -54,6 +56,7 @@ const allTasks = computed(() => store.state.task.allTasks); // 所有任务
const globals = computed(() => store.getters['task/globals']); // 所有的日常任务 永久 + 可变 日常任务
const timeGranularity = computed(() => store.getters['task/timeGranularity']); // 计算颗粒度 对应的 dayjs add 的单位
const height = ref(null); // 页面高度
+const timeLineType = computed(() => store.state.task.timeLineType); // 时间轴模式
onMounted(() => {
const system = uni.getSystemInfoSync();
@@ -217,6 +220,17 @@ function setScrollPosition() {
}
}
}
+
+
+function changeModal() {
+ store.commit('task/clearTasks'); // 清空定期任务
+ store.commit('task/clearRealTasks'); // 清空真实任务数据
+ store.commit('task/setUpNextPage', 1);
+ store.commit('task/setDownNextPage', 1);
+ store.commit('task/setTimeLineType', timeLineType.value === 1 ? 2 : 1);
+ let params = { pageNum: 1 };
+ getTasksHook.getTasks(params);
+}