342 lines
26 KiB
JavaScript
342 lines
26 KiB
JavaScript
// 【重要】必须使用 const Component 作为组件变量名 - Axhub 产品原型
|
||
// 数字化资产ONEOS运管平台 - 新增交车任务模块(参照新增租赁合同布局)
|
||
|
||
const Component = function() {
|
||
var antd = window.antd;
|
||
var Input = antd.Input;
|
||
var Select = antd.Select;
|
||
var Button = antd.Button;
|
||
var DatePicker = antd.DatePicker;
|
||
var Modal = antd.Modal;
|
||
var message = antd.message;
|
||
var Option = Select.Option;
|
||
var Checkbox = antd.Checkbox;
|
||
var Tooltip = antd.Tooltip;
|
||
var RangePicker = DatePicker.RangePicker;
|
||
|
||
var projectId = React.useState('');
|
||
var selectedProjectId = projectId[0];
|
||
var setSelectedProjectId = projectId[1];
|
||
|
||
var expectedDelivery = React.useState(null);
|
||
var expectedDeliveryValue = expectedDelivery[0];
|
||
var setExpectedDelivery = expectedDelivery[1];
|
||
|
||
var billingDate = React.useState(null);
|
||
var billingDateValue = billingDate[0];
|
||
var setBillingDate = billingDate[1];
|
||
|
||
// 续签合同:是否需要还车(勾选“不需要还车”则可选已交车车辆),续签时默认不勾选
|
||
var noReturnCarCheckedState = React.useState(false);
|
||
var noReturnCarChecked = noReturnCarCheckedState[0];
|
||
var setNoReturnCarChecked = noReturnCarCheckedState[1];
|
||
|
||
var selectedRowKeys = React.useState([]);
|
||
var checkedRowKeys = selectedRowKeys[0];
|
||
var setCheckedRowKeys = selectedRowKeys[1];
|
||
|
||
var formErrors = React.useState({});
|
||
var errors = formErrors[0];
|
||
var setErrors = formErrors[1];
|
||
|
||
var reqModalOpen = React.useState(false);
|
||
|
||
// Mock:项目列表及车辆样例。deliveryStatus: 'none' 可选,'submitted' 已提交交车任务不可选,'completed' 已完成交车不显示
|
||
var projectList = [
|
||
{ id: 'p1', name: '嘉兴某某物流氢能运输项目', contractCode: 'JXZL20260216YW101235A', customerName: '嘉兴某某物流有限公司', deliveryRegion: '浙江省 / 嘉兴市', deliveryLocation: '浙江省嘉兴市南湖区科技大道1号', vehicles: [
|
||
{ key: 'v1', brand: '东风', model: '氢燃料电池重卡 H31', plateNo: '浙A10001', vin: 'LFV2BJCH8K3123456', monthRent: '12800', serviceFee: '800', deposit: '30000', remark: '首车', deliveryStatus: 'submitted' },
|
||
{ key: 'v2', brand: '东风', model: '氢燃料电池重卡 H31', plateNo: '浙A10002', vin: 'LFV2BJCH8K3123457', monthRent: '12800', serviceFee: '800', deposit: '30000', remark: '', deliveryStatus: 'submitted' },
|
||
{ key: 'v3', brand: '福田', model: '智蓝氢能轻卡', plateNo: '', vin: 'LZYTBACR2M1234567', monthRent: '8500', serviceFee: '500', deposit: '20000', remark: '待上牌', deliveryStatus: 'none' },
|
||
{ key: 'v4', brand: '重汽', model: '豪沃氢能牵引车', plateNo: '浙F20001', vin: 'ZZ4257N386FZ12345', monthRent: '15000', serviceFee: '1000', deposit: '35000', remark: '', deliveryStatus: 'none' },
|
||
{ key: 'v5', brand: '陕汽', model: '德龙氢能自卸', plateNo: '浙F20002', vin: 'SX1313GR456123456', monthRent: '13200', serviceFee: '880', deposit: '32000', remark: '固定线路', deliveryStatus: 'none' }
|
||
]},
|
||
{ id: 'p1_r', name: '嘉兴某某物流氢能运输项目(续签合同)', isRenewal: true, contractCode: 'JXZL20270116YW101235B', customerName: '嘉兴某某物流有限公司', deliveryRegion: '浙江省 / 嘉兴市', deliveryLocation: '浙江省嘉兴市南湖区科技大道1号', vehicles: [
|
||
{ key: 'v1r_1', brand: '东风', model: '氢燃料电池重卡 H31', plateNo: '浙A10001', vin: 'LFV2BJCH8K3123456', monthRent: '12800', serviceFee: '800', deposit: '30000', remark: '续签合同车辆', deliveryStatus: 'none' },
|
||
{ key: 'v1r_0', brand: '东风', model: '氢燃料电池重卡 H31', plateNo: '浙A09999', vin: 'LFV2BJCH8K3000000', monthRent: '12800', serviceFee: '800', deposit: '30000', remark: '续签:已交车车辆样例', deliveryStatus: 'completed' },
|
||
{ key: 'v1r_0b', brand: '福田', model: '智蓝氢能轻卡', plateNo: '浙A08888', vin: 'LZYTBACR2M1000001', monthRent: '8500', serviceFee: '500', deposit: '20000', remark: '续签:已交车车辆样例', deliveryStatus: 'completed' },
|
||
{ key: 'v1r_0c', brand: '重汽', model: '豪沃氢能牵引车', plateNo: '浙A07777', vin: 'ZZ4257N386FZ00002', monthRent: '15000', serviceFee: '1000', deposit: '35000', remark: '续签:已交车车辆样例', deliveryStatus: 'completed' },
|
||
{ key: 'v1r_2', brand: '福田', model: '智蓝氢能轻卡', plateNo: '', vin: 'LZYTBACR2M1234567', monthRent: '8500', serviceFee: '500', deposit: '20000', remark: '续签待上牌', deliveryStatus: 'none' }
|
||
]},
|
||
{ id: 'p2', name: '上海某某运输氢能租赁项目', contractCode: 'SHZL20260201YW200123A', customerName: '上海某某运输公司', deliveryRegion: '上海市 / 上海市', deliveryLocation: '上海市浦东新区张江高科技园区', vehicles: [
|
||
{ key: 'v6', brand: '上汽红岩', model: '杰狮氢能牵引', plateNo: '沪A30003', vin: 'SH1313HY789012345', monthRent: '14500', serviceFee: '950', deposit: '34000', remark: '', deliveryStatus: 'submitted' },
|
||
{ key: 'v7', brand: '宇通', model: '氢能公交 ZK6126', plateNo: '沪B40001', vin: 'LZYTAGCF8K4567890', monthRent: '22000', serviceFee: '1200', deposit: '50000', remark: '示范线路', deliveryStatus: 'none' },
|
||
{ key: 'v8', brand: '福田', model: '欧辉氢能大巴', plateNo: '', vin: 'LZYTBACR2M2345678', monthRent: '19800', serviceFee: '1100', deposit: '45000', remark: '', deliveryStatus: 'none' }
|
||
]},
|
||
{ id: 'p3', name: '杭州某某租赁氢能项目', contractCode: 'HZZL20260115YW100089A', customerName: '杭州某某租赁有限公司', deliveryRegion: '浙江省 / 杭州市', deliveryLocation: '浙江省杭州市余杭区未来科技城', vehicles: [
|
||
{ key: 'v9', brand: '品牌C', model: '型号C1', plateNo: '浙A40004', vin: 'L4234567890ABCDEF', monthRent: '8200', serviceFee: '450', deposit: '20000', remark: '重点客户', deliveryStatus: 'completed' },
|
||
{ key: 'v10', brand: '品牌C', model: '型号C2', plateNo: '', vin: 'L5234567890ABCDEF', monthRent: '7800', serviceFee: '420', deposit: '19000', remark: '', deliveryStatus: 'submitted' },
|
||
{ key: 'v11', brand: '东风', model: '氢燃料电池厢货', plateNo: '浙A50001', vin: 'LFV2BJCH8K5678901', monthRent: '9200', serviceFee: '520', deposit: '22000', remark: '城配', deliveryStatus: 'none' },
|
||
{ key: 'v12', brand: '开沃', model: '创源氢能轻卡', plateNo: '浙A50002', vin: 'LJXTBACR9N6789012', monthRent: '8800', serviceFee: '480', deposit: '21000', remark: '', deliveryStatus: 'none' }
|
||
]}
|
||
];
|
||
|
||
var selectedProject = projectList.find(function(p) { return p.id === selectedProjectId; });
|
||
var isRenewalProject = !!(selectedProject && selectedProject.isRenewal);
|
||
var vehicleListRaw = selectedProject ? selectedProject.vehicles : [];
|
||
// 2.8.1 勾选「不需要还车」:只显示已交未还车辆;2.8.2 不勾选:显示已交未还+续签新增车辆,已交未还不可勾选。非续签:已完成交车不显示,已提交不可选。
|
||
var vehicleList = vehicleListRaw.filter(function(v) {
|
||
if (v.deliveryStatus === 'completed') {
|
||
if (!isRenewalProject) return false;
|
||
return true;
|
||
}
|
||
if (v.deliveryStatus === 'submitted') return true;
|
||
if (isRenewalProject && !!noReturnCarChecked) return false;
|
||
return true;
|
||
});
|
||
var selectableVehicles = vehicleList.filter(function(v) {
|
||
if (v.deliveryStatus === 'submitted') return false;
|
||
if (v.deliveryStatus === 'completed') return isRenewalProject && !!noReturnCarChecked;
|
||
return true;
|
||
});
|
||
|
||
var handleProjectChange = function(id) {
|
||
var nextId = id || '';
|
||
setSelectedProjectId(nextId);
|
||
var nextProject = projectList.find(function(p) { return p.id === nextId; });
|
||
var isRenewal = !!(nextProject && nextProject.isRenewal);
|
||
setCheckedRowKeys([]);
|
||
setNoReturnCarChecked(false);
|
||
};
|
||
|
||
var todayStr = (function() {
|
||
var d = new Date();
|
||
return d.getFullYear() + '-' + String(d.getMonth() + 1).padStart(2, '0') + '-' + String(d.getDate()).padStart(2, '0');
|
||
})();
|
||
|
||
var validateExpectedDelivery = function() {
|
||
if (!expectedDeliveryValue || !expectedDeliveryValue.length) return '请选择预计交车日期';
|
||
var start = expectedDeliveryValue[0] && expectedDeliveryValue[0].format ? expectedDeliveryValue[0].format('YYYY-MM-DD') : null;
|
||
var end = expectedDeliveryValue[1] && expectedDeliveryValue[1].format ? expectedDeliveryValue[1].format('YYYY-MM-DD') : null;
|
||
if (!start) return '请选择预计交车日期';
|
||
if (end && end < start) return '结束日期不能早于开始日期'; // 结束可与开始相同,即单日
|
||
if (end && end < todayStr) return '结束日期不能早于当前日期';
|
||
return null;
|
||
};
|
||
|
||
var needExpectedDelivery = !(isRenewalProject && noReturnCarChecked);
|
||
var expectedDeliveryError = needExpectedDelivery ? validateExpectedDelivery() : null;
|
||
|
||
var billingDateError = !billingDateValue ? '请选择开始计费日期' : null;
|
||
|
||
var handleSubmit = function() {
|
||
var err = {};
|
||
if (!selectedProjectId) err.projectName = '请选择项目名称';
|
||
if (needExpectedDelivery && expectedDeliveryError) err.expectedDelivery = expectedDeliveryError;
|
||
if (billingDateError) err.billingDate = billingDateError;
|
||
if (checkedRowKeys.length === 0 && selectableVehicles.length > 0) err.vehicles = '请至少选择一辆车';
|
||
setErrors(err);
|
||
if (Object.keys(err).length) return;
|
||
var count = checkedRowKeys.length;
|
||
message.success('已为 ' + count + ' 辆车生成交车任务,将按交车区域分配对应运维人员。');
|
||
};
|
||
|
||
var handleCancel = function() {
|
||
message.info('取消');
|
||
};
|
||
|
||
var onSelectAll = function(checked) {
|
||
if (checked) setCheckedRowKeys(selectableVehicles.map(function(v) { return v.key; }));
|
||
else setCheckedRowKeys([]);
|
||
};
|
||
|
||
var onSelectRow = function(record, checked) {
|
||
if (checked) setCheckedRowKeys(function(prev) { return prev.indexOf(record.key) === -1 ? prev.concat(record.key) : prev; });
|
||
else setCheckedRowKeys(function(prev) { return prev.filter(function(k) { return k !== record.key; }); });
|
||
};
|
||
|
||
var onToggleNoReturnCar = function(e) {
|
||
var next = !!(e && e.target ? e.target.checked : e);
|
||
setNoReturnCarChecked(next);
|
||
if (!next) {
|
||
setCheckedRowKeys(function(prev) {
|
||
var completedKeys = vehicleList.filter(function(v) { return v && v.deliveryStatus === 'completed'; }).map(function(v) { return v.key; });
|
||
return prev.filter(function(k) { return completedKeys.indexOf(k) === -1; });
|
||
});
|
||
}
|
||
};
|
||
|
||
var styles = {
|
||
page: { padding: '16px 24px 48px', backgroundColor: '#f5f5f5', minHeight: '100vh', fontFamily: '-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif', fontSize: 14 },
|
||
breadcrumb: { marginBottom: 16, color: '#666' },
|
||
breadcrumbSep: { margin: '0 8px', color: '#999' },
|
||
card: { backgroundColor: '#fff', borderRadius: 8, marginBottom: 16, boxShadow: '0 1px 2px rgba(0,0,0,0.05)', overflow: 'hidden' },
|
||
cardHeader: { padding: '16px 20px', borderBottom: '1px solid #f0f0f0' },
|
||
cardTitle: { fontSize: 16, fontWeight: 600, color: '#333' },
|
||
cardBody: { padding: '20px 24px' },
|
||
formRow: { display: 'flex', flexWrap: 'wrap', marginBottom: 16 },
|
||
formCol: { flex: '0 0 33.33%', minWidth: 200, paddingRight: 16, marginBottom: 8 },
|
||
label: { display: 'block', marginBottom: 6, color: '#333' },
|
||
labelRequired: { color: '#ff4d4f', marginRight: 4 },
|
||
errMsg: { color: '#ff4d4f', fontSize: 12, marginTop: 4 },
|
||
footer: { position: 'fixed', bottom: 0, left: 0, right: 0, padding: '12px 24px', backgroundColor: '#fff', borderTop: '1px solid #e8e8e8', display: 'flex', gap: 12, justifyContent: 'flex-start', zIndex: 99 },
|
||
tableWrap: { marginTop: 16, overflowX: 'auto' },
|
||
table: { width: '100%', borderCollapse: 'collapse', fontSize: 13 },
|
||
th: { padding: '10px 8px', textAlign: 'left', borderBottom: '1px solid #e8e8e8', backgroundColor: '#fafafa', fontWeight: 600 },
|
||
td: { padding: '8px', borderBottom: '1px solid #f0f0f0', verticalAlign: 'middle' },
|
||
inputDisabled: { width: '100%', padding: '6px 10px', border: '1px solid #d9d9d9', borderRadius: 4, backgroundColor: '#f5f5f5', color: '#666', fontSize: 13 },
|
||
modalMask: { position: 'fixed', left: 0, top: 0, right: 0, bottom: 0, backgroundColor: 'rgba(0,0,0,0.45)', zIndex: 1000, display: 'flex', alignItems: 'center', justifyContent: 'center' },
|
||
modalBox: { backgroundColor: '#fff', borderRadius: 8, width: '90%', maxWidth: 640, maxHeight: '85vh', overflow: 'hidden', display: 'flex', flexDirection: 'column', boxShadow: '0 4px 20px rgba(0,0,0,0.15)' },
|
||
modalHeader: { padding: '16px 20px', borderBottom: '1px solid #f0f0f0', fontSize: 16, fontWeight: 600 },
|
||
modalBody: { padding: 20, overflow: 'auto', flex: 1 }
|
||
};
|
||
|
||
var FormItem = function(props) {
|
||
return React.createElement('div', { style: styles.formCol },
|
||
React.createElement('label', { style: styles.label }, props.required ? React.createElement('span', { style: styles.labelRequired }, '*') : null, props.label),
|
||
props.children,
|
||
props.error ? React.createElement('div', { style: styles.errMsg }, props.error) : null
|
||
);
|
||
};
|
||
|
||
var projectOptions = projectList.map(function(p) { return React.createElement(Option, { key: p.id, value: p.id }, p.name); });
|
||
|
||
var formRow1 = React.createElement('div', { style: styles.formRow },
|
||
React.createElement(FormItem, { label: '选择项目名称', required: true, error: errors.projectName },
|
||
React.createElement(Select, {
|
||
placeholder: '请选择或输入项目名称(对应自营合同、租赁合同-项目名称)',
|
||
style: { width: '100%' },
|
||
value: selectedProjectId || undefined,
|
||
onChange: handleProjectChange,
|
||
showSearch: true,
|
||
allowClear: true,
|
||
filterOption: function(input, opt) { return opt.children && String(opt.children).toLowerCase().indexOf((input || '').toLowerCase()) >= 0; },
|
||
status: errors.projectName ? 'error' : undefined
|
||
}, projectOptions)),
|
||
React.createElement(FormItem, { label: '合同编码' }, React.createElement(Input, { value: selectedProject ? selectedProject.contractCode : '', disabled: true, style: { width: '100%' } })),
|
||
React.createElement(FormItem, { label: '客户名称' }, React.createElement(Input, { value: selectedProject ? selectedProject.customerName : '', disabled: true, style: { width: '100%' } })),
|
||
React.createElement(FormItem, { label: '交车区域' }, React.createElement(Input, { value: selectedProject ? selectedProject.deliveryRegion : '', disabled: true, style: { width: '100%' } })),
|
||
React.createElement(FormItem, { label: '交车地点' }, React.createElement(Input, { value: selectedProject ? selectedProject.deliveryLocation : '', disabled: true, style: { width: '100%' } }))
|
||
);
|
||
|
||
var formRow2 = React.createElement('div', { style: styles.formRow },
|
||
needExpectedDelivery ? React.createElement(FormItem, { label: '预计交车日期', required: true, error: errors.expectedDelivery },
|
||
React.createElement(RangePicker, {
|
||
style: { width: '100%' },
|
||
format: 'YYYY-MM-DD',
|
||
placeholder: ['请选择开始日期', '请选择结束日期(单日请选同一天)'],
|
||
value: expectedDeliveryValue,
|
||
onChange: function(dates) { setExpectedDelivery(dates && dates.length === 2 ? dates : null); },
|
||
status: errors.expectedDelivery ? 'error' : undefined
|
||
})) : null,
|
||
React.createElement(FormItem, { label: '开始计费日期', required: true, error: errors.billingDate },
|
||
React.createElement(DatePicker, {
|
||
style: { width: '100%' },
|
||
format: 'YYYY-MM-DD',
|
||
placeholder: '请选择日期',
|
||
value: billingDateValue,
|
||
onChange: function(d, dateStr) { setBillingDate(d); },
|
||
status: errors.billingDate ? 'error' : undefined
|
||
})),
|
||
isRenewalProject ? React.createElement(FormItem, { label: '已交车辆是否需要还车' },
|
||
React.createElement('div', { style: { display: 'flex', alignItems: 'flex-start', gap: 8, lineHeight: 1.6 } },
|
||
React.createElement(Checkbox, { checked: !!noReturnCarChecked, onChange: onToggleNoReturnCar }, '不需要还车'),
|
||
React.createElement('span', { style: { color: '#8c8c8c', fontSize: 12, marginTop: 2 } },
|
||
'勾选不需要还车,则车辆无需交车,',
|
||
React.createElement('br', null),
|
||
'只设置开始计费日期即可重新生成账单'
|
||
)
|
||
)
|
||
) : null
|
||
);
|
||
|
||
var allSelectableChecked = selectableVehicles.length > 0 && selectableVehicles.every(function(v) { return checkedRowKeys.indexOf(v.key) !== -1; });
|
||
var someSelectableChecked = selectableVehicles.some(function(v) { return checkedRowKeys.indexOf(v.key) !== -1; });
|
||
var tableHeader = React.createElement('thead', null,
|
||
React.createElement('tr', null,
|
||
React.createElement('th', { style: Object.assign({}, styles.th, { width: 48 }) },
|
||
React.createElement(Checkbox, {
|
||
checked: allSelectableChecked,
|
||
indeterminate: someSelectableChecked && !allSelectableChecked,
|
||
onChange: function(e) { onSelectAll(e.target.checked); }
|
||
})),
|
||
React.createElement('th', { style: styles.th }, '品牌'),
|
||
React.createElement('th', { style: styles.th }, '型号'),
|
||
React.createElement('th', { style: styles.th }, '车牌号'),
|
||
React.createElement('th', { style: styles.th }, '车辆识别代码'),
|
||
React.createElement('th', { style: styles.th }, '车辆月租金'),
|
||
React.createElement('th', { style: styles.th }, '服务费'),
|
||
React.createElement('th', { style: styles.th }, '保证金'),
|
||
React.createElement('th', { style: styles.th }, '备注')
|
||
)
|
||
);
|
||
|
||
var tableBody = React.createElement('tbody', null,
|
||
vehicleList.length === 0
|
||
? React.createElement('tr', null, React.createElement('td', { colSpan: 9, style: Object.assign({}, styles.td, { textAlign: 'center', color: '#999' }) }, '请先选择项目名称,将自动带出该合同下车辆信息'))
|
||
: vehicleList.map(function(row) {
|
||
var isSubmitted = row.deliveryStatus === 'submitted';
|
||
var isCompleted = row.deliveryStatus === 'completed';
|
||
var completedSelectable = isRenewalProject && !!noReturnCarChecked;
|
||
return React.createElement('tr', { key: row.key },
|
||
React.createElement('td', { style: styles.td },
|
||
isSubmitted
|
||
? React.createElement(Tooltip, { title: '该车辆已创建交车任务' },
|
||
React.createElement('span', { style: { display: 'inline-flex', alignItems: 'center', gap: 6, cursor: 'not-allowed' } },
|
||
React.createElement(Checkbox, { disabled: true, checked: false }),
|
||
React.createElement('span', { style: { color: '#999', fontSize: 12 } }, '已提交')))
|
||
: isCompleted
|
||
? React.createElement(Tooltip, { title: '该车辆已完成交车' },
|
||
React.createElement('span', { style: { display: 'inline-flex', alignItems: 'center' } },
|
||
React.createElement(Checkbox, {
|
||
disabled: !completedSelectable,
|
||
checked: completedSelectable ? (checkedRowKeys.indexOf(row.key) !== -1) : true,
|
||
onChange: function(e) { onSelectRow(row, e.target.checked); }
|
||
})
|
||
))
|
||
: React.createElement(Checkbox, { checked: checkedRowKeys.indexOf(row.key) !== -1, onChange: function(e) { onSelectRow(row, e.target.checked); } })),
|
||
React.createElement('td', { style: styles.td }, React.createElement(Input, { value: row.brand, disabled: true, style: styles.inputDisabled })),
|
||
React.createElement('td', { style: styles.td }, React.createElement(Input, { value: row.model, disabled: true, style: styles.inputDisabled })),
|
||
React.createElement('td', { style: styles.td }, React.createElement(Input, { value: row.plateNo || '-', disabled: true, style: styles.inputDisabled })),
|
||
React.createElement('td', { style: styles.td }, React.createElement(Input, { value: row.vin, disabled: true, style: styles.inputDisabled })),
|
||
React.createElement('td', { style: styles.td }, React.createElement(Input, { value: row.monthRent + '元', disabled: true, style: styles.inputDisabled })),
|
||
React.createElement('td', { style: styles.td }, React.createElement(Input, { value: row.serviceFee + '元', disabled: true, style: styles.inputDisabled })),
|
||
React.createElement('td', { style: styles.td }, React.createElement(Input, { value: row.deposit + '元', disabled: true, style: styles.inputDisabled })),
|
||
React.createElement('td', { style: styles.td }, React.createElement(Input, { value: row.remark || '-', disabled: true, style: styles.inputDisabled }))
|
||
);
|
||
})
|
||
);
|
||
|
||
var tableEl = React.createElement('div', { style: styles.tableWrap },
|
||
React.createElement('table', { style: styles.table }, tableHeader, tableBody)
|
||
);
|
||
|
||
if (errors.vehicles) {
|
||
tableEl = React.createElement('div', null,
|
||
React.createElement('div', { style: Object.assign({}, styles.errMsg, { marginBottom: 8 }) }, errors.vehicles),
|
||
tableEl
|
||
);
|
||
}
|
||
|
||
var reqSpecText = '新增交车任务\n一个「数字化资产ONEOS运管平台」中的「新增交车任务」模块\n1.面包屑:\n1.1.业务管理-交车任务-新增交车任务\n\n2.表单:\n2.1.选择项目名称:必选项,选择器,默认提示文本:请选择或输入项目名称,支持从输入框内输入内容进行模糊搜索,对应自营合同、租赁合同-「项目名称」字段;;\n2.2.合同编码:输入框(禁用状态),根据所选项目名称自动反写合同编码;\n2.3.客户名称:输入框(禁用状态),根据所选项目名称自动反写客户名称;\n2.4.交车区域:输入框(禁用状态),根据所选项目名称自动反写交车区域。提交时根据交车区域,为对应区域运维人员分配对应交车任务;\n2.5.交车地点:输入框(禁用状态),根据所选项目名称自动反写交车地点;\n2.6.预计交车日期:必填项,日期选择器,支持某天或某个时间段两种模式,格式为YYYY-MM-DD或YYYY-MM-DD至YYYY-MM-DD,结束日期不能早于开始日期,并且结束日期不能早于当前日期;\n 2.6.1.如勾选不需要还车,则预计交车日期隐藏,不需要设置;\n2.7.开始计费日期:必填项,日期选择器,支持单日选择,格式为YYYY-MM-DD;\n2.8.已交车辆是否需要还车:勾选框,内容为不需要还车,默认不勾选,不勾选时,无法在车辆列表勾选已交未还的车辆,勾选后,已交未还的车辆也可以勾选,但不会生成新交车任务,只是按照开始计费日期生成账单;\n 2.8.1.勾选时,车辆列表只显示已交未还的车辆清单,不能添加新车(避免已交未还部分车辆开始计费日期计算不精确);\n 2.8.2.不勾选时,车辆列表显示已交未还的车辆清单及续签合同新增车辆,但是已交未还部分的车辆不可勾选;\n2.9.下方为列表,列表拉取该车辆租赁合同对应所有车辆信息(该合同下已提交过交车任务的车辆不可选,已完成交车的车辆不显示在列表中),列表字段为:全选/多选、品牌、型号、车牌号、车辆识别代码、车辆月租金、服务费、保证金、备注;\n 2.9.1.全选/多选:支持全选、多选模式,选择对应车辆后,点击提交自动生成被选中车辆交车任务,需要至少选择1辆,才能进行提交,该合同下已提交过交车任务和已交车的车辆不可选,多选框为禁用状态,悬浮时提示:该车辆已完成交车/该车辆已创建交车任务;\n 2.9.2.品牌:输入框(禁用状态),根据所选项目名称自动反写品牌;\n 2.9.3.型号:输入框(禁用状态),根据所选项目名称自动反写型号;\n 2.9.4.车牌号:输入框(禁用状态),根据所选项目名称自动反写车牌号,车牌号可能为空,为空时显示为-;\n 2.9.5.车辆识别代码:输入框(禁用状态),根据所选项目名称自动反写车辆识别代码;\n 2.9.6.车辆月租金:输入框(禁用状态),根据所选项目名称自动反写车辆月租金,后缀为元;\n 2.9.7.服务费:输入框(禁用状态),根据所选项目名称自动反写服务费,后缀为元;\n 2.9.8.保证金:输入框(禁用状态),根据所选项目名称自动反写保证金,后缀为元;\n 2.9.9.备注:输入框(禁用状态),根据所选项目名称自动反写备注信息,备注为空时显示为-;\n2.10.页面底部为提交、取消;';
|
||
|
||
return React.createElement('div', { style: styles.page },
|
||
React.createElement('div', { style: { display: 'flex', justifyContent: 'space-between', alignItems: 'center', marginBottom: 16 } },
|
||
React.createElement('div', { style: styles.breadcrumb },
|
||
React.createElement('span', null, '业务管理'),
|
||
React.createElement('span', { style: styles.breadcrumbSep }, ' / '),
|
||
React.createElement('span', null, '交车任务'),
|
||
React.createElement('span', { style: styles.breadcrumbSep }, ' / '),
|
||
React.createElement('span', { style: { color: '#1890ff' } }, '新增交车任务')),
|
||
React.createElement(Button, { type: 'link', style: { padding: 0 }, onClick: function() { reqModalOpen[1](true); } }, '查看需求说明')),
|
||
React.createElement('div', { style: styles.card },
|
||
React.createElement('div', { style: styles.cardHeader }, React.createElement('span', { style: styles.cardTitle }, '交车任务')),
|
||
React.createElement('div', { style: styles.cardBody },
|
||
formRow1,
|
||
formRow2,
|
||
tableEl)),
|
||
React.createElement('div', { style: { height: 60 } }),
|
||
React.createElement('div', { style: styles.footer },
|
||
React.createElement(Button, { type: 'primary', onClick: handleSubmit }, '提交'),
|
||
React.createElement(Button, { onClick: handleCancel }, '取消')),
|
||
React.createElement(Modal, {
|
||
title: '需求说明',
|
||
open: reqModalOpen[0],
|
||
onCancel: function() { reqModalOpen[1](false); },
|
||
width: 720,
|
||
footer: React.createElement(Button, { onClick: function() { reqModalOpen[1](false); } }, '关闭'),
|
||
bodyStyle: { maxHeight: '70vh', overflow: 'auto' }
|
||
}, React.createElement('div', { style: { padding: '8px 0' } },
|
||
React.createElement('div', { style: { whiteSpace: 'pre-wrap', fontSize: 13, lineHeight: 1.6 } }, reqSpecText)))
|
||
);
|
||
};
|