Compare commits

..

No commits in common. 'master' and 'chenlianjie' have entirely different histories.

  1. 2
      .env.development
  2. 1
      .env.production
  3. 4
      package.json
  4. 9
      src/components/Upload/index.vue
  5. 20
      src/main.js
  6. 42
      src/utils/index.js
  7. 14
      src/views/product/productAdd/components/CustomUpload.vue
  8. 3225
      src/views/product/productAdd/newIndex.vue
  9. 21
      src/views/product/productList/index.vue
  10. 6
      vue.config.js

@ -13,7 +13,7 @@ VUE_APP_DOMAIN = uat.xingoil.com/ws
# uat.xingoil.com/ws
# 开发环境,不会进行加密,会打印出数据1
VUE_APP_ENV = 'production'
VUE_APP_ENV = 'development'
#production
VUE_CLI_BABEL_TRANSPILE_MODULES = true

@ -12,4 +12,3 @@ VUE_APP_UPLOAD_PRIVATE_URL = '/adminapi/oil-dict/imageHandler/uploadProtectedImg
VUE_APP_ENV = 'production'
VUE_APP_DOMAIN = www.xingoil.com/ws

@ -12,9 +12,7 @@
"test:ci": "npm run lint && npm run test:unit",
"svgo": "svgo -f src/icons/svg --config=src/icons/svgo.yml",
"analyzer": "cross-env use_analyzer=true npm run dev",
"new": "plop",
"dev2": "set NODE_OPTIONS=--openssl-legacy-provider & vue-cli-service serve",
"build:prod2": "set NODE_OPTIONS=--openssl-legacy-provider & vue-cli-service build"
"new": "plop"
},
"husky": {
"hooks": {

@ -89,13 +89,12 @@ export default {
}
},
beforeAvatarUpload(file) {
console.log(file)
const isLt2M = file.size / 1024 > 5 * 1024
const isLt2M = file.size / 1024 < 500
if (isLt2M) {
this.$message.error('图片大小不能超过5M! 请重新上传!')
if (!isLt2M) {
this.$message.error('图片大小不能超过500KB! 请重新上传!')
}
return !isLt2M
return isLt2M
}
}
}

@ -1,11 +1,12 @@
import 'babel-polyfill'
import 'babel-polyfill'
import Vue from 'vue'
import router from './router'
import Cookies from 'js-cookie'
import Element from 'element-ui'
import { UTable, UTableColumn } from 'umy-ui'
import Element from 'element-ui'
import { UTable, UTableColumn } from 'umy-ui'
Vue.use(UTable)
Vue.use(UTableColumn)
Vue.use(UTableColumn)
import App from './App'
import store from './store'
import * as filters from './filters' // 全局过滤器
@ -23,23 +24,23 @@ import 'normalize.css/normalize.css'
import 'vue2-animate/dist/vue2-animate.min.css'
import './styles/element-variables.scss'
import 'element-ui/lib/theme-chalk/display.css'
import 'element-ui/lib/theme-chalk/display.css'
import 'wowjs/css/libs/animate.css'
import '@/styles/index.scss'
import '@/styles/index.scss'
import './icons' // icon
import './permission' // permission control
import { getToken, setToken, removeToken } from '@/utils/auth.js'
import pagesHeader from '@/components/pagesHeader'
import pagesHeader from '@/components/pagesHeader';
import SlideVerify from 'vue-monoplasty-slide-verify'
import '@/theme/index.scss'
import '@/theme/index.scss';
Vue.use(SlideVerify)
Vue.use(permission)
Vue.use(dragDialog)
Vue.use(dragDrawer)
Vue.use(GlobalComponents)
Vue.component('pagesHeader', pagesHeader)
Vue.component('pagesHeader', pagesHeader);
if (process.env.NODE_ENV === 'production') {
// 切换环境时执行代码
@ -56,7 +57,6 @@ Object.keys(filters).forEach(key => {
Vue.config.productionTip = false
Vue.prototype.$utils = utils
Vue.prototype.$bus = new Vue()
new Vue({
el: '#app',

@ -212,15 +212,7 @@ export function param2Obj(url) {
if (!search) {
return {}
}
return JSON.parse(
'{"' +
decodeURIComponent(search)
.replace(/"/g, '\\"')
.replace(/&/g, '","')
.replace(/=/g, '":"')
.replace(/\+/g, ' ') +
'"}'
)
return JSON.parse('{"' + decodeURIComponent(search).replace(/"/g, '\\"').replace(/&/g, '","').replace(/=/g, '":"').replace(/\+/g, ' ') + '"}')
}
/**
@ -296,7 +288,7 @@ export function getTime(type) {
export function debounce(func, wait, immediate) {
let timeout, args, context, timestamp, result
const later = function() {
const later = function () {
// 据上一次触发时间间隔
const last = +new Date() - timestamp
@ -313,7 +305,7 @@ export function debounce(func, wait, immediate) {
}
}
return function(...args) {
return function (...args) {
context = this
timestamp = +new Date()
const callNow = immediate && !timeout
@ -428,9 +420,9 @@ export function fileAdd(file, resolve, reject) {
const reader = new FileReader()
const image = new Image()
reader.readAsDataURL(file)
reader.onload = function() {
reader.onload = function () {
file.src = this.result
image.onload = function() {
image.onload = function () {
const width = image.width
const height = image.height
file.width = width
@ -452,7 +444,7 @@ export function startImgCompress(path, obj, resolve, reject) {
// path是指上传的图片,obj是压缩的品质,越低越模糊
var img = new Image()
img.src = path.src
img.onload = function() {
img.onload = function () {
var that = this // 这里的this 是把img的对象指向改变为that
// 默认按比例压缩
var w = that.width
@ -509,7 +501,7 @@ export function formatXML(xml, tab) {
var formatted = ''
var indent = ''
tab = tab || ' '
xml.split(/>\s*</).forEach(function(node) {
xml.split(/>\s*</).forEach(function (node) {
if (node.match(/^\/\w/)) indent = indent.substring(tab.length)
formatted += indent + '<' + node + '>\r\n'
if (node.match(/^<?\w[^>]*[^\/]$/)) indent += tab
@ -668,7 +660,7 @@ export const exportDefault = 'export default '
// 类型判断
export function typeJudgment(object) {
try {
let res = {}.__proto__.toString.call(object)
let res = {}.__proto__.toString.call(object);
// let type = /(?<= ).+(?=\])/.exec(res);
let type = res.replace(/[\[\]]/g, '').split(' ')
return type.length ? type[1] : ''
@ -676,21 +668,3 @@ export function typeJudgment(object) {
return ''
}
}
// url取参
export function urlParamsHandle(url) {
const search = url.split('?')[1]
if (!search) {
return {}
}
const result = {}
const searchArr = search.split('&')
searchArr.forEach(v => {
const index = v.indexOf('=')
if (index !== -1) {
const name = v.substring(0, index)
const val = v.substring(index + 1, v.length)
result[name] = val
}
})
return result
}

@ -5,7 +5,7 @@
list-type="picture-card">
<i slot="default" class="el-icon-plus"></i>
<div slot="file" slot-scope="{file}">
<img class="el-upload-list__item-thumbnail" :src="file.url" alt="">
<img class="el-upload-list__item-thumbnail" :src="file.url" alt="">
<span class="el-upload-list__item-actions">
<span class="el-upload-list__item-preview" @click="handlePictureCardPreview(file)">
<i class="el-icon-zoom-in"></i>
@ -16,9 +16,9 @@
<slot :file="file" name="imgButton">
</slot>
</span>
</div>
</div>
</el-upload>
<!-- <div style="width: 100%;display: flex;justify-content: center;">
<slot name="footer">
@ -31,7 +31,7 @@
</div>
</template>
<script>
<script>
export default {
props: {
limit: {
@ -57,7 +57,7 @@ export default {
this.fileList.push(Object.assign(file, { url }));
},
handleRemove(file) {
this.fileList = this.fileList.filter(item => item !== file)
this.fileList = this.fileList.filter(item => item.name !== file.name)
},
handlePictureCardPreview(file) {
this.dialogImageUrl = file.url;
@ -68,7 +68,7 @@ export default {
}
}
}
</script>
</script>
<style scoped lang="scss"> ::v-deep .hiedd .el-upload--picture-card {
display: none !important;
/* 上传按钮隐藏 */
@ -79,4 +79,4 @@ export default {
display: flex;
justify-content: center;
}
</style>
</style>

File diff suppressed because it is too large Load Diff

@ -32,9 +32,9 @@
<el-option label="平台商品" value="1"> </el-option>
</el-select>
</el-form-item>
<!-- <el-form-item label="油站名称:" label-for="siteName">
<el-form-item label="油站名称:" label-for="siteName">
<el-input clearable placeholder="请输入油站名称:" v-model="page.params.siteName" class="form_content_width" />
</el-form-item> -->
</el-form-item>
<el-form-item>
<el-button type="primary" @click="userSearchs">查询</el-button>
</el-form-item>
@ -125,13 +125,13 @@
</div>
</template>
</el-table-column>
<!-- <el-table-column label="油站" min-width="150" align="center">
<el-table-column label="油站" min-width="150" align="center">
<template slot-scope="scope">
<span>
{{ scope.row.siteName || '暂无' }}
</span>
</template>
</el-table-column> -->
</el-table-column>
<el-table-column label="库存" min-width="80">
<template slot-scope="scope">
<!-- <span>{{ scope.row.stockList.length }}</span> <br /> -->
@ -459,17 +459,8 @@ export default {
},
created() {
this.init()
this.$bus.$on('productRefresh', () => {
console.log('productRefresh')
this.init()
})
},
activated() {
// let { refresh } = this.$utils.urlParamsHandle(location.href)
// if (refresh) {
// this.init()
// }
},
activated() {},
methods: {
auditing(row, auditStatus) {
this.$prompt('审核', '提示', {
@ -720,7 +711,7 @@ export default {
},
//
edit(row) {
// console.log(row)
console.log(row)
this.$router.push({
path: '/product/productAdd',
query: {

@ -25,12 +25,12 @@ module.exports = {
proxy: {
[process.env.VUE_APP_BASE_API]: {
// target: `cls`,
// target: `http://192.168.0.254:38080`,
// target: `http://192.168.110.230:38080`,
target: `http://192.168.0.254:38080`,
// target: `http://192.168.0.24:38080`,
// target: `http://192.168.1.83:38080`,
// target: 'http://222.132.26.119:8081',
// target: `https://www.xingoil.com/adminapi`,
target: 'http://uat.xingoil.com/adminapi',
// target: 'http://uat.xingoil.com/adminapi',
changeOrigin: true,
pathRewrite: {
['^' + process.env.VUE_APP_BASE_API]: ''

Loading…
Cancel
Save