n20-common-lib 1.3.192 → 1.3.194

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": "n20-common-lib",
3
- "version": "1.3.192",
3
+ "version": "1.3.194",
4
4
  "private": false,
5
5
  "main": "src/index.js",
6
6
  "scripts": {
@@ -6,12 +6,7 @@
6
6
  :options="areaTree"
7
7
  :filterable="filterable"
8
8
  :clearable="clearable"
9
- :props="{
10
- value: 'regionNo',
11
- label: 'regionName',
12
- children: 'children',
13
- expandTrigger: 'hover'
14
- }"
9
+ :props="propsAs"
15
10
  v-on="$listeners"
16
11
  />
17
12
  </template>
@@ -44,6 +39,10 @@ export default {
44
39
  countryId: {
45
40
  type: String,
46
41
  default: 'CHN'
42
+ },
43
+ props: {
44
+ type: Object,
45
+ default: undefined
47
46
  }
48
47
  },
49
48
  data() {
@@ -52,6 +51,15 @@ export default {
52
51
  }
53
52
  },
54
53
  computed: {
54
+ propsAs() {
55
+ let _prop = {
56
+ value: 'regionNo',
57
+ label: 'regionName',
58
+ children: 'children',
59
+ expandTrigger: 'hover'
60
+ }
61
+ return Object.assign(_prop, this.props)
62
+ },
55
63
  areaKey() {
56
64
  return this.countryId === 'CHN' ? '_china_area_tree_' : `_${this.countryId}_area_tree_`
57
65
  },
@@ -2,9 +2,9 @@
2
2
  <!--结算 日 周 月 年 时间选择控件封装 -->
3
3
  <div class="n20-date-select">
4
4
  <el-select v-model="type" placeholder="请选择" style="width: 65px" @change="dateTypeSelectChange">
5
- <el-option v-for="(item, index) in SelectList" :key="index" :label="item" :value="item" />
5
+ <el-option v-for="(item, index) in selectList" :key="index" :label="item" :value="item" />
6
6
  </el-select>
7
- <el-date-picker
7
+ <date-picker
8
8
  v-if="type === '日'"
9
9
  key="day"
10
10
  v-model="day"
@@ -16,10 +16,10 @@
16
16
  placeholder="选择日"
17
17
  @change="dayChange"
18
18
  />
19
- <el-date-picker
19
+ <date-picker
20
20
  v-if="type === '周'"
21
- v-model="week"
22
21
  key="week"
22
+ v-model="week"
23
23
  format="yyyy 第 WW 周"
24
24
  type="week"
25
25
  :picker-options="{ firstDayOfWeek: 1 }"
@@ -28,10 +28,10 @@
28
28
  @change="weekChange"
29
29
  />
30
30
 
31
- <el-date-picker
31
+ <date-picker
32
32
  v-if="type === '月'"
33
- v-model="month"
34
33
  key="month"
34
+ v-model="month"
35
35
  type="month"
36
36
  format="yyyy-MM"
37
37
  value-format="yyyy-MM"
@@ -39,9 +39,10 @@
39
39
  placeholder="选择月"
40
40
  @change="monthChange"
41
41
  />
42
- <quarter-date-picker key="quarter" v-if="type === '季'" v-model="quarter" @change="handleChange" />
43
- <el-date-picker key="year"
42
+ <quarter-date-picker v-if="type === '季'" key="quarter" v-model="quarter" @change="handleChange" />
43
+ <date-picker
44
44
  v-if="type === '年'"
45
+ key="year"
45
46
  v-model="year"
46
47
  type="year"
47
48
  format="yyyy"
@@ -54,13 +55,12 @@
54
55
  </template>
55
56
 
56
57
  <script>
58
+ import datePicker from '../DatePicker/index.vue'
57
59
  import quarterDatePicker from './quarterDatePicker'
58
60
  import dayjs from 'dayjs'
59
61
  export default {
60
62
  name: 'SelectDatePicker',
61
- components: {
62
- quarterDatePicker
63
- },
63
+ components: { datePicker, quarterDatePicker },
64
64
  props: {
65
65
  value: {
66
66
  type: [Array, String, Object],
@@ -72,7 +72,7 @@ export default {
72
72
  type: String,
73
73
  default: '日'
74
74
  },
75
- SelectList: {
75
+ selectList: {
76
76
  type: Array,
77
77
  default: () => {
78
78
  return ['日', '周', '月', '季', '年']
@@ -63,7 +63,7 @@
63
63
  clearable
64
64
  @focus="changeFocus"
65
65
  >
66
- <i slot="prefix" class="el-input__icon el-icon-date"></i>
66
+ <i slot="suffix" class="el-input__icon el-icon-date" :class="showValue && 'quarter-date-icon'"></i>
67
67
  </el-input>
68
68
  </el-popover>
69
69
  </template>
@@ -167,5 +167,8 @@ export default {
167
167
  }
168
168
  }
169
169
  </script>
170
-
171
- <style lang="scss"></style>
170
+ <style>
171
+ .el-date-editor:hover .quarter-date-icon {
172
+ display: none;
173
+ }
174
+ </style>
@@ -27,10 +27,10 @@
27
27
  </div>
28
28
  <div class="text-c m-t m-b">
29
29
  <slot name="actions">
30
- <el-button size="mini" type="primary" style="width: 76px" @click="filter">
30
+ <el-button type="primary" @click="filter">
31
31
  {{ filterText }}
32
32
  </el-button>
33
- <el-button size="mini" plain style="width: 76px" @click="clear">
33
+ <el-button plain @click="clear">
34
34
  {{ clearText }}
35
35
  </el-button>
36
36
  </slot>
@@ -1,11 +1,13 @@
1
1
  <template>
2
2
  <div class="n20-num-w" @mouseenter="isHove = true" @mouseleave="isHove = false">
3
3
  <el-input
4
+ ref="input"
4
5
  v-model="valueStr"
5
6
  class="n20-stc"
6
7
  :disabled="disabled"
7
8
  :placeholder="phd"
8
9
  :clearable="isClearable"
10
+ :validate-event="false"
9
11
  @clear="closeFn"
10
12
  @focus="focusFn"
11
13
  @input="inputFn"
@@ -24,9 +26,12 @@
24
26
 
25
27
  <script>
26
28
  import { $lc } from '../../utils/i18n/index'
27
- import numerify from 'numerify'
29
+ import emitter from '../../utils/element-ui-emitter'
30
+ import N from '../../utils/numberPor'
31
+
28
32
  export default {
29
33
  name: 'InputNumber',
34
+ mixins: [emitter],
30
35
  props: {
31
36
  value: {
32
37
  type: [Number, String],
@@ -41,11 +46,11 @@ export default {
41
46
  },
42
47
  min: {
43
48
  type: Number,
44
- default: -9999999999999
49
+ default: -9999999999999.99
45
50
  },
46
51
  max: {
47
52
  type: Number,
48
- default: 9999999999999
53
+ default: 9999999999999.99
49
54
  },
50
55
  step: {
51
56
  type: Number,
@@ -78,6 +83,10 @@ export default {
78
83
  suffix: {
79
84
  type: String,
80
85
  default: '%'
86
+ },
87
+ rangeAuto: {
88
+ type: Boolean,
89
+ default: false
81
90
  }
82
91
  },
83
92
  data() {
@@ -98,36 +107,37 @@ export default {
98
107
  } else {
99
108
  return $lc('请输入金额')
100
109
  }
110
+ },
111
+ fNum() {
112
+ if (this.format) {
113
+ let i_f = this.format.indexOf('.')
114
+ return i_f === -1 ? 0 : this.format.length - i_f - 1
115
+ }
116
+ if (this.dNum) {
117
+ return this.dNum
118
+ }
119
+ if (this.type === 'rate') {
120
+ return 4
121
+ }
122
+ if (this.type === 'money') {
123
+ return 2
124
+ }
125
+ return 2
101
126
  }
102
127
  },
103
128
  watch: {
104
129
  value: {
105
130
  handler(val) {
106
- if (val && typeof val === 'string') {
107
- val = NumberP(val)
108
-
109
- this.$emit('input', isNaN(val) ? undefined : val)
110
- this.valueStr = this.num2str(val)
111
- return
131
+ if (this.rangeAuto) {
132
+ this.valueStr = N.addThousands(val)
133
+ } else {
134
+ this.valueStr = N.addThousands(N.subFixed(val, this.fNum))
112
135
  }
113
- this.valueStr = this.num2str(val)
114
136
  },
115
137
  immediate: true
116
138
  }
117
139
  },
118
140
  methods: {
119
- num2str(val = '') {
120
- if (val === '' || val === null || val === undefined) {
121
- return ''
122
- }
123
- switch (this.type) {
124
- case 'rate':
125
- return numerify(val, this.format || '0.0000')
126
- case 'money':
127
- default:
128
- return numerify(val, this.format || '0,0.00')
129
- }
130
- },
131
141
  focusFn() {
132
142
  this.isFocus = true
133
143
  if (!this.disabled && this.valueStr) {
@@ -143,7 +153,7 @@ export default {
143
153
  },
144
154
  stepFn(ev) {
145
155
  if ((ev.code === 'ArrowUp' || ev.code === 'ArrowDown') && !this.disabled) {
146
- let val = NumberP(this.valueStr)
156
+ let val = N(this.valueStr)
147
157
  if (!isNaN(val)) {
148
158
  ev.preventDefault()
149
159
  val = ev.code === 'ArrowUp' ? val + this.step : val - this.step
@@ -152,9 +162,11 @@ export default {
152
162
  } else if (val > this.max) {
153
163
  val = this.max
154
164
  }
155
-
156
- let valueStr = Number(val.toFixed(9)).toString()
157
- this.valueStr = valueStr
165
+ if (this.rangeAuto) {
166
+ this.valueStr = N.toString(val)
167
+ } else {
168
+ this.valueStr = N.subFixed(val, this.fNum)
169
+ }
158
170
  }
159
171
  }
160
172
  },
@@ -172,51 +184,42 @@ export default {
172
184
  this.changeIng = false
173
185
  })
174
186
 
175
- valStr = valStr.trim()
176
- let val = NumberP(valStr)
177
-
187
+ let val = N(valStr)
178
188
  if (isNaN(val)) {
179
189
  this.valueStr = ''
180
190
  this.$emit('input', undefined)
181
191
  this.$emit('change', undefined)
192
+ this.dispatch('ElFormItem', 'el.form.change', [undefined])
182
193
  return
183
194
  }
184
195
 
185
- if (val < this.min) {
186
- val = this.min
187
- } else if (val > this.max) {
188
- val = this.max
189
- } else if (this.stepStrictly) {
190
- let N = val / this.step
191
- if (Number(N.toFixed(9)) !== Math.round(N)) {
192
- val = Math.round(N) * this.step
196
+ let nStr
197
+ if (this.rangeAuto) {
198
+ nStr = N.toString(val)
199
+ this.valueStr = N.addThousands(valStr)
200
+ } else {
201
+ if (this.stepStrictly) {
202
+ let N = val / this.step
203
+ if (val % this.step !== 0) {
204
+ val = Math.round(N) * this.step
205
+ }
193
206
  }
207
+ if (val < this.min) {
208
+ val = this.min
209
+ } else if (val > this.max) {
210
+ val = this.max
211
+ }
212
+ nStr = N.subFixed(val, this.fNum)
213
+ this.valueStr = N.addThousands(nStr)
194
214
  }
195
- this.valueStr = this.num2str(val)
196
215
 
197
- switch (this.type) {
198
- case 'rate':
199
- {
200
- let dNum = this.dNum !== undefined ? this.dNum : 4
201
- let nVar = Number(val.toFixed(dNum))
202
- this.$nextTick(() => {
203
- this.$emit('input', nVar)
204
- this.$emit('change', nVar)
205
- })
206
- }
207
- break
208
- case 'money':
209
- default:
210
- {
211
- let dNum = this.dNum !== undefined ? this.dNum : 2
212
- let nVar = Number(val.toFixed(dNum))
213
- this.$nextTick(() => {
214
- this.$emit('input', nVar)
215
- this.$emit('change', nVar)
216
- })
217
- }
218
- break
219
- }
216
+ this.$nextTick(() => {
217
+ let nVar = Number(nStr)
218
+ this.$emit('input', nVar)
219
+ this.$emit('change', nVar)
220
+
221
+ this.dispatch('ElFormItem', 'el.form.change', [nVar])
222
+ })
220
223
  },
221
224
  closeFn() {
222
225
  this.$emit('input', undefined)
@@ -224,15 +227,4 @@ export default {
224
227
  }
225
228
  }
226
229
  }
227
-
228
- function NumberP(val) {
229
- if (typeof val === 'string') {
230
- val = val.replace(/,/g, '').trim()
231
- }
232
- if (val === undefined || val === null || val === '') {
233
- return NaN
234
- } else {
235
- return Number(val)
236
- }
237
- }
238
230
  </script>
@@ -398,11 +398,11 @@ export default {
398
398
  this.updateK = ''
399
399
  })
400
400
  } else {
401
- window.postMessage({
402
- updateActiveCache: true,
403
- targetName: '*',
404
- originName: 'main'
405
- })
401
+ // window.postMessage({
402
+ // updateActiveCache: true,
403
+ // targetName: '*',
404
+ // originName: 'main'
405
+ // })
406
406
  this.CompatibleUpdateCache(tab.route) // 兼容旧的子模块清除缓存
407
407
  }
408
408
  }
@@ -21,12 +21,12 @@ export default {
21
21
  numerify({ label, value }, f, w, unit = '') {
22
22
  unit = unit ? (unit === true ? $lc('元') : unit) : ''
23
23
  if (!w) {
24
- return numerify(value, f) + unit
24
+ return numerify(value, f, Math.floor) + unit
25
25
  } else {
26
26
  if (value > n) {
27
27
  return numerify(value / n, f) + $lc('万') + unit
28
28
  } else {
29
- return numerify(value, f) + unit
29
+ return numerify(value, f, Math.floor) + unit
30
30
  }
31
31
  }
32
32
  }
@@ -14,10 +14,10 @@ function tplFn(row, sc, mck, map = {}) {
14
14
  let type = kA[1]
15
15
  switch (type) {
16
16
  case 'money':
17
- str += numerify(row[key], '0,0.00')
17
+ str += numerify(row[key], '0,0.00', Math.floor)
18
18
  break
19
19
  case 'rate':
20
- str += numerify(row[key], '0.000000')
20
+ str += numerify(row[key], '0.000000', Math.floor)
21
21
  break
22
22
  case 'map':
23
23
  str += map[row[key]]
package/src/index.js CHANGED
@@ -1,4 +1,3 @@
1
- import './utils/importGlobal.js' // 联合加载组件保存位置
2
1
  import './utils/storagePro.js' // 扩展Storage
3
2
  /** 提供组件给外部使用的入口 */
4
3
  import ContentLoading from './components/ContentLoading/index.vue'
@@ -87,7 +86,10 @@ import VHas from './directives/VHas/index.js'
87
86
 
88
87
  /** 注入方法 */
89
88
  import dayjs from 'dayjs'
90
- import numerify from 'numerify'
89
+ import _numerify from 'numerify'
90
+ function numerify(input, formatType, roundingFunction) {
91
+ return _numerify(input, formatType, roundingFunction || Math.floor)
92
+ }
91
93
  import axios from './utils/axios.js'
92
94
  import auth from './utils/auth.js'
93
95
  import { msgPor, msgboxPor } from './utils/msgboxPor.js'
@@ -100,6 +102,8 @@ import list2tree from './utils/list2tree'
100
102
  import { has as isHas } from './directives/VHas/index.js'
101
103
  import { hasG as isHasG } from './directives/VHas/index.js'
102
104
  import asyncGetRelaNos from './utils/asyncGetRelaNos.js'
105
+ import importG from './utils/importGlobal.js' // 联合加载组件保存位置
106
+ import N from './utils/numberPor.js' // 扩展Number
103
107
 
104
108
  /** 国际化 */
105
109
  import i18n, { $l } from './utils/i18n'
@@ -220,7 +224,8 @@ export {
220
224
  // 方法
221
225
  auth,
222
226
  axios,
223
- getJsonc,
227
+ $l,
228
+ N,
224
229
  downloadBlob,
225
230
  forEachs,
226
231
  list2tree,
@@ -233,7 +238,8 @@ export {
233
238
  dayjs,
234
239
  numerify,
235
240
  asyncGetRelaNos,
236
- $l,
241
+ getJsonc,
242
+ importG,
237
243
  // 组件
238
244
  ContentLoading,
239
245
  ContentNull,
@@ -0,0 +1,19 @@
1
+ export default {
2
+ methods: {
3
+ dispatch(componentName, eventName, params) {
4
+ var parent = this.$parent || this.$root
5
+ var name = parent.$options.componentName
6
+
7
+ while (parent && (!name || name !== componentName)) {
8
+ parent = parent.$parent
9
+
10
+ if (parent) {
11
+ name = parent.$options.componentName
12
+ }
13
+ }
14
+ if (parent) {
15
+ parent.$emit.apply(parent, [eventName].concat(params))
16
+ }
17
+ }
18
+ }
19
+ }
@@ -0,0 +1,274 @@
1
+ /* eslint-disable no-extend-native */
2
+ let i = 1
3
+
4
+ // 去括号
5
+ const splitPts = function (obj) {
6
+ let mc = obj.mEl.match(/\([^()]+\)/g)
7
+ if (mc) {
8
+ mc.forEach((m) => {
9
+ let vk = 'El' + i++
10
+ obj.Els[vk] = m.replace(/\(|\)/g, '')
11
+ obj.mEl = obj.mEl.replace(m, vk)
12
+ })
13
+
14
+ return splitPts(obj)
15
+ } else {
16
+ return obj
17
+ }
18
+ }
19
+ // 负数转括号
20
+ const negToPts = function (Els, k) {
21
+ if (/\+-/.test(Els[k])) {
22
+ Els[k] = Els[k].replace(/\+-/, '-')
23
+ }
24
+
25
+ if (/--/.test(Els[k])) {
26
+ Els[k] = Els[k].replace(/--/, '+')
27
+ }
28
+
29
+ if (/\*-/.test(Els[k])) {
30
+ let mc = Els[k].match(/\*-[^+|-|*|/]+/g)
31
+ if (mc) {
32
+ mc.forEach((m) => {
33
+ let vk = 'El' + i++
34
+ Els[vk] = m.replace('*', '0')
35
+ Els[k] = Els[k].replace(m, '*' + vk)
36
+ })
37
+ }
38
+ }
39
+
40
+ if (/\/-/.test(Els[k])) {
41
+ let mc = Els[k].match(/\/-[^+|-|*|/]+/g)
42
+ if (mc) {
43
+ mc.forEach((m) => {
44
+ let vk = 'El' + i++
45
+ Els[vk] = m.replace('/', '0')
46
+ Els[k] = Els[k].replace(m, '/' + vk)
47
+ })
48
+ }
49
+ }
50
+ }
51
+ // 乘除转括号
52
+ const muldivToPts = function (Els, k) {
53
+ if (/\*|\//.test(Els[k]) && /\+|-/.test(Els[k])) {
54
+ let mc = Els[k].match(/[^+|-]*[*|/][^+|-]*/g)
55
+ if (mc) {
56
+ mc.forEach((m) => {
57
+ let vk = 'El' + i++
58
+ Els[vk] = m.replace(/\(|\)/g, '')
59
+ Els[k] = Els[k].replace(m, vk)
60
+ })
61
+ }
62
+ }
63
+ }
64
+ // 符号切割运算
65
+ const splitSmb = function (Els) {
66
+ for (let k in Els) {
67
+ Els[k + 'O'] = Els[k]
68
+ Els[k] = Els[k].replace(/\+|-|\*|\//g, (v) => ',' + v + ',')
69
+ Els[k] = Els[k].split(',')
70
+ }
71
+ }
72
+
73
+ const compute = function (Els, k, fc) {
74
+ let El = Els[k]
75
+ El.forEach((e, i) => {
76
+ if (/^El/.test(e)) {
77
+ El[i] = compute(Els, e, fc)
78
+ }
79
+ })
80
+
81
+ let L = El.length
82
+ let Val = Number(El[0])
83
+ for (let i = 1; i < L; i) {
84
+ if (['+', '-', '*', '/'].includes(El[i])) {
85
+ switch (El[i]) {
86
+ case '+':
87
+ Val = add(Val, Number(El[i + 1]), fc)
88
+ break
89
+ case '-':
90
+ Val = sub(Val, Number(El[i + 1]), fc)
91
+ break
92
+ case '*':
93
+ Val = mul(Val, Number(El[i + 1]), fc)
94
+ break
95
+ case '/':
96
+ Val = div(Val, Number(El[i + 1]), fc)
97
+ break
98
+ }
99
+ i += 2
100
+ }
101
+ }
102
+ return Val
103
+ }
104
+
105
+ function nFloor(n, f) {
106
+ return Number(subFixed(n, f))
107
+ }
108
+
109
+ export function add(m, n, decimal = 10) {
110
+ if (decimal) {
111
+ return nFloor(nFloor(m, decimal) + nFloor(n, decimal), decimal)
112
+ } else {
113
+ return m + n
114
+ }
115
+ }
116
+ export function sub(m, n, decimal = 10) {
117
+ if (decimal) {
118
+ return nFloor(nFloor(m, decimal) - nFloor(n, decimal), decimal)
119
+ } else {
120
+ return m - n
121
+ }
122
+ }
123
+ export function mul(m, n, decimal = 10) {
124
+ if (decimal) {
125
+ return nFloor(nFloor(m, decimal) * nFloor(n, decimal), decimal)
126
+ } else {
127
+ return m * n
128
+ }
129
+ }
130
+ export function div(m, n, decimal = 10) {
131
+ if (decimal) {
132
+ return nFloor(nFloor(m, decimal) / nFloor(n, decimal), decimal)
133
+ } else {
134
+ return m / n
135
+ }
136
+ }
137
+
138
+ /**
139
+ * @param {string} [evalStr='']
140
+ * @param {number} [decimal=10]
141
+ * @param {number} proceDecimal
142
+ * @return {number}
143
+ */
144
+ export function evaluate(evalStr = '', decimal = 10, proceDecimal) {
145
+ if (decimal) {
146
+ i = 1
147
+ let obj = { mEl: evalStr.replace(/\s/g, ''), Els: {} }
148
+
149
+ splitPts(obj)
150
+
151
+ let Els = obj.Els
152
+ Els['Elm'] = obj.mEl
153
+ obj = undefined
154
+
155
+ negToPts(Els, 'Elm')
156
+ for (let k in Els) {
157
+ k !== 'Elm' && negToPts(Els, k)
158
+ }
159
+
160
+ muldivToPts(Els, 'Elm')
161
+ for (let k in Els) {
162
+ k !== 'Elm' && muldivToPts(Els, k)
163
+ }
164
+
165
+ splitSmb(Els)
166
+
167
+ let RES = compute(Els, 'Elm', proceDecimal || decimal)
168
+ RES = nFloor(RES, decimal)
169
+ return RES
170
+ } else {
171
+ // eslint-disable-next-line no-eval
172
+ eval('window._number_eval_res=' + evalStr)
173
+ let RES = window._number_eval_res
174
+ delete window._number_eval_res
175
+ return RES
176
+ }
177
+ }
178
+ /**
179
+ * @param {number}
180
+ * @return {string}
181
+ */
182
+ export const subFixed = function (n, decimal = 6) {
183
+ let res = ''
184
+ if (n === undefined || n === null || n === '') return ''
185
+ let ns = toString(n)
186
+ if (isNaN(ns)) return ''
187
+
188
+ let nss = ns.split('.')
189
+ let intC = nss[0] || '0'
190
+ let floatC = nss[1] || ''
191
+ if (decimal > 0) {
192
+ let floatCn = ''
193
+ for (let i = 0; i < decimal; i++) {
194
+ let fIs = floatC[i] || '0'
195
+ floatCn = floatCn + fIs
196
+ }
197
+ res = intC + '.' + floatCn
198
+ } else {
199
+ res = intC
200
+ }
201
+ return res
202
+ }
203
+ /**
204
+ * @param {number}
205
+ * @return {string}
206
+ */
207
+ export const addThousands = function (n) {
208
+ let res = ''
209
+ if (n === undefined || n === null || n === '') {
210
+ return res
211
+ }
212
+
213
+ let ns = toString(n)
214
+
215
+ let intC = ''
216
+ let floatC = ''
217
+ let nss = ns.split('.')
218
+ if (nss.length === 2) {
219
+ intC = nss[0] || '0'
220
+ floatC = nss[1] || ''
221
+ } else {
222
+ intC = ns
223
+ }
224
+
225
+ let L = intC.length
226
+ let intT = ''
227
+ for (let i = 1; i <= L; i++) {
228
+ intT = intC[L - i] + intT
229
+ if (i % 3 === 0 && i !== L) {
230
+ intT = ',' + intT
231
+ }
232
+ }
233
+ if (floatC) {
234
+ res = intT + '.' + floatC
235
+ } else {
236
+ res = intT
237
+ }
238
+ return res
239
+ }
240
+
241
+ export const toString = function (n) {
242
+ let ns = n
243
+ if (typeof n === 'number') {
244
+ ns = n.toString()
245
+ if (ns.includes('e+')) {
246
+ ns = n.toLocaleString().replace(/,/g, '')
247
+ }
248
+ } else if (typeof n === 'string') {
249
+ ns = n.replace(/,/g, '').trim()
250
+ }
251
+ return ns
252
+ }
253
+
254
+ function N(val) {
255
+ if (typeof val === 'string') {
256
+ val = val.replace(/,/g, '').trim()
257
+ }
258
+ if (val === undefined || val === null || val === '') {
259
+ return NaN
260
+ } else {
261
+ return Number(val)
262
+ }
263
+ }
264
+ N.add = add
265
+ N.sub = sub
266
+ N.mul = mul
267
+ N.div = div
268
+ N.eval = evaluate
269
+ N.evaluate = evaluate
270
+ N.toString = toString
271
+ N.subFixed = subFixed
272
+ N.addThousands = addThousands
273
+
274
+ export default N