From 798ff0bede63be7b7645d92acec5b449a0376c73 Mon Sep 17 00:00:00 2001
From: 小小儁爺 <1694218219@qq.com>
Date: 星期二, 20 一月 2026 11:10:00 +0800
Subject: [PATCH] 1.递交
---
src/views/gantt/index.vue | 958 ++++++++++++++++++++++++++++++++++++++++++-----------------
1 files changed, 672 insertions(+), 286 deletions(-)
diff --git a/src/views/gantt/index.vue b/src/views/gantt/index.vue
index 35fa237..f7f98a3 100644
--- a/src/views/gantt/index.vue
+++ b/src/views/gantt/index.vue
@@ -2,10 +2,19 @@
<div style="padding: 0 10px">
<div style="padding: 10px 0;display: flex;">
- <el-button type="primary" size="mini" @click="ganttUndo">鍥為��鎷栧姩鎿嶄綔</el-button>
- <el-button type="primary" size="mini" @click="ganttRedo">鍓嶈繘鎷栧姩鎿嶄綔</el-button>
- <el-button type="primary" size="mini" @click="ganttZoomIn">鏀惧ぇ</el-button>
- <el-button type="primary" size="mini" @click="ganttZoomOut">缂╁皬</el-button>
+ <el-select
+ v-model="scaleValue"
+ size="mini"
+ placeholder="璇烽�夋嫨"
+ @change="val=>changeTimeScale(val,true)"
+ >
+ <el-option
+ v-for="item in scaleArr"
+ :key="item.code"
+ :label="item.name"
+ :value="item.code"
+ />
+ </el-select>
<el-date-picker
v-model="ganttDateRange"
style="margin-left: 10px;"
@@ -24,6 +33,7 @@
<el-button size="mini" @click="handleClearSelection">
娓呯┖澶嶉�夋閫夋嫨
</el-button>
+
</div>
<div id="gantt_here" style="width:100%; height:calc(90vh - 50px);" />
@@ -51,15 +61,23 @@
export default {
data() {
return {
- value: 'default',
- ganttDateRange: ['2025-04-01', '2025-05-10'],
+ scaleArr: [
+ { code: '30min', name: '30min' },
+ { code: '60min', name: '60min' },
+ { code: '240min', name: '240min' },
+ { code: '360min', name: '360min' }
+ ],
+ scaleValue: '240min',
+ ganttDateRange: ['2026-01-20', '2026-01-25'],
selectedIds: [],
// 鍒嗛〉鐩稿叧鏁版嵁
currentPage: 1,
- pageSize: 10,
+ pageSize: 100,
totalTasks: 0,
allTasks: [], // 瀛樺偍鎵�鏈変换鍔℃暟鎹�
- paginatedTasks: [] // 褰撳墠椤电殑浠诲姟鏁版嵁
+ paginatedTasks: [], // 褰撳墠椤电殑浠诲姟鏁版嵁
+
+ fivePeriodsTimeName: ['OneStartDate', 'TwoStartDate', 'ThreeStartDate', 'FourStartDate', 'FiveStartDate']// 浜斾釜鏃堕棿娈电殑閿悕
}
},
mounted() {
@@ -93,7 +111,8 @@
// 涓嶅啀瀵归綈鏃堕棿杞村埢搴︼紙姣斿澶╂牸瀛愶級锛岃�屾槸鎸夆�滃皬鏃垛�濆榻�
gantt.config.round_dnd_dates = false
// 鏈�灏忔闀胯繕鏄� 1 灏忔椂锛屼絾浣犲凡缁忎粠鈥滃ぉ鏍煎瓙鈥濆彉鎴愨�滃皬鏃舵牸瀛愨�濅簡
- gantt.config.time_step = 60 // 60 鍒嗛挓 = 1 灏忔椂
+ // gantt.config.time_step = 60 // 60 鍒嗛挓 = 1 灏忔椂
+ gantt.config.time_step = 1 // 1鍒嗛挓
gantt.config.row_height = 32 // 琛岄珮
gantt.config.bar_height = 20 // bar楂�
@@ -102,7 +121,7 @@
gantt.config.drag_progress = false // 绂佹閫氳繃鎷栧姩杩涘害鏉℃敼鍙樹换鍔¤繘搴�
- // gantt.config.readonly = true //鍙妯″紡
+ gantt.config.readonly = true // 鍙妯″紡
/* 鈫撯啌鈫� Group configuration 鈫撯啌鈫� */
gantt.serverList('task_priority', [
@@ -129,115 +148,30 @@
/* 鈫戔啈鈫� Group configuration 鈫戔啈鈫� */
- // 鏀惧ぇ缂╁皬灞炴��
- /* 鈫撯啌鈫� Zoom configuration 鈫撯啌鈫� */
- const zoomConfig = {
- levels: [
- {
- name: 'hour',
- scale_height: 27,
- min_column_width: 50,
- scales: [
- { unit: 'day', format: '%Y骞�%M%d鍙�' },
- { unit: 'hour', format: '%H鏃�' }
- ]
- },
- {
- name: 'day',
- scale_height: 27,
- min_column_width: 80,
- scales: [
- // { unit: 'day', step: 1, format: '%d %M' }
- { unit: 'day', step: 1, format: '%M%d鍙�' }
- ]
- },
- {
- name: 'week',
- scale_height: 50,
- min_column_width: 70,
- scales: [
- // {
- // unit: 'week', step: 1, format: function(date) {
- // const dateToStr = gantt.date.date_to_str('%d %M')
- // const endDate = gantt.date.add(date, -6, 'day')
- // const weekNum = gantt.date.date_to_str('%W')(date)
- // return '绗�' + weekNum + '鍛�, ' + dateToStr(date) + ' - ' + dateToStr(endDate)
- // }
- // },
- // %M
- { unit: 'week', format: '%Y骞寸%W鍛�' },
- { unit: 'day', step: 1, format: '%M%d鍙�' }
- // { unit: 'minute', step: 60, format: '%H:%i' }
- // { unit: 'day', step: 1, format: '%j %D' }
- // { unit: 'day', step: 1, format: '鏄熸湡%D' }
- ]
- },
- {
- name: 'month',
- scale_height: 50,
- min_column_width: 120,
- scales: [
- // { unit: 'month', format: '%Y骞�%F' },
- { unit: 'month', format: '%Y骞�%M' },
- { unit: 'week', format: '绗�%W鍛�' }
- ]
- },
- {
- name: 'quarter',
- height: 50,
- min_column_width: 90,
- scales: [
- // {
- // unit: 'quarter', step: 1, format: function(date) {
- // const dateToStr = gantt.date.date_to_str('%M')
- // const endDate = gantt.date.add(gantt.date.add(date, 3, 'month'), -1, 'day')
- // return dateToStr(date) + ' - ' + dateToStr(endDate)
- // }
- // },
- { unit: 'month', step: 1, format: '%Y骞�%M' }
- ]
- },
- {
- name: 'year',
- scale_height: 50,
- min_column_width: 30,
- scales: [
- { unit: 'year', step: 1, format: '%Y骞�' }
-
- ]
- }
- ],
- useKey: 'ctrlKey',
- trigger: 'wheel',
- element: function() {
- return gantt.$root.querySelector('.gantt_task')
- }
- }
- gantt.ext.zoom.init(zoomConfig)
- gantt.ext.zoom.setLevel('week')
- /* 鈫戔啈鈫� Zoom configuration 鈫戔啈鈫� */
+ // 鍒诲害鍊兼敼鍙�
+ this.changeTimeScale()
// 鏄惁鏄伐浣滄椂闂�
/* 鈫撯啌鈫� Working Time configuration 鈫撯啌鈫� */
- gantt.templates.scale_cell_class = function(date) {
- if (!gantt.isWorkTime(date)) {
- return 'weekend'
- }
- }
-
- gantt.templates.timeline_cell_class = function(item, date) {
- if (!gantt.isWorkTime({ date: date, task: item })) {
- return 'weekend'
- }
- }
-
- gantt.config.work_time = true
-
+ // gantt.templates.scale_cell_class = function(date) {
+ // if (!gantt.isWorkTime(date)) {
+ // return 'weekend'
+ // }
+ // }
+ //
+ // gantt.templates.timeline_cell_class = function(item, date) {
+ // if (!gantt.isWorkTime({ date: date, task: item })) {
+ // return 'weekend'
+ // }
+ // }
+ //
+ // gantt.config.work_time = true
+ //
// gantt.addCalendar({
- // id: 'custom1',
+ // id: 'customCalendar1',
// worktime: {
- // hours: ['8:00-12:30', '13:00-17:30'], // global work hours for weekdays
- // days: [0, 1, 1, 1, 1, 1, 1]
+ // hours: ['00:00-24:00'], // global work hours for weekdays
+ // days: [1, 1, 1, 1, 1, 1, 1]
// }
// })
@@ -268,14 +202,23 @@
return `<input type="checkbox" class="taskCheckBox" data-action="check-row" ${checked} />`
}
},
- { name: 'wbs', label: '鑺傜偣', width: 80, template: gantt.getWBSCode },
- { name: 'text', tree: true, label: '浠诲姟鍚嶇О', width: 200, resize: true, editor: textEditor },
+ // { name: 'wbs', label: '鑺傜偣', width: 80, template: gantt.getWBSCode },
+ { name: 'text', tree: true, align: 'center', label: '浠诲姟鍚嶇О', width: 240, resize: true, editor: textEditor },
+ { name: 'saleOrder', align: 'center', label: '閿�鍞鍗�', width: 100, resize: true },
+ { name: 'partName', align: 'center', label: '浜у搧鍚嶇О', width: 80, resize: true },
+ { name: 'partCode', align: 'center', label: '浜у搧缂栫爜', width: 80, resize: true },
+ {
+ name: 'progress', align: 'center', label: '杩涘害', width: 120, resize: true, template: function(task) {
+ return `<input type="range" onmousedown="event.preventDefault()" onmouseup="event.preventDefault()" id="taskRange" value="${task.progress * 100}"/> ${task.progress * 100}%`
+ // return `<el-progress :percentage='${task.progress * 100}'></el-progress> ${task.progress * 100}%`
+ }
+ },
{ name: 'start_date', align: 'center', label: '寮�濮嬫棩鏈�', width: 80, resize: true, editor: startDateEditor },
{
name: 'duration',
width: 60,
align: 'center',
- label: '宸ユ湡(澶�)',
+ label: '鏃堕暱(鍒嗛挓)',
resize: true,
editor: durationEditor,
template: function(task) {
@@ -283,44 +226,8 @@
// return (task.duration || 0) + 1 // 鍦ㄥ綋鍓峝uration鐨勫熀纭�涓婂姞1
return task.duration
}
- },
- {
- name: 'owner', align: 'center', width: 75, label: '璐熻矗浜�', template: function(task) {
- // if (task.type == gantt.config.types.project) {
- // return ''
- // }
- //
- // const store = gantt.getDatastore('resource')
- // const assignments = task[gantt.config.resource_property]
- //
- // if (!assignments || !assignments.length) {
- // return 'Unassigned'
- // }
- //
- // if (assignments.length === 1) {
- // return store.getItem(assignments[0].resource_id).text
- // }
- //
- // let result = ''
- // assignments.forEach(function(assignment) {
- // const owner = store.getItem(assignment.resource_id)
- // if (!owner) {
- // return
- // }
- // result += '<div class=\'owner-label\' title=\'' + owner.text + '\'>' + owner.text.substr(0, 1) + '</div>'
- // })
- //
- // return result
- return '寮犱笁'
- },
- resize: true
- },
- {
- name: 'priority', width: 60, label: '浼樺厛绾�', align: 'center', resize: true, template: function(task) {
- return byId(gantt.serverList('task_priority'), task.priority)
- }
- },
- { name: 'add', width: 44 }
+ }
+ // { name: 'add', width: 44 }
]
/* 鈫戔啈鈫� Grid Columns configuration 鈫戔啈鈫� */
@@ -382,66 +289,10 @@
years: '骞�'
}
- gantt.config.lightbox.sections = [
- { name: 'description', height: 38, map_to: 'text', type: 'textarea', focus: true },
- {
- name: 'resources', type: 'resources', map_to: 'owner', options: gantt.serverList('people'), default_value: 8
- },
- {
- name: 'calendar', height: 25, map_to: 'calendar_id', type: 'select', options: [
- { key: '', label: '榛樿' },
- { key: 'custom1', label: '閫夐」涓�' },
- { key: 'custom2', label: '閫夐」浜�' }
- ]
- },
-
- { name: 'time', type: 'duration', map_to: 'auto' }
- ]
-
- gantt.config.resource_store = 'resource'
- gantt.config.resource_property = 'owner'
- gantt.config.order_branch = true
- gantt.config.open_tree_initially = true
+ // gantt.config.order_branch = true
+ // gantt.config.open_tree_initially = true
gantt.config.show_errors = false // 鍙戠敓寮傚父鏃讹紝涓嶅厑璁稿脊鍑鸿鍛婂埌 UI 鐣岄潰
-
- const resourcesStore = gantt.createDatastore({
- name: gantt.config.resource_store,
- type: 'treeDatastore',
- initItem: function(item) {
- item.parent = item.parent || gantt.config.root_id
- item[gantt.config.resource_property] = item.parent
- item.open = true
- return item
- }
- })
-
- resourcesStore.attachEvent('onParse', function() {
- const people = []
- resourcesStore.eachItem(function(res) {
- if (!resourcesStore.hasChild(res.id)) {
- const copy = gantt.copy(res)
- copy.key = res.id
- copy.label = res.text
- people.push(copy)
- }
- })
- gantt.updateCollection('people', people)
- })
-
- resourcesStore.parse([
- { id: 1, text: 'QA', parent: null },
- { id: 2, text: 'Development', parent: null },
- { id: 3, text: 'Sales', parent: null },
- { id: 4, text: 'Other', parent: null },
- { id: 5, text: 'Unassigned', parent: 4 },
- { id: 6, text: 'John', parent: 1, unit: 'hours/day' },
- { id: 7, text: 'Mike', parent: 2, unit: 'hours/day' },
- { id: 8, text: 'Anna', parent: 2, unit: 'hours/day' },
- { id: 9, text: 'Bill', parent: 3, unit: 'hours/day' },
- { id: 10, text: 'Floe', parent: 3, unit: 'hours/day' }
- ])
- /* 鈫戔啈鈫� Resource configuration 鈫戔啈鈫� */
gantt.config.grid_elastic_columns = true
@@ -449,9 +300,32 @@
gantt.templates.tooltip_text = function(start, end, task) {
// console.log(JSON.parse(JSON.stringify(task)))
// return '<b>浠诲姟:</b> ' + task.text + '<br/><b>寮�濮嬫椂闂�:</b> ' + `${gantt.date.date_to_str('%Y-%m-%d')(start)}` + '<br/><b>缁撴潫鏃堕棿:</b> ' + handleDateReduceOneDay(end)
- return '<b>浠诲姟:</b> ' + task.text + '<br/><b>寮�濮嬫椂闂�:</b> ' + handleDatetime2(start) + '<br/><b>缁撴潫鏃堕棿:</b> ' + handleDateReduceOneDay(end) + '<br/><b>杩涘害:</b> ' + task.progress * 100 + '%'
+ // return '<b>浠诲姟:</b> ' + task.text + '<br/><b>寮�濮嬫椂闂�:</b> ' + handleDatetime2(start) + '<br/><b>缁撴潫鏃堕棿:</b> ' + handleDateReduceOneDay(end) + '<br/><b>杩涘害:</b> ' + task.progress * 100 + '%'
+ return '<b>浠诲姟:</b> ' + task.text + '<br/><b>寮�濮嬫椂闂�:</b> ' + handleDatetime2(start) + '<br/><b>缁撴潫鏃堕棿:</b> ' + handleDatetime2(end) + '<br/><b>杩涘害:</b> ' + task.progress * 100 + '%'
}
+ gantt.templates.task_text = function(start, end, task) {
+ // return '<span style="color: white; font-weight: bold; text-shadow: 1px 1px 1px #000;">' +
+ // task.description + ' - ' +
+ // '</span>'
+ // return task.description
+ // return task.progress * 100 + '%'
+
+ if (task.type === 'task2') {
+ return `<div class="task2Css">`
+ }
+ if (task.type === 'task3') {
+ return `<div class="task3Css">`
+ }
+ return ''
+ }
+
+ // 璁剧疆鎸佺画鏃堕棿鍗曚綅涓哄皬鏃�
+ // gantt.config.duration_unit = 'hour'
+
+ gantt.config.duration_unit = 'minute'
+ gantt.config.duration_step = 1
+ // gantt.config.show_task_cells = false //闅愯棌鐢樼壒鍥惧唴閮ㄥ埢搴︾嚎
gantt.init('gantt_here')
// 娉ㄦ剰锛氳繖閲屼笉绔嬪嵆鍔犺浇鏁版嵁锛岃�屾槸绛夊緟loadTasks琚皟鐢�
@@ -487,72 +361,469 @@
// 鍔犺浇浠诲姟鏁版嵁
loadTasks() {
+ // 鎺ュ彛鑾峰彇鍒扮殑鏁版嵁
+ const rows = [
+ {
+ 'wo_code': null,
+ 'YearDate': '2026-01-20',
+ 'children': [
+ {
+ 'AdvaDevicNumber': 'JG010',
+ 'AdvaDevicName': '绮惧伐璁惧10#',
+ 'AdvaDevicCropMob': '10',
+ 'AdvaDevicRhythm': '5.0',
+ 'OneStartDate': '08:00~11:30',
+ 'TwoStartDate': '13:00~18:00',
+ 'ThreeStartDate': '',
+ 'FourStartDate': '',
+ 'FiveStartDate': ''
+ },
+ {
+ 'AdvaDevicNumber': 'SB001',
+ 'AdvaDevicName': '璁惧001',
+ 'AdvaDevicCropMob': '30',
+ 'AdvaDevicRhythm': '5.0',
+ 'OneStartDate': '08:00~11:30',
+ 'TwoStartDate': '13:00~18:00',
+ 'ThreeStartDate': '',
+ 'FourStartDate': '',
+ 'FiveStartDate': ''
+ }
+ ]
+ },
+ {
+ 'wo_code': null,
+ 'YearDate': '2026-01-21',
+ 'children': [
+ {
+ 'AdvaDevicNumber': 'JG010',
+ 'AdvaDevicName': '绮惧伐璁惧10#',
+ 'AdvaDevicCropMob': '10',
+ 'AdvaDevicRhythm': '5.0',
+ 'OneStartDate': '08:00~11:30',
+ 'TwoStartDate': '13:00~18:00',
+ 'ThreeStartDate': '',
+ 'FourStartDate': '',
+ 'FiveStartDate': ''
+ },
+ {
+ 'AdvaDevicNumber': 'SB001',
+ 'AdvaDevicName': '璁惧001',
+ 'AdvaDevicCropMob': '30',
+ 'AdvaDevicRhythm': '5.0',
+ 'OneStartDate': '08:00~11:30',
+ 'TwoStartDate': '13:00~18:00',
+ 'ThreeStartDate': '',
+ 'FourStartDate': '',
+ 'FiveStartDate': ''
+ }
+ ]
+ },
+ {
+ 'wo_code': null,
+ 'YearDate': '2026-01-22',
+ 'children': [
+ {
+ 'AdvaDevicNumber': 'JG010',
+ 'AdvaDevicName': '绮惧伐璁惧10#',
+ 'AdvaDevicCropMob': '10',
+ 'AdvaDevicRhythm': '5.0',
+ 'OneStartDate': '08:00~11:30',
+ 'TwoStartDate': '13:00~18:00',
+ 'ThreeStartDate': '',
+ 'FourStartDate': '',
+ 'FiveStartDate': ''
+ },
+ {
+ 'AdvaDevicNumber': 'SB001',
+ 'AdvaDevicName': '璁惧001',
+ 'AdvaDevicCropMob': '30',
+ 'AdvaDevicRhythm': '5.0',
+ 'OneStartDate': '08:00~11:30',
+ 'TwoStartDate': '13:00~18:00',
+ 'ThreeStartDate': '',
+ 'FourStartDate': '',
+ 'FiveStartDate': ''
+ }
+ ]
+ },
+ {
+ 'wo_code': null,
+ 'YearDate': '2026-01-23',
+ 'children': [
+ {
+ 'AdvaDevicNumber': 'JG010',
+ 'AdvaDevicName': '绮惧伐璁惧10#',
+ 'AdvaDevicCropMob': '10',
+ 'AdvaDevicRhythm': '5.0',
+ 'OneStartDate': '08:00~11:30',
+ 'TwoStartDate': '13:00~18:00',
+ 'ThreeStartDate': '',
+ 'FourStartDate': '',
+ 'FiveStartDate': ''
+ },
+ {
+ 'AdvaDevicNumber': 'SB001',
+ 'AdvaDevicName': '璁惧001',
+ 'AdvaDevicCropMob': '30',
+ 'AdvaDevicRhythm': '5.0',
+ 'OneStartDate': '08:00~11:30',
+ 'TwoStartDate': '13:00~18:00',
+ 'ThreeStartDate': '',
+ 'FourStartDate': '',
+ 'FiveStartDate': ''
+ }
+ ]
+ },
+ {
+ 'wo_code': null,
+ 'YearDate': '2026-01-24',
+ 'children': [
+ {
+ 'AdvaDevicNumber': 'JG010',
+ 'AdvaDevicName': '绮惧伐璁惧10#',
+ 'AdvaDevicCropMob': '10',
+ 'AdvaDevicRhythm': '5.0',
+ 'OneStartDate': '08:00~11:30',
+ 'TwoStartDate': '13:00~18:00',
+ 'ThreeStartDate': '',
+ 'FourStartDate': '',
+ 'FiveStartDate': ''
+ },
+ {
+ 'AdvaDevicNumber': 'SB001',
+ 'AdvaDevicName': '璁惧001',
+ 'AdvaDevicCropMob': '30',
+ 'AdvaDevicRhythm': '5.0',
+ 'OneStartDate': '08:00~11:30',
+ 'TwoStartDate': '13:00~18:00',
+ 'ThreeStartDate': '',
+ 'FourStartDate': '',
+ 'FiveStartDate': ''
+ }
+ ]
+ },
+ {
+ 'wo_code': null,
+ 'YearDate': '2026-01-25',
+ 'children': [
+ {
+ 'AdvaDevicNumber': 'JG010',
+ 'AdvaDevicName': '绮惧伐璁惧10#',
+ 'AdvaDevicCropMob': '10',
+ 'AdvaDevicRhythm': '5.0',
+ 'OneStartDate': '08:00~11:30',
+ 'TwoStartDate': '13:00~18:00',
+ 'ThreeStartDate': '',
+ 'FourStartDate': '',
+ 'FiveStartDate': ''
+ },
+ {
+ 'AdvaDevicNumber': 'SB001',
+ 'AdvaDevicName': '璁惧001',
+ 'AdvaDevicCropMob': '30',
+ 'AdvaDevicRhythm': '5.0',
+ 'OneStartDate': '08:00~11:30',
+ 'TwoStartDate': '13:00~18:00',
+ 'ThreeStartDate': '',
+ 'FourStartDate': '',
+ 'FiveStartDate': ''
+ }
+ ]
+ }
+ ]
+
+ // {
+ // 'id': 3,
+ // 'text': '璁惧:閲戝伐杞﹂棿1鍙疯澶�',
+ // saleOrder: 'SO-2025-05001',
+ // 'calendar_id': 'customCalendar1',
+ // partName: '璺戞鏈�',
+ // partCode: 'Run01',
+ // description: '鎺掍骇鏁伴噺:500 鎶ュ伐鏁伴噺:100 杩涘害:20%',
+ // 'type': 'task',
+ // 'start_date': '2025-04-07 00:00',
+ // 'parent': '2',
+ // 'duration': 4,
+ // 'progress': 0,
+ // checked: false
+ // },
+
+ const newArr = []
+ // 杩欎竴姝ョ殑鎿嶄綔涓昏鏄鍋氫骇鑳借儗鏅殑鏄剧ず
+ rows.forEach((item, index) => {
+ // 鏁版嵁鎺ュ彛杩斿洖鐨勬椂闂磋寖鍥磋鍦ㄦ棩鏈熼�夋嫨鑼冨洿涔嬪唴
+ if (new Date(item.YearDate).getTime() >= new Date(this.ganttDateRange[0]).getTime() && new Date(item.YearDate).getTime() <= new Date(this.ganttDateRange[1]).getTime()) {
+ // console.log(JSON.stringify(item))
+ item.children.forEach((it, ind) => {
+ // console.log(JSON.stringify(it))
+ // 杩欓噷搴旇瑕佺敓鎴愪竴涓互璁惧缁村害涓哄熀纭�鐨勬暟缁� 涓嶉噸涓嶆紡
+ if (!this.allTasks.map(i => i.partCode).includes(it.AdvaDevicNumber)) {
+ newArr.push({
+ id: it.AdvaDevicNumber,
+ type: 'task',
+ text: '浠诲姟鍚嶇О棰勭暀',
+ partName: it.AdvaDevicName,
+ partCode: it.AdvaDevicNumber,
+ // start_date: item.YearDate + ' ' + it.OneStartDate.split('~')[0],
+ // duration: this.calculateTimeRangeInMinutes(it.OneStartDate),
+ render: 'split', // 鐢ㄤ簬鍦ㄤ竴涓伐浣滄椂闂存鍐呮樉绀轰笉涓嬶紝闇�瑕佽繘琛屽垎鍓叉樉绀�
+ checked: false,
+ progress: 0,
+ parent: 0,
+ saleOrder: 'SO-2026-01001'
+ })
+ // console.log(this.allTasks, 'allTasks')
+ }
+
+ // 鍥犱负鏄簲涓椂闂存锛屾墍鏈夎鏈変釜寰幆娆℃暟涓�5鐨勫惊鐜�
+ for (let i = 0; i < 5; i++) {
+ // console.log(item.YearDate + ' ' + it[this.fivePeriodsTimeName[i]].split('~')[0])
+ if (it[this.fivePeriodsTimeName[i]]) {
+ newArr.push({
+ id: index.toString() + ind.toString() + i.toString(),
+ type: 'task',
+ text: '浠诲姟鍚嶇О棰勭暀',
+ partName: it.AdvaDevicName,
+ partCode: it.AdvaDevicNumber,
+ start_date: item.YearDate + ' ' + it[this.fivePeriodsTimeName[i]].split('~')[0],
+ duration: this.calculateTimeRangeInMinutes(it[this.fivePeriodsTimeName[i]]),
+ checked: false,
+ progress: 0,
+ parent: it.AdvaDevicNumber,
+ saleOrder: 'SO-2026-01001'
+ })
+ }
+ }
+ })
+ }
+ })
+
// 浣跨敤鍘熸湁鐨勭ず渚嬫暟鎹綔涓哄熀纭�
- this.allTasks = [
+ this.allTasks = newArr
+
+ const dataBack = [
{
'id': 1,
- 'text': '椤圭洰1',
+ 'text': '宸ュ崟:MO-2025-05-001',
+ saleOrder: 'SO-2025-05001',
+ 'calendar_id': 'customCalendar1',
+ partName: '璺戞鏈�',
+ partCode: 'Run01',
+ description: '鎺掍骇鏁伴噺:500 鎶ュ伐鏁伴噺:100 杩涘害:20%',
'type': 'project',
'start_date': '2025-04-02 00:00',
// 'duration': 5,
- 'progress': 0.4,
- 'owner': [{ 'resource_id': '5', 'value': 3 }],
+ 'progress': 0.2,
'parent': 0,
- 'checked': false,
- render: 'split'
+ 'checked': false
+ // render: 'split'
},
{
'id': 2,
- 'text': '浠诲姟2',
- 'type': 'task',
+ 'text': '宸ュ簭:鍒囧壊',
+ saleOrder: 'SO-2025-05001',
+ 'calendar_id': 'customCalendar1',
+ partName: '璺戞鏈�',
+ partCode: 'Run01',
+ description: '鎺掍骇鏁伴噺:500 鎶ュ伐鏁伴噺:100 杩涘害:20%',
+ 'type': 'project',
'start_date': '2025-04-02 00:00',
'duration': 2,
- 'progress': 0.6,
- 'owner': [{ 'resource_id': '5', 'value': 4 }],
+ 'progress': 0.2,
'parent': '1',
checked: false
},
{
'id': 3,
- 'text': '浠诲姟3',
+ 'text': '璁惧:閲戝伐杞﹂棿1鍙疯澶�',
+ saleOrder: 'SO-2025-05001',
+ 'calendar_id': 'customCalendar1',
+ partName: '璺戞鏈�',
+ partCode: 'Run01',
+ description: '鎺掍骇鏁伴噺:500 鎶ュ伐鏁伴噺:100 杩涘害:20%',
'type': 'task',
'start_date': '2025-04-07 00:00',
- 'parent': '1',
- 'duration': 3,
- 'progress': 0.6,
- 'owner': [{ 'resource_id': '5', 'value': 2 }],
+ 'parent': '2',
+ 'duration': 4,
+ 'progress': 0,
checked: false
},
{
'id': 4,
- 'text': '浠诲姟4',
+ 'text': '璁惧:閲戝伐杞﹂棿2鍙疯澶�',
+ saleOrder: 'SO-2025-05001',
+ 'calendar_id': 'customCalendar1',
+ partName: '璺戞鏈�',
+ partCode: 'Run01',
+ description: '鎺掍骇鏁伴噺:500 鎶ュ伐鏁伴噺:100 杩涘害:20%',
'type': 'task',
'start_date': '2025-04-15 00:00',
- 'parent': '1',
+ 'parent': '2',
'duration': 3,
- 'progress': 0.2,
- 'owner': [{ 'resource_id': '5', 'value': 2 }],
+ 'progress': 0,
+ checked: false
+ },
+ {
+ 'id': 5,
+ 'text': '宸ュ崟:MO-2025-05-002',
+ saleOrder: 'SO-2025-05002',
+ 'calendar_id': 'customCalendar1',
+ partName: '璧版鏈�',
+ partCode: 'W01',
+ description: '鎺掍骇鏁伴噺:1000 鎶ュ伐鏁伴噺:500 杩涘害:50%',
+ 'type': 'project',
+ 'start_date': '2025-04-02 00:00',
+ // 'duration': 5,
+ 'progress': 0.5,
+ 'parent': 0,
+ 'checked': false
+ // render: 'split'
+ },
+ {
+ 'id': 6,
+ 'text': '宸ュ簭:鍒囧壊',
+ saleOrder: 'SO-2025-05002',
+ 'calendar_id': 'customCalendar1',
+ partName: '璧版鏈�',
+ partCode: 'W01',
+ description: '鎺掍骇鏁伴噺:1000 鎶ュ伐鏁伴噺:500 杩涘害:50%',
+ 'type': 'project',
+ 'start_date': '2025-04-02 00:00',
+ 'duration': 5,
+ 'progress': 0.5,
+ 'parent': '5',
+ checked: false
+ },
+ {
+ 'id': 7,
+ 'text': '璁惧:閲戝伐杞﹂棿3鍙疯澶�',
+ saleOrder: 'SO-2025-05002',
+ partName: '璧版鏈�',
+ 'calendar_id': 'customCalendar1',
+ partCode: 'W01',
+ description: '鎺掍骇鏁伴噺:1000 鎶ュ伐鏁伴噺:500 杩涘害:50%',
+ 'type': 'task',
+ 'start_date': '2025-04-07 06:23',
+ 'parent': '6',
+ 'duration': 3,
+ 'progress': 0,
+ checked: false
+ },
+ {
+ 'id': 8,
+ 'text': '璁惧:閲戝伐杞﹂棿4鍙疯澶�',
+ saleOrder: 'SO-2025-05002',
+ partName: '璧版鏈�',
+ partCode: 'W01',
+ 'calendar_id': 'customCalendar1',
+ description: '鎺掍骇鏁伴噺:1000 鎶ュ伐鏁伴噺:600 杩涘害:60%',
+ 'type': 'task',
+ render: 'split', // 鐢ㄤ簬鍦ㄤ竴涓伐浣滄椂闂存鍐呮樉绀轰笉涓嬶紝闇�瑕佽繘琛屽垎鍓叉樉绀�
+ 'start_date': '2025-04-12 00:00',
+ 'parent': '6',
+ 'duration': 4,
+ 'progress': 0,
+ checked: false
+ },
+
+ {
+ 'id': 11,
+ 'text': '璁惧:閲戝伐杞﹂棿4鍙疯澶�',
+ saleOrder: 'SO-2025-05002',
+ partName: '璧版鏈�',
+ partCode: 'W01',
+ 'calendar_id': 'customCalendar1',
+ description: '鎺掍骇鏁伴噺:1000 鎶ュ伐鏁伴噺:600 杩涘害:60%',
+ 'type': 'task',
+
+ 'start_date': '2025-04-14 00:00',
+ 'parent': '8',
+ 'duration': 3,
+ 'progress': 0,
+ checked: false
+ },
+
+ {
+ 'id': 12,
+ 'text': '璁惧:閲戝伐杞﹂棿4鍙疯澶�',
+ saleOrder: 'SO-2025-05002',
+ partName: '璧版鏈�',
+ partCode: 'W01',
+ 'calendar_id': 'customCalendar1',
+ description: '鎺掍骇鏁伴噺:1000 鎶ュ伐鏁伴噺:600 杩涘害:60%',
+ 'type': 'task',
+ 'start_date': '2025-04-18 00:00',
+ 'parent': '8',
+ 'duration': 1,
+ 'progress': 0,
+ checked: false
+ },
+
+ {
+ 'id': 13,
+ 'text': '璁惧:閲戝伐杞﹂棿4鍙疯澶�',
+ saleOrder: 'SO-2025-05002',
+ partName: '璧版鏈�',
+ partCode: 'W01',
+ 'calendar_id': 'customCalendar1',
+ description: '鎺掍骇鏁伴噺:1000 鎶ュ伐鏁伴噺:600 杩涘害:60%',
+ 'type': 'task',
+ 'start_date': '2025-04-10 02:50',
+ 'parent': '8',
+ 'duration': 2,
+ 'progress': 0,
+ checked: false
+ },
+ {
+ 'id': 10,
+ 'text': '璁惧:閲戝伐杞﹂棿4鍙疯澶�',
+ saleOrder: 'SO-2025-05002',
+ partName: '璧版鏈�',
+ partCode: 'W01',
+ 'calendar_id': 'customCalendar1',
+ description: '鎺掍骇鏁伴噺:1000 鎶ュ伐鏁伴噺:600 杩涘害:60%',
+ 'type': 'task3',
+ 'start_date': '2025-04-10 06:24',
+ 'parent': '8',
+ 'duration': 1,
+ 'progress': 0,
+ checked: false
+ },
+ {
+ 'id': 14,
+ 'text': '璁惧:閲戝伐杞﹂棿4鍙疯澶�',
+ saleOrder: 'SO-2025-05002',
+ partName: '璧版鏈�',
+ partCode: 'W01',
+ 'calendar_id': 'customCalendar1',
+ description: '鎺掍骇鏁伴噺:1000 鎶ュ伐鏁伴噺:600 杩涘害:60%',
+ 'type': 'task2',
+
+ 'start_date': '2025-04-11 06:24',
+ 'parent': '8',
+ 'duration': 1,
+ 'progress': 0,
+ checked: false
+ },
+
+ {
+ 'id': 9,
+ 'text': '璁惧:閲戝伐杞﹂棿5鍙疯澶�',
+ saleOrder: 'SO-2025-05002',
+ partName: '璧版鏈�',
+ partCode: 'W01',
+ 'calendar_id': 'customCalendar1',
+ description: '鎺掍骇鏁伴噺:1000 鎶ュ伐鏁伴噺:400 杩涘害:40%',
+ 'type': 'task',
+ 'start_date': '2025-04-10 00:00',
+ 'parent': '6',
+ 'duration': 3,
+ 'progress': 0,
checked: false
}
-
]
- // 娣诲姞鏇村绀轰緥鏁版嵁锛屼娇鍒嗛〉鏁堟灉鏇存槑鏄�
- // for (let i = 25; i <= 100; i++) {
- // this.allTasks.push({
- // 'id': i,
- // 'text': '浠诲姟' + i,
- // 'type': 'task',
- // // 'start_date': handleDatetime(`0${Math.floor(Math.random() * 9 + 1)}-04-2025 00:00`),
- // 'start_date': `0${Math.floor(Math.random() * 9 + 1)}-04-2025 00:00`,
- // 'duration': Math.floor(Math.random() * 5) + 1,
- // 'parent': Math.floor(Math.random() * 10) + 1,
- // 'progress': Math.random(),
- // 'owner': [{ 'resource_id': '5', 'value': 3 }],
- // 'priority': Math.floor(Math.random() * 3) + 1,
- // 'checked': false
- // })
- // }
this.totalTasks = this.allTasks.length
this.updatePaginatedTasks()
this.renderGanttChart()
@@ -563,6 +834,68 @@
const startIndex = (this.currentPage - 1) * this.pageSize
const endIndex = Math.min(startIndex + this.pageSize, this.allTasks.length)
this.paginatedTasks = this.allTasks.slice(startIndex, endIndex)
+ },
+
+ // 鎷嗗垎鏃堕棿瀛楃涓插苟鍒嗗埆璁$畻鍒嗛挓鍊�
+ calculateTimeRangeInMinutes(timeRangeStr) {
+ // 鍒嗗壊瀛楃涓诧紝鑾峰彇寮�濮嬫椂闂村拰缁撴潫鏃堕棿
+ const [startTimeStr, endTimeStr] = timeRangeStr.split('~')
+
+ // 灏嗘椂闂村瓧绗︿覆锛圚H:MM锛夎浆鎹负鎬诲垎閽熸暟
+ const timeStringToMinutes = (timeStr) => {
+ const [hours, minutes] = timeStr.split(':').map(Number)
+ return hours * 60 + (minutes || 0)
+ }
+
+ const startMinutes = timeStringToMinutes(startTimeStr)
+ const endMinutes = timeStringToMinutes(endTimeStr)
+
+ // 杩斿洖鏃堕棿宸紙鍒嗛挓锛�
+ return endMinutes - startMinutes
+ },
+
+ // 鍒诲害鍊兼敼鍙�
+ changeTimeScale(val, boolean) {
+ let scaleConfig
+ switch (this.scaleValue) {
+ case '30min':
+ scaleConfig = [
+ { unit: 'day', step: 1, format: '%Y-%m-%d 鏄熸湡%D' },
+ { unit: 'minute', step: 30, format: '%H:%i' } // 瀛愬昂搴�
+ ]
+ break
+ case '60min':
+ scaleConfig = [
+ { unit: 'day', step: 1, format: '%Y-%m-%d 鏄熸湡%D' },
+ // { unit: 'hour', step: 1, format: '%H:%i' },
+ { unit: 'minute', step: 60, format: '%H:%i' }
+ ]
+ break
+ case '240min':
+ scaleConfig = [
+ { unit: 'day', step: 1, format: '%Y-%m-%d 鏄熸湡%D' },
+ { unit: 'minute', step: 240, format: '%H:%i' } // 姣�4灏忔椂涓�涓埢搴�
+ ]
+ break
+ case '360min':
+ scaleConfig = [
+ { unit: 'day', step: 1, format: '%Y-%m-%d 鏄熸湡%D' },
+ { unit: 'minute', step: 360, format: '%H:%i' } // 姣�6灏忔椂涓�涓埢搴�
+ // { unit: 'hour', step: 6, format: '%H:%i' } // 姣�6灏忔椂涓�涓埢搴�
+ ]
+ break
+ default:
+ scaleConfig = [
+ { unit: 'hour', step: 1, format: '%Y-%m-%d 鏄熸湡%D' },
+ { unit: 'minute', step: 60, format: '%H:%i' }
+ ]
+ }
+ gantt.config.start_date = new Date(this.ganttDateRange[0] + ' 00:00')
+ gantt.config.end_date = new Date(this.ganttDateRange[1] + ' 24:00')
+ gantt.config.scales = scaleConfig
+ if (boolean) {
+ gantt.render()// gantt閲嶇粯
+ }
},
// 娓叉煋鐢樼壒鍥�
@@ -603,38 +936,23 @@
},
// 鐢樼壒鍥炬棩鏈熸敼鍙�
ganttDateRangeChange(val) {
- gantt.config.start_date = val[0]
- gantt.config.end_date = val[1]
+ gantt.config.start_date = new Date(val[0] + ' 00:00')
+ gantt.config.end_date = new Date(val[1] + ' 24:00')
gantt.render()
},
- // 鍥為��鎷栧姩鎿嶄綔
- ganttUndo() {
- gantt.undo()
- },
- // 鍓嶈繘鎷栧姩鎿嶄綔
- ganttRedo() {
- gantt.redo()
- },
- // 鏀惧ぇ
- ganttZoomIn() {
- gantt.ext.zoom.zoomIn()
- },
- // 缂╁皬
- ganttZoomOut() {
- gantt.ext.zoom.zoomOut()
- },
-
// 浠庣敇鐗瑰浘涓悓姝ラ�変腑鐨� id 鍒� Vue data
syncSelected() {
// 鍚屾褰撳墠椤甸潰浠诲姟鍒板叏灞�鏁版嵁
gantt.eachTask((task) => {
const globalTask = this.allTasks.find(t => t.id === task.id)
if (globalTask) {
+ // console.log(globalTask, 'globalTask')
globalTask.checked = task.checked
}
})
// 鑾峰彇鎵�鏈夐�変腑鐨勪换鍔D
+ // this.selectedIds = [...new Set(this.allTasks.filter(t => t.checked).map(t => t.id))]//鏁扮粍鍘婚噸
this.selectedIds = this.allTasks.filter(t => t.checked).map(t => t.id)
console.log(this.selectedIds)
},
@@ -642,7 +960,8 @@
// 鑾峰彇閫変腑浠诲姟锛堢ず渚嬶級
handleGetSelected() {
const selected = this.allTasks.filter(t => t.checked)
- this.$notify.success(`褰撳墠宸查�変腑${selected.length} 鏉′换鍔)
+ // this.$notify.success(`褰撳墠宸查�変腑${selected.length} 鏉′换鍔)
+ this.$notify.success(`鐐瑰嚮浜哷)
},
// 娓呯┖鎵�鏈夐�夋嫨
@@ -678,27 +997,38 @@
margin: unset;
}
-.gantt_task_cell {
- background: rgba(5, 185, 100, .1);
-}
+/*.gantt_task_cell {*/
+/* background: rgba(5, 185, 100, .1);*/
+/*}*/
-/*闈炲伐浣滄棩*/
-.weekend {
- background: rgba(255, 255, 255, 0.5);
-}
+/*!*闈炲伐浣滄棩*!*/
+/*.weekend {*/
+/* background: rgba(255, 255, 255, 0.1);*/
+/*}*/
+
+/*.row-completed {*/
+/* background-color: #bee4be !important; !* 娴呯豢鑹� *!*/
+/*}*/
+
+/*.gantt_grid_head_cell[data-column-id="duration"],*/
+/*.gantt_row .gantt_cell[data-column-name="duration"] {*/
+/* background-color: #f5f5f5 !important;*/
+/*}*/
/* 涓轰换鍔℃潯鍐呴儴鐨勮繘搴︽潯娣诲姞鍦嗚锛屼繚鎸佽瑙夌粺涓� */
-.gantt_task_progress {
- border-radius: 10px !important; /* 寤鸿涓庝换鍔℃潯鍗婂緞涓�鑷� */
-}
+/*.gantt_task_progress {*/
+/*border-radius: 10px !important; !* 寤鸿涓庝换鍔℃潯鍗婂緞涓�鑷� *!*/
+/*}*/
-.gantt_bar_task {
- border-radius: 10px !important;
-}
+/*.gantt_bar_task {*/
+/*border-radius: 10px !important;*/
+/*padding: 3px !important;*/
+/*transform: scaleX(-1) !important;*/
+/*}*/
-.gantt_bar_project {
- border-radius: 10px !important;
-}
+/*.gantt_bar_project {*/
+/*border-radius: 10px !important;*/
+/*}*/
.taskCheckBox {
cursor: pointer;
@@ -713,4 +1043,60 @@
background-color: #fff;
border-top: 1px solid #ebeef5;
}
+
+#taskRange {
+ width: 80px;
+ height: 6px;
+ border-radius: 2px;
+}
+
+/* 闅愯棌婊戝潡 */
+#taskRange::-webkit-slider-thumb {
+ opacity: 0;
+ -webkit-appearance: none !important;
+ width: 1px !important;
+ height: 1px !important;
+}
+
+#taskRange::-moz-range-thumb {
+ opacity: 0;
+ width: 1px !important;
+ height: 1px !important;
+}
+
+#taskRange::-ms-thumb {
+ opacity: 0;
+ width: 1px !important;
+ height: 1px !important;
+}
+
+.task2Css {
+ width: 100%;
+ height: 100%;
+ margin-left: 0;
+ background-color: #ac96ff;
+}
+
+.task3Css {
+ width: 100%;
+ height: 100%;
+ margin-left: 0;
+ background-color: rgb(255, 145, 0);
+}
+
+.gantt_scale_cell {
+ border: none !important;
+}
+
+.gantt_task_scale {
+ margin-left: -35px;
+}
+
+.gantt_scale_line:last-child {
+ width: 105%;
+}
+
+/*.gantt_task_bg:first-child > .gantt_task_row:first-child > .gantt_last_cell {*/
+/* border-top: 1px solid rgb(166, 166, 166);*/
+/*}*/
</style>
--
Gitblit v1.9.3