@pisell/utils 1.0.54 → 1.0.56

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.
@@ -0,0 +1,499 @@
1
+ import dayjs from 'dayjs';
2
+
3
+ // 文案配置类型定义
4
+
5
+ // 常量定义
6
+ var CONSTANTS = {
7
+ ALL_DAY_START: '00:00',
8
+ ALL_DAY_END: '23:59',
9
+ DEFAULT_FUTURE_YEARS: 10,
10
+ SECONDS_SUFFIX: ':59'
11
+ };
12
+
13
+ // 日程项接口定义
14
+
15
+ // 多语言文案配置
16
+ var textConfig = {
17
+ 'zh-HK': {
18
+ weekdays: ['日', '一', '二', '三', '四', '五', '六'],
19
+ separator: '、',
20
+ timeSeparator: '–',
21
+ rangeSeparator: ' 至 ',
22
+ periodSeparator: ';',
23
+ timeSlotSeparator: ',',
24
+ every: '每',
25
+ day: '天',
26
+ week: '周',
27
+ month: '月',
28
+ year: '年',
29
+ available: '可用',
30
+ unlimited: '无限期',
31
+ multipleRules: '多規則,點詳情',
32
+ multipleSlots: ',多時段',
33
+ until: '至',
34
+ daily: '每天',
35
+ days: '天',
36
+ weeks: '周',
37
+ everyPrefix: '每',
38
+ weekPrefix: '周',
39
+ dateFormat: 'YYYY-MM-DD',
40
+ dateTimeFormat: 'YYYY-MM-DD HH:mm',
41
+ longTermValidFrom: '自',
42
+ noExpiry: '起長期有效',
43
+ on: ''
44
+ },
45
+ 'zh-CN': {
46
+ weekdays: ['日', '一', '二', '三', '四', '五', '六'],
47
+ separator: '、',
48
+ timeSeparator: '–',
49
+ rangeSeparator: ' 至 ',
50
+ periodSeparator: ';',
51
+ timeSlotSeparator: ',',
52
+ every: '每',
53
+ day: '天',
54
+ week: '周',
55
+ month: '月',
56
+ year: '年',
57
+ available: '可用',
58
+ unlimited: '无限期',
59
+ multipleRules: '多规则,点详情',
60
+ multipleSlots: ',多时段',
61
+ until: '至',
62
+ daily: '每天',
63
+ days: '天',
64
+ weeks: '周',
65
+ everyPrefix: '每',
66
+ weekPrefix: '周',
67
+ dateFormat: 'YYYY-MM-DD',
68
+ dateTimeFormat: 'YYYY-MM-DD HH:mm',
69
+ longTermValidFrom: '自',
70
+ noExpiry: '起长期有效',
71
+ on: ''
72
+ },
73
+ 'en': {
74
+ weekdays: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],
75
+ separator: ', ',
76
+ timeSeparator: '–',
77
+ rangeSeparator: ' - ',
78
+ periodSeparator: '; ',
79
+ timeSlotSeparator: ', ',
80
+ every: 'every ',
81
+ day: 'day',
82
+ week: 'week',
83
+ month: 'month',
84
+ year: 'year',
85
+ available: 'available',
86
+ unlimited: 'unlimited',
87
+ multipleRules: 'Multiple rules, see details',
88
+ multipleSlots: ', multiple slots',
89
+ until: 'Until ',
90
+ daily: 'daily',
91
+ days: 'days',
92
+ weeks: 'weeks',
93
+ everyPrefix: 'every ',
94
+ weekPrefix: '',
95
+ dateFormat: 'DD MMM YYYY',
96
+ dateTimeFormat: 'DD MMM YYYY h:mm A',
97
+ longTermValidFrom: 'from ',
98
+ noExpiry: ', no expiry',
99
+ on: 'on '
100
+ }
101
+ };
102
+
103
+ /**
104
+ * 获取星期几的表示
105
+ * @param dayNumbers 星期几的数字数组 (0-6, 0代表周日)
106
+ * @param locale 语言设置
107
+ * @param separator 分隔符,可选,默认使用locale配置的分隔符
108
+ * @returns 格式化的星期几文案
109
+ */
110
+ function getWeekdayText(dayNumbers, locale, separator) {
111
+ var config = textConfig[locale];
112
+ return dayNumbers.map(function (day) {
113
+ return config.weekdays[day];
114
+ }).join(separator || config.separator);
115
+ }
116
+
117
+ /**
118
+ * 获取指定语言的文案配置
119
+ * @param locale 语言设置
120
+ * @param key 配置项key
121
+ * @returns 对应语言的文案
122
+ */
123
+ function getText(locale, key) {
124
+ return textConfig[locale][key];
125
+ }
126
+
127
+ /**
128
+ * 获取指定语言的配置对象(缓存优化)
129
+ * @param locale 语言设置
130
+ * @returns 对应语言的完整配置对象
131
+ */
132
+ function getConfig(locale) {
133
+ return textConfig[locale];
134
+ }
135
+
136
+ /**
137
+ * 获取每日频率文案
138
+ * @param frequency 频率数字
139
+ * @param locale 语言设置
140
+ * @returns 格式化的每日频率文案
141
+ */
142
+ function getDailyFrequencyText(frequency, locale) {
143
+ if (frequency === 1) {
144
+ return getText(locale, 'daily');
145
+ }
146
+ var config = textConfig[locale];
147
+ if (locale === 'en') {
148
+ return "".concat(config.everyPrefix).concat(frequency, " ").concat(config.days);
149
+ } else {
150
+ return "".concat(config.everyPrefix).concat(frequency).concat(config.days);
151
+ }
152
+ }
153
+
154
+ /**
155
+ * 获取每周频率前缀文案
156
+ * @param frequency 频率数字
157
+ * @param locale 语言设置
158
+ * @returns 格式化的每周频率前缀文案
159
+ */
160
+ function getWeeklyFrequencyPrefix(frequency, locale) {
161
+ if (frequency === 1) {
162
+ return '';
163
+ }
164
+ var config = textConfig[locale];
165
+ if (locale === 'en') {
166
+ return "".concat(config.everyPrefix).concat(frequency, " ").concat(config.weeks, ", ");
167
+ } else {
168
+ return "".concat(config.everyPrefix).concat(frequency).concat(config.weeks, " ");
169
+ }
170
+ }
171
+
172
+ /**
173
+ * 格式化日期时间函数
174
+ * @param dateTime 日期时间字符串
175
+ * @param isAll 是否为全天
176
+ * @param locale 语言设置
177
+ * @returns 格式化后的日期时间字符串
178
+ */
179
+ function formatDateTime(dateTime) {
180
+ var isAll = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
181
+ var locale = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'zh-CN';
182
+ var date = dayjs(dateTime);
183
+ var config = getConfig(locale);
184
+ if (isAll) {
185
+ // 全天情况下的日期格式
186
+ return date.format(config.dateFormat);
187
+ }
188
+
189
+ // 非全天情况下的日期时间格式
190
+ return date.format(config.dateTimeFormat);
191
+ }
192
+
193
+ /**
194
+ * 判断是否为全天日程
195
+ * @param startTime 开始时间 (HH:mm格式)
196
+ * @param endTime 结束时间 (HH:mm格式)
197
+ * @returns 是否为全天日程
198
+ */
199
+ function isAllDaySchedule(startTime, endTime) {
200
+ return startTime === CONSTANTS.ALL_DAY_START && endTime === CONSTANTS.ALL_DAY_END;
201
+ }
202
+
203
+ /**
204
+ * 生成日期范围文案
205
+ * @param startDate 开始日期
206
+ * @param endDate 结束日期
207
+ * @param isStarted 是否已开始
208
+ * @param locale 语言设置
209
+ * @param isAllDay 是否为全天
210
+ * @returns 格式化的日期范围文案
211
+ */
212
+ function formatDateRange(startDate, endDate, isStarted, locale) {
213
+ var isAllDay = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;
214
+ var config = getConfig(locale);
215
+ if (isStarted) {
216
+ var endDateStr = formatDateTime(endDate, isAllDay, locale);
217
+ return "".concat(config.until).concat(endDateStr);
218
+ } else {
219
+ var startDateStr = formatDateTime(startDate, isAllDay, locale);
220
+ var _endDateStr = formatDateTime(endDate, isAllDay, locale);
221
+ return "".concat(startDateStr).concat(config.rangeSeparator).concat(_endDateStr);
222
+ }
223
+ }
224
+
225
+ /**
226
+ * 获取schedule摘要信息
227
+ * @param scheduleList 日程列表
228
+ * @param locale 语言设置
229
+ * @returns 摘要文本
230
+ */
231
+ export function getScheduleSummary(scheduleList) {
232
+ var locale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'zh-CN';
233
+ try {
234
+ // 输入验证
235
+ if (!scheduleList || !Array.isArray(scheduleList)) {
236
+ return '';
237
+ }
238
+
239
+ // 如果是多个日程,直接返回多规则提示
240
+ if (scheduleList.length > 1) {
241
+ return getText(locale, 'multipleRules');
242
+ }
243
+
244
+ // 如果没有日程,返回空字符串
245
+ if (scheduleList.length === 0) {
246
+ return '';
247
+ }
248
+ var schedule = scheduleList[0];
249
+ if (!schedule) {
250
+ return '';
251
+ }
252
+ var now = dayjs();
253
+
254
+ // 获取日程开始时间
255
+ var startTime = null;
256
+ if (schedule.start_time) {
257
+ startTime = dayjs(schedule.start_time);
258
+ } else if (schedule.designation && schedule.designation.length > 0) {
259
+ // designation类型,取第一个日期作为开始时间
260
+ var firstDesignation = schedule.designation[0];
261
+ if (firstDesignation && firstDesignation.start_date && firstDesignation.start_time) {
262
+ startTime = dayjs("".concat(firstDesignation.start_date, " ").concat(firstDesignation.start_time));
263
+ }
264
+ }
265
+
266
+ // 判断开始时间是否在当前时间之后
267
+ var isStarted = startTime ? isTimeStarted(now, startTime) : false;
268
+
269
+ // 根据不同类型和状态返回摘要
270
+ return generateSummaryText(schedule, isStarted, locale);
271
+ } catch (error) {
272
+ console.warn('Error in getScheduleSummary:', error);
273
+ return '';
274
+ }
275
+ }
276
+
277
+ /**
278
+ * 判断开始时间是否在当前时间之后
279
+ * @param now 当前时间
280
+ * @param startTime 开始时间
281
+ * @returns 是否已开始
282
+ */
283
+ function isTimeStarted(now, startTime) {
284
+ return startTime.isBefore(now);
285
+ }
286
+
287
+ /**
288
+ * 生成摘要文本
289
+ * @param schedule 日程对象
290
+ * @param isStarted 是否已开始
291
+ * @param locale 语言设置
292
+ * @returns 生成的摘要文本
293
+ */
294
+ function generateSummaryText(schedule, isStarted, locale) {
295
+ // 1. 多天多段 (designation类型且有多个日期段)
296
+ if (schedule.type === 'designation' && schedule.designation && schedule.designation.length > 1) {
297
+ return getText(locale, 'multipleRules');
298
+ }
299
+
300
+ // 2. 单日多段 (time-slots类型)
301
+ if (schedule.type === 'time-slots') {
302
+ var endDate = getScheduleEndDate(schedule);
303
+ if (!endDate) return '';
304
+ var endDateStr = formatDateTime(endDate, true, locale);
305
+ var prefix = '';
306
+ var suffix = getText(locale, 'multipleSlots');
307
+ return "".concat(prefix).concat(endDateStr).concat(suffix);
308
+ }
309
+
310
+ // 3. 循环日程
311
+ if (schedule.repeat_type !== 'none' && schedule.repeat_rule) {
312
+ return generateRecurringSummary(schedule, isStarted, locale);
313
+ }
314
+
315
+ // 4. 单个日程(包括designation类型的单个日期段)
316
+ return generateSingleScheduleSummary(schedule, isStarted, locale);
317
+ }
318
+
319
+ /**
320
+ * 生成循环日程摘要
321
+ * @param schedule 日程对象
322
+ * @param isStarted 是否已开始
323
+ * @param locale 语言设置
324
+ * @returns 循环日程摘要文本
325
+ */
326
+ function generateRecurringSummary(schedule, isStarted, locale) {
327
+ var repeat_type = schedule.repeat_type,
328
+ repeat_rule = schedule.repeat_rule;
329
+ if (!repeat_rule) return '';
330
+ var frequency = repeat_rule.frequency,
331
+ frequency_date = repeat_rule.frequency_date,
332
+ end = repeat_rule.end;
333
+
334
+ // 特殊处理:当 end.type === 'never' 时的格式
335
+ if (end.type === 'never') {
336
+ return generateNeverEndingRecurringSummary(schedule, isStarted, locale, repeat_type, frequency, frequency_date);
337
+ }
338
+
339
+ // 原有逻辑:有结束时间的循环日程
340
+ var endDate = getScheduleEndDate(schedule);
341
+ if (!endDate) return '';
342
+ var endDateStr = formatDateTime(endDate, true, locale);
343
+
344
+ // 按天循环
345
+ if (repeat_type === 'daily') {
346
+ var frequencyText = getDailyFrequencyText(frequency, locale);
347
+ var dateRange = formatDateRange(schedule.start_time, endDate, isStarted, locale, true);
348
+ return "".concat(dateRange, "\uFF0C").concat(frequencyText);
349
+ }
350
+
351
+ // 按周循环
352
+ if (repeat_type === 'weekly') {
353
+ var weekdaysText = getWeekdayText(frequency_date, locale, '/');
354
+ var frequencyPrefix = getWeeklyFrequencyPrefix(frequency, locale);
355
+ var config = getConfig(locale);
356
+ var _dateRange = formatDateRange(schedule.start_time, endDate, isStarted, locale, true);
357
+ return "".concat(_dateRange, "\uFF0C").concat(frequencyPrefix).concat(config.weekPrefix).concat(weekdaysText);
358
+ }
359
+ return '';
360
+ }
361
+
362
+ /**
363
+ * 生成永不结束的循环日程摘要
364
+ * @param schedule 日程对象
365
+ * @param isStarted 是否已开始
366
+ * @param locale 语言设置
367
+ * @param repeatType 循环类型
368
+ * @param frequency 频率
369
+ * @param frequencyDate 频率日期数组(用于周循环)
370
+ * @returns 永不结束的循环日程摘要文本
371
+ */
372
+ function generateNeverEndingRecurringSummary(schedule, isStarted, locale, repeatType, frequency, frequencyDate) {
373
+ var config = getConfig(locale);
374
+
375
+ // 按天循环
376
+ if (repeatType === 'daily') {
377
+ if (frequency === 1) {
378
+ // 频率=1:中文"自 YYYY-MM-DD 起长期有效",英文"Valid from DD MMM YYYY, no expiry"
379
+ if (schedule.start_time) {
380
+ var startDateStr = formatDateTime(schedule.start_time, true, locale);
381
+ return "".concat(config.longTermValidFrom).concat(startDateStr).concat(config.noExpiry);
382
+ }
383
+ return '';
384
+ } else {
385
+ // 频率>1:中文"每2天可用",英文"Every 2 days"
386
+ var frequencyText = getDailyFrequencyText(frequency, locale);
387
+ if (locale === 'en') {
388
+ return "".concat(frequencyText);
389
+ } else {
390
+ return "".concat(frequencyText).concat(config.available);
391
+ }
392
+ }
393
+ }
394
+
395
+ // 按周循环
396
+ if (repeatType === 'weekly') {
397
+ var weekdaysText = getWeekdayText(frequencyDate, locale, locale === 'en' ? ' & ' : '/');
398
+ if (frequency === 1) {
399
+ // 频率=1:中文"每周三/五可用",英文"on Wed & Fri"
400
+ if (locale === 'en') {
401
+ return "".concat(config.on).concat(weekdaysText);
402
+ } else {
403
+ return "".concat(config.everyPrefix).concat(config.weekPrefix).concat(weekdaysText).concat(config.available);
404
+ }
405
+ } else {
406
+ // 频率>1:中文"每2周 周三/五",英文"Every 2 weeks, on Wed & Fri"
407
+ var frequencyPrefix = getWeeklyFrequencyPrefix(frequency, locale);
408
+ if (locale === 'en') {
409
+ return "".concat(frequencyPrefix).concat(config.on).concat(weekdaysText);
410
+ } else {
411
+ return "".concat(frequencyPrefix).concat(config.weekPrefix).concat(weekdaysText);
412
+ }
413
+ }
414
+ }
415
+ return '';
416
+ }
417
+
418
+ /**
419
+ * 生成单个日程摘要
420
+ * @param schedule 日程对象
421
+ * @param isStarted 是否已开始
422
+ * @param locale 语言设置
423
+ * @returns 单个日程摘要文本
424
+ */
425
+ function generateSingleScheduleSummary(schedule, isStarted, locale) {
426
+ var isAllDay = schedule.is_all === 1;
427
+
428
+ // 处理designation类型的单个日期段
429
+ if (schedule.type === 'designation' && schedule.designation && schedule.designation.length === 1) {
430
+ var designation = schedule.designation[0];
431
+ var startDate = designation.start_date;
432
+ var endDate = designation.end_date;
433
+ var startTime = designation.start_time;
434
+ var endTime = designation.end_time;
435
+
436
+ // 判断是否为全天
437
+ var isDesignationAllDay = isAllDaySchedule(startTime, endTime);
438
+ if (isDesignationAllDay || isAllDay) {
439
+ // 全天日程
440
+ return formatDateRange(startDate, endDate, isStarted, locale, true);
441
+ } else {
442
+ // 非全天日程
443
+ var startDateTime = "".concat(startDate, " ").concat(startTime).concat(CONSTANTS.SECONDS_SUFFIX);
444
+ var endDateTime = "".concat(endDate, " ").concat(endTime).concat(CONSTANTS.SECONDS_SUFFIX);
445
+ return formatDateRange(startDateTime, endDateTime, isStarted, locale, false);
446
+ }
447
+ }
448
+
449
+ // 标准日程处理
450
+ if (isAllDay) {
451
+ // 全天日程
452
+ var _endDate = getScheduleEndDate(schedule);
453
+ if (!_endDate) return '';
454
+ return formatDateRange(schedule.start_time, _endDate, isStarted, locale, true);
455
+ } else {
456
+ // 非全天日程
457
+ return formatDateRange(schedule.start_time, schedule.end_time, isStarted, locale, false);
458
+ }
459
+ }
460
+
461
+ /**
462
+ * 获取日程结束日期
463
+ * @param schedule 日程对象
464
+ * @returns 结束日期字符串,如果无法确定则返回null
465
+ */
466
+ function getScheduleEndDate(schedule) {
467
+ try {
468
+ // 循环日程
469
+ if (schedule.repeat_rule) {
470
+ if (schedule.repeat_rule.end.type === 'never') {
471
+ // 无限期的情况,返回一个合理的未来日期作为显示
472
+ var futureDate = dayjs().add(CONSTANTS.DEFAULT_FUTURE_YEARS, 'year');
473
+ return "".concat(futureDate.format('YYYY-MM-DD'), " ").concat(CONSTANTS.ALL_DAY_END).concat(CONSTANTS.SECONDS_SUFFIX);
474
+ } else if (schedule.repeat_rule.end.end_date) {
475
+ return "".concat(schedule.repeat_rule.end.end_date, " ").concat(CONSTANTS.ALL_DAY_END).concat(CONSTANTS.SECONDS_SUFFIX);
476
+ }
477
+ }
478
+
479
+ // designation类型
480
+ if (schedule.designation && schedule.designation.length > 0) {
481
+ var lastDesignation = schedule.designation[schedule.designation.length - 1];
482
+ return "".concat(lastDesignation.end_date, " ").concat(lastDesignation.end_time).concat(CONSTANTS.SECONDS_SUFFIX);
483
+ }
484
+
485
+ // 标准日程
486
+ if (schedule.end_time) {
487
+ return schedule.end_time;
488
+ }
489
+
490
+ // time-slots类型
491
+ if (schedule.start_time) {
492
+ return schedule.start_time;
493
+ }
494
+ return null;
495
+ } catch (error) {
496
+ console.warn('Error in getScheduleEndDate:', error);
497
+ return null;
498
+ }
499
+ }
@@ -0,0 +1 @@
1
+ export declare const uniqueByKey: <T>(arr: T[], key: keyof T) => T[];
@@ -0,0 +1,13 @@
1
+ /**
2
+ * @Title: 设置主题
3
+ * @Describe: 传入字符串键值对
4
+ * @Author: Wzw
5
+ */
6
+ export declare const setTheme: (themes: {
7
+ [key: string]: string;
8
+ }) => void;
9
+ /**
10
+ * 复制到剪切板
11
+ * @param text
12
+ */
13
+ export declare const copyToClipboard: (text: string) => Promise<void>;
@@ -0,0 +1,13 @@
1
+ declare type InjectedConfigType = {
2
+ apiKey: string;
3
+ authDomain: string;
4
+ projectId: string;
5
+ storageBucket: string;
6
+ messagingSenderId: string;
7
+ appId: string;
8
+ databaseURL: string;
9
+ };
10
+ export declare const injectConfig: (context: InjectedConfigType) => void;
11
+ export declare const firebaseConfig: any;
12
+ declare const _default: any;
13
+ export default _default;
@@ -0,0 +1,28 @@
1
+ import { FirebaseApp } from 'firebase/app';
2
+ import { Auth } from 'firebase/auth';
3
+ import { ref, Database, goOnline, goOffline } from 'firebase/database';
4
+ declare let firebaseApp: FirebaseApp;
5
+ declare let auth: Auth;
6
+ declare let database: Database;
7
+ export declare const initFirebase: (config?: any) => void;
8
+ export { database, firebaseApp, auth, ref, goOnline, goOffline };
9
+ export declare const getPath: (path: string) => string;
10
+ export declare const setAuthStateChangeCallback: (callback: (user: any) => void) => void;
11
+ export declare const signUp: (email: string, password: string) => Promise<import("firebase/auth").User>;
12
+ export declare const signInUser: (email: string, password: string) => Promise<import("firebase/auth").User>;
13
+ export declare const signOutUser: () => Promise<void>;
14
+ export declare const readData: (path: string) => Promise<any>;
15
+ export declare const writeData: (path: string, data: any) => Promise<void>;
16
+ export declare const onDataChange: (path: string, callback: (snapshot: any) => void) => import("firebase/database").Unsubscribe;
17
+ export declare const onDataChanged: (path: string, callback: (snapshot: any) => void) => import("firebase/database").Unsubscribe;
18
+ export declare const removeDataListener: (listener: any) => void;
19
+ declare const _default: {
20
+ signInUser: (email: string, password: string) => Promise<import("firebase/auth").User>;
21
+ signOutUser: () => Promise<void>;
22
+ readData: (path: string) => Promise<any>;
23
+ writeData: (path: string, data: any) => Promise<void>;
24
+ onDataChange: (path: string, callback: (snapshot: any) => void) => import("firebase/database").Unsubscribe;
25
+ removeDataListener: (listener: any) => void;
26
+ onDataChanged: (path: string, callback: (snapshot: any) => void) => import("firebase/database").Unsubscribe;
27
+ };
28
+ export default _default;
@@ -0,0 +1,28 @@
1
+ /**
2
+ * @title: 格式化金额
3
+ * @description:
4
+ * @param {number} amount 原金额
5
+ * @param {number} precision 小数位数
6
+ * @param {string} symbol 货币符号
7
+ * @return {*}
8
+ * @Author: zhiwei.Wang
9
+ * @Date: 2023-11-06 16:51
10
+ */
11
+ export declare const formatAmount: (amount?: number | string, precision?: number, symbol?: string) => string | number;
12
+ export declare type FormatOptions = {
13
+ /** 小数点后位数 默认是小数点后2位 */
14
+ precision?: number;
15
+ /** 显示货币符号 指的是 ¥$ 等货币符号等显隐,默认是展示 */
16
+ showCurrencySymbol?: boolean;
17
+ /** 千分位 指的是长金额的千分位逗号隔开,比如“123, 245, 315” 这种展现形式,默认是关闭 */
18
+ useThousandsSeparator?: boolean;
19
+ /** 整数位隐藏小数 指的是如果价格为整数,后面的".00" 将被省略以节省页面空间 */
20
+ hideDecimalForWholeNumbers?: boolean;
21
+ };
22
+ /**
23
+ * 根据配置格式化金额
24
+ * @param amount
25
+ * @param symbol
26
+ * @param options
27
+ */
28
+ export declare const formatAmountWithOptions: (amount: string | number | undefined, symbol: string | undefined, options: FormatOptions) => string | number;
package/lib/format.js CHANGED
@@ -30,7 +30,10 @@ var formatAmount = (amount = 0, precision = 2, symbol = "") => {
30
30
  return amount;
31
31
  }
32
32
  try {
33
- const roundedAmount = Math.round(amount * Math.pow(10, precision)) / Math.pow(10, precision);
33
+ const roundedAmount = (
34
+ //@ts-ignore
35
+ Math.round(amount * Math.pow(10, precision)) / Math.pow(10, precision)
36
+ );
34
37
  const absoluteAmount = Math.abs(roundedAmount);
35
38
  const integerPart = Math.floor(absoluteAmount);
36
39
  const decimalPart = (absoluteAmount - integerPart).toFixed(precision).substring(2);
@@ -65,7 +68,10 @@ var formatAmountWithOptions = (amount = 0, symbol = "", options) => {
65
68
  return amount;
66
69
  }
67
70
  try {
68
- const roundedAmount = Math.round(amount * Math.pow(10, precision)) / Math.pow(10, precision);
71
+ const roundedAmount = (
72
+ //@ts-ignore
73
+ Math.round(amount * Math.pow(10, precision)) / Math.pow(10, precision)
74
+ );
69
75
  const absoluteAmount = Math.abs(roundedAmount);
70
76
  const integerPart = Math.floor(absoluteAmount);
71
77
  const decimalPart = (absoluteAmount - integerPart).toFixed(precision).substring(2);
package/lib/index.js CHANGED
@@ -37,6 +37,7 @@ __reExport(src_exports, require("./jsBridge"), module.exports);
37
37
  __reExport(src_exports, require("./image"), module.exports);
38
38
  __reExport(src_exports, require("./locales"), module.exports);
39
39
  __reExport(src_exports, require("./arrayUtils"), module.exports);
40
+ __reExport(src_exports, require("./walletValidity"), module.exports);
40
41
  var setPisellUtilsConfig = (config) => {
41
42
  globalThis.pisellUtilsConfig = {
42
43
  ...globalThis.pisellUtilsConfig || {},
@@ -64,5 +65,6 @@ var getPisellUtilsConfig = () => {
64
65
  ...require("./jsBridge"),
65
66
  ...require("./image"),
66
67
  ...require("./locales"),
67
- ...require("./arrayUtils")
68
+ ...require("./arrayUtils"),
69
+ ...require("./walletValidity")
68
70
  });
@@ -0,0 +1,16 @@
1
+ interface MiniReduxProps<State, Namespace> {
2
+ namespace?: Namespace;
3
+ state?: State;
4
+ reducers?: any;
5
+ effects?: any;
6
+ }
7
+ export declare const miniRedux: <State extends Record<string, any>, Namespace extends string>({ namespace, state, reducers, effects, }: MiniReduxProps<State, Namespace>) => {
8
+ Context: React.Context<{ [K in Namespace]: State; } & {
9
+ dispatch: (params: {
10
+ type: string;
11
+ payload: any;
12
+ }) => void;
13
+ }>;
14
+ Provider: (ComponentUi: any) => any;
15
+ };
16
+ export {};
package/lib/miniRedux.js CHANGED
@@ -61,10 +61,13 @@ var miniRedux = ({
61
61
  dispatch({ type, payload });
62
62
  }
63
63
  }, []);
64
- const contextValue = (0, import_react.useMemo)(() => ({
65
- [namespace]: providerState,
66
- dispatch: _dispatch
67
- }), [providerState, _dispatch]);
64
+ const contextValue = (0, import_react.useMemo)(
65
+ () => ({
66
+ [namespace]: providerState,
67
+ dispatch: _dispatch
68
+ }),
69
+ [providerState, _dispatch]
70
+ );
68
71
  let _props = {
69
72
  ...props,
70
73
  [namespace]: providerState,