xianniu-ui 0.8.0 → 0.8.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "xianniu-ui",
3
- "version": "0.8.0",
3
+ "version": "0.8.3",
4
4
  "private": false,
5
5
  "main": "lib/xianniu-ui.umd.min.js",
6
6
  "scripts": {
@@ -6,6 +6,20 @@
6
6
  }
7
7
  }
8
8
  }
9
+ &.is-idcard {
10
+ overflow: hidden;
11
+ .el-upload--picture-card {
12
+ width: 100%;
13
+ height: 100%;
14
+ }
15
+ .el-upload-list--picture-card {
16
+ .el-upload-list__item {
17
+ width: 100%;
18
+ height: 100%;
19
+ line-height: normal;
20
+ }
21
+ }
22
+ }
9
23
  &-list__item {
10
24
  &-file {
11
25
  height: 100%;
@@ -58,10 +72,7 @@
58
72
  }
59
73
  }
60
74
  }
61
- // &-main {
62
-
63
- // }
64
- .el-upload-list {
75
+ &:not(.is-idcard) .el-upload-list {
65
76
  &.el-upload-list--picture-card {
66
77
  .el-upload-list__item {
67
78
  width: 80px;
@@ -72,28 +83,29 @@
72
83
  }
73
84
  }
74
85
  }
75
- .el-upload {
76
- &.el-upload--picture-card {
77
- width: 80px;
78
- height: 80px;
79
- line-height: 80px;
80
- font-size: 14px;
81
- position: relative;
82
- .el-upload-list__item {
86
+ &:not(.is-idcard) {
87
+ .el-upload{
88
+ &.el-upload--picture-card {
83
89
  width: 80px;
84
90
  height: 80px;
85
- img.el-upload-list__item-thumbnail {
86
- object-fit: cover;
91
+ line-height: 80px;
92
+ font-size: 14px;
93
+ position: relative;
94
+ .el-upload-list__item {
95
+ width: 80px;
96
+ height: 80px;
97
+ img.el-upload-list__item-thumbnail {
98
+ object-fit: cover;
99
+ }
87
100
  }
88
- }
89
- .upload-limit {
90
- width: inherit;
91
- height: inherit;
92
- i {
93
- font-size: 20px;
101
+ .upload-limit {
102
+ width: inherit;
103
+ height: inherit;
104
+ i {
105
+ font-size: 20px;
106
+ }
94
107
  }
95
108
  }
96
-
97
109
  }
98
110
  }
99
111
  &--slot {
@@ -106,8 +118,6 @@
106
118
  width: 100%;
107
119
  height: 100%;
108
120
  .el-progress {
109
- width: 70%;
110
- height: auto;
111
121
  .el-progress-circle {
112
122
  width: 99% !important;
113
123
  height: 99% !important;
@@ -132,4 +142,9 @@
132
142
  border-radius: 0 0 0 0;
133
143
  }
134
144
  }
145
+ .el-upload-list__item {
146
+ .el-progress{
147
+ width: 50%;
148
+ }
149
+ }
135
150
  }
@@ -0,0 +1,137 @@
1
+ <template>
2
+ <div class="xn-idcard" :style="objStyle">
3
+ <img v-if="type === 'front' && url === ''" src="" >
4
+
5
+ <img v-if="type === 'back' && url === ''" src="" >
6
+ <div v-if="url" class="xn-idcard-img">
7
+ <img :src="url" alt="" />
8
+ </div>
9
+ <div v-if="url === ''" class="tip">
10
+ <i class="el-icon-upload" />
11
+ <span>点击上传{{ type === "front" ? "人像" : "国徽" }}面</span>
12
+ </div>
13
+ <el-dialog
14
+ title="查看"
15
+ append-to-body
16
+ :visible.sync="isShowView"
17
+ width="650px"
18
+ >
19
+ <div class="rotate" :style="rotateSty">
20
+ <el-image style="width: 100%" :src="previewUrl" fit="cover" />
21
+ </div>
22
+ <div class="text-center" style="position: relative">
23
+ <el-button
24
+ type="primary"
25
+ icon="el-icon-refresh-left"
26
+ @click="onRotate(1)"
27
+ />
28
+ <el-button
29
+ type="primary"
30
+ icon="el-icon-refresh-right"
31
+ @click="onRotate(2)"
32
+ />
33
+ </div>
34
+ </el-dialog>
35
+ </div>
36
+ </template>
37
+
38
+ <script>
39
+ export default {
40
+ name: "XnIdcard",
41
+ props: {
42
+ type: {
43
+ type: String,
44
+ default: "front",
45
+ validator: (val) => {
46
+ return ["front", "back"].includes(val);
47
+ },
48
+ },
49
+ url: {
50
+ type: String,
51
+ default: "",
52
+ },
53
+ width: {
54
+ type: Number,
55
+ default: 300,
56
+ },
57
+ },
58
+ data() {
59
+ return {
60
+ isShowView: false,
61
+ previewUrl: "",
62
+ rotate: 0,
63
+ };
64
+ },
65
+ computed: {
66
+ objStyle() {
67
+ const { width } = this;
68
+ return {
69
+ width: `${width}px`,
70
+ height: `${width / 1.59}px`,
71
+ };
72
+ },
73
+ rotateSty() {
74
+ return {
75
+ transform: `rotate(${this.rotate}deg)`,
76
+ };
77
+ },
78
+ },
79
+ methods: {
80
+ handlePreview(url) {
81
+ this.previewUrl = url;
82
+ this.isShowView = true;
83
+ },
84
+ onRotate(type) {
85
+ if (type === 1) {
86
+ this.rotate -= 90;
87
+ } else {
88
+ this.rotate += 90;
89
+ }
90
+ },
91
+ getIdcardSize(){
92
+ return this.objStyle
93
+ }
94
+ },
95
+ };
96
+ </script>
97
+
98
+ <style lang="scss" scoped>
99
+ ::v-deep .el-dialog__body {
100
+ overflow: hidden;
101
+ }
102
+ .rotate {
103
+ width: 100%;
104
+ height: 100%;
105
+ transition: all 0.2s ease-in-out;
106
+ overflow: hidden;
107
+ }
108
+ .xn-idcard {
109
+ position: relative;
110
+ border-radius: 10px;
111
+ overflow: hidden;
112
+ img {
113
+ display: block;
114
+ width: calc(100% - 2px);
115
+ height: 100%;
116
+ object-fit: cover;
117
+ }
118
+ .tip {
119
+ display: flex;
120
+ flex-direction: column;
121
+ position: absolute;
122
+ top: 50%;
123
+ left: 50%;
124
+ transform: translate(-50%, -50%);
125
+ font-size: 16px;
126
+ color: #999;
127
+ text-align: center;
128
+ i {
129
+ font-size: 36px;
130
+ }
131
+ span{
132
+ line-height: 1.5;
133
+
134
+ }
135
+ }
136
+ }
137
+ </style>
@@ -3,22 +3,28 @@
3
3
  ref="upload"
4
4
  :class="{
5
5
  'is-disabled': $attrs.disabled != undefined,
6
- 'is-hidden': preview,
6
+ 'is-hidden': preview || hideUpload || isHidden,
7
+ 'is-idcard': listType === 'idcard',
7
8
  }"
8
- class="xn-upload xn-upload-main"
9
+ class="xn-upload"
9
10
  action="###"
10
11
  :limit="limit"
11
- :list-type="listType"
12
+ :list-type="listType === 'idcard' ? 'picture-card' : listType"
12
13
  v-bind="$attrs"
13
14
  :file-list.sync="fileList"
14
15
  :http-request="onHttpUpload"
15
16
  :on-error="onError"
16
17
  :before-upload="onBeforeUpload"
17
- :style="styles"
18
+ :style="{ ...styles,...idCardSizeData }"
18
19
  :on-exceed="onExceed"
19
20
  :on-change="onChange"
20
21
  >
21
- <template v-if="listType === 'picture-card'">
22
+ <template v-if="listType === 'idcard'">
23
+ <template slot="trigger">
24
+ <idCard ref="idcard" :type="type" />
25
+ </template>
26
+ </template>
27
+ <template v-else-if="listType === 'picture-card'">
22
28
  <div slot="trigger" class="upload-limit">
23
29
  <i class="el-icon el-icon-plus" />
24
30
  </div>
@@ -30,11 +36,12 @@
30
36
  >
31
37
  </slot>
32
38
  </template>
39
+
33
40
  <div
34
41
  slot="file"
35
42
  slot-scope="{ file }"
36
43
  class="xn-upload--slot"
37
- v-if="listType === 'picture-card'"
44
+ v-if="['picture-card', 'idcard'].includes(listType)"
38
45
  >
39
46
  <uploadPop :file="file" @on-download="handleDownload(file)"></uploadPop>
40
47
  <template v-if="$utils.isImg(file)">
@@ -42,7 +49,6 @@
42
49
  class="el-upload-list__item-thumbnail"
43
50
  :src="file.url"
44
51
  fit="cover"
45
- :lazy="true"
46
52
  />
47
53
  </template>
48
54
  <template v-else>
@@ -58,7 +64,7 @@
58
64
  <el-progress
59
65
  :status="file.percentage === 100 && !isUploading ? 'success' : null"
60
66
  type="circle"
61
- :percentage="process(file.percentage)"
67
+ :percentage="process(file.percentage || 0)"
62
68
  :stroke-width="6"
63
69
  />
64
70
  </div>
@@ -77,7 +83,7 @@
77
83
  <i class="fz-16 el-icon-download" />
78
84
  </span>
79
85
  <span
80
- v-if="!$attrs.disabled && !preview"
86
+ v-if="(!$attrs.disabled && !preview) || hideUpload"
81
87
  class="el-upload-list__item-delete icon ml-5"
82
88
  @click="handleRemove(file, fileList)"
83
89
  >
@@ -99,6 +105,7 @@
99
105
  import ElImageViewer from "element-ui/packages/image/src/image-viewer";
100
106
  import Client from "@/oss";
101
107
  import uploadPop from "./upload-pop.vue";
108
+ import idCard from "./idCard.vue";
102
109
  // const MAX_WARNING = 1024 * 10 * 1024;
103
110
  export default {
104
111
  name: "XnUpload",
@@ -106,6 +113,7 @@ export default {
106
113
  components: {
107
114
  uploadPop,
108
115
  ElImageViewer,
116
+ idCard,
109
117
  },
110
118
  props: {
111
119
  listType: {
@@ -141,6 +149,17 @@ export default {
141
149
  type: Object,
142
150
  default: () => {},
143
151
  },
152
+ hideUpload: {
153
+ type: Boolean,
154
+ default: false,
155
+ },
156
+ type: {
157
+ type: String,
158
+ default: "front",
159
+ validator: (val) => {
160
+ return ["front", "back"].includes(val);
161
+ },
162
+ },
144
163
  },
145
164
  data() {
146
165
  return {
@@ -154,6 +173,7 @@ export default {
154
173
  file: {},
155
174
  oss: null,
156
175
  client: null,
176
+ idCardSizeData: {},
157
177
  };
158
178
  },
159
179
  computed: {
@@ -180,11 +200,19 @@ export default {
180
200
  stsUrl: this.$XN.stsUrl || "",
181
201
  setFileIdUrl: this.$XN.setFileIdUrl || "",
182
202
  });
203
+ this.idCardSize()
183
204
  },
184
205
  beforeDestroy() {
185
206
  this.$emit("update:fileList", []);
186
207
  },
187
208
  methods: {
209
+ async idCardSize() {
210
+ if (this.listType !== "idcard") return {};
211
+ this.$nextTick(() => {
212
+ this.idCardSizeData =
213
+ this.$refs.idcard && this.$refs.idcard.getIdcardSize();
214
+ });
215
+ },
188
216
  async onBeforeUpload(file) {
189
217
  this.file = file;
190
218
  return Promise.all([
@@ -277,10 +305,9 @@ export default {
277
305
  },
278
306
  async handleDownload(file) {
279
307
  const { url, name } = file;
280
- return this.$utils.download({url, name})
308
+ return this.$utils.download({ url, name });
281
309
  },
282
310
  handleRemove(file, fileList) {
283
- console.log('file, fileList: ', file, fileList,this.files);
284
311
  fileList.forEach((item, idx) => {
285
312
  if (file.uid === item.uid) {
286
313
  fileList.splice(idx, 1);
@@ -65,7 +65,6 @@ const download = (params = { name: '', url: '' }) => {
65
65
  name: '下载模板'
66
66
  }
67
67
  const _params = Object.assign(defaultParams, params)
68
- console.log('_params: ', _params);
69
68
  const { url, name } = _params
70
69
  const x = new XMLHttpRequest();
71
70
  x.open("GET", url, true);
@@ -116,10 +115,32 @@ const arrMerge = (arr = [], key = '') => {
116
115
  }
117
116
  return result
118
117
  }
118
+ // 判空
119
+ const isBlank = (str) => {
120
+ if (str === null || (!str && str !== 0)) {
121
+ return true
122
+ }
123
+ return false
124
+ }
125
+ /* 重置方法 */
126
+ const reset = (obj) => {
127
+ for (const key in obj) {
128
+ if (Array.isArray(obj[key])) {
129
+ obj[key] = []
130
+ } else if (typeof obj[key] === 'object') {
131
+ obj[key] = reset(obj[key])
132
+ } else {
133
+ obj[key] = ''
134
+ }
135
+ }
136
+ return obj
137
+ }
119
138
  export default {
120
139
  isEmpty,
121
140
  isImg,
122
141
  deepClone,
123
142
  download,
124
- arrMerge
143
+ arrMerge,
144
+ reset,
145
+ isBlank
125
146
  }