| ¶Ô±ÈÐÂÎļþ |
| | |
| | | <template> |
| | | <div style="padding: 0 10px"> |
| | | |
| | | <div style="padding: 10px 0;display: flex;"> |
| | | <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="priorityMethodChange" |
| | | > |
| | | <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;" |
| | | size="mini" |
| | | value-format="yyyy-MM-dd" |
| | | type="daterange" |
| | | :clearable="false" |
| | | :picker-options="pickerOptions" |
| | | range-separator="è³" |
| | | start-placeholder="å¼å§æ¥æ" |
| | | end-placeholder="ç»ææ¥æ" |
| | | @change="ganttDateRangeChange" |
| | | /> |
| | | <el-button type="primary" style="margin-left: 10px;" size="mini" @click="handleGetSelected"> |
| | | è·åå¤éæ¡éä¸ä»»å¡ |
| | | </el-button> |
| | | <el-button size="mini" @click="handleClearSelection"> |
| | | æ¸
空å¤éæ¡éæ© |
| | | </el-button> |
| | | |
| | | <el-button size="mini" type="primary" @click="prepareArrange"> |
| | | 颿 |
| | | </el-button> |
| | | <el-button size="mini" disabled> |
| | | 颿è¿åº¦ï¼{{ canArrangeNumber }}/{{ needArrangeNumber }} |
| | | </el-button> |
| | | |
| | | </div> |
| | | |
| | | <div id="gantt_here" style="width:100%; height:calc(90vh - 50px);" /> |
| | | |
| | | <!-- å页ç»ä»¶ --> |
| | | <div class="pagination-container"> |
| | | <el-pagination |
| | | :current-page="currentPage" |
| | | :page-sizes="[10, 20, 50, 100]" |
| | | :page-size="pageSize" |
| | | layout="total, sizes, prev, pager, next, jumper" |
| | | :total="totalTasks" |
| | | @size-change="handleSizeChange" |
| | | @current-change="handleCurrentChange" |
| | | /> |
| | | </div> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | 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 { |
| | | scaleArr: [ |
| | | { code: '30min', name: '30min' }, |
| | | { code: '60min', name: '60min' }, |
| | | { code: '240min', name: '240min' }, |
| | | { code: '360min', name: '360min' } |
| | | ], |
| | | scaleValue: '240min', |
| | | ganttDateRange: ['2026-01-22', '2026-01-25'], // '2026-01-20', '2026-01-25' |
| | | selectedIds: [], |
| | | // å页ç¸å
³æ°æ® |
| | | currentPage: 1, |
| | | pageSize: 100, |
| | | totalTasks: 0, |
| | | allTasks: [], // å卿æä»»å¡æ°æ® |
| | | paginatedTasks: [], // å½å页ç任塿°æ® |
| | | |
| | | fivePeriodsTimeName: ['OneStartDate', 'TwoStartDate', 'ThreeStartDate', 'FourStartDate', 'FiveStartDate'], // äºä¸ªæ¶é´æ®µçé®å |
| | | needArrangeNumber: 5000, // å设éè¦æäº§æ°é5000 |
| | | canArrangeNumber: 0, // è½ææ°éé»è®¤ä¸º 0 |
| | | priorityMethod: 'device', // device è®¾å¤ time æ¶é´ |
| | | priorityMethodArr: [ |
| | | { code: 'device', name: '设å¤ä¼å
' }, |
| | | { code: 'time', name: 'æ¶é´ä¼å
' } |
| | | ], |
| | | pickerOptions: { |
| | | disabledDate(time) { |
| | | return time.getTime() <= Date.now() - 24 * 60 * 60 * 1000 |
| | | } |
| | | } |
| | | } |
| | | }, |
| | | mounted() { |
| | | // åå§åçç¹å¾é
ç½® |
| | | this.initGantt() |
| | | |
| | | // æ¹åæ¥æèå´é
ç½® |
| | | this.ganttDateRangeChange(this.ganttDateRange) |
| | | |
| | | // ç¶åå è½½ä»»å¡æ°æ®ï¼ä¼èªå¨æ¸²æå½åé¡µï¼ |
| | | // this.loadTasks() |
| | | }, |
| | | methods: { |
| | | |
| | | initGantt() { |
| | | gantt.plugins({ |
| | | critical_path: true, |
| | | drag_timeline: true, |
| | | grouping: true, |
| | | keyboard_navigation: true, |
| | | marker: true, |
| | | multiselect: true, |
| | | tooltip: true, |
| | | undo: true |
| | | }) |
| | | gantt.i18n.setLocale('cn') |
| | | gantt.config.multiselect = true // å¼å¯å¤ä»»å¡éæ© |
| | | gantt.config.show_links = false // 䏿¾ç¤ºè¿æ¥çº¿ |
| | | |
| | | // ä¸å坹齿¶é´è½´å»åº¦ï¼æ¯å¦å¤©æ ¼åï¼ï¼èæ¯æâå°æ¶âå¯¹é½ |
| | | gantt.config.round_dnd_dates = false |
| | | // æå°æ¥é¿è¿æ¯ 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é« |
| | | gantt.config.xml_date = '%Y-%m-%d %H:%i' // ganttçæ¥ææ ¼å¼ |
| | | gantt.config.drag_progress = false // ç¦æ¢éè¿æå¨è¿åº¦æ¡æ¹åä»»å¡è¿åº¦ |
| | | gantt.config.readonly = true // åªè¯»æ¨¡å¼ |
| | | |
| | | // å»åº¦å¼æ¹å |
| | | 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.addCalendar({ |
| | | // id: 'customCalendar1', |
| | | // worktime: { |
| | | // hours: ['00:00-24:00'], // global work hours for weekdays |
| | | // days: [1, 1, 1, 1, 1, 1, 1] |
| | | // } |
| | | // }) |
| | | |
| | | // gantt.addCalendar({ |
| | | // id: 'custom2', |
| | | // hours: ['12:00-21:00'], |
| | | // days: [1, 0, 1, 0, 1, 0, 1] |
| | | // }) |
| | | /* âââ Working Time configuration âââ */ |
| | | |
| | | // çç¹å¾ååæ°è®¾ç½® |
| | | /* âââ Grid Columns configuration âââ */ |
| | | gantt.config.reorder_grid_columns = true |
| | | const textEditor = { type: 'text', map_to: 'text' } |
| | | const startDateEditor = { type: 'date', map_to: 'start_date' } |
| | | const durationEditor = { type: 'number', map_to: 'duration', min: 1, max: 100 } |
| | | gantt.config.columns = [ |
| | | { |
| | | name: 'checked', |
| | | label: 'éæ©', |
| | | align: 'center', |
| | | width: 35, |
| | | resize: false, |
| | | // å
³é®ï¼ç¨ template è¿åä¸ä¸ªå¤éæ¡ |
| | | template: (task) => { |
| | | const checked = task.checked ? 'checked' : '' |
| | | // data-action ç¨äºå¨äºä»¶å§ææ¶è¯å«æ¯å¤éæ¡ |
| | | return `<input type="checkbox" class="taskCheckBox" data-action="check-row" ${checked} />` |
| | | } |
| | | }, |
| | | // { 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: 'æ¶é¿(åé)', |
| | | resize: true, |
| | | editor: durationEditor, |
| | | template: function(task) { |
| | | // 妿durationæ¯nullæundefinedï¼è¿å0 |
| | | // return (task.duration || 0) + 1 // å¨å½ådurationçåºç¡ä¸å 1 |
| | | return task.duration |
| | | } |
| | | } |
| | | // { name: 'add', width: 44 } |
| | | ] |
| | | /* âââ Grid Columns configuration âââ */ |
| | | |
| | | gantt.config.show_errors = false // åçå¼å¸¸æ¶ï¼ä¸å
许弹åºè¦åå° UI çé¢ |
| | | gantt.config.grid_elastic_columns = true |
| | | |
| | | // èªå®ä¹æµ®å¨æ¡çæ¾ç¤ºå
容 tooltipæµ®å¨æ¡æ¾ç¤ºçEnd Date被追å 1çé®é¢ä¿®å¤ï¼åºè¯¥æ¾ç¤ºæ°æ®åºçåå§å¼ï¼ |
| | | gantt.templates.tooltip_text = function(start, end, 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>' + `${task.type === 'task' ? '产è½' : 'ç产æ°é'}` + ' :</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">${task.producedCount}</div>` |
| | | } |
| | | 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被è°ç¨ |
| | | |
| | | // ç»å®çç¹å¾ç¹å»äºä»¶ï¼å®æ¹æ¨èçäºä»¶å§æç¨æ³ï¼ |
| | | gantt.attachEvent('onTaskClick', (id, e) => { |
| | | // æ¾å°ç¹å»çæ¯å¦æ¯å¤éæ¡ |
| | | const checkbox = e.target.closest('[data-action="check-row"]') |
| | | if (!checkbox) { |
| | | // 䏿¯ç¹å¤éæ¡ï¼å°±ä¿æé»è®¤è¡ä¸º |
| | | return true |
| | | } |
| | | |
| | | // æ¯å¤éæ¡ï¼åæ¢éä¸ç¶æ |
| | | const task = gantt.getTask(id) |
| | | if (task) { |
| | | task.checked = !task.checked |
| | | // åæ¶æ´æ°å
¨å±æ°æ® |
| | | const globalTask = this.allTasks.find(t => t.id === id) |
| | | if (globalTask) { |
| | | globalTask.checked = task.checked |
| | | } |
| | | gantt.updateTask(id) // åªå·æ°è¿ä¸è¡ï¼æ§è½æ´å¥½ |
| | | this.syncSelected() // åæ¥å° Vue ç selectedIds |
| | | } |
| | | |
| | | // 黿¢é»è®¤ç¹å»è¡è¡ä¸ºï¼é¿å
误触åå
¶ä»é»è¾ï¼ |
| | | return false |
| | | }) |
| | | |
| | | // åå§å宿å忥䏿¬¡éä¸ç¶æ |
| | | this.syncSelected() |
| | | |
| | | // this.loadTasks() |
| | | }, |
| | | |
| | | // å è½½ä»»å¡æ°æ® |
| | | 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 Cont = [ |
| | | { |
| | | 'wo_code': 'MO-2023-06-0007_1', |
| | | 'eqp_code': 'JG010', |
| | | 'time_start': '2026-01-21 13:51:55', |
| | | 'time_end': '2026-01-21 18:00:00', |
| | | 'status': 'S', |
| | | 'alloc_qty': 298.00, |
| | | 'part_code': '302', |
| | | 'part_name': '8504å
æº', |
| | | 'uom_name': 'åª' |
| | | }, |
| | | { |
| | | 'wo_code': 'MO-2023-06-0007_1', |
| | | 'eqp_code': 'JG010', |
| | | 'time_start': '2026-01-22 08:00:00', |
| | | 'time_end': '2026-01-22 11:30:00', |
| | | 'status': 'S', |
| | | 'alloc_qty': 252.00, |
| | | 'part_code': '302', |
| | | 'part_name': '8504å
æº', |
| | | 'uom_name': 'åª' |
| | | }, |
| | | { |
| | | 'wo_code': 'MO-2023-06-0007_1', |
| | | 'eqp_code': 'JG010', |
| | | 'time_start': '2026-01-22 13:00:00', |
| | | 'time_end': '2026-01-22 18:00:00', |
| | | 'status': 'S', |
| | | 'alloc_qty': 360, |
| | | 'part_code': '302', |
| | | 'part_name': '8504å
æº', |
| | | 'uom_name': 'åª' |
| | | }, |
| | | { |
| | | 'wo_code': 'MO-2023-06-0007_1', |
| | | 'eqp_code': 'JG010', |
| | | 'time_start': '2026-01-23 08:00:00', |
| | | 'time_end': '2026-01-23 11:30:00', |
| | | 'status': 'S', |
| | | 'alloc_qty': 252.00, |
| | | 'part_code': '302', |
| | | 'part_name': '8504å
æº', |
| | | 'uom_name': 'åª' |
| | | }, |
| | | { |
| | | 'wo_code': 'MO-2023-06-0007_1', |
| | | 'eqp_code': 'JG010', |
| | | 'time_start': '2026-01-23 13:00:00', |
| | | 'time_end': '2026-01-23 15:00:00', |
| | | 'status': 'S', |
| | | 'alloc_qty': 144.00, |
| | | 'part_code': '302', |
| | | 'part_name': '8504å
æº', |
| | | 'uom_name': 'åª' |
| | | } |
| | | // { |
| | | // 'wo_code': 'MO-2023-06-0007_1', |
| | | // 'eqp_code': 'JG010', |
| | | // 'time_start': '2026-01-24 08:00:00', |
| | | // 'time_end': '2026-01-24 11:30:00', |
| | | // 'status': 'S', |
| | | // 'alloc_qty': 252.00, |
| | | // 'part_code': '302', |
| | | // 'part_name': '8504å
æº', |
| | | // 'uom_name': 'åª' |
| | | // }, |
| | | // { |
| | | // 'wo_code': 'MO-2023-06-0007_1', |
| | | // 'eqp_code': 'JG010', |
| | | // 'time_start': '2026-01-24 13:00:00', |
| | | // 'time_end': '2026-01-24 18:00:00', |
| | | // 'status': 'S', |
| | | // 'alloc_qty': 360.00, |
| | | // 'part_code': '302', |
| | | // 'part_name': '8504å
æº', |
| | | // 'uom_name': 'åª' |
| | | // }, |
| | | // { |
| | | // 'wo_code': 'MO-2023-06-0007_1', |
| | | // 'eqp_code': 'JG010', |
| | | // 'time_start': '2026-01-25 08:00:00', |
| | | // 'time_end': '2026-01-25 11:30:00', |
| | | // 'status': 'S', |
| | | // 'alloc_qty': 252.00, |
| | | // 'part_code': '302', |
| | | // 'part_name': '8504å
æº', |
| | | // 'uom_name': 'åª' |
| | | // }, |
| | | // { |
| | | // 'wo_code': 'MO-2023-06-0007_1', |
| | | // 'eqp_code': 'JG010', |
| | | // 'time_start': '2026-01-25 13:00:00', |
| | | // 'time_end': '2026-01-25 18:00:00', |
| | | // 'status': 'S', |
| | | // 'alloc_qty': 360.00, |
| | | // 'part_code': '302', |
| | | // 'part_name': '8504å
æº', |
| | | // 'uom_name': 'åª' |
| | | // } |
| | | ] |
| | | |
| | | 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()) { |
| | | item.children.forEach((it, ind) => { |
| | | // è¿éåºè¯¥è¦çæä¸ä¸ªä»¥è®¾å¤ç»´åº¦ä¸ºåºç¡çæ°ç» ä¸é䏿¼ |
| | | 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: handleDatetime2(item.YearDate + ' ' + it.OneStartDate.split('~')[0]), // è¿ä¸ªæ¯æ æçï¼åªæ¯ä¸ºäºé¢æprepareArrangeæ¹æ³éé¢ä¸æ¥é |
| | | end_date: handleDatetime2(item.YearDate + ' ' + it.OneStartDate.split('~')[1]), // è¿ä¸ªæ¯æ æçï¼åªæ¯ä¸ºäºé¢æprepareArrangeæ¹æ³éé¢ä¸æ¥é |
| | | // 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]), |
| | | // start_date: new Date(handleDatetime2(item.YearDate + ' ' + it[this.fivePeriodsTimeName[i]].split('~')[0])).getTime() < new Date().getTime() ? handleDatetime2(new Date()) : handleDatetime2(item.YearDate + ' ' + it[this.fivePeriodsTimeName[i]].split('~')[0]), |
| | | // end_date: new Date(handleDatetime2(item.YearDate + ' ' + it[this.fivePeriodsTimeName[i]].split('~')[1])).getTime() < new Date().getTime() ? handleDatetime2(new Date()) : handleDatetime2(item.YearDate + ' ' + it[this.fivePeriodsTimeName[i]].split('~')[1]), |
| | | end_date: handleDatetime2(item.YearDate + ' ' + it[this.fivePeriodsTimeName[i]].split('~')[1]), |
| | | 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 |
| | | }) |
| | | } |
| | | } |
| | | }) |
| | | } |
| | | }) |
| | | |
| | | // è¿ä¸æ¥çæä½æ¯åå·²æçæ¾ç¤º |
| | | const scheduledDevices = [...new Set(Cont.map(i => i.eqp_code))]// è¿æ¯å·²æç设å¤ç¼ç |
| | | Cont.forEach(item => { |
| | | if (scheduledDevices.includes(item.eqp_code)) { |
| | | newArr.push({ |
| | | id: nanoid(), |
| | | type: 'task3', |
| | | text: 'ä»»å¡åç§°é¢ç', |
| | | partName: item.part_name, |
| | | partCode: item.part_code, |
| | | start_date: item.time_start, |
| | | end_date: item.time_end, |
| | | // duration: this.calculateTimeRangeInMinutes(it.OneStartDate), |
| | | duration: this.calculateTimeRangeInMinutes(item.time_start.split(' ')[1] + '~' + item.time_end.split(' ')[1]), |
| | | checked: false, |
| | | progress: 0, |
| | | parent: item.eqp_code, |
| | | saleOrder: 'SO-2026-01001', |
| | | producedCount: item.alloc_qty |
| | | }) |
| | | } |
| | | }) |
| | | |
| | | // task ä»£è¡¨çæ¯äº§è½ task2 ä»£è¡¨çæ¯å¯ä»¥æäº§çå¼ task3 ä»£è¡¨çæ¯å·²æäº§çå¼ |
| | | // task2 çå¼å¾ä» taskåå»task3çæ¶é´ ä»£è¡¨å¯æäº§æ¶é´ |
| | | // è¥åä¸ç¶èç¹çå¼ç¸åæ¶,å½taskçå¼å§æ¶é´åç»ææ¶é´ä¸task3ç¸çæ¶,ä»£è¡¨æ¤æ®µä¸è½åæäº§ |
| | | // å½taskçå¼å§æ¶é´çäºtask3çå¼å§æ¶é´,ä½taskçç»ææ¶é´å¤§äºtask3çç»ææ¶é´æ¶ï¼è¿æ¶åï¼å¯æäº§æ¶é´ä¸ºï¼task3çç»ææ¶é´å°taskçç»ææ¶é´ |
| | | const task = newArr.filter(item => item.type === 'task') |
| | | const task3 = newArr.filter(item => item.type === 'task3') |
| | | task.forEach(item => { // æ»äº§è½ |
| | | task3.forEach(it => { // å·²ææ°æ® |
| | | if (item.parent === it.parent) { // è¯´ææ¯å¨åä¸ä¸ªè®¾å¤ä¸ |
| | | // å½ä¸¤ä¸ªæ¶é´ç¸çæ¶è¯´æè¯å®ä¸è½æäº§äº |
| | | if (new Date(item.start_date).getTime() === new Date(it.start_date).getTime() && new Date(item.end_date).getTime() === new Date(it.end_date).getTime()) { |
| | | item.schedulingPossible = false |
| | | } |
| | | |
| | | if (new Date(item.start_date).getTime() === new Date(it.start_date).getTime() && new Date(item.end_date).getTime() > new Date(it.end_date).getTime()) { |
| | | item.start_date2 = it.end_date |
| | | } |
| | | |
| | | // ä¸ç¥éè¦ä¸è¦æ³¨éæ å¾
éªè¯ |
| | | // if (new Date(item.start_date).getTime() < new Date().getTime() && item.producedCount !== it.producedCount) { |
| | | // item.start_date2 = handleDatetime2(new Date()) |
| | | // } |
| | | } |
| | | }) |
| | | }) |
| | | |
| | | // 使ç¨åæçç¤ºä¾æ°æ®ä½ä¸ºåºç¡ |
| | | this.allTasks = newArr.filter(i => i.schedulingPossible !== false) |
| | | // this.allTasks = newArr |
| | | |
| | | this.totalTasks = this.allTasks.length |
| | | this.updatePaginatedTasks() |
| | | this.renderGanttChart() |
| | | |
| | | // this.prepareArrange() |
| | | }, |
| | | |
| | | // æ´æ°å页åç任塿°æ® |
| | | updatePaginatedTasks() { |
| | | 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('~') |
| | | |
| | | // å°æ¶é´å符串ï¼HH: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éç» |
| | | this.renderGanttChart() |
| | | } |
| | | }, |
| | | |
| | | // 渲æçç¹å¾ |
| | | renderGanttChart() { |
| | | gantt.clearAll() |
| | | console.log(JSON.parse(JSON.stringify(this.paginatedTasks))) |
| | | gantt.parse({ |
| | | 'data': this.paginatedTasks |
| | | }) |
| | | // ç¡®ä¿çç¹å¾éæ°æ¸²æ |
| | | // gantt.render() |
| | | }, |
| | | |
| | | // 页大尿¹å |
| | | handleSizeChange(newSize) { |
| | | console.log('æ§è¡2') |
| | | this.pageSize = newSize |
| | | this.currentPage = 1 // éç½®å°ç¬¬ä¸é¡µ |
| | | this.updatePaginatedTasks() |
| | | this.renderGanttChart() |
| | | this.syncSelected() |
| | | }, |
| | | |
| | | // å½å页æ¹å |
| | | handleCurrentChange(newPage) { |
| | | console.log('æ§è¡1') |
| | | // è®¡ç®æå¤§é¡µæ°ï¼é²æ¢è¶
åºèå´ |
| | | const maxPage = Math.ceil(this.totalTasks / this.pageSize) |
| | | if (newPage > maxPage) { |
| | | this.currentPage = maxPage |
| | | } else if (newPage < 1) { |
| | | this.currentPage = 1 |
| | | } else { |
| | | this.currentPage = newPage |
| | | } |
| | | |
| | | this.updatePaginatedTasks() |
| | | this.renderGanttChart() |
| | | this.syncSelected() |
| | | }, |
| | | // çç¹å¾æ¥ææ¹å |
| | | ganttDateRangeChange(val) { |
| | | this.priorityMethodChange()// æ¸
空已æå¼ |
| | | gantt.config.start_date = new Date(val[0] + ' 00:00') |
| | | gantt.config.end_date = new Date(val[1] + ' 24:00') |
| | | |
| | | this.loadTasks() |
| | | |
| | | // gantt.render() |
| | | }, |
| | | // ä»çç¹å¾ä¸åæ¥éä¸ç id å° Vue data |
| | | syncSelected() { |
| | | // 忥å½å页é¢ä»»å¡å°å
¨å±æ°æ® |
| | | gantt.eachTask((task) => { |
| | | const globalTask = this.allTasks.find(t => t.id === task.id) |
| | | if (globalTask) { |
| | | globalTask.checked = task.checked |
| | | } |
| | | }) |
| | | |
| | | // è·åææéä¸çä»»å¡ID |
| | | // 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) |
| | | }, |
| | | |
| | | // è·åéä¸ä»»å¡ï¼ç¤ºä¾ï¼ |
| | | handleGetSelected() { |
| | | const selected = this.allTasks.filter(t => t.checked) |
| | | // this.$notify.success(`å½åå·²éä¸${selected.length} æ¡ä»»å¡`) |
| | | this.$notify.success(`ç¹å»äº`) |
| | | }, |
| | | |
| | | // æ¸
空ææéæ© |
| | | handleClearSelection() { |
| | | // éåææä»»å¡ï¼å° checked 屿§è®¾ç½®ä¸º false |
| | | this.allTasks.forEach(task => { |
| | | task.checked = false |
| | | }) |
| | | |
| | | // æ´æ°å½å页颿¾ç¤ºçä»»å¡ |
| | | gantt.eachTask((task) => { |
| | | task.checked = false |
| | | gantt.updateTask(task.id) |
| | | }) |
| | | |
| | | // åæ¥å° Vue ç»ä»¶æ°æ® |
| | | this.syncSelected() |
| | | |
| | | // æ¾ç¤ºæç¤ºä¿¡æ¯ |
| | | this.$notify.success('å·²æ¸
空ææéæ©') |
| | | }, |
| | | // 颿 |
| | | prepareArrange() { |
| | | this.priorityMethodChange() |
| | | |
| | | this.loadTasks() |
| | | |
| | | // ä¼å
æ¹å¼ 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) => parseFloat(a.AdvaDevicCropMob) - parseFloat(b.AdvaDevicCropMob)) |
| | | } |
| | | |
| | | // å¨è¿ä¸ªå¾ªç¯éé¢è¿å¾èèä¸ä¸ªç¹ï¼å¨å·²æçæ°æ®ä¸ä¸è½åæäº |
| | | // ç¸å½äºå¨task åtask3ä¸ è¦å¨taskéé¢å餿task3çæ¶é´æ®µ |
| | | const newArr = [] |
| | | // this.canArrangeNumber = 0 |
| | | let needArrangeNumber = this.needArrangeNumber |
| | | this.allTasks.forEach(item => { |
| | | // if (item.type === 'task') { // è¿éç夿æ¡ä»¶è¿å¾å ä¸ªæ¥æå¤æ |
| | | if (item.type === 'task' && |
| | | new Date(item.start_date).getTime() >= new Date(this.ganttDateRange[0] + ' 00:00:00').getTime() && |
| | | new Date(item.end_date).getTime() >= new Date().getTime()) { // è¿éç夿æ¡ä»¶è¿å¾å ä¸ªæ¥æå¤æ ç»ææ¶é´è¦å¤§äºç®åæ¶é´ |
| | | let ratio = 1 // é»è®¤ç³»æ° 1 |
| | | |
| | | if (item.start_date2) { |
| | | const d = this.calculateTimeRangeInMinutes(item.start_date2.split(' ')[1] + '~' + handleDatetime2(item.end_date).split(' ')[1]) |
| | | ratio = Math.round((d / item.duration) * 100) / 100 |
| | | } |
| | | |
| | | if ( |
| | | new Date(item.start_date).getTime() < new Date().getTime() && |
| | | new Date(item.end_date).getTime() >= new Date().getTime() |
| | | ) { |
| | | const d = this.calculateTimeRangeInMinutes(handleDatetime2(new Date()).split(' ')[1] + '~' + handleDatetime2(item.end_date).split(' ')[1]) |
| | | ratio = Math.round((d / item.duration) * 100) / 100 |
| | | } |
| | | |
| | | // è¿ä¸ªå°æ¹çcountå¼ å¾åæ´ item.producedCount å¾ä¹ä»¥ä¸ªç³»æ° é»è®¤ç³»æ° 1 |
| | | const count = needArrangeNumber > 0 && needArrangeNumber <= item.producedCount * ratio ? needArrangeNumber : item.producedCount * ratio |
| | | needArrangeNumber = needArrangeNumber - item.producedCount * ratio // å©ä½å¾
æå¼ |
| | | |
| | | if (count > 0 && (needArrangeNumber > 0 || Math.abs(needArrangeNumber) < item.producedCount * ratio)) { // ä¸å®æ¯å¤§äºé¶ä¸å°äºæ´æ¡çç产å¼ç |
| | | // duration åä½ åé |
| | | const duration = (count / (item.AdvaDevicCropMob / 100)) * item.AdvaDevicRhythm / 60 |
| | | // if (count < item.producedCount && new Date().getTime() <= new Date(item.start_date).getTime()) { |
| | | // duration = duration * (count / item.producedCount) //好忳¨éæå°±å¯¹äº å¾
éªè¯ |
| | | // } |
| | | |
| | | const obj = { |
| | | id: nanoid(), |
| | | type: 'task2', |
| | | text: 'ä»»å¡åç§°111', |
| | | partName: item.partName, |
| | | partCode: item.partCode, |
| | | start_date: new Date(item.start_date).getTime() < new Date().getTime() ? handleDatetime2(new Date()) : (item.start_date2 ? item.start_date2 : handleDatetime2(item.start_date)), |
| | | // end_date: handleDatetime2(item.end_date), |
| | | // end_date: item.end_date, |
| | | duration, // ä»£è¡¨çæ¯è¿åº¦æ¡ |
| | | checked: false, |
| | | progress: 0, |
| | | parent: item.parent, |
| | | saleOrder: item.saleOrder, |
| | | producedCount: count <= item.producedCount ? Math.round(count) : item.producedCount |
| | | // producedCount: count <= item.producedCount ? count : item.producedCount |
| | | } |
| | | this.canArrangeNumber += parseFloat(obj.producedCount) |
| | | if (Math.abs(this.canArrangeNumber - this.needArrangeNumber) === 1) { |
| | | obj.producedCount = obj.producedCount + (this.needArrangeNumber - this.canArrangeNumber) |
| | | } |
| | | |
| | | newArr.push({ ...obj }) |
| | | } |
| | | } |
| | | }) |
| | | |
| | | // for (let i = 0; i < this.allTasks.length; i++) { |
| | | // |
| | | // } |
| | | |
| | | this.allTasks = [...this.allTasks, ...newArr] |
| | | |
| | | console.log(JSON.parse(JSON.stringify(this.allTasks)), '888') |
| | | |
| | | this.totalTasks = this.allTasks.length |
| | | this.updatePaginatedTasks() |
| | | this.renderGanttChart() |
| | | }, |
| | | // æ¸
空已æå¼ |
| | | priorityMethodChange() { |
| | | this.canArrangeNumber = 0 |
| | | this.allTasks = this.allTasks.filter(i => i.type !== 'task2') |
| | | this.totalTasks = this.allTasks.length |
| | | this.updatePaginatedTasks() |
| | | this.renderGanttChart() |
| | | } |
| | | } |
| | | } |
| | | |
| | | </script> |
| | | |
| | | <style> |
| | | body, |
| | | html { |
| | | width: 100%; |
| | | height: 100%; |
| | | margin: unset; |
| | | } |
| | | |
| | | /*.gantt_task_cell {*/ |
| | | /* background: rgba(5, 185, 100, .1);*/ |
| | | /*}*/ |
| | | |
| | | /*!*é工使¥*!*/ |
| | | /*.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_bar_task {*/ |
| | | /*border-radius: 10px !important;*/ |
| | | /*padding: 3px !important;*/ |
| | | /*transform: scaleX(-1) !important;*/ |
| | | /*}*/ |
| | | |
| | | /*.gantt_bar_project {*/ |
| | | /*border-radius: 10px !important;*/ |
| | | /*}*/ |
| | | |
| | | .taskCheckBox { |
| | | cursor: pointer; |
| | | } |
| | | |
| | | /* å页容卿 ·å¼ */ |
| | | .pagination-container { |
| | | margin-top: 10px; |
| | | display: flex; |
| | | justify-content: end; |
| | | padding: 10px 0; |
| | | 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> |