From 527250b10d6ecda0a8f3f9ea426dbe0bbc630a2c Mon Sep 17 00:00:00 2001
From: 小小儁爺 <1694218219@qq.com>
Date: 星期三, 21 一月 2026 08:57:15 +0800
Subject: [PATCH] 1.递交

---
 src/views/gantt/index.vue | 1097 +++++++++++++++++++++++++++++++++++++++------------------
 1 files changed, 752 insertions(+), 345 deletions(-)

diff --git a/src/views/gantt/index.vue b/src/views/gantt/index.vue
index 35fa237..7cf09d4 100644
--- a/src/views/gantt/index.vue
+++ b/src/views/gantt/index.vue
@@ -2,10 +2,33 @@
   <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-select
+        v-model="priorityMethod"
+        size="mini"
+        style="margin-left: 10px;"
+        placeholder="璇烽�夋嫨"
+        @change="prepareArrange"
+      >
+        <el-option
+          v-for="item in priorityMethodArr"
+          :key="item.code"
+          :label="item.name"
+          :value="item.code"
+        />
+      </el-select>
       <el-date-picker
         v-model="ganttDateRange"
         style="margin-left: 10px;"
@@ -24,6 +47,7 @@
       <el-button size="mini" @click="handleClearSelection">
         娓呯┖澶嶉�夋閫夋嫨
       </el-button>
+
     </div>
 
     <div id="gantt_here" style="width:100%; height:calc(90vh - 50px);" />
@@ -47,19 +71,34 @@
 import { gantt } from '@/components/dhtmlxGantt'
 import '@/components/dhtmlxGantt/codebase/dhtmlxgantt.css'
 import { handleDateReduceOneDay, handleDatetime, handleDatetime2 } from '@/utils/global'
+import { nanoid } from 'nanoid'
 
 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'], // 浜斾釜鏃堕棿娈电殑閿悕
+      needArrangeNumber: 5000, // 鍋囪闇�瑕佹帓浜ф暟閲�5000
+      priorityMethod: 'device', // device 璁惧   time  鏃堕棿
+      priorityMethodArr: [
+        { code: 'device', name: '璁惧浼樺厛' },
+        { code: 'time', name: '鏃堕棿浼樺厛' }
+      ]
     }
   },
   mounted() {
@@ -93,7 +132,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 +142,7 @@
 
       gantt.config.drag_progress = false // 绂佹閫氳繃鎷栧姩杩涘害鏉℃敼鍙樹换鍔¤繘搴�
 
-      // gantt.config.readonly = true  //鍙妯″紡
+      gantt.config.readonly = true // 鍙妯″紡
 
       /* 鈫撯啌鈫� Group configuration 鈫撯啌鈫� */
       gantt.serverList('task_priority', [
@@ -129,115 +169,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 +223,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,165 +247,17 @@
             // 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 鈫戔啈鈫� */
 
       // 姹夊寲绐楀彛
-      gantt.locale.labels = {
-        dhx_cal_today_button: '浠婂ぉ',
-        day_tab: '鏃�',
-        week_tab: '鍛�',
-        month_tab: '鏈�',
-        new_event: '鏂板缓鏃ョ▼',
-        icon_save: '淇濆瓨',
-        icon_cancel: '鍏抽棴',
-        icon_details: '璇︾粏',
-        icon_edit: '缂栬緫',
-        icon_delete: '鍒犻櫎',
-        confirm_closing: '璇风‘璁ゆ槸鍚︽挙閿�淇敼!', // Your changes will be lost, are your sure?
-        confirm_deleting: '鏄惁鍒犻櫎璁″垝?',
-        section_description: '鎻忚堪:',
-        section_resources: '鑷畾涔夐�夋嫨:',
-        section_calendar: '鑷畾涔夐�夋嫨2:',
-        section_time: '鏃堕棿鑼冨洿:',
-        section_type: '绫诲瀷:',
-        section_text: '璁″垝鍚嶇О:',
-        section_test: '娴嬭瘯:',
-        section_projectClass: '椤圭洰绫诲瀷:',
-        taskProjectType_0: '椤圭洰浠诲姟',
-        taskProjectType_1: '鏅�氫换鍔�',
-        section_head: '璐熻矗浜�:',
-        section_priority: '浼樺厛绾�:',
-        taskProgress: '浠诲姟鐘舵��',
-        taskProgress_0: '鏈紑濮�',
-        taskProgress_1: '杩涜涓�',
-        taskProgress_2: '宸插畬鎴�',
-        taskProgress_3: '宸插欢鏈�',
-        taskProgress_4: '鎼佺疆涓�',
-        section_template: 'Details',
-        /* grid columns */
-        column_text: '璁″垝鍚嶇О',
-        column_start_date: '寮�濮嬫椂闂�',
-        column_duration: '鎸佺画鏃堕棿',
-        column_add: '',
-        column_priority: '闅惧害',
-        /* link confirmation */
-        link: '鍏宠仈',
-        confirm_link_deleting: '灏嗚鍒犻櫎',
-        message_ok: '纭畾',
-        message_cancel: '鍙栨秷',
-        link_start: ' (寮�濮�)',
-        link_end: ' (缁撴潫)',
 
-        type_task: '浠诲姟',
-        type_project: '椤圭洰',
-        type_milestone: '閲岀▼纰�',
-        minutes: '鍒嗛挓',
-        hours: '灏忔椂',
-        days: '澶�',
-        weeks: '鍛�',
-        months: '鏈�',
-        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 +265,37 @@
       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> ' + task.producedCount +
+          '<br/><b>杩涘害:</b> ' + task.progress * 100 + '%' +
+          '<br/><b>寮�濮嬫椂闂�:</b> ' + handleDatetime2(start) +
+          '<br/><b>缁撴潫鏃堕棿:</b> ' + handleDatetime2(end)
       }
 
+      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">${task.producedCount}</div>`
+          // return task.producedCount
+        }
+        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,75 +331,463 @@
 
     // 鍔犺浇浠诲姟鏁版嵁
     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', // 绋煎姩鐜�    闇�瑕侀櫎100
+              'AdvaDevicRhythm': '5.0', // 鐢熶骇鑺傛媿
+              'OneStartDate': '08:00~11:30',
+              'TwoStartDate': '13:00~18:00',
+              'ThreeStartDate': '',
+              'FourStartDate': '',
+              'FiveStartDate': ''
+            }
+          ]
+        }
+      ]
+
+      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 (!newArr.map(i => i.partCode).includes(it.AdvaDevicNumber)) {
+              console.log(' it.AdvaDevicNumber,', it.AdvaDevicNumber)
+              newArr.push({
+                id: it.AdvaDevicNumber,
+                type: 'project',
+                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'
+              })
+            }
+
+            // 鍥犱负鏄簲涓椂闂存锛屾墍鏈夎鏈変釜寰幆娆℃暟涓�5鐨勫惊鐜�
+            for (let i = 0; i < 5; i++) { // 杩欐寰幆鏄负浜嗘樉绀轰骇鑳�
+              if (it[this.fivePeriodsTimeName[i]]) {
+                const duration = this.calculateTimeRangeInMinutes(it[this.fivePeriodsTimeName[i]]) // 宸ユ湡 鍗曚綅 鍒嗛挓
+                newArr.push({
+                  // id:  index.toString() + ind.toString() + i.toString(),
+                  id: nanoid(),
+                  type: 'task',
+                  text: '浠诲姟鍚嶇О棰勭暀',
+                  partName: it.AdvaDevicName,
+                  partCode: it.AdvaDevicNumber,
+                  start_date: handleDatetime2(item.YearDate + ' ' + it[this.fivePeriodsTimeName[i]].split('~')[0]),
+                  duration,
+                  checked: false,
+                  progress: 0,
+                  parent: it.AdvaDevicNumber,
+                  saleOrder: 'SO-2026-01001',
+                  //  瑕佸湪姣忎竴涓椂闂存鍐呯畻鍑鸿兘鐢熶骇澶氬皯涓�     宸ユ湡锛堝垎閽燂級涔樹互60 闄や互鐢熶骇鑺傛媿 * 绋煎姩鐜�
+                  producedCount: (duration * 60 / it.AdvaDevicRhythm) * (it.AdvaDevicCropMob / 100),
+                  AdvaDevicRhythm: it.AdvaDevicRhythm, // 鐢熶骇鑺傛媿
+                  AdvaDevicCropMob: it.AdvaDevicCropMob // 绋煎姩鐜�    闇�瑕侀櫎100
+                })
+              }
+            }
+          })
+        }
+      })
+
       // 浣跨敤鍘熸湁鐨勭ず渚嬫暟鎹綔涓哄熀纭�
-      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()
+      // this.totalTasks = this.allTasks.length
+      // this.updatePaginatedTasks()
+      // this.renderGanttChart()
+
+      this.prepareArrange()
     },
 
     // 鏇存柊鍒嗛〉鍚庣殑浠诲姟鏁版嵁
@@ -563,6 +795,69 @@
       const startIndex = (this.currentPage - 1) * this.pageSize
       const endIndex = Math.min(startIndex + this.pageSize, this.allTasks.length)
       this.paginatedTasks = this.allTasks.slice(startIndex, endIndex)
+      // this.paginatedTasks = JSON.parse(JSON.stringify(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閲嶇粯
+      }
     },
 
     // 娓叉煋鐢樼壒鍥�
@@ -578,6 +873,7 @@
 
     // 椤靛ぇ灏忔敼鍙�
     handleSizeChange(newSize) {
+      console.log('鎵ц2')
       this.pageSize = newSize
       this.currentPage = 1 // 閲嶇疆鍒扮涓�椤�
       this.updatePaginatedTasks()
@@ -587,6 +883,7 @@
 
     // 褰撳墠椤垫敼鍙�
     handleCurrentChange(newPage) {
+      console.log('鎵ц1')
       // 璁$畻鏈�澶ч〉鏁帮紝闃叉瓒呭嚭鑼冨洿
       const maxPage = Math.ceil(this.totalTasks / this.pageSize)
       if (newPage > maxPage) {
@@ -603,38 +900,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 +924,8 @@
     // 鑾峰彇閫変腑浠诲姟锛堢ず渚嬶級
     handleGetSelected() {
       const selected = this.allTasks.filter(t => t.checked)
-      this.$notify.success(`褰撳墠宸查�変腑${selected.length} 鏉′换鍔)
+      // this.$notify.success(`褰撳墠宸查�変腑${selected.length} 鏉′换鍔)
+      this.$notify.success(`鐐瑰嚮浜哷)
     },
 
     // 娓呯┖鎵�鏈夐�夋嫨
@@ -663,6 +946,63 @@
 
       // 鏄剧ず鎻愮ず淇℃伅
       this.$notify.success('宸叉竻绌烘墍鏈夐�夋嫨')
+    },
+    // 棰勬帓
+    prepareArrange() {
+      this.allTasks = this.allTasks.filter(i => i.type !== 'task2')
+      // 浼樺厛鏂瑰紡  time  device
+      if (this.priorityMethod === 'time') {
+        this.allTasks.sort((a, b) => a.start_date - b.start_date)
+      }
+      if (this.priorityMethod === 'device') {
+        this.allTasks.sort((a, b) => Number(a.partCode.replace(/\D/g, '')) - Number(b.partCode.replace(/\D/g, '')))
+        // this.allTasks.sort((a, b) => Number(b.partCode.replace(/\D/g, '')) - Number(a.partCode.replace(/\D/g, '')))
+        // this.allTasks.sort((a, b) => a.producedCount - b.producedCount)
+      }
+
+      const newArr = []
+      let needArrangeNumber = this.needArrangeNumber
+      this.allTasks.forEach(item => {
+        if (item.type === 'task') {
+          console.log(JSON.parse(JSON.stringify(item)))
+          const count = needArrangeNumber > 0 && needArrangeNumber <= item.producedCount ? needArrangeNumber : item.producedCount
+          needArrangeNumber = needArrangeNumber - item.producedCount // 鍓╀綑寰呮帓鍊�
+          if (count > 0 && (needArrangeNumber > 0 || Math.abs(needArrangeNumber) < item.producedCount)) { // 涓�瀹氭槸澶т簬闆朵笖灏忎簬鏁存潯鐨勭敓浜у�肩殑
+            // duration  鏈�鍚庝竴鏉$殑鏁版嵁搴旇鏄�氳繃璁$畻寰楀嚭鏃堕棿闀垮害鐨�
+            const duration = (count / (item.AdvaDevicCropMob / 100)) * item.AdvaDevicRhythm / 60
+            newArr.push({
+              id: nanoid(),
+              type: 'task2',
+              text: '浠诲姟鍚嶇О111',
+              partName: item.partName,
+              partCode: item.partCode,
+              start_date: handleDatetime2(item.start_date),
+              // duration: item.duration,
+              duration: duration,
+              checked: false,
+              progress: 0,
+              parent: item.parent,
+              saleOrder: item.saleOrder,
+              producedCount: count <= item.producedCount ? count : item.producedCount
+            })
+          }
+        }
+      })
+
+      console.log(JSON.parse(JSON.stringify(newArr)), 'newArr')
+
+      // for (let i = 0; i < this.allTasks.length; i++) {
+      //
+      // }
+
+      this.allTasks = [...this.allTasks, ...newArr]
+      // console.log(JSON.parse(JSON.stringify(this.allTasks)), '77')
+
+      console.log(JSON.parse(JSON.stringify(this.allTasks)), '888')
+
+      this.totalTasks = this.allTasks.length
+      this.updatePaginatedTasks()
+      this.renderGanttChart()
     }
 
   }
@@ -678,27 +1018,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 +1064,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