@yelon/util 17.3.2 → 18.0.0

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