@yelon/util 15.2.0 → 15.2.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (229) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +22 -22
  3. package/analysis/global-event.subject.d.ts +7 -0
  4. package/analysis/index.d.ts +1 -0
  5. package/array/array-type.service.d.ts +68 -68
  6. package/array/array.service.d.ts +78 -78
  7. package/array/index.d.ts +2 -2
  8. package/browser/cookie.service.d.ts +67 -67
  9. package/browser/copy.d.ts +6 -6
  10. package/browser/index.d.ts +5 -5
  11. package/browser/is-empty.d.ts +6 -6
  12. package/browser/scroll.service.d.ts +37 -37
  13. package/browser/style.d.ts +21 -21
  14. package/config/abc/date-picker.type.d.ts +52 -52
  15. package/config/abc/error-collect.type.d.ts +10 -10
  16. package/config/abc/exception.type.d.ts +9 -9
  17. package/config/abc/image.type.d.ts +15 -15
  18. package/config/abc/index.d.ts +17 -17
  19. package/config/abc/loading.type.d.ts +31 -31
  20. package/config/abc/lodop.type.d.ts +33 -33
  21. package/config/abc/media.type.d.ts +11 -11
  22. package/config/abc/onboarding.type.d.ts +4 -4
  23. package/config/abc/page-header.type.d.ts +39 -39
  24. package/config/abc/pdf.type.d.ts +35 -35
  25. package/config/abc/qr.type.d.ts +25 -25
  26. package/config/abc/se.type.d.ts +32 -32
  27. package/config/abc/sg.type.d.ts +10 -10
  28. package/config/abc/st.type.d.ts +465 -465
  29. package/config/abc/sv.type.d.ts +14 -14
  30. package/config/abc/xlsx.type.d.ts +12 -12
  31. package/config/abc/zip.type.d.ts +10 -10
  32. package/config/acl/acl.type.d.ts +32 -32
  33. package/config/auth/auth.type.d.ts +55 -55
  34. package/config/bis/bis.type.d.ts +7 -7
  35. package/config/cache/cache.type.d.ts +40 -40
  36. package/config/chart/chart.type.d.ts +33 -33
  37. package/config/config.service.d.ts +13 -13
  38. package/config/config.types.d.ts +48 -48
  39. package/config/index.d.ts +14 -14
  40. package/config/mock/mock.type.d.ts +18 -18
  41. package/config/sf/sf.type.d.ts +133 -133
  42. package/config/socket/socket.type.d.ts +4 -4
  43. package/config/theme/http.type.d.ts +14 -14
  44. package/config/theme/i18n.type.d.ts +14 -14
  45. package/config/theme/index.d.ts +3 -3
  46. package/config/theme/responsive.type.d.ts +12 -12
  47. package/config/util/array.type.d.ts +22 -22
  48. package/config/util/currency.type.d.ts +39 -39
  49. package/date-time/index.d.ts +2 -2
  50. package/date-time/picker.d.ts +68 -68
  51. package/date-time/time.d.ts +29 -29
  52. package/decorator/convert.d.ts +24 -24
  53. package/decorator/index.d.ts +2 -2
  54. package/decorator/zone-outside.d.ts +35 -35
  55. package/esm2020/analysis/analysis.mjs +5 -0
  56. package/esm2020/analysis/global-event.subject.mjs +17 -0
  57. package/esm2020/analysis/index.mjs +2 -0
  58. package/esm2020/array/array-type.service.mjs +1 -1
  59. package/esm2020/array/array.mjs +4 -4
  60. package/esm2020/array/array.service.mjs +276 -276
  61. package/esm2020/array/index.mjs +2 -2
  62. package/esm2020/browser/browser.mjs +4 -4
  63. package/esm2020/browser/cookie.service.mjs +102 -102
  64. package/esm2020/browser/copy.mjs +27 -27
  65. package/esm2020/browser/index.mjs +5 -5
  66. package/esm2020/browser/is-empty.mjs +18 -18
  67. package/esm2020/browser/scroll.service.mjs +87 -87
  68. package/esm2020/browser/style.mjs +37 -37
  69. package/esm2020/config/abc/date-picker.type.mjs +1 -1
  70. package/esm2020/config/abc/error-collect.type.mjs +1 -1
  71. package/esm2020/config/abc/exception.type.mjs +1 -1
  72. package/esm2020/config/abc/image.type.mjs +1 -1
  73. package/esm2020/config/abc/index.mjs +17 -17
  74. package/esm2020/config/abc/loading.type.mjs +1 -1
  75. package/esm2020/config/abc/lodop.type.mjs +1 -1
  76. package/esm2020/config/abc/media.type.mjs +1 -1
  77. package/esm2020/config/abc/onboarding.type.mjs +1 -1
  78. package/esm2020/config/abc/page-header.type.mjs +1 -1
  79. package/esm2020/config/abc/pdf.type.mjs +1 -1
  80. package/esm2020/config/abc/qr.type.mjs +1 -1
  81. package/esm2020/config/abc/se.type.mjs +1 -1
  82. package/esm2020/config/abc/sg.type.mjs +1 -1
  83. package/esm2020/config/abc/st.type.mjs +1 -1
  84. package/esm2020/config/abc/sv.type.mjs +2 -2
  85. package/esm2020/config/abc/xlsx.type.mjs +1 -1
  86. package/esm2020/config/abc/zip.type.mjs +1 -1
  87. package/esm2020/config/acl/acl.type.mjs +1 -1
  88. package/esm2020/config/auth/auth.type.mjs +1 -1
  89. package/esm2020/config/bis/bis.type.mjs +1 -1
  90. package/esm2020/config/cache/cache.type.mjs +1 -1
  91. package/esm2020/config/chart/chart.type.mjs +1 -1
  92. package/esm2020/config/config.mjs +4 -4
  93. package/esm2020/config/config.service.mjs +36 -36
  94. package/esm2020/config/config.types.mjs +8 -8
  95. package/esm2020/config/index.mjs +14 -14
  96. package/esm2020/config/mock/mock.type.mjs +1 -1
  97. package/esm2020/config/sf/sf.type.mjs +1 -1
  98. package/esm2020/config/socket/socket.type.mjs +1 -1
  99. package/esm2020/config/theme/http.type.mjs +1 -1
  100. package/esm2020/config/theme/i18n.type.mjs +1 -1
  101. package/esm2020/config/theme/index.mjs +3 -3
  102. package/esm2020/config/theme/responsive.type.mjs +1 -1
  103. package/esm2020/config/util/array.type.mjs +1 -1
  104. package/esm2020/config/util/currency.type.mjs +1 -1
  105. package/esm2020/date-time/date-time.mjs +4 -4
  106. package/esm2020/date-time/index.mjs +2 -2
  107. package/esm2020/date-time/picker.mjs +115 -115
  108. package/esm2020/date-time/time.mjs +88 -88
  109. package/esm2020/decorator/convert.mjs +57 -57
  110. package/esm2020/decorator/decorator.mjs +4 -4
  111. package/esm2020/decorator/index.mjs +2 -2
  112. package/esm2020/decorator/zone-outside.mjs +56 -56
  113. package/esm2020/form/form.mjs +4 -4
  114. package/esm2020/form/index.mjs +2 -2
  115. package/esm2020/form/match-control.mjs +29 -29
  116. package/esm2020/form/validators.mjs +80 -80
  117. package/esm2020/format/currency.service.mjs +237 -237
  118. package/esm2020/format/currency.types.mjs +7 -7
  119. package/esm2020/format/format.mjs +4 -4
  120. package/esm2020/format/index.mjs +4 -4
  121. package/esm2020/format/string.mjs +84 -84
  122. package/esm2020/format/validate.mjs +93 -93
  123. package/esm2020/index.mjs +13 -12
  124. package/esm2020/math/in-range.mjs +24 -24
  125. package/esm2020/math/index.mjs +2 -2
  126. package/esm2020/math/math.mjs +4 -4
  127. package/esm2020/math/round.mjs +52 -52
  128. package/esm2020/other/assert.mjs +66 -66
  129. package/esm2020/other/deep.mjs +77 -77
  130. package/esm2020/other/favicon.mjs +28 -28
  131. package/esm2020/other/index.mjs +7 -7
  132. package/esm2020/other/lazy.service.mjs +131 -131
  133. package/esm2020/other/logger.mjs +32 -32
  134. package/esm2020/other/other.mjs +4 -4
  135. package/esm2020/other/path-to-regexp.service.mjs +238 -238
  136. package/esm2020/other/resize.mjs +3 -3
  137. package/esm2020/pipes/currency/cny.pipe.mjs +22 -22
  138. package/esm2020/pipes/currency/index.mjs +4 -4
  139. package/esm2020/pipes/currency/mega.pipe.mjs +28 -28
  140. package/esm2020/pipes/currency/module.mjs +18 -18
  141. package/esm2020/pipes/currency/pipe-currency.mjs +4 -4
  142. package/esm2020/pipes/currency/price.pipe.mjs +26 -26
  143. package/esm2020/pipes/filter/filter.pipe.mjs +18 -18
  144. package/esm2020/pipes/filter/index.mjs +2 -2
  145. package/esm2020/pipes/filter/module.mjs +16 -16
  146. package/esm2020/pipes/filter/pipe-filter.mjs +4 -4
  147. package/esm2020/pipes/format/index.mjs +2 -2
  148. package/esm2020/pipes/format/mask.pipe.mjs +33 -33
  149. package/esm2020/pipes/format/module.mjs +16 -16
  150. package/esm2020/pipes/format/pipe-format.mjs +4 -4
  151. package/esm2020/pipes/index.mjs +3 -3
  152. package/esm2020/pipes/pipes.mjs +4 -4
  153. package/esm2020/token/index.mjs +2 -2
  154. package/esm2020/token/page-visibility.mjs +14 -14
  155. package/esm2020/token/token.mjs +4 -4
  156. package/esm2020/token/window.mjs +16 -16
  157. package/esm2020/yelon-util.mjs +4 -4
  158. package/fesm2015/analysis.mjs +24 -0
  159. package/fesm2015/analysis.mjs.map +1 -0
  160. package/fesm2015/array.mjs +254 -254
  161. package/fesm2015/browser.mjs +283 -283
  162. package/fesm2015/config.mjs +56 -56
  163. package/fesm2015/date-time.mjs +207 -207
  164. package/fesm2015/decorator.mjs +121 -121
  165. package/fesm2015/form.mjs +118 -118
  166. package/fesm2015/format.mjs +413 -413
  167. package/fesm2015/math.mjs +85 -85
  168. package/fesm2015/other.mjs +589 -589
  169. package/fesm2015/pipe-currency.mjs +96 -96
  170. package/fesm2015/pipe-filter.mjs +40 -40
  171. package/fesm2015/pipe-format.mjs +55 -55
  172. package/fesm2015/pipes.mjs +8 -8
  173. package/fesm2015/token.mjs +37 -37
  174. package/fesm2015/yelon-util.mjs +17 -16
  175. package/fesm2015/yelon-util.mjs.map +1 -1
  176. package/fesm2020/analysis.mjs +24 -0
  177. package/fesm2020/analysis.mjs.map +1 -0
  178. package/fesm2020/array.mjs +284 -284
  179. package/fesm2020/browser.mjs +279 -279
  180. package/fesm2020/config.mjs +54 -54
  181. package/fesm2020/date-time.mjs +211 -211
  182. package/fesm2020/decorator.mjs +121 -121
  183. package/fesm2020/form.mjs +118 -118
  184. package/fesm2020/format.mjs +431 -431
  185. package/fesm2020/math.mjs +85 -85
  186. package/fesm2020/other.mjs +586 -586
  187. package/fesm2020/pipe-currency.mjs +94 -94
  188. package/fesm2020/pipe-filter.mjs +40 -40
  189. package/fesm2020/pipe-format.mjs +55 -55
  190. package/fesm2020/pipes.mjs +8 -8
  191. package/fesm2020/token.mjs +37 -37
  192. package/fesm2020/yelon-util.mjs +17 -16
  193. package/fesm2020/yelon-util.mjs.map +1 -1
  194. package/form/index.d.ts +2 -2
  195. package/form/match-control.d.ts +15 -15
  196. package/form/validators.d.ts +62 -62
  197. package/format/currency.service.d.ts +37 -37
  198. package/format/currency.types.d.ts +77 -77
  199. package/format/index.d.ts +4 -4
  200. package/format/string.d.ts +44 -44
  201. package/format/validate.d.ts +72 -72
  202. package/index.d.ts +12 -11
  203. package/math/in-range.d.ts +14 -14
  204. package/math/index.d.ts +2 -2
  205. package/math/round.d.ts +33 -33
  206. package/other/assert.d.ts +36 -36
  207. package/other/deep.d.ts +35 -35
  208. package/other/favicon.d.ts +2 -2
  209. package/other/index.d.ts +7 -7
  210. package/other/lazy.service.d.ts +48 -48
  211. package/other/logger.d.ts +5 -5
  212. package/other/path-to-regexp.service.d.ts +26 -26
  213. package/other/resize.d.ts +1 -1
  214. package/package.json +165 -157
  215. package/pipes/currency/cny.pipe.d.ts +15 -15
  216. package/pipes/currency/index.d.ts +4 -4
  217. package/pipes/currency/mega.pipe.d.ts +16 -16
  218. package/pipes/currency/module.d.ts +9 -9
  219. package/pipes/currency/price.pipe.d.ts +19 -19
  220. package/pipes/filter/filter.pipe.d.ts +13 -13
  221. package/pipes/filter/index.d.ts +2 -2
  222. package/pipes/filter/module.d.ts +7 -7
  223. package/pipes/format/index.d.ts +2 -2
  224. package/pipes/format/mask.pipe.d.ts +27 -27
  225. package/pipes/format/module.d.ts +7 -7
  226. package/pipes/index.d.ts +3 -3
  227. package/token/index.d.ts +2 -2
  228. package/token/page-visibility.d.ts +8 -8
  229. package/token/window.d.ts +7 -7
@@ -1,413 +1,413 @@
1
- import { deepGet } from '@yelon/util/other';
2
- import { CurrencyPipe, formatNumber } from '@angular/common';
3
- import * as i0 from '@angular/core';
4
- import { LOCALE_ID, DEFAULT_CURRENCY_CODE, Injectable, Inject } from '@angular/core';
5
- import * as i1 from '@yelon/util/config';
6
-
7
- /**
8
- * String formatting
9
- *
10
- * 字符串格式化
11
- * ```
12
- * format('this is ${name}', { name: 'asdf' })
13
- * // output: this is asdf
14
- * format('this is ${user.name}', { user: { name: 'asdf' } }, true)
15
- * // output: this is asdf
16
- * ```
17
- */
18
- function format(str, obj, needDeepGet = false) {
19
- return (str || '').replace(/\${([^}]+)}/g, (_work, key) => needDeepGet ? deepGet(obj, key.split('.'), '') : (obj || {})[key] || '');
20
- }
21
- /**
22
- * Format mask
23
- *
24
- * 格式化掩码
25
- *
26
- * | 字符 | 描述 |
27
- * | --- | --- |
28
- * | `0` | 任意数字,若该位置字符不符合,则默认为 `0` 填充 |
29
- * | `9` | 任意数字 |
30
- * | `#` | 任意字符 |
31
- * | `U` | 转换大写 |
32
- * | `L` | 转换小写 |
33
- * | `*` | 转换为 `*` 字符 |
34
- *
35
- * ```ts
36
- * formatMask('123', '(###)') => (123)
37
- * formatMask('15900000000', '999****9999') => 159****0000
38
- * ```
39
- */
40
- function formatMask(value, option) {
41
- if (!value) {
42
- return '';
43
- }
44
- const opt = Object.assign({}, (typeof option === 'string' ? { mask: option } : option));
45
- const tokens = Object.assign({ '0': { pattern: /\d/, default: '0' }, '9': { pattern: /\d/ }, '#': { pattern: /[a-zA-Z0-9]/ }, U: {
46
- pattern: /[a-zA-Z]/,
47
- transform: char => char.toLocaleUpperCase()
48
- }, L: {
49
- pattern: /[a-zA-Z]/,
50
- transform: char => char.toLocaleLowerCase()
51
- }, '*': {
52
- pattern: /.*/,
53
- transform: _ => `*`
54
- } }, opt.tokens);
55
- const splitValue = value.split('');
56
- return opt.mask
57
- .split('')
58
- .reduce((res, cur) => {
59
- var _a;
60
- const token = tokens[cur];
61
- if (!token) {
62
- res.push(cur);
63
- return res;
64
- }
65
- const value = (_a = splitValue.shift()) !== null && _a !== void 0 ? _a : '';
66
- if (!token.pattern.test(value)) {
67
- if (token.default)
68
- res.push(token.default);
69
- return res;
70
- }
71
- if (typeof token.transform === 'function') {
72
- res.push(token.transform(value));
73
- }
74
- else {
75
- res.push(value);
76
- }
77
- return res;
78
- }, [])
79
- .join('');
80
- }
81
-
82
- const REGEX_STR = {
83
- num: `(([-+]?\\d+\\.\\d+)|([-+]?\\d+)|([-+]?\\.\\d+))(?:[eE]([-+]?\\d+))?`,
84
- idCard: `(^\\d{15}$)|(^\\d{17}(?:[0-9]|X)$)`,
85
- mobile: `^(0|\\+?86|17951)?1[0-9]{10}$`,
86
- url: `(((^https?:(?:\/\/)?)(?:[-;:&=\\+\\$,\\w]+@)?[A-Za-z0-9.-]+(?::\\d+)?|(?:www.|[-;:&=\\+\\$,\\w]+@)[A-Za-z0-9.-]+)((?:\/[\\+~%\\/.\\w-_]*)?\\??(?:[-\\+=&;%@.\\w_]*)#?(?:[\\w]*))?)`,
87
- ip: `(?:^(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}$)|(?:^(?:(?:[a-fA-F\\d]{1,4}:){7}(?:[a-fA-F\\d]{1,4}|:)|(?:[a-fA-F\\d]{1,4}:){6}(?:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|:[a-fA-F\\d]{1,4}|:)|(?:[a-fA-F\\d]{1,4}:){5}(?::(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,2}|:)|(?:[a-fA-F\\d]{1,4}:){4}(?:(?::[a-fA-F\\d]{1,4}){0,1}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,3}|:)|(?:[a-fA-F\\d]{1,4}:){3}(?:(?::[a-fA-F\\d]{1,4}){0,2}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,4}|:)|(?:[a-fA-F\\d]{1,4}:){2}(?:(?::[a-fA-F\\d]{1,4}){0,3}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,5}|:)|(?:[a-fA-F\\d]{1,4}:){1}(?:(?::[a-fA-F\\d]{1,4}){0,4}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,6}|:)|(?::(?:(?::[a-fA-F\\d]{1,4}){0,5}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,7}|:)))(?:%[0-9a-zA-Z]{1,})?$)`,
88
- color: `(?:#|0x)(?:[a-f0-9]{3}|[a-f0-9]{6})\\b|(?:rgb|hsl)a?\\([^\\)]*\\)`,
89
- chinese: `[\u4e00-\u9fa5]+`
90
- };
91
- function genRegex(str, flags) {
92
- return new RegExp(`^${str}$`, flags);
93
- }
94
- const REGEX = {
95
- num: genRegex(REGEX_STR.num),
96
- idCard: genRegex(REGEX_STR.idCard, 'i'),
97
- mobile: genRegex(REGEX_STR.mobile),
98
- url: genRegex(REGEX_STR.url),
99
- ip: genRegex(REGEX_STR.ip),
100
- color: genRegex(REGEX_STR.color),
101
- chinese: genRegex(REGEX_STR.chinese)
102
- };
103
- /**
104
- * Wheter is number
105
- *
106
- * 是否为数字
107
- */
108
- function isNum(value) {
109
- return REGEX.num.test(value.toString());
110
- }
111
- /**
112
- * Wheter is integer
113
- *
114
- * 是否为整数
115
- */
116
- function isInt(value) {
117
- return isNum(value) && parseInt(value.toString(), 10).toString() === value.toString();
118
- }
119
- /**
120
- * Wheter is decimal
121
- *
122
- * 是否为小数点数值
123
- */
124
- function isDecimal(value) {
125
- return isNum(value) && !isInt(value);
126
- }
127
- /**
128
- * Wheter is People's Republic of China identity card
129
- *
130
- * 是否为中华人民共和国居民身份证
131
- */
132
- function isIdCard(value) {
133
- return REGEX.idCard.test(value);
134
- }
135
- /**
136
- * Wheter is china mobile (China)
137
- *
138
- * 是否为手机号(中国)
139
- */
140
- function isMobile(value) {
141
- return REGEX.mobile.test(value);
142
- }
143
- /**
144
- * Wheter is url address
145
- *
146
- * 是否URL地址
147
- */
148
- function isUrl(url) {
149
- return REGEX.url.test(url);
150
- }
151
- /**
152
- * Wheter is IPv4 address (Support v4, v6)
153
- *
154
- * 是否IP4地址(支持v4、v6)
155
- */
156
- function isIp(ip) {
157
- return REGEX.ip.test(ip);
158
- }
159
- /**
160
- * Wheter is color
161
- *
162
- * 是否颜色代码值
163
- */
164
- function isColor(color) {
165
- return REGEX.color.test(color);
166
- }
167
- /**
168
- * Wheter is chinese
169
- *
170
- * 是否中文
171
- */
172
- function isChinese(value) {
173
- return REGEX.chinese.test(value);
174
- }
175
-
176
- const CurrencyMega_Powers = [
177
- { unit: 'Q', value: Math.pow(10, 15) },
178
- { unit: 'T', value: Math.pow(10, 12) },
179
- { unit: 'B', value: Math.pow(10, 9) },
180
- { unit: 'M', value: Math.pow(10, 6) },
181
- { unit: 'K', value: 1000 }
182
- ];
183
-
184
- class CurrencyService {
185
- constructor(cog, locale, _defaultCurrencyCode = 'USD') {
186
- this.locale = locale;
187
- this.currencyPipe = new CurrencyPipe(locale, _defaultCurrencyCode);
188
- this.c = cog.merge('utilCurrency', {
189
- startingUnit: 'yuan',
190
- megaUnit: { Q: '京', T: '兆', B: '亿', M: '万', K: '千' },
191
- precision: 2,
192
- ignoreZeroPrecision: true
193
- });
194
- }
195
- /**
196
- * Format a number with commas as thousands separators
197
- *
198
- * 格式化货币,用逗号将数字格式化为千位分隔符
199
- * ```ts
200
- * 10000 => `10,000`
201
- * 10000.567 => `10,000.57`
202
- * ```
203
- */
204
- format(value, options) {
205
- options = Object.assign({ startingUnit: this.c.startingUnit, precision: this.c.precision, ignoreZeroPrecision: this.c.ignoreZeroPrecision, ngCurrency: this.c.ngCurrency }, options);
206
- let truthValue = Number(value);
207
- if (value == null || isNaN(truthValue)) {
208
- return '';
209
- }
210
- if (options.startingUnit === 'cent') {
211
- truthValue = truthValue / 100;
212
- }
213
- if (options.ngCurrency != null) {
214
- const cur = options.ngCurrency;
215
- return this.currencyPipe.transform(truthValue, cur.currencyCode, cur.display, cur.digitsInfo, cur.locale || this.locale);
216
- }
217
- const res = formatNumber(truthValue, this.locale, `.${options.ignoreZeroPrecision ? 1 : options.precision}-${options.precision}`);
218
- return options.ignoreZeroPrecision ? res.replace(/(?:\.[0]+)$/g, '') : res;
219
- }
220
- /**
221
- * Large number format filter
222
- *
223
- * 大数据格式化
224
- * ```ts
225
- * 1000 => { value: '1', unit: 'K', unitI18n: '千' }
226
- * 12456 => { value: '12.46', unit: 'K', unitI18n: '千' }
227
- * ```
228
- */
229
- mega(value, options) {
230
- options = Object.assign({ precision: this.c.precision, unitI18n: this.c.megaUnit, startingUnit: this.c.startingUnit }, options);
231
- let num = Number(value);
232
- const res = { raw: value, value: '', unit: '', unitI18n: '' };
233
- if (isNaN(num) || num === 0) {
234
- res.value = value.toString();
235
- return res;
236
- }
237
- if (options.startingUnit === 'cent') {
238
- num = num / 100;
239
- }
240
- let abs = Math.abs(+num);
241
- const rounder = Math.pow(10, options.precision);
242
- const isNegative = num < 0;
243
- for (const p of CurrencyMega_Powers) {
244
- let reduced = abs / p.value;
245
- reduced = Math.round(reduced * rounder) / rounder;
246
- if (reduced >= 1) {
247
- abs = reduced;
248
- res.unit = p.unit;
249
- break;
250
- }
251
- }
252
- res.value = (isNegative ? '-' : '') + abs;
253
- res.unitI18n = options.unitI18n[res.unit];
254
- return res;
255
- }
256
- /**
257
- * Converted into RMB notation.
258
- *
259
- * 转化成人民币表示法
260
- */
261
- cny(value, options) {
262
- options = Object.assign({ inWords: true, minusSymbol: '负', startingUnit: this.c.startingUnit }, options);
263
- value = Number(value);
264
- if (isNaN(value)) {
265
- return '';
266
- }
267
- if (options.startingUnit === 'cent') {
268
- value = value / 100;
269
- }
270
- value = value.toString();
271
- let integer;
272
- let decimal;
273
- [integer, decimal] = value.split('.');
274
- let symbol = '';
275
- if (integer.startsWith('-')) {
276
- symbol = options.minusSymbol;
277
- integer = integer.substring(1);
278
- }
279
- if (/^-?\d+$/.test(value)) {
280
- decimal = null;
281
- }
282
- integer = (+integer).toString();
283
- const inWords = options.inWords;
284
- const unit = {
285
- num: inWords
286
- ? ['', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖', '点']
287
- : ['', '一', '二', '三', '四', '五', '六', '七', '八', '九', '点'],
288
- radice: inWords
289
- ? [
290
- '',
291
- '拾',
292
- '佰',
293
- '仟',
294
- '万',
295
- '拾',
296
- '佰',
297
- '仟',
298
- '亿',
299
- '拾',
300
- '佰',
301
- '仟',
302
- '万亿',
303
- '拾',
304
- '佰',
305
- '仟',
306
- '兆',
307
- '拾',
308
- '佰',
309
- '仟'
310
- ]
311
- : [
312
- '',
313
- '十',
314
- '百',
315
- '千',
316
- '万',
317
- '十',
318
- '百',
319
- '千',
320
- '亿',
321
- '十',
322
- '百',
323
- '千',
324
- '万亿',
325
- '十',
326
- '百',
327
- '千',
328
- '兆',
329
- '十',
330
- '百',
331
- '千'
332
- ],
333
- dec: ['角', '分', '厘', '毫']
334
- };
335
- if (inWords) {
336
- value = (+value).toFixed(5).toString();
337
- }
338
- let integerRes = '';
339
- const integerCount = integer.length;
340
- if (integer === '0' || integerCount === 0) {
341
- integerRes = '零';
342
- }
343
- else {
344
- let cnDesc = '';
345
- for (let i = 0; i < integerCount; i++) {
346
- const n = +integer[i];
347
- const j = integerCount - i - 1;
348
- const isZero = i > 1 && n !== 0 && integer[i - 1] === '0';
349
- const cnZero = isZero ? '零' : '';
350
- const isEmpptyUnit = (n === 0 && j % 4 !== 0) || integer.substring(i - 3, i - 3 + 4) === '0000';
351
- const descMark = cnDesc;
352
- let cnNum = unit.num[n];
353
- cnDesc = isEmpptyUnit ? '' : unit.radice[j];
354
- // 第一位是一十
355
- if (i === 0 && cnNum === '一' && cnDesc === '十')
356
- cnNum = '';
357
- const isChangeEr = n > 1 &&
358
- cnNum === '二' && // 去除首位
359
- ['', '十', '百'].indexOf(cnDesc) === -1 && // 不读两\两十\两百
360
- descMark !== '十'; // 不读十两
361
- if (isChangeEr)
362
- cnNum = '两';
363
- integerRes += cnZero + cnNum + cnDesc;
364
- }
365
- }
366
- // 小数部分拼接
367
- let decimalRes = '';
368
- const decimalCount = decimal ? decimal.toString().length : 0;
369
- if (decimal === null) {
370
- decimalRes = inWords ? '整' : '';
371
- }
372
- else if (decimal === '0') {
373
- decimalRes = '零';
374
- }
375
- else {
376
- for (let i = 0; i < decimalCount; i++) {
377
- if (inWords && i > unit.dec.length - 1)
378
- break;
379
- const n = decimal[i];
380
- const cnZero = n === '0' ? '零' : '';
381
- const cnNum = unit.num[+n];
382
- const cnDesc = inWords ? unit.dec[i] : '';
383
- decimalRes += cnZero + cnNum + cnDesc;
384
- }
385
- }
386
- const ret = symbol +
387
- (inWords
388
- ? integerRes + (decimalRes === '零' ? '元整' : `元${decimalRes}`)
389
- : integerRes + (decimalRes === '' ? '' : `点${decimalRes}`));
390
- return ret;
391
- }
392
- }
393
- CurrencyService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: CurrencyService, deps: [{ token: i1.YunzaiConfigService }, { token: LOCALE_ID }, { token: DEFAULT_CURRENCY_CODE }], target: i0.ɵɵFactoryTarget.Injectable });
394
- CurrencyService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: CurrencyService, providedIn: 'root' });
395
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: CurrencyService, decorators: [{
396
- type: Injectable,
397
- args: [{ providedIn: 'root' }]
398
- }], ctorParameters: function () {
399
- return [{ type: i1.YunzaiConfigService }, { type: undefined, decorators: [{
400
- type: Inject,
401
- args: [LOCALE_ID]
402
- }] }, { type: undefined, decorators: [{
403
- type: Inject,
404
- args: [DEFAULT_CURRENCY_CODE]
405
- }] }];
406
- } });
407
-
408
- /**
409
- * Generated bundle index. Do not edit.
410
- */
411
-
412
- export { CurrencyMega_Powers, CurrencyService, REGEX, REGEX_STR, format, formatMask, isChinese, isColor, isDecimal, isIdCard, isInt, isIp, isMobile, isNum, isUrl };
413
- //# sourceMappingURL=format.mjs.map
1
+ import { deepGet } from '@yelon/util/other';
2
+ import { CurrencyPipe, formatNumber } from '@angular/common';
3
+ import * as i0 from '@angular/core';
4
+ import { LOCALE_ID, DEFAULT_CURRENCY_CODE, Injectable, Inject } from '@angular/core';
5
+ import * as i1 from '@yelon/util/config';
6
+
7
+ /**
8
+ * String formatting
9
+ *
10
+ * 字符串格式化
11
+ * ```
12
+ * format('this is ${name}', { name: 'asdf' })
13
+ * // output: this is asdf
14
+ * format('this is ${user.name}', { user: { name: 'asdf' } }, true)
15
+ * // output: this is asdf
16
+ * ```
17
+ */
18
+ function format(str, obj, needDeepGet = false) {
19
+ return (str || '').replace(/\${([^}]+)}/g, (_work, key) => needDeepGet ? deepGet(obj, key.split('.'), '') : (obj || {})[key] || '');
20
+ }
21
+ /**
22
+ * Format mask
23
+ *
24
+ * 格式化掩码
25
+ *
26
+ * | 字符 | 描述 |
27
+ * | --- | --- |
28
+ * | `0` | 任意数字,若该位置字符不符合,则默认为 `0` 填充 |
29
+ * | `9` | 任意数字 |
30
+ * | `#` | 任意字符 |
31
+ * | `U` | 转换大写 |
32
+ * | `L` | 转换小写 |
33
+ * | `*` | 转换为 `*` 字符 |
34
+ *
35
+ * ```ts
36
+ * formatMask('123', '(###)') => (123)
37
+ * formatMask('15900000000', '999****9999') => 159****0000
38
+ * ```
39
+ */
40
+ function formatMask(value, option) {
41
+ if (!value) {
42
+ return '';
43
+ }
44
+ const opt = Object.assign({}, (typeof option === 'string' ? { mask: option } : option));
45
+ const tokens = Object.assign({ '0': { pattern: /\d/, default: '0' }, '9': { pattern: /\d/ }, '#': { pattern: /[a-zA-Z0-9]/ }, U: {
46
+ pattern: /[a-zA-Z]/,
47
+ transform: char => char.toLocaleUpperCase()
48
+ }, L: {
49
+ pattern: /[a-zA-Z]/,
50
+ transform: char => char.toLocaleLowerCase()
51
+ }, '*': {
52
+ pattern: /.*/,
53
+ transform: _ => `*`
54
+ } }, opt.tokens);
55
+ const splitValue = value.split('');
56
+ return opt.mask
57
+ .split('')
58
+ .reduce((res, cur) => {
59
+ var _a;
60
+ const token = tokens[cur];
61
+ if (!token) {
62
+ res.push(cur);
63
+ return res;
64
+ }
65
+ const value = (_a = splitValue.shift()) !== null && _a !== void 0 ? _a : '';
66
+ if (!token.pattern.test(value)) {
67
+ if (token.default)
68
+ res.push(token.default);
69
+ return res;
70
+ }
71
+ if (typeof token.transform === 'function') {
72
+ res.push(token.transform(value));
73
+ }
74
+ else {
75
+ res.push(value);
76
+ }
77
+ return res;
78
+ }, [])
79
+ .join('');
80
+ }
81
+
82
+ const REGEX_STR = {
83
+ num: `(([-+]?\\d+\\.\\d+)|([-+]?\\d+)|([-+]?\\.\\d+))(?:[eE]([-+]?\\d+))?`,
84
+ idCard: `(^\\d{15}$)|(^\\d{17}(?:[0-9]|X)$)`,
85
+ mobile: `^(0|\\+?86|17951)?1[0-9]{10}$`,
86
+ url: `(((^https?:(?:\/\/)?)(?:[-;:&=\\+\\$,\\w]+@)?[A-Za-z0-9.-]+(?::\\d+)?|(?:www.|[-;:&=\\+\\$,\\w]+@)[A-Za-z0-9.-]+)((?:\/[\\+~%\\/.\\w-_]*)?\\??(?:[-\\+=&;%@.\\w_]*)#?(?:[\\w]*))?)`,
87
+ ip: `(?:^(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}$)|(?:^(?:(?:[a-fA-F\\d]{1,4}:){7}(?:[a-fA-F\\d]{1,4}|:)|(?:[a-fA-F\\d]{1,4}:){6}(?:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|:[a-fA-F\\d]{1,4}|:)|(?:[a-fA-F\\d]{1,4}:){5}(?::(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,2}|:)|(?:[a-fA-F\\d]{1,4}:){4}(?:(?::[a-fA-F\\d]{1,4}){0,1}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,3}|:)|(?:[a-fA-F\\d]{1,4}:){3}(?:(?::[a-fA-F\\d]{1,4}){0,2}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,4}|:)|(?:[a-fA-F\\d]{1,4}:){2}(?:(?::[a-fA-F\\d]{1,4}){0,3}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,5}|:)|(?:[a-fA-F\\d]{1,4}:){1}(?:(?::[a-fA-F\\d]{1,4}){0,4}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,6}|:)|(?::(?:(?::[a-fA-F\\d]{1,4}){0,5}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,7}|:)))(?:%[0-9a-zA-Z]{1,})?$)`,
88
+ color: `(?:#|0x)(?:[a-f0-9]{3}|[a-f0-9]{6})\\b|(?:rgb|hsl)a?\\([^\\)]*\\)`,
89
+ chinese: `[\u4e00-\u9fa5]+`
90
+ };
91
+ function genRegex(str, flags) {
92
+ return new RegExp(`^${str}$`, flags);
93
+ }
94
+ const REGEX = {
95
+ num: genRegex(REGEX_STR.num),
96
+ idCard: genRegex(REGEX_STR.idCard, 'i'),
97
+ mobile: genRegex(REGEX_STR.mobile),
98
+ url: genRegex(REGEX_STR.url),
99
+ ip: genRegex(REGEX_STR.ip),
100
+ color: genRegex(REGEX_STR.color),
101
+ chinese: genRegex(REGEX_STR.chinese)
102
+ };
103
+ /**
104
+ * Wheter is number
105
+ *
106
+ * 是否为数字
107
+ */
108
+ function isNum(value) {
109
+ return REGEX.num.test(value.toString());
110
+ }
111
+ /**
112
+ * Wheter is integer
113
+ *
114
+ * 是否为整数
115
+ */
116
+ function isInt(value) {
117
+ return isNum(value) && parseInt(value.toString(), 10).toString() === value.toString();
118
+ }
119
+ /**
120
+ * Wheter is decimal
121
+ *
122
+ * 是否为小数点数值
123
+ */
124
+ function isDecimal(value) {
125
+ return isNum(value) && !isInt(value);
126
+ }
127
+ /**
128
+ * Wheter is People's Republic of China identity card
129
+ *
130
+ * 是否为中华人民共和国居民身份证
131
+ */
132
+ function isIdCard(value) {
133
+ return REGEX.idCard.test(value);
134
+ }
135
+ /**
136
+ * Wheter is china mobile (China)
137
+ *
138
+ * 是否为手机号(中国)
139
+ */
140
+ function isMobile(value) {
141
+ return REGEX.mobile.test(value);
142
+ }
143
+ /**
144
+ * Wheter is url address
145
+ *
146
+ * 是否URL地址
147
+ */
148
+ function isUrl(url) {
149
+ return REGEX.url.test(url);
150
+ }
151
+ /**
152
+ * Wheter is IPv4 address (Support v4, v6)
153
+ *
154
+ * 是否IP4地址(支持v4、v6)
155
+ */
156
+ function isIp(ip) {
157
+ return REGEX.ip.test(ip);
158
+ }
159
+ /**
160
+ * Wheter is color
161
+ *
162
+ * 是否颜色代码值
163
+ */
164
+ function isColor(color) {
165
+ return REGEX.color.test(color);
166
+ }
167
+ /**
168
+ * Wheter is chinese
169
+ *
170
+ * 是否中文
171
+ */
172
+ function isChinese(value) {
173
+ return REGEX.chinese.test(value);
174
+ }
175
+
176
+ const CurrencyMega_Powers = [
177
+ { unit: 'Q', value: Math.pow(10, 15) },
178
+ { unit: 'T', value: Math.pow(10, 12) },
179
+ { unit: 'B', value: Math.pow(10, 9) },
180
+ { unit: 'M', value: Math.pow(10, 6) },
181
+ { unit: 'K', value: 1000 }
182
+ ];
183
+
184
+ class CurrencyService {
185
+ constructor(cog, locale, _defaultCurrencyCode = 'USD') {
186
+ this.locale = locale;
187
+ this.currencyPipe = new CurrencyPipe(locale, _defaultCurrencyCode);
188
+ this.c = cog.merge('utilCurrency', {
189
+ startingUnit: 'yuan',
190
+ megaUnit: { Q: '京', T: '兆', B: '亿', M: '万', K: '千' },
191
+ precision: 2,
192
+ ignoreZeroPrecision: true
193
+ });
194
+ }
195
+ /**
196
+ * Format a number with commas as thousands separators
197
+ *
198
+ * 格式化货币,用逗号将数字格式化为千位分隔符
199
+ * ```ts
200
+ * 10000 => `10,000`
201
+ * 10000.567 => `10,000.57`
202
+ * ```
203
+ */
204
+ format(value, options) {
205
+ options = Object.assign({ startingUnit: this.c.startingUnit, precision: this.c.precision, ignoreZeroPrecision: this.c.ignoreZeroPrecision, ngCurrency: this.c.ngCurrency }, options);
206
+ let truthValue = Number(value);
207
+ if (value == null || isNaN(truthValue)) {
208
+ return '';
209
+ }
210
+ if (options.startingUnit === 'cent') {
211
+ truthValue = truthValue / 100;
212
+ }
213
+ if (options.ngCurrency != null) {
214
+ const cur = options.ngCurrency;
215
+ return this.currencyPipe.transform(truthValue, cur.currencyCode, cur.display, cur.digitsInfo, cur.locale || this.locale);
216
+ }
217
+ const res = formatNumber(truthValue, this.locale, `.${options.ignoreZeroPrecision ? 1 : options.precision}-${options.precision}`);
218
+ return options.ignoreZeroPrecision ? res.replace(/(?:\.[0]+)$/g, '') : res;
219
+ }
220
+ /**
221
+ * Large number format filter
222
+ *
223
+ * 大数据格式化
224
+ * ```ts
225
+ * 1000 => { value: '1', unit: 'K', unitI18n: '千' }
226
+ * 12456 => { value: '12.46', unit: 'K', unitI18n: '千' }
227
+ * ```
228
+ */
229
+ mega(value, options) {
230
+ options = Object.assign({ precision: this.c.precision, unitI18n: this.c.megaUnit, startingUnit: this.c.startingUnit }, options);
231
+ let num = Number(value);
232
+ const res = { raw: value, value: '', unit: '', unitI18n: '' };
233
+ if (isNaN(num) || num === 0) {
234
+ res.value = value.toString();
235
+ return res;
236
+ }
237
+ if (options.startingUnit === 'cent') {
238
+ num = num / 100;
239
+ }
240
+ let abs = Math.abs(+num);
241
+ const rounder = Math.pow(10, options.precision);
242
+ const isNegative = num < 0;
243
+ for (const p of CurrencyMega_Powers) {
244
+ let reduced = abs / p.value;
245
+ reduced = Math.round(reduced * rounder) / rounder;
246
+ if (reduced >= 1) {
247
+ abs = reduced;
248
+ res.unit = p.unit;
249
+ break;
250
+ }
251
+ }
252
+ res.value = (isNegative ? '-' : '') + abs;
253
+ res.unitI18n = options.unitI18n[res.unit];
254
+ return res;
255
+ }
256
+ /**
257
+ * Converted into RMB notation.
258
+ *
259
+ * 转化成人民币表示法
260
+ */
261
+ cny(value, options) {
262
+ options = Object.assign({ inWords: true, minusSymbol: '负', startingUnit: this.c.startingUnit }, options);
263
+ value = Number(value);
264
+ if (isNaN(value)) {
265
+ return '';
266
+ }
267
+ if (options.startingUnit === 'cent') {
268
+ value = value / 100;
269
+ }
270
+ value = value.toString();
271
+ let integer;
272
+ let decimal;
273
+ [integer, decimal] = value.split('.');
274
+ let symbol = '';
275
+ if (integer.startsWith('-')) {
276
+ symbol = options.minusSymbol;
277
+ integer = integer.substring(1);
278
+ }
279
+ if (/^-?\d+$/.test(value)) {
280
+ decimal = null;
281
+ }
282
+ integer = (+integer).toString();
283
+ const inWords = options.inWords;
284
+ const unit = {
285
+ num: inWords
286
+ ? ['', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖', '点']
287
+ : ['', '一', '二', '三', '四', '五', '六', '七', '八', '九', '点'],
288
+ radice: inWords
289
+ ? [
290
+ '',
291
+ '拾',
292
+ '佰',
293
+ '仟',
294
+ '万',
295
+ '拾',
296
+ '佰',
297
+ '仟',
298
+ '亿',
299
+ '拾',
300
+ '佰',
301
+ '仟',
302
+ '万亿',
303
+ '拾',
304
+ '佰',
305
+ '仟',
306
+ '兆',
307
+ '拾',
308
+ '佰',
309
+ '仟'
310
+ ]
311
+ : [
312
+ '',
313
+ '十',
314
+ '百',
315
+ '千',
316
+ '万',
317
+ '十',
318
+ '百',
319
+ '千',
320
+ '亿',
321
+ '十',
322
+ '百',
323
+ '千',
324
+ '万亿',
325
+ '十',
326
+ '百',
327
+ '千',
328
+ '兆',
329
+ '十',
330
+ '百',
331
+ '千'
332
+ ],
333
+ dec: ['角', '分', '厘', '毫']
334
+ };
335
+ if (inWords) {
336
+ value = (+value).toFixed(5).toString();
337
+ }
338
+ let integerRes = '';
339
+ const integerCount = integer.length;
340
+ if (integer === '0' || integerCount === 0) {
341
+ integerRes = '零';
342
+ }
343
+ else {
344
+ let cnDesc = '';
345
+ for (let i = 0; i < integerCount; i++) {
346
+ const n = +integer[i];
347
+ const j = integerCount - i - 1;
348
+ const isZero = i > 1 && n !== 0 && integer[i - 1] === '0';
349
+ const cnZero = isZero ? '零' : '';
350
+ const isEmpptyUnit = (n === 0 && j % 4 !== 0) || integer.substring(i - 3, i - 3 + 4) === '0000';
351
+ const descMark = cnDesc;
352
+ let cnNum = unit.num[n];
353
+ cnDesc = isEmpptyUnit ? '' : unit.radice[j];
354
+ // 第一位是一十
355
+ if (i === 0 && cnNum === '一' && cnDesc === '十')
356
+ cnNum = '';
357
+ const isChangeEr = n > 1 &&
358
+ cnNum === '二' && // 去除首位
359
+ ['', '十', '百'].indexOf(cnDesc) === -1 && // 不读两\两十\两百
360
+ descMark !== '十'; // 不读十两
361
+ if (isChangeEr)
362
+ cnNum = '两';
363
+ integerRes += cnZero + cnNum + cnDesc;
364
+ }
365
+ }
366
+ // 小数部分拼接
367
+ let decimalRes = '';
368
+ const decimalCount = decimal ? decimal.toString().length : 0;
369
+ if (decimal === null) {
370
+ decimalRes = inWords ? '整' : '';
371
+ }
372
+ else if (decimal === '0') {
373
+ decimalRes = '零';
374
+ }
375
+ else {
376
+ for (let i = 0; i < decimalCount; i++) {
377
+ if (inWords && i > unit.dec.length - 1)
378
+ break;
379
+ const n = decimal[i];
380
+ const cnZero = n === '0' ? '零' : '';
381
+ const cnNum = unit.num[+n];
382
+ const cnDesc = inWords ? unit.dec[i] : '';
383
+ decimalRes += cnZero + cnNum + cnDesc;
384
+ }
385
+ }
386
+ const ret = symbol +
387
+ (inWords
388
+ ? integerRes + (decimalRes === '零' ? '元整' : `元${decimalRes}`)
389
+ : integerRes + (decimalRes === '' ? '' : `点${decimalRes}`));
390
+ return ret;
391
+ }
392
+ }
393
+ CurrencyService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CurrencyService, deps: [{ token: i1.YunzaiConfigService }, { token: LOCALE_ID }, { token: DEFAULT_CURRENCY_CODE }], target: i0.ɵɵFactoryTarget.Injectable });
394
+ CurrencyService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CurrencyService, providedIn: 'root' });
395
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CurrencyService, decorators: [{
396
+ type: Injectable,
397
+ args: [{ providedIn: 'root' }]
398
+ }], ctorParameters: function () {
399
+ return [{ type: i1.YunzaiConfigService }, { type: undefined, decorators: [{
400
+ type: Inject,
401
+ args: [LOCALE_ID]
402
+ }] }, { type: undefined, decorators: [{
403
+ type: Inject,
404
+ args: [DEFAULT_CURRENCY_CODE]
405
+ }] }];
406
+ } });
407
+
408
+ /**
409
+ * Generated bundle index. Do not edit.
410
+ */
411
+
412
+ export { CurrencyMega_Powers, CurrencyService, REGEX, REGEX_STR, format, formatMask, isChinese, isColor, isDecimal, isIdCard, isInt, isIp, isMobile, isNum, isUrl };
413
+ //# sourceMappingURL=format.mjs.map