12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283 |
- <template>
- <div>
- <!-- 左侧树形结构和右侧表格 -->
- <el-row :gutter="20">
- <!-- 左侧树形结构 -->
- <el-col :span="3">
- <div style="marginTop:20px;margin-left: 10px;">
- <el-tree
- :data="goodsTypeData"
- v-model="getGoodsListParm.parammaps.goodsTypeId"
- :props="defaultProps"
- @node-click="handleNodeClick"
- :disabled="false"
- ></el-tree>
- </div>
- </el-col>
- <!-- 右侧表格和表单 -->
- <el-col :span="21">
- <!-- 搜索条件 -->
- <div class="app-container">
- <tree-select
- v-model="getGoodsListParm.parammaps.goodsTypeId"
- class="typeSelect"
- :height="300"
- :width="250"
- clearable
- :data="goodsTypeData1"
- :placeholder="placeholder"
- style="display: inline-block"
- :default-props="defaultProps"
- :node-key="nodeKey"
- :checked-keys="defaultCheckedKeys"
- @popoverHide="popoverHide"
- :disabled="false"
- />
- <el-input
- v-model="getGoodsListParm.parammaps.goodsName"
- placeholder="货品名称"
- clearable
- style="width: 120px"
- class="filter-item"
- />
- <el-input
- v-model="getGoodsListParm.parammaps.goodsCode"
- placeholder="货品编码"
- clearable
- style="width: 120px"
- class="filter-item"
- />
- <el-input
- v-model="getGoodsListParm.parammaps.goodsSpecification"
- placeholder="货品规格"
- clearable
- style="width: 120px"
- class="filter-item"
- />
- <el-select
- v-model="getGoodsListParm.parammaps.goodsEnabled"
- clearable
- placeholder="货品状态"
- class="filter-item"
- style="width: 120px"
- >
- <el-option
- v-for="item in statuesList"
- :key="item.id"
- :label="item.name"
- :value="item.id"
- />
- </el-select>
- <el-date-picker
- ref="inputDatetime2"
- v-model="getGoodsListParm.parammaps.inputDatetime2"
- class="inputDatetime"
- type="daterange"
- style="width: 250px; top: -3px"
- format="yyyy-MM-dd"
- value-format="yyyy-MM-dd"
- range-separator="至"
- start-placeholder="开始日期"
- end-placeholder="结束日期"
- />
- <el-button
- v-waves
- class="search-button"
- type="primary"
- icon="el-icon-search"
- @click="form_search"
- >搜索</el-button>
- </div>
- <!-- 操作按钮 -->
- <div class="search-button-container">
- <el-button
- class="search-button"
- type="primary"
- icon="el-icon-circle-plus"
- @click="form_add"
- >新增</el-button>
- <el-button
- class="search-button"
- type="primary"
- style="background-color: #aaaaaa;"
- icon="el-icon-s-order"
- @click="template_excel"
- >模板</el-button>
- <el-upload
- style="display: inline-block"
- :headers="headers"
- :data="uploadData"
- :action="uploadExcelUrl"
- :show-file-list="false"
- :before-upload="beforeImportExcel"
- :on-success="handleImportExcelSuccess"
- >
- <el-button
- v-waves
- class="search-button-upload"
- type="primary"
- style="background-color: #ffaa00;"
- icon="el-icon-upload2"
- >导入</el-button>
- </el-upload>
- <el-button
- class="search-button"
- type="primary"
- style="background-color: #00ff15;"
- icon="el-icon-upload2"
- @click="derive_data"
- >导出</el-button>
- </div>
- <!-- 表格 -->
- <el-table
- :key="tableKey"
- v-loading="listLoading"
- element-loading-text="给我一点时间"
- :data="list"
- border
- fit
- highlight-current-row
- style="width: 100%;margin-left: 20px;"
- :row-style="rowStyle"
- :cell-style="cellStyle"
- class="elTable table-fixed"
- :max-height="myHeight"
- >
- <el-table-column label="序号" align="center" type="index" width="50px">
- <template slot-scope="scope">
- <span>{{ scope.$index + (pageNum - 1) * pageSize + 1 }}</span>
- </template>
- </el-table-column>
- <el-table-column label="货品类别" align="center" prop="goodsTypeName" />
- <el-table-column label="货品名称" align="center" prop="goodsName" />
- <el-table-column label="货品编号" align="center" prop="goodsCode" />
- <el-table-column label="货品规格" align="center" prop="goodsSpecification" />
- <el-table-column label="计量单位" align="center" prop="goodsUnit" />
- <el-table-column label="录入日期" align="center" prop="createTime" />
- <el-table-column label="录入人" align="center" prop="createrName" />
- <el-table-column label="货品图片" align="center">
- <template slot-scope="scope">
- <el-popover placement="right" title="" trigger="hover">
- <img
- slot="reference"
- :src="scope.row.goodsImagePath"
- style="height: 100px; width: 100px"
- />
- <!-- 悬停时显示的内容 -->
- <img
- :src="scope.row.goodsImagePath"
- style="height: 200px; width: 200px"
- />
- </el-popover>
- </template>
- </el-table-column>
- <el-table-column label="货品状态" align="center">
- <template slot-scope="scope">
- <el-switch
- v-model="scope.row.goodsEnabled"
- :active-value="0"
- :inactive-value="1"
- active-color="#13ce66"
- inactive-color="#ff4949"
- @change="handleSwitchChange(scope.$index, scope.row)"
- />
- </template>
- </el-table-column>
- <el-table-column label="操作" min-width="150px" header-align="center" align="center">
- <template slot-scope="scope">
- <el-button type="primary" size="mini" @click="handleGet(scope.row)">查看</el-button>
- <el-button type="primary" size="mini" @click="handleEdit(scope.row)">编辑</el-button>
- <el-button type="primary" size="mini" @click="handleDel(scope.row)">删除</el-button>
- </template>
- </el-table-column>
- </el-table>
- <!-- 分页 -->
- <pagination
- v-show="total >= 0"
- :total="total"
- :page.sync="getGoodsListParm.offset"
- :limit.sync="getGoodsListParm.pagecount"
- @pagination="get_goods_data"
- />
- </el-col>
- </el-row>
- <!-- 弹窗 -->
- <el-dialog
- :title="dialogTitle"
- :visible.sync="dialogFormVisible"
- :close-on-click-modal="false"
- @close="handleCancel"
- :style="{ maxHeight: '100vh', overflowY: 'auto' }"
- >
- <div class="app-add">
- <el-form
- :rules="rules"
- :inline="true"
- :model="formLabelAlign"
- label-position="left"
- label-width="auto"
- style="width: 90%; margin: 0 auto 30px"
- >
- <el-row :gutter="24">
- <el-col :span="8">
- <el-form-item label="货品类别:" prop="typea">
- <tree-select
- class="typeSelect"
- :height="300"
- :width="160"
- size="small"
- clearable
- :data="goodsTypeData"
- :placeholder="placeholder"
- :default-props="defaultProps"
- :node-key="nodeKey"
- :checked-keys="defaultCheckedKeys"
- @popoverHide="popoverHideAdd"
- :disabled="isView"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="货品编号:" prop="goodsCode">
- <el-input
- v-model="formLabelAlign.goodsCode"
- placeholder="请输入货品编号"
- :disabled="isView || !formLabelAlign.goodsTypeId"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="货品名称:" prop="goodsName">
- <el-input
- v-model="formLabelAlign.goodsName"
- placeholder="请输入货品名称"
- :disabled="isView"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="24">
- <el-col :span="8">
- <el-form-item label="货品规格:" >
- <el-input
- v-model="formLabelAlign.goodsSpecification"
- placeholder="请输入货品规格"
- :disabled="isView"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="货品型号:" >
- <el-input
- v-model="formLabelAlign.goodsModel"
- placeholder="请输入货品型号"
- :disabled="isView"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="计量单位:">
- <el-select v-model="formLabelAlign.goodsUnit" placeholder="请选择" :disabled="isView" clearable style="width: 187px">
- <el-option
- v-for="item in measureList"
- :key="item.id"
- :label="item.name"
- :value="item.id">
- </el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="24">
- <el-col :span="8">
- <el-form-item label="用途:">
- <el-input
- v-model="formLabelAlign.purpose"
- placeholder="请输入用途"
- :disabled="isView"
- />
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label=" 录入人:">
- <el-select v-model="formLabelAlign.createrId" placeholder="请选择" :disabled="isView" clearable style="width: 187px">
- <el-option
- v-for="item in empList"
- :key="item.id"
- :label="item.name"
- :value="item.id">
- </el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="录入日期:">
- <el-date-picker
- style="width: 187px"
- v-model="formLabelAlign.date"
- type="date"
- format="yyyy-MM-dd"
- :disabled="isView"
- value-format="yyyy-MM-dd"
- placeholder="选择日期">
- </el-date-picker>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="24">
- <el-col :span="8">
- <el-form-item label="备注:">
- <el-input
- v-model="formLabelAlign.remarks"
- placeholder="请输入备注"
- :disabled="isView"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <!-- <div> -->
- <el-row :gutter="24">
- <el-form-item label="货品图片:">
- <el-upload id="uploadPic"
- :action="uploadImageUrl"
- :limit='1'
- :file-list="fileList"
- list-type="picture-card"
- :on-preview="handlePictureCardPreview"
- :on-change="(file, fileList) => handlePicChange(file, fileList)"
- :on-success="(response, file, fileList) => handlePicSuccess(response, file, fileList)"
- :headers="headers"
- :disabled="isView"
- :on-remove="(file, fileList) => handlePicRemove(file, fileList)"
- >
- <i slot="default" class="el-icon-plus"></i>
- </el-upload>
- <el-dialog :visible.sync="dialogVisible">
- <img width="100%" :src="dialogImageUrl" alt="">
- </el-dialog>
- </el-form-item>
- </el-form-item>
- </el-col>
- </el-row>
- <el-table
- :key="tableKey"
- v-loading="listLoading"
- element-loading-text="给我一点时间"
- :data="list"
- border
- fit
- highlight-current-row
- style="width: 100%;margin-left: 20px;"
- :row-style="rowStyle"
- :cell-style="cellStyle"
- class="elTable table-fixed"
- :max-height="myHeight"
- >
- <el-table-column
- label="序号"
- align="center"
- type="index"
- width="50px"
- />
- </el-table>
- <!-- </div> -->
- </el-form>
- </div>
- <div slot="footer" class="dialog-footer">
- <el-button class="add-button" v-if="!isEdit && isShow" style="background-color: #13ce66;" @click="handleAdd">保存并新增</el-button>
- <el-button class="add-button" v-if="!isEdit && isShow" @click="handleAddAndOff">保存并关闭</el-button>
- <el-button class="add-button" v-if="!isEdit && isShow" style="background-color: #ffffff; color: black;" @click="handleCancel">取消并关闭</el-button>
- <el-button class="add-button" v-if="isEdit" @click="handleEditAndOff">保存并关闭</el-button>
- <el-button class="add-button" v-if="isEdit" style="background-color: #ffffff; color: black;" @click="handleCancel">取消并关闭</el-button>
- </div>
- </el-dialog>
- </div>
- </template>
- <!-- <el-form ref="form" label-position="top" :rules="rules" label-width="80px" :model="formLabelAlign">
- <el-form-item label="资产编号" prop="assetCode" style="display: flex; align-items: center;">
- <el-input v-model="formLabelAlign.assetCode"></el-input>
- </el-form-item>
- </el-form> -->
- <script>
- import { PostDataByName, ExecDataByConfig, failproccess, GetDataByName, transData } from '@/api/common';
- import TreeSelect from '@/components/TreeSelect'; // 确保路径正确
- import Pagination from '@/components/Pagination'
- import waves from '@/directive/waves'
- import { MessageBox } from 'element-ui'
- import { getToken } from '@/utils/auth'
- import 'element-ui/lib/theme-chalk/index.css';
- import Cookies from 'js-cookie'
- export default {
- inject: ['reload'],
- name: 'Basics',
- components: { Pagination, TreeSelect },
- directives: { waves },
- data() {
- return {
- rules: { goodsCode: [
- { required: true, message: '货品编码不能为空', trigger: 'blur' },
- ],
- uploadData: {
- name: 'importDiesel',
- importParams: '牧场,油卡编号,设备名称,设备编号,加油日期,加油量(升),单价,加油人,录入人,柴油类型,备注',
- sheetname: 'SheetJS'
- },
- goodsName: [
- { required: true, message: '货品名称不能为空', trigger: 'blur' },
- ],
- goodsSpecification: [
- { required: true, message: '货品规格不能为空', trigger: 'blur' },
- ],
- goodsUnit: [
- { required: true, message: '货品单位不能为空', trigger: 'blur' },
- ],
- typea : [
- { required: true, message: '货品分类不能为空', trigger: 'blur' },
- ],
- },
- total: 0,
- dialogImageUrl: '',
- dialogVisible: false,
- uploadImageUrl: process.env.VUE_APP_BASE_API + 'authdata/uploaderimage',
- uploadExcelUrl: process.env.VUE_APP_BASE_API + 'authdata/GoodsExcel',
- //图片请求头
- headers: { optname: 'insertcustompic', id: 1,token: getToken()},
- getDictList :{name:"getDictListSelect",parammaps:{pid:"75"}},
- fileList: [],
- statuesList: [
- { id: '0', name: '启用' },
- { id: '1', name: '禁用' }
- ],
- measureList:[],
- pageNum: 0,
- pageSize: 0,
- isView : false,
- isEdit : false,
- nodeKey: 'id',
- disabled: false, // 是否禁用
- listLoading: true,
- isShow: false,
- myHeight: document.documentElement.clientHeight - 85 - 250,
- rowStyle: { maxHeight: 50 + 'px', height: 45 + 'px' },
- cellStyle: { padding: 0 + 'px' },
- tableKey :0,
- list: [],//数据列表
- defaultCheckedKeys: [], // 默认选中 的节点
- getGoodsListParm:{name:'getGoodsList' ,page: 1,offset: 1, returntype: 'Map', pagecount: 7, parammaps:{ goodsTypeId:''}},
- getEmployeesSelectParm :{name:'getEmployeesSelect'},
- updateGoodsStatusByIdParm : { name: "updateGoodsStatusById", returntype: "Map", parammaps: {goodsEnabled: 0, id: 0 } },
- empList :[],
- placeholder: '请选择设备分类',
- deleteGoodsParm:{name: 'deleteGoods',parammaps:{ id:''}},
- getGoodsTypeParm: { name: 'GetGoodsTypeList' },
- goodsTypeData:[],
- goodsTypeData1:[],
- formLabelAlign :{ goodsTypeId: '',
- goodsCode: ''},
- dialogTitle : '',
- dialogFormVisible: false,
- defaultProps: {
- children: 'children',
- label: 'goodsTypeName'
- }
- };
- },
- methods: {
- buildInsertRequest() {
- return {
- common: { returnmap: "0" },
- data: [
- {
- name: "CheckGoodsNameUniqueOnInsert",
- type: "v",
- parammaps: { goodsName: this.formLabelAlign.goodsName }, // 动态绑定 goodsName
- },
- {
- name: "CheckGoodsCodeUniqueOnInsert",
- type: "v",
- parammaps: { goodsCode: this.formLabelAlign.goodsCode }, // 动态绑定 goodsCode
- },
- {
- name: "InsertGoods",
- type: "e",
- parammaps: {
- goodsTypeId: this.formLabelAlign.goodsTypeId,
- goodsCode: this.formLabelAlign.goodsCode,
- goodsName: this.formLabelAlign.goodsName,
- goodsSpecification: this.formLabelAlign.goodsSpecification,
- goodsModel: this.formLabelAlign.goodsModel,
- goodsUnit: this.formLabelAlign.goodsUnit,
- createrId: this.formLabelAlign.createrId,
- remarks: this.formLabelAlign.remarks,
- goodsImage: this.formLabelAlign.goodsImage || "0",
- goodsEnabled:0,
- purpose: this.formLabelAlign.purpose || "",
- createTime: this.formLabelAlign.date,
- },
- },
- ],
- };
- },
- buildUpdateRequest() {
- return {
- common: { returnmap: "0" },
- data: [
- {
- name: "CheckGoodsNameUniqueOnUpdate",
- type: "v",
- parammaps: {
- goodsName: this.formLabelAlign.goodsName, // 动态绑定 goodsName
- id: this.formLabelAlign.id, // 动态绑定 id
- },
- },
- {
- name: "CheckGoodsCodeUniqueOnUpdate",
- type: "v",
- parammaps: {
- goodsCode: this.formLabelAlign.goodsCode, // 动态绑定 goodsCode
- id: this.formLabelAlign.id, // 动态绑定 id
- },
- },
- {
- name: "updateGoods",
- type: "e",
- parammaps: {
- id: this.formLabelAlign.id, // 动态绑定 id
- goodsTypeId: this.formLabelAlign.goodsTypeId,
- goodsCode: this.formLabelAlign.goodsCode,
- goodsName: this.formLabelAlign.goodsName,
- goodsSpecification: this.formLabelAlign.goodsSpecification,
- goodsModel: this.formLabelAlign.goodsModel,
- goodsUnit: this.formLabelAlign.goodsUnit,
- remarks: this.formLabelAlign.remarks,
- goodsImage: this.formLabelAlign.goodsImage || "0", // 默认值为 "0"
- goodsEnabled: this.formLabelAlign.goodsEnabled || "1", // 默认值为 "1"
- },
- },
- ],
- };
- },
- resetInsertForm() {
- // 重置 formLabelAlign 数据
- this.formLabelAlign = {
- goodsTypeId: '', // 商品类别 ID
- goodsCode: '', // 商品编码
- goodsName: '', // 商品名称
- goodsSpecification: '', // 商品规格
- goodsModel: '', // 商品型号
- goodsUnit: '', // 商品单位
- createrId: '', // 创建人 ID
- remarks: '', // 备注
- goodsImage: '0', // 商品图片
- goodsEnabled: '1', // 商品状态(默认启用)
- purpose: '', // 用途
- picture: '', // 图片
- };
- this.fileList= [];
- },
- handleEditAndOff(){
- this.handleEdit1();
- this.dialogFormVisible = false;
- },
- handleEdit1(){
- const code = this.formLabelAlign.goodsUnit;
- const id = this.formLabelAlign.goodsUnitId;
- console.log("goodsCode : ",code);
- console.log("goodsTypeId : ",id);
- if (typeof code === 'number') {
- this.formLabelAlign.goodsUnit = code ;
- } else {
- this.formLabelAlign.goodsUnit = id ;
- }
- const requestParam = this.buildUpdateRequest();
- console.log(requestParam);
- ExecDataByConfig(requestParam).then(response => {
- if (response.msg !== 'fail') {
- this.resetInsertForm();
- this.get_goods_data();
- this.isEdit= false;
- this.defaultCheckedKeys= [];
- this.$notify({
- title: '成功',
- message: '操作成功',
- type: 'success',
- duration: 2000,
- });
- } else {
- this.$notify({
- title: '失败',
- message: response.data,
- type: 'error',
- duration: 2000,
- });
- }
- });
- },
- handleAddAndOff(){
- this.handleAdd();
- this.dialogFormVisible = false;
- },
- handleAdd() {
- const requestParam = this.buildInsertRequest();
- ExecDataByConfig(requestParam).then(response => {
- if (response.msg !== 'fail') {
- this.resetInsertForm();
- this.get_goods_data();
- this.isEdit= false;
- this.defaultCheckedKeys= [];
- this.$notify({
- title: '成功',
- message: '操作成功',
- type: 'success',
- duration: 2000,
- });
- } else {
- this.$notify({
- title: '失败',
- message: response.data,
- type: 'error',
- duration: 2000,
- });
- }
- });
- },
- handleCancel(){
- this.defaultCheckedKeys= [];
- this.formLabelAlign.createrId = '';
- this.dialogFormVisible = false;
- this.dialogImageUrl = '';
- this.isShow = false;
- this.isView = false;
- this.resetInsertForm();
- this.isEdit= false;
- },
- handlePicChange(file, fileList) {
- },
- beforeImportExcel(file) {
- const isLt2M = file.size / 1024 / 1024 < 2
- if (!isLt2M) {
- this.$message.error('上传文件大小不能超过 2MB!')
- }
- return isLt2M
- },
- handleImportExcelSuccess(res, file) {
- // if (res.msg === 'ok') {
- if (res.msg === 'ok') {
- if (res.data.err_count > 0) {
- this.$message({
- title: '失败',
- message: '导入失败',
- type: 'danger',
- duration: 2000
- })
- this.$notify({
- title: '失败',
- message: '导入失败',
- type: 'danger',
- duration: 2000
- })
- import('@/vendor/Export2Excel').then(excel => {
- const list1 = res.data.result
- const tHeader = [
- '货品类别',
- '货品编号',
- '货品名称',
- '货品规格',
- '货品型号',
- '计量单位',
- '用途',
- '录入人',
- '备注', '错误信息'
- ]
- const filterVal = [
- '货品类别',
- '货品编号',
- '货品名称',
- '货品规格',
- '货品型号',
- '计量单位',
- '用途',
- '录入人',
- '备注','error_msg'
- ]
- const data1 = this.formatJson(filterVal, list1)
- excel.export_json_to_excel({
- header: tHeader,
- data: data1,
- filename: '货品信息_error',
- autoWidth: true,
- bookType: 'xlsx'
- })
- })
- }else{
- this.get_goods_data();
- this.$message({
- title: '成功',
- message: '导入成功',
- type: 'success',
- duration: 2000
- })
- this.$notify({
- title: '成功',
- message: '导入成功',
- type: 'success',
- duration: 2000
- })
- }
- } else {
- this.$notify({
- title: '失败',
- message: '上传失败',
- type: 'danger',
- duration: 2000
- })
- }
- },
- handlePicRemove(file, fileList) {
- console.log(file, fileList);
- console.log(fileList.length);
- if (fileList.length == 1) {
- document.getElementById('uploadPic').lastChild.style.display = "none"
- } else {
- document.getElementById('uploadPic').lastChild.style.display = "inline-block"
- }
- },
- handlePicSuccess(response, file, fileList) {
- console.log('文件上传成功时的钩子response', response, );
- console.log('文件上传成功时的钩子file', file);
- console.log('fileList', fileList);
- if (fileList.length == 1) {
- document.getElementById('uploadPic').lastChild.style.display = "none"
- } else {
- document.getElementById('uploadPic').lastChild.style.display = "inline-block"
- }
- this.$set(this.formLabelAlign, 'goodsImage', response.execresult.LastInsertId);
- },
- handlePictureCardPreview(file) {
- this.dialogImageUrl = file.url;
- this.dialogVisible = true;
- },
- popoverHideAdd(checkedIds,row){
- this.formLabelAlign.goodsTypeId = row.id;
- console.log(row);
- console.log(row.goodsTypeCode);
- console.log("11111111111111111");
- this.formLabelAlign.goodsCode = row.goodsTypeCode;
- console.log( this.formLabelAlign.goodsCode);
- },
- handleDel(row) {
- MessageBox.confirm('名称:' + row.goodsName, '确认删除?', {
- confirmButtonText: '确认',
- cancelButtonText: '取消',
- type: 'warning',
- }).then(() => {
- this.deleteGoodsParm.parammaps.id = row.id;
- PostDataByName(this.deleteGoodsParm).then(response => {
- if (response.msg !== 'fail') {
- this.get_goods_data();
- this.$notify({
- title: '成功',
- message: '删除成功',
- type: 'success',
- duration: 2000,
- });
- } else {
- failproccess(response, this.$notify);
- }
- });
- });
- },
- handleSwitchChange(index,row) {
- console.log(row.goodsEnabled);
- this.updateGoodsStatusByIdParm.parammaps.id = row.id;
- this.updateGoodsStatusByIdParm.parammaps.goodsEnabled = row.goodsEnabled;
- // if (row.goodsEnabled == 1 ){
- // console.log("00000000000000");
- // this.updateGoodsStatusByIdParm.parammaps.goodsEnabled = 0;
- // }else{
- // console.log("1111111111111111111");
- // this.updateGoodsStatusByIdParm.parammaps.goodsEnabled = 1;
- // }
- // 调用API更新状态
- PostDataByName(this.updateGoodsStatusByIdParm).then(response => {
- if (response.msg !== 'fail') {
- // 更新前端状态
- this.get_goods_data();
- // 显示成功通知
- this.$notify({
- title: '成功',
- message: '修改成功',
- type: 'success',
- duration: 2000,
- });
- } else {
- // 处理失败情况
- failproccess(response, this.$notify);
- }
- });
- },
- form_search(){
- this.get_goods_data();
- },
- template_excel(){
- import('@/vendor/Export2Excel').then(excel => {
- const tHeader = [
- '货品类别',
- '货品编号',
- '货品名称',
- '货品规格',
- '货品型号',
- '计量单位',
- '用途',
- '录入人',
- '备注'
- ];
- excel.export_json_to_excel({
- header: tHeader,
- data: [],
- filename: '货品模板',
- autoWidth: true,
- bookType: 'xlsx'
- })
- })
- },
- derive_data(){
- this.get_goods_data()
- import('@/vendor/Export2Excel').then(excel => {
- const tHeader = [
- '货品名称',
- '货品编号',
- '货品规格',
- '货品型号',
- '计量单位',
- '用途',
- '录入人',
- '一级分类',
- '二级分类',
- '三级分类'
- ];
- const filterVal = [
- 'goodsName',
- 'goodsCode',
- 'goodsSpecification',
- 'goodsModel',
- 'goodsUnit',
- 'purpose',
- 'createrName',
- 'goodsTypeName1',
- 'goodsTypeName2',
- 'goodsTypeName'
- ];
- const data1 = this.formatJson(filterVal, this.list)
- excel.export_json_to_excel({
- header: tHeader,
- data: data1,
- filename: '货品导出',
- autoWidth: true,
- bookType: 'xlsx'
- })
- })
- },
- formatJson(filterVal, jsonData) {
- return jsonData.map(v =>
- filterVal.map(j => {
- if (j === 'timestamp') {
- return parseTime(v[j])
- } else {
- return v[j]
- }
- })
- )
- },
- form_add(){
- this.isShow = true;
- this.isView = false;
- console.log("form_add called, isView set to:", this.isView);
- this.dialogTitle = "新增货品"
- this.formLabelAlign.createrId = Cookies.get('employeid');
- this.formLabelAlign.date = this.getDefaultDate();
- this.dialogFormVisible = true;
- },
- getDefaultDate() {
- const today = new Date();
- const year = today.getFullYear();
- const month = String(today.getMonth() + 1).padStart(2, '0');
- const day = String(today.getDate()).padStart(2, '0');
- return `${year}-${month}-${day}`;
- },
- handleGet(row){
- this.dialogTitle = "查看货品";
- this.isView = true;
- this.dialogFormVisible = true;
- this.formLabelAlign.id = row.id;
- this.formLabelAlign.goodsModel = row.goodsModel;
- this.formLabelAlign.goodsImage = row.goodsImage;
- this.formLabelAlign.goodsTypeId = row.goodsTypeId;
- this.formLabelAlign.goodsCode = row.goodsCode;
- this.formLabelAlign.goodsName = row.goodsName;
- this.formLabelAlign.goodsSpecification = row.goodsSpecification;
- this.formLabelAlign.purpose = row.purpose;
- this.formLabelAlign.goodsEnabled = row.goodsEnabled;
- this.formLabelAlign.date = row.createTime;
- this.formLabelAlign.remarks = row.remarks;
- this.defaultCheckedKeys = [row.goodsTypeId];
- this.formLabelAlign.createrId = row.createrId;
- this.formLabelAlign.goodsUnitId= row.goodsUnitId;
- this.formLabelAlign.goodsUnit = row.goodsUnit;
- this.dialogImageUrl = row.goodsImagePath;
- const fileList = [];
- var urlObj = { "url": "", "response": { "execresult": { "LastInsertId": "" } } };
- urlObj.url = row.goodsImagePath;
- urlObj.response.execresult.LastInsertId = row.goodsImage;
- fileList.push(urlObj);
- this.fileList = fileList;
- },
- handleEdit(row){
- this.dialogTitle = "修改货品";
- this.isEdit = true;
- this.dialogFormVisible = true;
- this.formLabelAlign.id = row.id;
- this.formLabelAlign.goodsEnabled = row.goodsEnabled;
- this.formLabelAlign.goodsModel = row.goodsModel;
- this.formLabelAlign.goodsImage = row.goodsImage;
- this.formLabelAlign.goodsTypeId = row.goodsTypeId;
- this.formLabelAlign.goodsCode = row.goodsCode;
- this.formLabelAlign.goodsName = row.goodsName;
- this.formLabelAlign.goodsSpecification = row.goodsSpecification;
- this.formLabelAlign.purpose = row.purpose;
- this.formLabelAlign.date = row.createTime;
- this.formLabelAlign.remarks = row.remarks;
- this.defaultCheckedKeys = [row.goodsTypeId];
- this.formLabelAlign.createrId = row.createrId;
- this.formLabelAlign.goodsUnitId= row.goodsUnitId;
- this.formLabelAlign.goodsUnit = row.goodsUnit;
- this.dialogImageUrl = row.goodsImagePath;
- const fileList = [];
- var urlObj = { "url": "", "response": { "execresult": { "LastInsertId": "" } } };
- urlObj.url = row.goodsImagePath;
- urlObj.response.execresult.LastInsertId = row.goodsImage;
- fileList.push(urlObj);
- this.fileList = fileList;
- },
- popoverHide(checkedIds,checkedData) {
- if (checkedIds !== null) {
- this.getGoodsListParm.parammaps.goodsTypeId = checkedData.id
- } else {
- this.getGoodsListParm.parammaps.goodsTypeId ='';
- }
- },
- handleNodeClick(data, node) {
- console.log(data);
- this.getGoodsListParm.parammaps.goodsTypeId = data.id;
- this.get_goods_data_left();
- },
- get_goods_type_data() {
- GetDataByName(this.getGoodsTypeParm).then((response) => {
- if (response.data && response.data.list) {
- const list = response.data.list.map(item => ({
- ...item,
- pid: parseInt(item.pid),
- id: parseInt(item.id),
- }));
- this.goodsTypeData = transData(list, 'id', 'pid', 'children');
- for (let i = 0; i < response.data.list.length; i++) {
- response.data.list[i].goodsTypeName = response.data.list[i].goodsTypeName +'/' +response.data.list[i].goodsTypeCode
- }
- const list1 = response.data.list.map(item => ({
- ...item,
- pid: parseInt(item.pid),
- id: parseInt(item.id),
- }));
- this.goodsTypeData1 = transData(list1, 'id', 'pid', 'children');
- }
- });
- },
- get_emp_data(){
- GetDataByName(this.getEmployeesSelectParm).then((response) => {
- if (response.data && response.data.list) {
- this.empList = response.data.list;
- }else{
- this.empList = [];
- }
- });
- },
- get_goods_data() {
- if (
- this.getGoodsListParm.parammaps.inputDatetime2 !== undefined &&
- this.getGoodsListParm.parammaps.inputDatetime2 !== null
- ) {
- this.getGoodsListParm.parammaps.startTime = this.getGoodsListParm.parammaps.inputDatetime2[0]
- this.getGoodsListParm.parammaps.stopTime = this.getGoodsListParm.parammaps.inputDatetime2[1]
- } else {
- this.getGoodsListParm.parammaps.startTime = ''
- this.getGoodsListParm.parammaps.stopTime = ''
- }
- GetDataByName(this.getGoodsListParm).then((response) => {
- if (response.data && response.data.list) {
- this.list = response.data.list;
- this.listLoading = false;
- for (let i = 0; i < response.data.list.length; i++) {
- if (
- response.data.list[i].goodsImagePath !== null
- ) {
- this.list[i].goodsImagePath =
- process.env.VUE_APP_BASE_API + response.data.list[i].goodsImagePath;
- } else {
- this.list[i].goodsImagePath = ''
- }
- }
- this.pageNum = response.data.pageNum
- this.pageSize = response.data.pageSize
- this.total = response.data.total
- }else{
- this.list = [];
- this.listLoading = false;
- }
- });
- },
- get_dict_list(){
- GetDataByName(this.getDictList).then((response) => {
- if (response.data && response.data.list) {
- this.measureList = response.data.list;
- }
- });
- },
- get_goods_data_left() {
- if (
- this.getGoodsListParm.parammaps.inputDatetime2 !== undefined &&
- this.getGoodsListParm.parammaps.inputDatetime2 !== null
- ) {
- this.getGoodsListParm.parammaps.startTime = this.getGoodsListParm.parammaps.inputDatetime2[0]
- this.getGoodsListParm.parammaps.stopTime = this.getGoodsListParm.parammaps.inputDatetime2[1]
- } else {
- this.getGoodsListParm.parammaps.startTime = ''
- this.getGoodsListParm.parammaps.stopTime = ''
- }
- GetDataByName(this.getGoodsListParm).then((response) => {
- if (response.data && response.data.list) {
- this.list = response.data.list;
- this.listLoading = false;
- for (let i = 0; i < response.data.list.length; i++) {
- if (
- response.data.list[i].goodsImagePath !== null
- ) {
- this.list[i].goodsImagePath =
- process.env.VUE_APP_BASE_API + response.data.list[i].goodsImagePath;
- } else {
- this.list[i].goodsImagePath = ''
- }
- }
- this.pageNum = response.data.pageNum
- this.pageSize = response.data.pageSize
- this.total = response.data.total
- }else{
- this.list = [];
- this.listLoading = false;
- }
- this.getGoodsListParm.parammaps.goodsTypeId = '';
- });
- }
- },
- computed: {
- // 设置请求头
- headers() {
- return {
- // 设置token
- token: getToken()
- }
- },
- uploadData() {
- return {
- name: 'importGoodsExecl',
- importParams: '货品类别,货品编号,货品名称,货品规格,货品型号,计量单位,用途,录入人,备注',
- sheetname: 'SheetJS'
- }
- }
- },
- created() {
- console.log('defaultProps:', this.defaultProps);
- console.log('getGoodsListParm:', this.getGoodsListParm);
- this.get_goods_type_data();
- this.get_emp_data();
- this.get_dict_list();
- this.get_goods_data();
- },
- };
- </script>
- <style scoped>
- .inline-form-item {
- display: flex;
- align-items: center;
- }
- .inline-form-item .el-form-item__label {
- margin-right: 10px; /* 调整标签和输入框之间的间距 */
- }
- ::v-deep .el-tree-node {
- margin-bottom: 5px; /* 调整节点之间的间距 */
- }
- ::v-deep .el-tree-node__label {
- font-size: 20px; /* 调整字体大小 */
- }
- </style>
- <style>
- .app-container {
- padding: 10px;
- margin-left: 10px;
- }
- .search-button-container {
- padding: 10px;
- padding-left: 20px;
- }
- .typeSelect span .el-popover__reference .el-input--suffix {
- top: -3px;
- .el-input__inner {
- height: 40px !important;
- }
- }
- .filter-item {
- margin-left: 10px; /* 设置左边距 */
- }
- .inputDatetime {
- padding: 0;
- margin: 0 10px;
- margin-left: 10px;
- }
- .search-button {
- padding: 10px 20px;
- border: 0.01px solid #ccc; /* 黑色边框,宽度为 2px */
- margin-right: 10px;
- }
- .search-button-upload {
- padding: 10px 20px;
- border: 0.01px solid #ccc; /* 黑色边框,宽度为 2px */
- margin-right: 20px;
- }
- .el-table .warning-row {
- background: oldlace;
- }
- .el-table .success-row {
- background: #f0f9eb;
- }
- .form-item {
- width:40%;
- display: flex;
- flex-direction: column;
- gap: 10px; /* 调整内部间距 */
- }
- #uploadPic {
- width: 700px;
- }
- .dialog-footer{
- right:10px;
- position:absolute;
- bottom:10px;
- }
- .add-button {
- background-color: #2196f3; /* 绿色背景 */
- color: white; /* 白色文字 */
- padding: 10px 20px; /* 内边距 */
- border-radius: 5px; /* 圆角 */
- cursor: pointer; /* 鼠标悬停时显示手型 */
- font-size: 16px; /* 字体大小 */
- transition: background-color 0.3s ease; /* 背景颜色过渡效果 */
- padding: 8px 12px;
- margin: 15px 30px;
- border: 0.01px solid #ccc; /* 黑色边框,宽度为 2px */
- }
- </style>
|