@oanda/labs-widget-common 1.0.213 → 1.0.214

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -3,6 +3,850 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ ## 1.0.214 (2025-08-14)
7
+
8
+
9
+
10
+ ## 1.0.213 (2025-08-12)
11
+
12
+
13
+
14
+ ## 1.0.212 (2025-08-05)
15
+
16
+
17
+
18
+ ## 1.0.211 (2025-08-05)
19
+
20
+
21
+
22
+ ## 1.0.210 (2025-07-31)
23
+
24
+
25
+
26
+ ## 1.0.209 (2025-07-31)
27
+
28
+
29
+
30
+ ## 1.0.208 (2025-07-24)
31
+
32
+
33
+
34
+ ## 1.0.207 (2025-07-18)
35
+
36
+
37
+
38
+ ## 1.0.206 (2025-07-18)
39
+
40
+
41
+
42
+ ## 1.0.205 (2025-07-17)
43
+
44
+
45
+
46
+ ## 1.0.204 (2025-07-09)
47
+
48
+
49
+
50
+ ## 1.0.203 (2025-06-16)
51
+
52
+
53
+
54
+ ## 1.0.202 (2025-06-04)
55
+
56
+
57
+
58
+ ## 1.0.201 (2025-06-02)
59
+
60
+
61
+
62
+ ## 1.0.200 (2025-05-30)
63
+
64
+
65
+
66
+ ## 1.0.199 (2025-05-29)
67
+
68
+
69
+
70
+ ## 1.0.198 (2025-05-26)
71
+
72
+
73
+
74
+ ## 1.0.197 (2025-05-23)
75
+
76
+
77
+
78
+ ## 1.0.196 (2025-05-22)
79
+
80
+
81
+
82
+ ## 1.0.195 (2025-05-21)
83
+
84
+
85
+
86
+ ## 1.0.194 (2025-05-21)
87
+
88
+
89
+
90
+ ## 1.0.193 (2025-05-15)
91
+
92
+
93
+
94
+ ## 1.0.192 (2025-05-14)
95
+
96
+
97
+
98
+ ## 1.0.191 (2025-04-30)
99
+
100
+
101
+
102
+ ## 1.0.190 (2025-04-28)
103
+
104
+
105
+
106
+ ## 1.0.189 (2025-04-23)
107
+
108
+
109
+
110
+ ## 1.0.188 (2025-04-22)
111
+
112
+
113
+
114
+ ## 1.0.187 (2025-04-18)
115
+
116
+
117
+
118
+ ## 1.0.186 (2025-04-10)
119
+
120
+
121
+
122
+ ## 1.0.185 (2025-04-09)
123
+
124
+
125
+
126
+ ## 1.0.184 (2025-04-08)
127
+
128
+
129
+
130
+ ## 1.0.183 (2025-04-04)
131
+
132
+
133
+
134
+ ## 1.0.182 (2025-03-21)
135
+
136
+
137
+
138
+ ## 1.0.181 (2025-03-13)
139
+
140
+
141
+
142
+ ## 1.0.180 (2025-01-30)
143
+
144
+
145
+
146
+ ## 1.0.179 (2025-01-29)
147
+
148
+
149
+
150
+ ## 1.0.178 (2025-01-12)
151
+
152
+
153
+
154
+ ## 1.0.177 (2025-01-10)
155
+
156
+
157
+
158
+ ## 1.0.176 (2025-01-10)
159
+
160
+
161
+
162
+ ## 1.0.175 (2025-01-08)
163
+
164
+
165
+
166
+ ## 1.0.174 (2024-12-16)
167
+
168
+
169
+
170
+ ## 1.0.173 (2024-12-11)
171
+
172
+
173
+
174
+ ## 1.0.172 (2024-11-29)
175
+
176
+
177
+
178
+ ## 1.0.171 (2024-11-28)
179
+
180
+
181
+
182
+ ## 1.0.170 (2024-11-28)
183
+
184
+
185
+
186
+ ## 1.0.169 (2024-11-20)
187
+
188
+
189
+
190
+ ## 1.0.168 (2024-11-19)
191
+
192
+
193
+
194
+ ## 1.0.167 (2024-10-14)
195
+
196
+
197
+
198
+ ## 1.0.166 (2024-10-07)
199
+
200
+
201
+
202
+ ## 1.0.165 (2024-10-03)
203
+
204
+
205
+
206
+ ## 1.0.164 (2024-09-26)
207
+
208
+
209
+
210
+ ## 1.0.163 (2024-09-18)
211
+
212
+
213
+
214
+ ## 1.0.162 (2024-09-12)
215
+
216
+
217
+
218
+ ## 1.0.161 (2024-09-11)
219
+
220
+
221
+
222
+ ## 1.0.160 (2024-09-10)
223
+
224
+
225
+
226
+ ## 1.0.159 (2024-09-09)
227
+
228
+
229
+
230
+ ## 1.0.158 (2024-09-04)
231
+
232
+
233
+
234
+ ## 1.0.157 (2024-09-04)
235
+
236
+
237
+
238
+ ## 1.0.156 (2024-09-02)
239
+
240
+
241
+
242
+ ## 1.0.155 (2024-08-29)
243
+
244
+
245
+
246
+ ## 1.0.154 (2024-08-29)
247
+
248
+
249
+
250
+ ## 1.0.153 (2024-08-23)
251
+
252
+
253
+
254
+ ## 1.0.152 (2024-08-23)
255
+
256
+
257
+
258
+ ## 1.0.151 (2024-08-20)
259
+
260
+
261
+
262
+ ## 1.0.150 (2024-08-19)
263
+
264
+
265
+
266
+ ## 1.0.149 (2024-08-07)
267
+
268
+
269
+
270
+ ## 1.0.148 (2024-08-01)
271
+
272
+
273
+
274
+ ## 1.0.147 (2024-08-01)
275
+
276
+
277
+
278
+ ## 1.0.146 (2024-07-26)
279
+
280
+
281
+
282
+ ## 1.0.145 (2024-07-25)
283
+
284
+
285
+
286
+ ## 1.0.144 (2024-07-22)
287
+
288
+
289
+
290
+ ## 1.0.143 (2024-07-19)
291
+
292
+
293
+
294
+ ## 1.0.142 (2024-07-16)
295
+
296
+
297
+
298
+ ## 1.0.141 (2024-07-16)
299
+
300
+
301
+
302
+ ## 1.0.140 (2024-07-12)
303
+
304
+
305
+
306
+ ## 1.0.139 (2024-07-12)
307
+
308
+
309
+
310
+ ## 1.0.138 (2024-07-10)
311
+
312
+
313
+
314
+ ## 1.0.137 (2024-07-05)
315
+
316
+
317
+
318
+ ## 1.0.136 (2024-07-03)
319
+
320
+
321
+
322
+ ## 1.0.135 (2024-07-03)
323
+
324
+
325
+
326
+ ## 1.0.134 (2024-07-03)
327
+
328
+
329
+
330
+ ## 1.0.133 (2024-06-28)
331
+
332
+
333
+
334
+ ## 1.0.132 (2024-06-27)
335
+
336
+
337
+
338
+ ## 1.0.131 (2024-06-27)
339
+
340
+
341
+
342
+ ## 1.0.130 (2024-06-26)
343
+
344
+
345
+
346
+ ## 1.0.129 (2024-06-17)
347
+
348
+
349
+
350
+ ## 1.0.128 (2024-06-17)
351
+
352
+
353
+
354
+ ## 1.0.127 (2024-06-10)
355
+
356
+
357
+
358
+ ## 1.0.126 (2024-05-29)
359
+
360
+
361
+
362
+ ## 1.0.125 (2024-05-29)
363
+
364
+
365
+
366
+ ## 1.0.124 (2024-05-29)
367
+
368
+
369
+
370
+ ## 1.0.123 (2024-05-28)
371
+
372
+
373
+
374
+ ## 1.0.122 (2024-05-27)
375
+
376
+
377
+
378
+ ## 1.0.121 (2024-05-27)
379
+
380
+
381
+
382
+ ## 1.0.120 (2024-05-24)
383
+
384
+
385
+
386
+ ## 1.0.119 (2024-05-17)
387
+
388
+
389
+
390
+ ## 1.0.118 (2024-05-09)
391
+
392
+
393
+
394
+ ## 1.0.117 (2024-05-07)
395
+
396
+
397
+
398
+ ## 1.0.116 (2024-04-23)
399
+
400
+
401
+
402
+ ## 1.0.115 (2024-04-22)
403
+
404
+
405
+
406
+ ## 1.0.114 (2024-04-19)
407
+
408
+
409
+
410
+ ## 1.0.113 (2024-04-19)
411
+
412
+
413
+
414
+ ## 1.0.112 (2024-04-15)
415
+
416
+
417
+
418
+ ## 1.0.111 (2024-04-11)
419
+
420
+
421
+
422
+ ## 1.0.110 (2024-04-05)
423
+
424
+
425
+
426
+ ## 1.0.109 (2024-04-05)
427
+
428
+
429
+
430
+ ## 1.0.108 (2024-04-04)
431
+
432
+
433
+
434
+ ## 1.0.107 (2024-04-03)
435
+
436
+
437
+
438
+ ## 1.0.106 (2024-03-29)
439
+
440
+
441
+
442
+ ## 1.0.105 (2024-03-28)
443
+
444
+
445
+
446
+ ## 1.0.104 (2024-03-21)
447
+
448
+
449
+
450
+ ## 1.0.103 (2024-03-20)
451
+
452
+
453
+
454
+ ## 1.0.102 (2024-03-20)
455
+
456
+
457
+
458
+ ## 1.0.101 (2024-03-13)
459
+
460
+
461
+
462
+ ## 1.0.100 (2024-03-12)
463
+
464
+
465
+
466
+ ## 1.0.99 (2024-03-11)
467
+
468
+
469
+
470
+ ## 1.0.98 (2024-03-07)
471
+
472
+
473
+
474
+ ## 1.0.97 (2024-03-06)
475
+
476
+
477
+
478
+ ## 1.0.96 (2024-03-06)
479
+
480
+
481
+
482
+ ## 1.0.95 (2024-03-04)
483
+
484
+
485
+
486
+ ## 1.0.94 (2024-02-29)
487
+
488
+
489
+
490
+ ## 1.0.93 (2024-02-28)
491
+
492
+
493
+
494
+ ## 1.0.92 (2024-02-28)
495
+
496
+
497
+
498
+ ## 1.0.91 (2024-02-23)
499
+
500
+
501
+
502
+ ## 1.0.90 (2024-02-23)
503
+
504
+
505
+
506
+ ## 1.0.89 (2024-02-21)
507
+
508
+
509
+
510
+ ## 1.0.88 (2024-02-21)
511
+
512
+
513
+
514
+ ## 1.0.87 (2024-02-20)
515
+
516
+
517
+
518
+ ## 1.0.86 (2024-02-20)
519
+
520
+
521
+
522
+ ## 1.0.85 (2024-02-13)
523
+
524
+
525
+
526
+ ## 1.0.84 (2024-02-13)
527
+
528
+
529
+
530
+ ## 1.0.83 (2024-02-09)
531
+
532
+
533
+
534
+ ## 1.0.82 (2024-02-05)
535
+
536
+
537
+
538
+ ## 1.0.81 (2024-02-05)
539
+
540
+
541
+
542
+ ## 1.0.80 (2024-02-05)
543
+
544
+
545
+
546
+ ## 1.0.79 (2024-02-05)
547
+
548
+
549
+
550
+ ## 1.0.78 (2024-01-30)
551
+
552
+
553
+
554
+ ## 1.0.77 (2024-01-25)
555
+
556
+
557
+
558
+ ## 1.0.76 (2024-01-25)
559
+
560
+
561
+
562
+ ## 1.0.75 (2024-01-22)
563
+
564
+
565
+
566
+ ## 1.0.74 (2024-01-22)
567
+
568
+
569
+
570
+ ## 1.0.73 (2024-01-22)
571
+
572
+
573
+
574
+ ## 1.0.72 (2024-01-19)
575
+
576
+
577
+
578
+ ## 1.0.71 (2024-01-18)
579
+
580
+
581
+
582
+ ## 1.0.70 (2024-01-17)
583
+
584
+
585
+
586
+ ## 1.0.69 (2024-01-17)
587
+
588
+
589
+
590
+ ## 1.0.68 (2024-01-15)
591
+
592
+
593
+
594
+ ## 1.0.67 (2024-01-15)
595
+
596
+
597
+
598
+ ## 1.0.66 (2024-01-12)
599
+
600
+
601
+
602
+ ## 1.0.65 (2024-01-11)
603
+
604
+
605
+
606
+ ## 1.0.64 (2024-01-11)
607
+
608
+
609
+
610
+ ## 1.0.63 (2024-01-11)
611
+
612
+
613
+
614
+ ## 1.0.62 (2024-01-10)
615
+
616
+
617
+
618
+ ## 1.0.61 (2024-01-09)
619
+
620
+
621
+
622
+ ## 1.0.60 (2024-01-05)
623
+
624
+
625
+
626
+ ## 1.0.59 (2023-12-27)
627
+
628
+
629
+
630
+ ## 1.0.58 (2023-12-22)
631
+
632
+
633
+
634
+ ## 1.0.57 (2023-12-22)
635
+
636
+
637
+
638
+ ## 1.0.56 (2023-12-21)
639
+
640
+
641
+
642
+ ## 1.0.55 (2023-12-19)
643
+
644
+
645
+
646
+ ## 1.0.54 (2023-12-15)
647
+
648
+
649
+
650
+ ## 1.0.53 (2023-12-13)
651
+
652
+
653
+
654
+ ## 1.0.52 (2023-12-13)
655
+
656
+
657
+
658
+ ## 1.0.51 (2023-12-07)
659
+
660
+
661
+
662
+ ## 1.0.50 (2023-12-04)
663
+
664
+
665
+
666
+ ## 1.0.49 (2023-12-01)
667
+
668
+
669
+
670
+ ## 1.0.48 (2023-12-01)
671
+
672
+
673
+
674
+ ## 1.0.47 (2023-11-29)
675
+
676
+
677
+
678
+ ## 1.0.46 (2023-11-28)
679
+
680
+
681
+
682
+ ## 1.0.45 (2023-11-23)
683
+
684
+
685
+
686
+ ## 1.0.44 (2023-11-22)
687
+
688
+
689
+
690
+ ## 1.0.43 (2023-11-15)
691
+
692
+
693
+
694
+ ## 1.0.42 (2023-11-10)
695
+
696
+
697
+
698
+ ## 1.0.41 (2023-11-03)
699
+
700
+
701
+
702
+ ## 1.0.40 (2023-11-02)
703
+
704
+
705
+
706
+ ## 1.0.39 (2023-11-02)
707
+
708
+
709
+
710
+ ## 1.0.38 (2023-10-26)
711
+
712
+
713
+
714
+ ## 1.0.37 (2023-10-26)
715
+
716
+
717
+
718
+ ## 1.0.36 (2023-10-25)
719
+
720
+
721
+
722
+ ## 1.0.35 (2023-10-24)
723
+
724
+
725
+
726
+ ## 1.0.34 (2023-10-23)
727
+
728
+
729
+
730
+ ## 1.0.33 (2023-10-23)
731
+
732
+
733
+
734
+ ## 1.0.32 (2023-10-23)
735
+
736
+
737
+
738
+ ## 1.0.31 (2023-10-20)
739
+
740
+
741
+
742
+ ## 1.0.30 (2023-10-19)
743
+
744
+
745
+
746
+ ## 1.0.29 (2023-10-19)
747
+
748
+
749
+
750
+ ## 1.0.28 (2023-10-19)
751
+
752
+
753
+
754
+ ## 1.0.27 (2023-10-18)
755
+
756
+
757
+
758
+ ## 1.0.26 (2023-10-18)
759
+
760
+
761
+
762
+ ## 1.0.25 (2023-10-17)
763
+
764
+
765
+
766
+ ## 1.0.24 (2023-10-13)
767
+
768
+
769
+
770
+ ## 1.0.23 (2023-10-13)
771
+
772
+
773
+
774
+ ## 1.0.22 (2023-10-11)
775
+
776
+
777
+
778
+ ## 1.0.21 (2023-10-10)
779
+
780
+
781
+
782
+ ## 1.0.20 (2023-10-06)
783
+
784
+
785
+
786
+ ## 1.0.19 (2023-10-06)
787
+
788
+
789
+
790
+ ## 1.0.18 (2023-10-05)
791
+
792
+
793
+
794
+ ## 1.0.17 (2023-10-04)
795
+
796
+
797
+
798
+ ## 1.0.16 (2023-10-04)
799
+
800
+
801
+
802
+ ## 1.0.15 (2023-10-04)
803
+
804
+
805
+
806
+ ## 1.0.14 (2023-10-03)
807
+
808
+
809
+
810
+ ## 1.0.13 (2023-10-03)
811
+
812
+
813
+
814
+ ## 1.0.12 (2023-10-03)
815
+
816
+
817
+
818
+ ## 1.0.11 (2023-10-02)
819
+
820
+
821
+
822
+ ## 1.0.10 (2023-09-29)
823
+
824
+
825
+
826
+ ## 1.0.9 (2023-09-28)
827
+
828
+
829
+
830
+ ## 1.0.8 (2023-09-27)
831
+
832
+
833
+
834
+ ## 1.0.7 (2023-09-26)
835
+
836
+
837
+
838
+ ## 1.0.6 (2023-09-21)
839
+
840
+
841
+
842
+ ## 1.0.5 (2023-09-13)
843
+
844
+ **Note:** Version bump only for package @oanda/labs-widget-common
845
+
846
+
847
+
848
+
849
+
6
850
  ## 1.0.213 (2025-08-12)
7
851
 
8
852
 
@@ -25,19 +25,18 @@ const InstrumentRate = _ref => {
25
25
  } = (0, _providers.useLayoutProvider)();
26
26
  const checkLoading = id => !isError && record?.[id] === undefined;
27
27
  const isExpanded = size === 'full' || size === 'fullWithChart';
28
- const isCompact = size === 'compact';
29
28
  return _react.default.createElement("div", {
30
29
  className: (0, _tailwind.cn)('lw-flex lw-flex-col', isExpanded && 'lw-h-full'),
31
30
  "data-testid": "instrument-rate-wrapper"
32
31
  }, _react.default.createElement("div", {
33
- className: (0, _tailwind.cn)('lw-flex lw-gap-x-2', isExpanded && 'lw-h-1/2 lw-pt-3', !slim && isCompact && 'lw-py-3', slim && 'lw-py-1'),
32
+ className: (0, _tailwind.cn)('lw-flex lw-gap-x-2 lw-text-xl', isExpanded && 'lw-h-1/2', !slim && 'lw-py-2', slim && 'lw-py-1'),
34
33
  "data-testid": "instrument-rate-wrapper-label"
35
34
  }, _react.default.createElement(_LabelWrapper.LabelWrapper, {
36
35
  isError: !!isError,
37
36
  isLoading: checkLoading('instrument'),
38
37
  size: _LabelWrapper.LabelSize.lg
39
38
  }, _react.default.createElement("span", {
40
- className: "lw-text-xl lw-font-bold"
39
+ className: "lw-font-bold"
41
40
  }, _react.default.createElement(_Truncate.Truncate, {
42
41
  maxWidth: 100,
43
42
  text: record.displayName,
@@ -47,12 +46,12 @@ const InstrumentRate = _ref => {
47
46
  isLoading: checkLoading('buy'),
48
47
  size: _LabelWrapper.LabelSize.lg
49
48
  }, _react.default.createElement("div", {
50
- className: "lw-text-xl lw-font-bold"
49
+ className: "lw-font-bold"
51
50
  }, _react.default.createElement(_Price.Price, {
52
51
  movementIndicator: "text",
53
52
  priceMovement: record.buyPriceMovement
54
53
  }, _react.default.createElement("span", null, record.buy?.toFixed(record.displayPrecision)))))), isExpanded && _react.default.createElement("div", {
55
- className: (0, _tailwind.cn)('lw-flex lw-h-1/2 lw-w-fit lw-items-center lw-gap-x-2 lw-py-2.5 lw-pr-2.5', !isDark && 'lw-bg-whiteOpacity', isDark && 'lw-bg-blackOpacity', slim && 'lw-py-1.5'),
54
+ className: (0, _tailwind.cn)('lw-flex lw-h-1/2 lw-w-fit lw-items-center lw-gap-x-2 lw-pr-2.5', !isDark && 'lw-bg-whiteOpacity', isDark && 'lw-bg-blackOpacity', !slim && 'lw-py-1', slim && 'lw-pb-1'),
56
55
  "data-testid": "instrument-rate-wrapper-expanded"
57
56
  }, _react.default.createElement(_LabelWrapper.LabelWrapper, {
58
57
  isError: !!isError,
@@ -1 +1 @@
1
- {"version":3,"file":"InstrumentRate.js","names":["_react","_interopRequireDefault","require","_providers","_tailwind","_LabelWrapper","_Price","_Truncate","e","__esModule","default","InstrumentRate","_ref","isError","record","tooltipId","size","slim","colorIndicator","indicator","isDark","useLayoutProvider","checkLoading","id","undefined","isExpanded","isCompact","createElement","className","cn","LabelWrapper","isLoading","LabelSize","lg","Truncate","maxWidth","text","displayName","Price","movementIndicator","priceMovement","buyPriceMovement","buy","toFixed","displayPrecision","sm","dailyPercentChange","withoutLoader","dailyPipsChange","exports"],"sources":["../../../../src/components/InstrumentRate/InstrumentRate.tsx"],"sourcesContent":["import React from 'react';\n\nimport { useLayoutProvider } from '../../providers';\nimport { cn } from '../../tailwind';\nimport { LabelSize, LabelWrapper } from '../LabelWrapper';\nimport { Price } from '../Price';\nimport { Truncate } from '../Truncate';\nimport type { InstrumentRateProps } from './types';\n\nconst InstrumentRate = ({\n isError,\n record,\n tooltipId,\n size,\n slim,\n colorIndicator: indicator,\n}: InstrumentRateProps) => {\n const { isDark } = useLayoutProvider();\n const checkLoading = (id: string) => !isError && record?.[id] === undefined;\n const isExpanded = size === 'full' || size === 'fullWithChart';\n const isCompact = size === 'compact';\n\n return (\n <div\n className={cn('lw-flex lw-flex-col', isExpanded && 'lw-h-full')}\n data-testid=\"instrument-rate-wrapper\"\n >\n <div\n className={cn(\n 'lw-flex lw-gap-x-2',\n isExpanded && 'lw-h-1/2 lw-pt-3',\n !slim && isCompact && 'lw-py-3',\n slim && 'lw-py-1'\n )}\n data-testid=\"instrument-rate-wrapper-label\"\n >\n <LabelWrapper\n isError={!!isError}\n isLoading={checkLoading('instrument')}\n size={LabelSize.lg}\n >\n <span className=\"lw-text-xl lw-font-bold\">\n <Truncate\n maxWidth={100}\n text={record.displayName}\n tooltipId={tooltipId}\n />\n </span>\n </LabelWrapper>\n <LabelWrapper\n isError={!!isError}\n isLoading={checkLoading('buy')}\n size={LabelSize.lg}\n >\n <div className=\"lw-text-xl lw-font-bold\">\n <Price\n movementIndicator=\"text\"\n priceMovement={record.buyPriceMovement}\n >\n <span>{record.buy?.toFixed(record.displayPrecision)}</span>\n </Price>\n </div>\n </LabelWrapper>\n </div>\n {isExpanded && (\n <div\n className={cn(\n 'lw-flex lw-h-1/2 lw-w-fit lw-items-center lw-gap-x-2 lw-py-2.5 lw-pr-2.5',\n !isDark && 'lw-bg-whiteOpacity',\n isDark && 'lw-bg-blackOpacity',\n slim && 'lw-py-1.5'\n )}\n data-testid=\"instrument-rate-wrapper-expanded\"\n >\n <LabelWrapper\n isError={!!isError}\n isLoading={checkLoading('dailyPercentChange')}\n size={LabelSize.sm}\n >\n <span\n className={cn(\n 'lw-font-bold',\n indicator > 0 && 'lw-text-text-ok',\n indicator < 0 && 'lw-text-text-danger',\n indicator === 0 && 'lw-text-text-disabled'\n )}\n >\n {record.dailyPercentChange}\n </span>\n </LabelWrapper>\n <LabelWrapper\n withoutLoader\n isError={!!isError}\n isLoading={checkLoading('dailyPipsChange')}\n size={LabelSize.sm}\n >\n <span\n className={cn(\n 'lw-font-bold',\n indicator > 0 && 'lw-text-text-ok',\n indicator < 0 && 'lw-text-text-danger',\n indicator === 0 && 'lw-text-text-disabled'\n )}\n >\n {`(${record.dailyPipsChange})`}\n </span>\n </LabelWrapper>\n </div>\n )}\n </div>\n );\n};\n\nexport { InstrumentRate };\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"InstrumentRate.js","names":["_react","_interopRequireDefault","require","_providers","_tailwind","_LabelWrapper","_Price","_Truncate","e","__esModule","default","InstrumentRate","_ref","isError","record","tooltipId","size","slim","colorIndicator","indicator","isDark","useLayoutProvider","checkLoading","id","undefined","isExpanded","createElement","className","cn","LabelWrapper","isLoading","LabelSize","lg","Truncate","maxWidth","text","displayName","Price","movementIndicator","priceMovement","buyPriceMovement","buy","toFixed","displayPrecision","sm","dailyPercentChange","withoutLoader","dailyPipsChange","exports"],"sources":["../../../../src/components/InstrumentRate/InstrumentRate.tsx"],"sourcesContent":["import React from 'react';\n\nimport { useLayoutProvider } from '../../providers';\nimport { cn } from '../../tailwind';\nimport { LabelSize, LabelWrapper } from '../LabelWrapper';\nimport { Price } from '../Price';\nimport { Truncate } from '../Truncate';\nimport type { InstrumentRateProps } from './types';\n\nconst InstrumentRate = ({\n isError,\n record,\n tooltipId,\n size,\n slim,\n colorIndicator: indicator,\n}: InstrumentRateProps) => {\n const { isDark } = useLayoutProvider();\n const checkLoading = (id: string) => !isError && record?.[id] === undefined;\n const isExpanded = size === 'full' || size === 'fullWithChart';\n\n return (\n <div\n className={cn('lw-flex lw-flex-col', isExpanded && 'lw-h-full')}\n data-testid=\"instrument-rate-wrapper\"\n >\n <div\n className={cn(\n 'lw-flex lw-gap-x-2 lw-text-xl',\n isExpanded && 'lw-h-1/2',\n !slim && 'lw-py-2',\n slim && 'lw-py-1'\n )}\n data-testid=\"instrument-rate-wrapper-label\"\n >\n <LabelWrapper\n isError={!!isError}\n isLoading={checkLoading('instrument')}\n size={LabelSize.lg}\n >\n <span className=\"lw-font-bold\">\n <Truncate\n maxWidth={100}\n text={record.displayName}\n tooltipId={tooltipId}\n />\n </span>\n </LabelWrapper>\n <LabelWrapper\n isError={!!isError}\n isLoading={checkLoading('buy')}\n size={LabelSize.lg}\n >\n <div className=\"lw-font-bold\">\n <Price\n movementIndicator=\"text\"\n priceMovement={record.buyPriceMovement}\n >\n <span>{record.buy?.toFixed(record.displayPrecision)}</span>\n </Price>\n </div>\n </LabelWrapper>\n </div>\n {isExpanded && (\n <div\n className={cn(\n 'lw-flex lw-h-1/2 lw-w-fit lw-items-center lw-gap-x-2 lw-pr-2.5',\n !isDark && 'lw-bg-whiteOpacity',\n isDark && 'lw-bg-blackOpacity',\n !slim && 'lw-py-1',\n slim && 'lw-pb-1'\n )}\n data-testid=\"instrument-rate-wrapper-expanded\"\n >\n <LabelWrapper\n isError={!!isError}\n isLoading={checkLoading('dailyPercentChange')}\n size={LabelSize.sm}\n >\n <span\n className={cn(\n 'lw-font-bold',\n indicator > 0 && 'lw-text-text-ok',\n indicator < 0 && 'lw-text-text-danger',\n indicator === 0 && 'lw-text-text-disabled'\n )}\n >\n {record.dailyPercentChange}\n </span>\n </LabelWrapper>\n <LabelWrapper\n withoutLoader\n isError={!!isError}\n isLoading={checkLoading('dailyPipsChange')}\n size={LabelSize.sm}\n >\n <span\n className={cn(\n 'lw-font-bold',\n indicator > 0 && 'lw-text-text-ok',\n indicator < 0 && 'lw-text-text-danger',\n indicator === 0 && 'lw-text-text-disabled'\n )}\n >\n {`(${record.dailyPipsChange})`}\n </span>\n </LabelWrapper>\n </div>\n )}\n </div>\n );\n};\n\nexport { InstrumentRate };\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEA,IAAAC,UAAA,GAAAD,OAAA;AACA,IAAAE,SAAA,GAAAF,OAAA;AACA,IAAAG,aAAA,GAAAH,OAAA;AACA,IAAAI,MAAA,GAAAJ,OAAA;AACA,IAAAK,SAAA,GAAAL,OAAA;AAAuC,SAAAD,uBAAAO,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAGvC,MAAMG,cAAc,GAAGC,IAAA,IAOI;EAAA,IAPH;IACtBC,OAAO;IACPC,MAAM;IACNC,SAAS;IACTC,IAAI;IACJC,IAAI;IACJC,cAAc,EAAEC;EACG,CAAC,GAAAP,IAAA;EACpB,MAAM;IAAEQ;EAAO,CAAC,GAAG,IAAAC,4BAAiB,EAAC,CAAC;EACtC,MAAMC,YAAY,GAAIC,EAAU,IAAK,CAACV,OAAO,IAAIC,MAAM,GAAGS,EAAE,CAAC,KAAKC,SAAS;EAC3E,MAAMC,UAAU,GAAGT,IAAI,KAAK,MAAM,IAAIA,IAAI,KAAK,eAAe;EAE9D,OACEhB,MAAA,CAAAU,OAAA,CAAAgB,aAAA;IACEC,SAAS,EAAE,IAAAC,YAAE,EAAC,qBAAqB,EAAEH,UAAU,IAAI,WAAW,CAAE;IAChE,eAAY;EAAyB,GAErCzB,MAAA,CAAAU,OAAA,CAAAgB,aAAA;IACEC,SAAS,EAAE,IAAAC,YAAE,EACX,+BAA+B,EAC/BH,UAAU,IAAI,UAAU,EACxB,CAACR,IAAI,IAAI,SAAS,EAClBA,IAAI,IAAI,SACV,CAAE;IACF,eAAY;EAA+B,GAE3CjB,MAAA,CAAAU,OAAA,CAAAgB,aAAA,CAACrB,aAAA,CAAAwB,YAAY;IACXhB,OAAO,EAAE,CAAC,CAACA,OAAQ;IACnBiB,SAAS,EAAER,YAAY,CAAC,YAAY,CAAE;IACtCN,IAAI,EAAEe,uBAAS,CAACC;EAAG,GAEnBhC,MAAA,CAAAU,OAAA,CAAAgB,aAAA;IAAMC,SAAS,EAAC;EAAc,GAC5B3B,MAAA,CAAAU,OAAA,CAAAgB,aAAA,CAACnB,SAAA,CAAA0B,QAAQ;IACPC,QAAQ,EAAE,GAAI;IACdC,IAAI,EAAErB,MAAM,CAACsB,WAAY;IACzBrB,SAAS,EAAEA;EAAU,CACtB,CACG,CACM,CAAC,EACff,MAAA,CAAAU,OAAA,CAAAgB,aAAA,CAACrB,aAAA,CAAAwB,YAAY;IACXhB,OAAO,EAAE,CAAC,CAACA,OAAQ;IACnBiB,SAAS,EAAER,YAAY,CAAC,KAAK,CAAE;IAC/BN,IAAI,EAAEe,uBAAS,CAACC;EAAG,GAEnBhC,MAAA,CAAAU,OAAA,CAAAgB,aAAA;IAAKC,SAAS,EAAC;EAAc,GAC3B3B,MAAA,CAAAU,OAAA,CAAAgB,aAAA,CAACpB,MAAA,CAAA+B,KAAK;IACJC,iBAAiB,EAAC,MAAM;IACxBC,aAAa,EAAEzB,MAAM,CAAC0B;EAAiB,GAEvCxC,MAAA,CAAAU,OAAA,CAAAgB,aAAA,eAAOZ,MAAM,CAAC2B,GAAG,EAAEC,OAAO,CAAC5B,MAAM,CAAC6B,gBAAgB,CAAQ,CACrD,CACJ,CACO,CACX,CAAC,EACLlB,UAAU,IACTzB,MAAA,CAAAU,OAAA,CAAAgB,aAAA;IACEC,SAAS,EAAE,IAAAC,YAAE,EACX,gEAAgE,EAChE,CAACR,MAAM,IAAI,oBAAoB,EAC/BA,MAAM,IAAI,oBAAoB,EAC9B,CAACH,IAAI,IAAI,SAAS,EAClBA,IAAI,IAAI,SACV,CAAE;IACF,eAAY;EAAkC,GAE9CjB,MAAA,CAAAU,OAAA,CAAAgB,aAAA,CAACrB,aAAA,CAAAwB,YAAY;IACXhB,OAAO,EAAE,CAAC,CAACA,OAAQ;IACnBiB,SAAS,EAAER,YAAY,CAAC,oBAAoB,CAAE;IAC9CN,IAAI,EAAEe,uBAAS,CAACa;EAAG,GAEnB5C,MAAA,CAAAU,OAAA,CAAAgB,aAAA;IACEC,SAAS,EAAE,IAAAC,YAAE,EACX,cAAc,EACdT,SAAS,GAAG,CAAC,IAAI,iBAAiB,EAClCA,SAAS,GAAG,CAAC,IAAI,qBAAqB,EACtCA,SAAS,KAAK,CAAC,IAAI,uBACrB;EAAE,GAEDL,MAAM,CAAC+B,kBACJ,CACM,CAAC,EACf7C,MAAA,CAAAU,OAAA,CAAAgB,aAAA,CAACrB,aAAA,CAAAwB,YAAY;IACXiB,aAAa;IACbjC,OAAO,EAAE,CAAC,CAACA,OAAQ;IACnBiB,SAAS,EAAER,YAAY,CAAC,iBAAiB,CAAE;IAC3CN,IAAI,EAAEe,uBAAS,CAACa;EAAG,GAEnB5C,MAAA,CAAAU,OAAA,CAAAgB,aAAA;IACEC,SAAS,EAAE,IAAAC,YAAE,EACX,cAAc,EACdT,SAAS,GAAG,CAAC,IAAI,iBAAiB,EAClCA,SAAS,GAAG,CAAC,IAAI,qBAAqB,EACtCA,SAAS,KAAK,CAAC,IAAI,uBACrB;EAAE,GAED,IAAIL,MAAM,CAACiC,eAAe,GACvB,CACM,CACX,CAEJ,CAAC;AAEV,CAAC;AAACC,OAAA,CAAArC,cAAA,GAAAA,cAAA","ignoreList":[]}
@@ -20,7 +20,7 @@ const LabelWrapper = _ref => {
20
20
  withoutLoader = false
21
21
  } = _ref;
22
22
  return _react.default.createElement("div", {
23
- className: (0, _classnames.default)('lw-h-[inherit] lw-py-0 lw-font-sans', {
23
+ className: (0, _classnames.default)('lw-flex lw-h-[inherit] lw-min-h-[28px] lw-items-center lw-py-0 lw-font-sans', {
24
24
  'lw-min-w-[100px]': size === _types.LabelSize.lg,
25
25
  'lw-min-w-[70px]': size === _types.LabelSize.md,
26
26
  'lw-min-w-[50px]': size === _types.LabelSize.sm
@@ -1 +1 @@
1
- {"version":3,"file":"LabelWrapper.js","names":["_classnames","_interopRequireDefault","require","_react","_constant","_Loader","_types","e","__esModule","default","LabelWrapper","_ref","loaderSize","LoaderSize","md","size","LabelSize","children","isError","isLoading","withoutLoader","createElement","className","classnames","lg","sm","Loader","CELL_EMPTY_VALUE","exports"],"sources":["../../../../src/components/LabelWrapper/LabelWrapper.tsx"],"sourcesContent":["import classnames from 'classnames';\nimport React from 'react';\n\nimport { CELL_EMPTY_VALUE } from '../constant';\nimport { Loader, LoaderSize } from '../Loader';\nimport type { LabelWrapperProps } from './types';\nimport { LabelSize } from './types';\n\nconst LabelWrapper = ({\n loaderSize = LoaderSize.md,\n size = LabelSize.md,\n children,\n isError,\n isLoading,\n withoutLoader = false,\n}: LabelWrapperProps) => (\n <div\n className={classnames('lw-h-[inherit] lw-py-0 lw-font-sans', {\n 'lw-min-w-[100px]': size === LabelSize.lg,\n 'lw-min-w-[70px]': size === LabelSize.md,\n 'lw-min-w-[50px]': size === LabelSize.sm,\n })}\n data-testid=\"label-wrapper\"\n >\n <div className={classnames('lw-flex lw-h-[inherit] lw-items-center')}>\n {isLoading && !withoutLoader && <Loader size={loaderSize} />}\n {!isLoading && !isError && children}\n {!isLoading && isError && <span>{CELL_EMPTY_VALUE}</span>}\n </div>\n </div>\n);\n\nexport { LabelWrapper };\n"],"mappings":";;;;;;AAAA,IAAAA,WAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAF,sBAAA,CAAAC,OAAA;AAEA,IAAAE,SAAA,GAAAF,OAAA;AACA,IAAAG,OAAA,GAAAH,OAAA;AAEA,IAAAI,MAAA,GAAAJ,OAAA;AAAoC,SAAAD,uBAAAM,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAEpC,MAAMG,YAAY,GAAGC,IAAA;EAAA,IAAC;IACpBC,UAAU,GAAGC,kBAAU,CAACC,EAAE;IAC1BC,IAAI,GAAGC,gBAAS,CAACF,EAAE;IACnBG,QAAQ;IACRC,OAAO;IACPC,SAAS;IACTC,aAAa,GAAG;EACC,CAAC,GAAAT,IAAA;EAAA,OAClBR,MAAA,CAAAM,OAAA,CAAAY,aAAA;IACEC,SAAS,EAAE,IAAAC,mBAAU,EAAC,qCAAqC,EAAE;MAC3D,kBAAkB,EAAER,IAAI,KAAKC,gBAAS,CAACQ,EAAE;MACzC,iBAAiB,EAAET,IAAI,KAAKC,gBAAS,CAACF,EAAE;MACxC,iBAAiB,EAAEC,IAAI,KAAKC,gBAAS,CAACS;IACxC,CAAC,CAAE;IACH,eAAY;EAAe,GAE3BtB,MAAA,CAAAM,OAAA,CAAAY,aAAA;IAAKC,SAAS,EAAE,IAAAC,mBAAU,EAAC,wCAAwC;EAAE,GAClEJ,SAAS,IAAI,CAACC,aAAa,IAAIjB,MAAA,CAAAM,OAAA,CAAAY,aAAA,CAAChB,OAAA,CAAAqB,MAAM;IAACX,IAAI,EAAEH;EAAW,CAAE,CAAC,EAC3D,CAACO,SAAS,IAAI,CAACD,OAAO,IAAID,QAAQ,EAClC,CAACE,SAAS,IAAID,OAAO,IAAIf,MAAA,CAAAM,OAAA,CAAAY,aAAA,eAAOM,0BAAuB,CACrD,CACF,CAAC;AAAA,CACP;AAACC,OAAA,CAAAlB,YAAA,GAAAA,YAAA","ignoreList":[]}
1
+ {"version":3,"file":"LabelWrapper.js","names":["_classnames","_interopRequireDefault","require","_react","_constant","_Loader","_types","e","__esModule","default","LabelWrapper","_ref","loaderSize","LoaderSize","md","size","LabelSize","children","isError","isLoading","withoutLoader","createElement","className","classnames","lg","sm","Loader","CELL_EMPTY_VALUE","exports"],"sources":["../../../../src/components/LabelWrapper/LabelWrapper.tsx"],"sourcesContent":["import classnames from 'classnames';\nimport React from 'react';\n\nimport { CELL_EMPTY_VALUE } from '../constant';\nimport { Loader, LoaderSize } from '../Loader';\nimport type { LabelWrapperProps } from './types';\nimport { LabelSize } from './types';\n\nconst LabelWrapper = ({\n loaderSize = LoaderSize.md,\n size = LabelSize.md,\n children,\n isError,\n isLoading,\n withoutLoader = false,\n}: LabelWrapperProps) => (\n <div\n className={classnames(\n 'lw-flex lw-h-[inherit] lw-min-h-[28px] lw-items-center lw-py-0 lw-font-sans',\n {\n 'lw-min-w-[100px]': size === LabelSize.lg,\n 'lw-min-w-[70px]': size === LabelSize.md,\n 'lw-min-w-[50px]': size === LabelSize.sm,\n }\n )}\n data-testid=\"label-wrapper\"\n >\n <div className={classnames('lw-flex lw-h-[inherit] lw-items-center')}>\n {isLoading && !withoutLoader && <Loader size={loaderSize} />}\n {!isLoading && !isError && children}\n {!isLoading && isError && <span>{CELL_EMPTY_VALUE}</span>}\n </div>\n </div>\n);\n\nexport { LabelWrapper };\n"],"mappings":";;;;;;AAAA,IAAAA,WAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAF,sBAAA,CAAAC,OAAA;AAEA,IAAAE,SAAA,GAAAF,OAAA;AACA,IAAAG,OAAA,GAAAH,OAAA;AAEA,IAAAI,MAAA,GAAAJ,OAAA;AAAoC,SAAAD,uBAAAM,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAEpC,MAAMG,YAAY,GAAGC,IAAA;EAAA,IAAC;IACpBC,UAAU,GAAGC,kBAAU,CAACC,EAAE;IAC1BC,IAAI,GAAGC,gBAAS,CAACF,EAAE;IACnBG,QAAQ;IACRC,OAAO;IACPC,SAAS;IACTC,aAAa,GAAG;EACC,CAAC,GAAAT,IAAA;EAAA,OAClBR,MAAA,CAAAM,OAAA,CAAAY,aAAA;IACEC,SAAS,EAAE,IAAAC,mBAAU,EACnB,6EAA6E,EAC7E;MACE,kBAAkB,EAAER,IAAI,KAAKC,gBAAS,CAACQ,EAAE;MACzC,iBAAiB,EAAET,IAAI,KAAKC,gBAAS,CAACF,EAAE;MACxC,iBAAiB,EAAEC,IAAI,KAAKC,gBAAS,CAACS;IACxC,CACF,CAAE;IACF,eAAY;EAAe,GAE3BtB,MAAA,CAAAM,OAAA,CAAAY,aAAA;IAAKC,SAAS,EAAE,IAAAC,mBAAU,EAAC,wCAAwC;EAAE,GAClEJ,SAAS,IAAI,CAACC,aAAa,IAAIjB,MAAA,CAAAM,OAAA,CAAAY,aAAA,CAAChB,OAAA,CAAAqB,MAAM;IAACX,IAAI,EAAEH;EAAW,CAAE,CAAC,EAC3D,CAACO,SAAS,IAAI,CAACD,OAAO,IAAID,QAAQ,EAClC,CAACE,SAAS,IAAID,OAAO,IAAIf,MAAA,CAAAM,OAAA,CAAAY,aAAA,eAAOM,0BAAuB,CACrD,CACF,CAAC;AAAA,CACP;AAACC,OAAA,CAAAlB,YAAA,GAAAA,YAAA","ignoreList":[]}
@@ -29,17 +29,16 @@ const Truncate = exports.Truncate = (0, _react.memo)(_ref => {
29
29
  ref,
30
30
  onResize
31
31
  });
32
- return (_react.default.createElement("a", {
33
- ref: ref,
34
- className: (0, _classnames.default)('lw-block lw-w-max lw-truncate', className),
35
- "data-testid": "truncate",
36
- "data-tooltip-content": text,
37
- "data-tooltip-id": isTruncated ? tooltipId : undefined,
38
- style: {
39
- maxWidth: `${maxWidth}px`
40
- }
41
- }, text)
42
- );
32
+ return _react.default.createElement("span", {
33
+ ref: ref,
34
+ className: (0, _classnames.default)('lw-block lw-w-max lw-truncate', className),
35
+ "data-testid": "truncate",
36
+ "data-tooltip-content": text,
37
+ "data-tooltip-id": isTruncated ? tooltipId : undefined,
38
+ style: {
39
+ maxWidth: `${maxWidth}px`
40
+ }
41
+ }, text);
43
42
  });
44
43
  Truncate.displayName = 'Truncate';
45
44
  //# sourceMappingURL=Truncate.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Truncate.js","names":["_classnames","_interopRequireDefault","require","_react","_interopRequireWildcard","_usehooksTs","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","Truncate","exports","memo","_ref","maxWidth","text","tooltipId","className","isTruncated","setIsTruncated","useState","ref","useRef","onResize","useDebounceCallback","_ref2","width","useResizeObserver","createElement","classnames","undefined","style","displayName"],"sources":["../../../../src/components/Truncate/Truncate.tsx"],"sourcesContent":["import classnames from 'classnames';\nimport React, { memo, useRef, useState } from 'react';\nimport { useDebounceCallback, useResizeObserver } from 'usehooks-ts';\n\nimport type { TruncateProps } from './types';\n\nconst Truncate = memo(\n ({ maxWidth = 150, text, tooltipId, className }: TruncateProps) => {\n const [isTruncated, setIsTruncated] = useState(false);\n const ref = useRef<HTMLAnchorElement>(null);\n\n const onResize = useDebounceCallback(({ width }) => {\n setIsTruncated(width >= maxWidth);\n }, 50);\n\n useResizeObserver({\n ref,\n onResize,\n });\n\n return (\n // eslint-disable-next-line jsx-a11y/anchor-is-valid\n <a\n ref={ref}\n className={classnames('lw-block lw-w-max lw-truncate', className)}\n data-testid=\"truncate\"\n data-tooltip-content={text}\n data-tooltip-id={isTruncated ? tooltipId : undefined}\n style={{ maxWidth: `${maxWidth}px` }}\n >\n {text}\n </a>\n );\n }\n);\n\nTruncate.displayName = 'Truncate';\n\nexport { Truncate };\n"],"mappings":";;;;;;AAAA,IAAAA,WAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAC,uBAAA,CAAAF,OAAA;AACA,IAAAG,WAAA,GAAAH,OAAA;AAAqE,SAAAI,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAH,wBAAAG,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,WAAAK,OAAA,EAAAL,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,CAAAH,OAAA,GAAAL,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAAA,SAAAd,uBAAAM,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAI,UAAA,GAAAJ,CAAA,KAAAK,OAAA,EAAAL,CAAA;AAIrE,MAAMmB,QAAQ,GAAAC,OAAA,CAAAD,QAAA,GAAG,IAAAE,WAAI,EACnBC,IAAA,IAAmE;EAAA,IAAlE;IAAEC,QAAQ,GAAG,GAAG;IAAEC,IAAI;IAAEC,SAAS;IAAEC;EAAyB,CAAC,GAAAJ,IAAA;EAC5D,MAAM,CAACK,WAAW,EAAEC,cAAc,CAAC,GAAG,IAAAC,eAAQ,EAAC,KAAK,CAAC;EACrD,MAAMC,GAAG,GAAG,IAAAC,aAAM,EAAoB,IAAI,CAAC;EAE3C,MAAMC,QAAQ,GAAG,IAAAC,+BAAmB,EAACC,KAAA,IAAe;IAAA,IAAd;MAAEC;IAAM,CAAC,GAAAD,KAAA;IAC7CN,cAAc,CAACO,KAAK,IAAIZ,QAAQ,CAAC;EACnC,CAAC,EAAE,EAAE,CAAC;EAEN,IAAAa,6BAAiB,EAAC;IAChBN,GAAG;IACHE;EACF,CAAC,CAAC;EAEF,QAEEpC,MAAA,CAAAS,OAAA,CAAAgC,aAAA;MACEP,GAAG,EAAEA,GAAI;MACTJ,SAAS,EAAE,IAAAY,mBAAU,EAAC,+BAA+B,EAAEZ,SAAS,CAAE;MAClE,eAAY,UAAU;MACtB,wBAAsBF,IAAK;MAC3B,mBAAiBG,WAAW,GAAGF,SAAS,GAAGc,SAAU;MACrDC,KAAK,EAAE;QAAEjB,QAAQ,EAAE,GAAGA,QAAQ;MAAK;IAAE,GAEpCC,IACA;EAAC;AAER,CACF,CAAC;AAEDL,QAAQ,CAACsB,WAAW,GAAG,UAAU","ignoreList":[]}
1
+ {"version":3,"file":"Truncate.js","names":["_classnames","_interopRequireDefault","require","_react","_interopRequireWildcard","_usehooksTs","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","Truncate","exports","memo","_ref","maxWidth","text","tooltipId","className","isTruncated","setIsTruncated","useState","ref","useRef","onResize","useDebounceCallback","_ref2","width","useResizeObserver","createElement","classnames","undefined","style","displayName"],"sources":["../../../../src/components/Truncate/Truncate.tsx"],"sourcesContent":["import classnames from 'classnames';\nimport React, { memo, useRef, useState } from 'react';\nimport { useDebounceCallback, useResizeObserver } from 'usehooks-ts';\n\nimport type { TruncateProps } from './types';\n\nconst Truncate = memo(\n ({ maxWidth = 150, text, tooltipId, className }: TruncateProps) => {\n const [isTruncated, setIsTruncated] = useState(false);\n const ref = useRef<HTMLAnchorElement>(null);\n\n const onResize = useDebounceCallback(({ width }) => {\n setIsTruncated(width >= maxWidth);\n }, 50);\n\n useResizeObserver({\n ref,\n onResize,\n });\n\n return (\n <span\n ref={ref}\n className={classnames('lw-block lw-w-max lw-truncate', className)}\n data-testid=\"truncate\"\n data-tooltip-content={text}\n data-tooltip-id={isTruncated ? tooltipId : undefined}\n style={{ maxWidth: `${maxWidth}px` }}\n >\n {text}\n </span>\n );\n }\n);\n\nTruncate.displayName = 'Truncate';\n\nexport { Truncate };\n"],"mappings":";;;;;;AAAA,IAAAA,WAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAC,uBAAA,CAAAF,OAAA;AACA,IAAAG,WAAA,GAAAH,OAAA;AAAqE,SAAAI,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAH,wBAAAG,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,WAAAK,OAAA,EAAAL,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,CAAAH,OAAA,GAAAL,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAAA,SAAAd,uBAAAM,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAI,UAAA,GAAAJ,CAAA,KAAAK,OAAA,EAAAL,CAAA;AAIrE,MAAMmB,QAAQ,GAAAC,OAAA,CAAAD,QAAA,GAAG,IAAAE,WAAI,EACnBC,IAAA,IAAmE;EAAA,IAAlE;IAAEC,QAAQ,GAAG,GAAG;IAAEC,IAAI;IAAEC,SAAS;IAAEC;EAAyB,CAAC,GAAAJ,IAAA;EAC5D,MAAM,CAACK,WAAW,EAAEC,cAAc,CAAC,GAAG,IAAAC,eAAQ,EAAC,KAAK,CAAC;EACrD,MAAMC,GAAG,GAAG,IAAAC,aAAM,EAAoB,IAAI,CAAC;EAE3C,MAAMC,QAAQ,GAAG,IAAAC,+BAAmB,EAACC,KAAA,IAAe;IAAA,IAAd;MAAEC;IAAM,CAAC,GAAAD,KAAA;IAC7CN,cAAc,CAACO,KAAK,IAAIZ,QAAQ,CAAC;EACnC,CAAC,EAAE,EAAE,CAAC;EAEN,IAAAa,6BAAiB,EAAC;IAChBN,GAAG;IACHE;EACF,CAAC,CAAC;EAEF,OACEpC,MAAA,CAAAS,OAAA,CAAAgC,aAAA;IACEP,GAAG,EAAEA,GAAI;IACTJ,SAAS,EAAE,IAAAY,mBAAU,EAAC,+BAA+B,EAAEZ,SAAS,CAAE;IAClE,eAAY,UAAU;IACtB,wBAAsBF,IAAK;IAC3B,mBAAiBG,WAAW,GAAGF,SAAS,GAAGc,SAAU;IACrDC,KAAK,EAAE;MAAEjB,QAAQ,EAAE,GAAGA,QAAQ;IAAK;EAAE,GAEpCC,IACG,CAAC;AAEX,CACF,CAAC;AAEDL,QAAQ,CAACsB,WAAW,GAAG,UAAU","ignoreList":[]}
@@ -18,19 +18,18 @@ const InstrumentRate = _ref => {
18
18
  } = useLayoutProvider();
19
19
  const checkLoading = id => !isError && record?.[id] === undefined;
20
20
  const isExpanded = size === 'full' || size === 'fullWithChart';
21
- const isCompact = size === 'compact';
22
21
  return React.createElement("div", {
23
22
  className: cn('lw-flex lw-flex-col', isExpanded && 'lw-h-full'),
24
23
  "data-testid": "instrument-rate-wrapper"
25
24
  }, React.createElement("div", {
26
- className: cn('lw-flex lw-gap-x-2', isExpanded && 'lw-h-1/2 lw-pt-3', !slim && isCompact && 'lw-py-3', slim && 'lw-py-1'),
25
+ className: cn('lw-flex lw-gap-x-2 lw-text-xl', isExpanded && 'lw-h-1/2', !slim && 'lw-py-2', slim && 'lw-py-1'),
27
26
  "data-testid": "instrument-rate-wrapper-label"
28
27
  }, React.createElement(LabelWrapper, {
29
28
  isError: !!isError,
30
29
  isLoading: checkLoading('instrument'),
31
30
  size: LabelSize.lg
32
31
  }, React.createElement("span", {
33
- className: "lw-text-xl lw-font-bold"
32
+ className: "lw-font-bold"
34
33
  }, React.createElement(Truncate, {
35
34
  maxWidth: 100,
36
35
  text: record.displayName,
@@ -40,12 +39,12 @@ const InstrumentRate = _ref => {
40
39
  isLoading: checkLoading('buy'),
41
40
  size: LabelSize.lg
42
41
  }, React.createElement("div", {
43
- className: "lw-text-xl lw-font-bold"
42
+ className: "lw-font-bold"
44
43
  }, React.createElement(Price, {
45
44
  movementIndicator: "text",
46
45
  priceMovement: record.buyPriceMovement
47
46
  }, React.createElement("span", null, record.buy?.toFixed(record.displayPrecision)))))), isExpanded && React.createElement("div", {
48
- className: cn('lw-flex lw-h-1/2 lw-w-fit lw-items-center lw-gap-x-2 lw-py-2.5 lw-pr-2.5', !isDark && 'lw-bg-whiteOpacity', isDark && 'lw-bg-blackOpacity', slim && 'lw-py-1.5'),
47
+ className: cn('lw-flex lw-h-1/2 lw-w-fit lw-items-center lw-gap-x-2 lw-pr-2.5', !isDark && 'lw-bg-whiteOpacity', isDark && 'lw-bg-blackOpacity', !slim && 'lw-py-1', slim && 'lw-pb-1'),
49
48
  "data-testid": "instrument-rate-wrapper-expanded"
50
49
  }, React.createElement(LabelWrapper, {
51
50
  isError: !!isError,
@@ -1 +1 @@
1
- {"version":3,"file":"InstrumentRate.js","names":["React","useLayoutProvider","cn","LabelSize","LabelWrapper","Price","Truncate","InstrumentRate","_ref","isError","record","tooltipId","size","slim","colorIndicator","indicator","isDark","checkLoading","id","undefined","isExpanded","isCompact","createElement","className","isLoading","lg","maxWidth","text","displayName","movementIndicator","priceMovement","buyPriceMovement","buy","toFixed","displayPrecision","sm","dailyPercentChange","withoutLoader","dailyPipsChange"],"sources":["../../../../src/components/InstrumentRate/InstrumentRate.tsx"],"sourcesContent":["import React from 'react';\n\nimport { useLayoutProvider } from '../../providers';\nimport { cn } from '../../tailwind';\nimport { LabelSize, LabelWrapper } from '../LabelWrapper';\nimport { Price } from '../Price';\nimport { Truncate } from '../Truncate';\nimport type { InstrumentRateProps } from './types';\n\nconst InstrumentRate = ({\n isError,\n record,\n tooltipId,\n size,\n slim,\n colorIndicator: indicator,\n}: InstrumentRateProps) => {\n const { isDark } = useLayoutProvider();\n const checkLoading = (id: string) => !isError && record?.[id] === undefined;\n const isExpanded = size === 'full' || size === 'fullWithChart';\n const isCompact = size === 'compact';\n\n return (\n <div\n className={cn('lw-flex lw-flex-col', isExpanded && 'lw-h-full')}\n data-testid=\"instrument-rate-wrapper\"\n >\n <div\n className={cn(\n 'lw-flex lw-gap-x-2',\n isExpanded && 'lw-h-1/2 lw-pt-3',\n !slim && isCompact && 'lw-py-3',\n slim && 'lw-py-1'\n )}\n data-testid=\"instrument-rate-wrapper-label\"\n >\n <LabelWrapper\n isError={!!isError}\n isLoading={checkLoading('instrument')}\n size={LabelSize.lg}\n >\n <span className=\"lw-text-xl lw-font-bold\">\n <Truncate\n maxWidth={100}\n text={record.displayName}\n tooltipId={tooltipId}\n />\n </span>\n </LabelWrapper>\n <LabelWrapper\n isError={!!isError}\n isLoading={checkLoading('buy')}\n size={LabelSize.lg}\n >\n <div className=\"lw-text-xl lw-font-bold\">\n <Price\n movementIndicator=\"text\"\n priceMovement={record.buyPriceMovement}\n >\n <span>{record.buy?.toFixed(record.displayPrecision)}</span>\n </Price>\n </div>\n </LabelWrapper>\n </div>\n {isExpanded && (\n <div\n className={cn(\n 'lw-flex lw-h-1/2 lw-w-fit lw-items-center lw-gap-x-2 lw-py-2.5 lw-pr-2.5',\n !isDark && 'lw-bg-whiteOpacity',\n isDark && 'lw-bg-blackOpacity',\n slim && 'lw-py-1.5'\n )}\n data-testid=\"instrument-rate-wrapper-expanded\"\n >\n <LabelWrapper\n isError={!!isError}\n isLoading={checkLoading('dailyPercentChange')}\n size={LabelSize.sm}\n >\n <span\n className={cn(\n 'lw-font-bold',\n indicator > 0 && 'lw-text-text-ok',\n indicator < 0 && 'lw-text-text-danger',\n indicator === 0 && 'lw-text-text-disabled'\n )}\n >\n {record.dailyPercentChange}\n </span>\n </LabelWrapper>\n <LabelWrapper\n withoutLoader\n isError={!!isError}\n isLoading={checkLoading('dailyPipsChange')}\n size={LabelSize.sm}\n >\n <span\n className={cn(\n 'lw-font-bold',\n indicator > 0 && 'lw-text-text-ok',\n indicator < 0 && 'lw-text-text-danger',\n indicator === 0 && 'lw-text-text-disabled'\n )}\n >\n {`(${record.dailyPipsChange})`}\n </span>\n </LabelWrapper>\n </div>\n )}\n </div>\n );\n};\n\nexport { InstrumentRate };\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"InstrumentRate.js","names":["React","useLayoutProvider","cn","LabelSize","LabelWrapper","Price","Truncate","InstrumentRate","_ref","isError","record","tooltipId","size","slim","colorIndicator","indicator","isDark","checkLoading","id","undefined","isExpanded","createElement","className","isLoading","lg","maxWidth","text","displayName","movementIndicator","priceMovement","buyPriceMovement","buy","toFixed","displayPrecision","sm","dailyPercentChange","withoutLoader","dailyPipsChange"],"sources":["../../../../src/components/InstrumentRate/InstrumentRate.tsx"],"sourcesContent":["import React from 'react';\n\nimport { useLayoutProvider } from '../../providers';\nimport { cn } from '../../tailwind';\nimport { LabelSize, LabelWrapper } from '../LabelWrapper';\nimport { Price } from '../Price';\nimport { Truncate } from '../Truncate';\nimport type { InstrumentRateProps } from './types';\n\nconst InstrumentRate = ({\n isError,\n record,\n tooltipId,\n size,\n slim,\n colorIndicator: indicator,\n}: InstrumentRateProps) => {\n const { isDark } = useLayoutProvider();\n const checkLoading = (id: string) => !isError && record?.[id] === undefined;\n const isExpanded = size === 'full' || size === 'fullWithChart';\n\n return (\n <div\n className={cn('lw-flex lw-flex-col', isExpanded && 'lw-h-full')}\n data-testid=\"instrument-rate-wrapper\"\n >\n <div\n className={cn(\n 'lw-flex lw-gap-x-2 lw-text-xl',\n isExpanded && 'lw-h-1/2',\n !slim && 'lw-py-2',\n slim && 'lw-py-1'\n )}\n data-testid=\"instrument-rate-wrapper-label\"\n >\n <LabelWrapper\n isError={!!isError}\n isLoading={checkLoading('instrument')}\n size={LabelSize.lg}\n >\n <span className=\"lw-font-bold\">\n <Truncate\n maxWidth={100}\n text={record.displayName}\n tooltipId={tooltipId}\n />\n </span>\n </LabelWrapper>\n <LabelWrapper\n isError={!!isError}\n isLoading={checkLoading('buy')}\n size={LabelSize.lg}\n >\n <div className=\"lw-font-bold\">\n <Price\n movementIndicator=\"text\"\n priceMovement={record.buyPriceMovement}\n >\n <span>{record.buy?.toFixed(record.displayPrecision)}</span>\n </Price>\n </div>\n </LabelWrapper>\n </div>\n {isExpanded && (\n <div\n className={cn(\n 'lw-flex lw-h-1/2 lw-w-fit lw-items-center lw-gap-x-2 lw-pr-2.5',\n !isDark && 'lw-bg-whiteOpacity',\n isDark && 'lw-bg-blackOpacity',\n !slim && 'lw-py-1',\n slim && 'lw-pb-1'\n )}\n data-testid=\"instrument-rate-wrapper-expanded\"\n >\n <LabelWrapper\n isError={!!isError}\n isLoading={checkLoading('dailyPercentChange')}\n size={LabelSize.sm}\n >\n <span\n className={cn(\n 'lw-font-bold',\n indicator > 0 && 'lw-text-text-ok',\n indicator < 0 && 'lw-text-text-danger',\n indicator === 0 && 'lw-text-text-disabled'\n )}\n >\n {record.dailyPercentChange}\n </span>\n </LabelWrapper>\n <LabelWrapper\n withoutLoader\n isError={!!isError}\n isLoading={checkLoading('dailyPipsChange')}\n size={LabelSize.sm}\n >\n <span\n className={cn(\n 'lw-font-bold',\n indicator > 0 && 'lw-text-text-ok',\n indicator < 0 && 'lw-text-text-danger',\n indicator === 0 && 'lw-text-text-disabled'\n )}\n >\n {`(${record.dailyPipsChange})`}\n </span>\n </LabelWrapper>\n </div>\n )}\n </div>\n );\n};\n\nexport { InstrumentRate };\n"],"mappings":"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","ignoreList":[]}
@@ -13,7 +13,7 @@ const LabelWrapper = _ref => {
13
13
  withoutLoader = false
14
14
  } = _ref;
15
15
  return React.createElement("div", {
16
- className: classnames('lw-h-[inherit] lw-py-0 lw-font-sans', {
16
+ className: classnames('lw-flex lw-h-[inherit] lw-min-h-[28px] lw-items-center lw-py-0 lw-font-sans', {
17
17
  'lw-min-w-[100px]': size === LabelSize.lg,
18
18
  'lw-min-w-[70px]': size === LabelSize.md,
19
19
  'lw-min-w-[50px]': size === LabelSize.sm
@@ -1 +1 @@
1
- {"version":3,"file":"LabelWrapper.js","names":["classnames","React","CELL_EMPTY_VALUE","Loader","LoaderSize","LabelSize","LabelWrapper","_ref","loaderSize","md","size","children","isError","isLoading","withoutLoader","createElement","className","lg","sm"],"sources":["../../../../src/components/LabelWrapper/LabelWrapper.tsx"],"sourcesContent":["import classnames from 'classnames';\nimport React from 'react';\n\nimport { CELL_EMPTY_VALUE } from '../constant';\nimport { Loader, LoaderSize } from '../Loader';\nimport type { LabelWrapperProps } from './types';\nimport { LabelSize } from './types';\n\nconst LabelWrapper = ({\n loaderSize = LoaderSize.md,\n size = LabelSize.md,\n children,\n isError,\n isLoading,\n withoutLoader = false,\n}: LabelWrapperProps) => (\n <div\n className={classnames('lw-h-[inherit] lw-py-0 lw-font-sans', {\n 'lw-min-w-[100px]': size === LabelSize.lg,\n 'lw-min-w-[70px]': size === LabelSize.md,\n 'lw-min-w-[50px]': size === LabelSize.sm,\n })}\n data-testid=\"label-wrapper\"\n >\n <div className={classnames('lw-flex lw-h-[inherit] lw-items-center')}>\n {isLoading && !withoutLoader && <Loader size={loaderSize} />}\n {!isLoading && !isError && children}\n {!isLoading && isError && <span>{CELL_EMPTY_VALUE}</span>}\n </div>\n </div>\n);\n\nexport { LabelWrapper };\n"],"mappings":"AAAA,OAAOA,UAAU,MAAM,YAAY;AACnC,OAAOC,KAAK,MAAM,OAAO;AAEzB,SAASC,gBAAgB,QAAQ,aAAa;AAC9C,SAASC,MAAM,EAAEC,UAAU,QAAQ,WAAW;AAE9C,SAASC,SAAS,QAAQ,SAAS;AAEnC,MAAMC,YAAY,GAAGC,IAAA;EAAA,IAAC;IACpBC,UAAU,GAAGJ,UAAU,CAACK,EAAE;IAC1BC,IAAI,GAAGL,SAAS,CAACI,EAAE;IACnBE,QAAQ;IACRC,OAAO;IACPC,SAAS;IACTC,aAAa,GAAG;EACC,CAAC,GAAAP,IAAA;EAAA,OAClBN,KAAA,CAAAc,aAAA;IACEC,SAAS,EAAEhB,UAAU,CAAC,qCAAqC,EAAE;MAC3D,kBAAkB,EAAEU,IAAI,KAAKL,SAAS,CAACY,EAAE;MACzC,iBAAiB,EAAEP,IAAI,KAAKL,SAAS,CAACI,EAAE;MACxC,iBAAiB,EAAEC,IAAI,KAAKL,SAAS,CAACa;IACxC,CAAC,CAAE;IACH,eAAY;EAAe,GAE3BjB,KAAA,CAAAc,aAAA;IAAKC,SAAS,EAAEhB,UAAU,CAAC,wCAAwC;EAAE,GAClEa,SAAS,IAAI,CAACC,aAAa,IAAIb,KAAA,CAAAc,aAAA,CAACZ,MAAM;IAACO,IAAI,EAAEF;EAAW,CAAE,CAAC,EAC3D,CAACK,SAAS,IAAI,CAACD,OAAO,IAAID,QAAQ,EAClC,CAACE,SAAS,IAAID,OAAO,IAAIX,KAAA,CAAAc,aAAA,eAAOb,gBAAuB,CACrD,CACF,CAAC;AAAA,CACP;AAED,SAASI,YAAY","ignoreList":[]}
1
+ {"version":3,"file":"LabelWrapper.js","names":["classnames","React","CELL_EMPTY_VALUE","Loader","LoaderSize","LabelSize","LabelWrapper","_ref","loaderSize","md","size","children","isError","isLoading","withoutLoader","createElement","className","lg","sm"],"sources":["../../../../src/components/LabelWrapper/LabelWrapper.tsx"],"sourcesContent":["import classnames from 'classnames';\nimport React from 'react';\n\nimport { CELL_EMPTY_VALUE } from '../constant';\nimport { Loader, LoaderSize } from '../Loader';\nimport type { LabelWrapperProps } from './types';\nimport { LabelSize } from './types';\n\nconst LabelWrapper = ({\n loaderSize = LoaderSize.md,\n size = LabelSize.md,\n children,\n isError,\n isLoading,\n withoutLoader = false,\n}: LabelWrapperProps) => (\n <div\n className={classnames(\n 'lw-flex lw-h-[inherit] lw-min-h-[28px] lw-items-center lw-py-0 lw-font-sans',\n {\n 'lw-min-w-[100px]': size === LabelSize.lg,\n 'lw-min-w-[70px]': size === LabelSize.md,\n 'lw-min-w-[50px]': size === LabelSize.sm,\n }\n )}\n data-testid=\"label-wrapper\"\n >\n <div className={classnames('lw-flex lw-h-[inherit] lw-items-center')}>\n {isLoading && !withoutLoader && <Loader size={loaderSize} />}\n {!isLoading && !isError && children}\n {!isLoading && isError && <span>{CELL_EMPTY_VALUE}</span>}\n </div>\n </div>\n);\n\nexport { LabelWrapper };\n"],"mappings":"AAAA,OAAOA,UAAU,MAAM,YAAY;AACnC,OAAOC,KAAK,MAAM,OAAO;AAEzB,SAASC,gBAAgB,QAAQ,aAAa;AAC9C,SAASC,MAAM,EAAEC,UAAU,QAAQ,WAAW;AAE9C,SAASC,SAAS,QAAQ,SAAS;AAEnC,MAAMC,YAAY,GAAGC,IAAA;EAAA,IAAC;IACpBC,UAAU,GAAGJ,UAAU,CAACK,EAAE;IAC1BC,IAAI,GAAGL,SAAS,CAACI,EAAE;IACnBE,QAAQ;IACRC,OAAO;IACPC,SAAS;IACTC,aAAa,GAAG;EACC,CAAC,GAAAP,IAAA;EAAA,OAClBN,KAAA,CAAAc,aAAA;IACEC,SAAS,EAAEhB,UAAU,CACnB,6EAA6E,EAC7E;MACE,kBAAkB,EAAEU,IAAI,KAAKL,SAAS,CAACY,EAAE;MACzC,iBAAiB,EAAEP,IAAI,KAAKL,SAAS,CAACI,EAAE;MACxC,iBAAiB,EAAEC,IAAI,KAAKL,SAAS,CAACa;IACxC,CACF,CAAE;IACF,eAAY;EAAe,GAE3BjB,KAAA,CAAAc,aAAA;IAAKC,SAAS,EAAEhB,UAAU,CAAC,wCAAwC;EAAE,GAClEa,SAAS,IAAI,CAACC,aAAa,IAAIb,KAAA,CAAAc,aAAA,CAACZ,MAAM;IAACO,IAAI,EAAEF;EAAW,CAAE,CAAC,EAC3D,CAACK,SAAS,IAAI,CAACD,OAAO,IAAID,QAAQ,EAClC,CAACE,SAAS,IAAID,OAAO,IAAIX,KAAA,CAAAc,aAAA,eAAOb,gBAAuB,CACrD,CACF,CAAC;AAAA,CACP;AAED,SAASI,YAAY","ignoreList":[]}
@@ -20,17 +20,16 @@ const Truncate = memo(_ref => {
20
20
  ref,
21
21
  onResize
22
22
  });
23
- return (React.createElement("a", {
24
- ref: ref,
25
- className: classnames('lw-block lw-w-max lw-truncate', className),
26
- "data-testid": "truncate",
27
- "data-tooltip-content": text,
28
- "data-tooltip-id": isTruncated ? tooltipId : undefined,
29
- style: {
30
- maxWidth: `${maxWidth}px`
31
- }
32
- }, text)
33
- );
23
+ return React.createElement("span", {
24
+ ref: ref,
25
+ className: classnames('lw-block lw-w-max lw-truncate', className),
26
+ "data-testid": "truncate",
27
+ "data-tooltip-content": text,
28
+ "data-tooltip-id": isTruncated ? tooltipId : undefined,
29
+ style: {
30
+ maxWidth: `${maxWidth}px`
31
+ }
32
+ }, text);
34
33
  });
35
34
  Truncate.displayName = 'Truncate';
36
35
  export { Truncate };
@@ -1 +1 @@
1
- {"version":3,"file":"Truncate.js","names":["classnames","React","memo","useRef","useState","useDebounceCallback","useResizeObserver","Truncate","_ref","maxWidth","text","tooltipId","className","isTruncated","setIsTruncated","ref","onResize","_ref2","width","createElement","undefined","style","displayName"],"sources":["../../../../src/components/Truncate/Truncate.tsx"],"sourcesContent":["import classnames from 'classnames';\nimport React, { memo, useRef, useState } from 'react';\nimport { useDebounceCallback, useResizeObserver } from 'usehooks-ts';\n\nimport type { TruncateProps } from './types';\n\nconst Truncate = memo(\n ({ maxWidth = 150, text, tooltipId, className }: TruncateProps) => {\n const [isTruncated, setIsTruncated] = useState(false);\n const ref = useRef<HTMLAnchorElement>(null);\n\n const onResize = useDebounceCallback(({ width }) => {\n setIsTruncated(width >= maxWidth);\n }, 50);\n\n useResizeObserver({\n ref,\n onResize,\n });\n\n return (\n // eslint-disable-next-line jsx-a11y/anchor-is-valid\n <a\n ref={ref}\n className={classnames('lw-block lw-w-max lw-truncate', className)}\n data-testid=\"truncate\"\n data-tooltip-content={text}\n data-tooltip-id={isTruncated ? tooltipId : undefined}\n style={{ maxWidth: `${maxWidth}px` }}\n >\n {text}\n </a>\n );\n }\n);\n\nTruncate.displayName = 'Truncate';\n\nexport { Truncate };\n"],"mappings":"AAAA,OAAOA,UAAU,MAAM,YAAY;AACnC,OAAOC,KAAK,IAAIC,IAAI,EAAEC,MAAM,EAAEC,QAAQ,QAAQ,OAAO;AACrD,SAASC,mBAAmB,EAAEC,iBAAiB,QAAQ,aAAa;AAIpE,MAAMC,QAAQ,GAAGL,IAAI,CACnBM,IAAA,IAAmE;EAAA,IAAlE;IAAEC,QAAQ,GAAG,GAAG;IAAEC,IAAI;IAAEC,SAAS;IAAEC;EAAyB,CAAC,GAAAJ,IAAA;EAC5D,MAAM,CAACK,WAAW,EAAEC,cAAc,CAAC,GAAGV,QAAQ,CAAC,KAAK,CAAC;EACrD,MAAMW,GAAG,GAAGZ,MAAM,CAAoB,IAAI,CAAC;EAE3C,MAAMa,QAAQ,GAAGX,mBAAmB,CAACY,KAAA,IAAe;IAAA,IAAd;MAAEC;IAAM,CAAC,GAAAD,KAAA;IAC7CH,cAAc,CAACI,KAAK,IAAIT,QAAQ,CAAC;EACnC,CAAC,EAAE,EAAE,CAAC;EAENH,iBAAiB,CAAC;IAChBS,GAAG;IACHC;EACF,CAAC,CAAC;EAEF,QAEEf,KAAA,CAAAkB,aAAA;MACEJ,GAAG,EAAEA,GAAI;MACTH,SAAS,EAAEZ,UAAU,CAAC,+BAA+B,EAAEY,SAAS,CAAE;MAClE,eAAY,UAAU;MACtB,wBAAsBF,IAAK;MAC3B,mBAAiBG,WAAW,GAAGF,SAAS,GAAGS,SAAU;MACrDC,KAAK,EAAE;QAAEZ,QAAQ,EAAE,GAAGA,QAAQ;MAAK;IAAE,GAEpCC,IACA;EAAC;AAER,CACF,CAAC;AAEDH,QAAQ,CAACe,WAAW,GAAG,UAAU;AAEjC,SAASf,QAAQ","ignoreList":[]}
1
+ {"version":3,"file":"Truncate.js","names":["classnames","React","memo","useRef","useState","useDebounceCallback","useResizeObserver","Truncate","_ref","maxWidth","text","tooltipId","className","isTruncated","setIsTruncated","ref","onResize","_ref2","width","createElement","undefined","style","displayName"],"sources":["../../../../src/components/Truncate/Truncate.tsx"],"sourcesContent":["import classnames from 'classnames';\nimport React, { memo, useRef, useState } from 'react';\nimport { useDebounceCallback, useResizeObserver } from 'usehooks-ts';\n\nimport type { TruncateProps } from './types';\n\nconst Truncate = memo(\n ({ maxWidth = 150, text, tooltipId, className }: TruncateProps) => {\n const [isTruncated, setIsTruncated] = useState(false);\n const ref = useRef<HTMLAnchorElement>(null);\n\n const onResize = useDebounceCallback(({ width }) => {\n setIsTruncated(width >= maxWidth);\n }, 50);\n\n useResizeObserver({\n ref,\n onResize,\n });\n\n return (\n <span\n ref={ref}\n className={classnames('lw-block lw-w-max lw-truncate', className)}\n data-testid=\"truncate\"\n data-tooltip-content={text}\n data-tooltip-id={isTruncated ? tooltipId : undefined}\n style={{ maxWidth: `${maxWidth}px` }}\n >\n {text}\n </span>\n );\n }\n);\n\nTruncate.displayName = 'Truncate';\n\nexport { Truncate };\n"],"mappings":"AAAA,OAAOA,UAAU,MAAM,YAAY;AACnC,OAAOC,KAAK,IAAIC,IAAI,EAAEC,MAAM,EAAEC,QAAQ,QAAQ,OAAO;AACrD,SAASC,mBAAmB,EAAEC,iBAAiB,QAAQ,aAAa;AAIpE,MAAMC,QAAQ,GAAGL,IAAI,CACnBM,IAAA,IAAmE;EAAA,IAAlE;IAAEC,QAAQ,GAAG,GAAG;IAAEC,IAAI;IAAEC,SAAS;IAAEC;EAAyB,CAAC,GAAAJ,IAAA;EAC5D,MAAM,CAACK,WAAW,EAAEC,cAAc,CAAC,GAAGV,QAAQ,CAAC,KAAK,CAAC;EACrD,MAAMW,GAAG,GAAGZ,MAAM,CAAoB,IAAI,CAAC;EAE3C,MAAMa,QAAQ,GAAGX,mBAAmB,CAACY,KAAA,IAAe;IAAA,IAAd;MAAEC;IAAM,CAAC,GAAAD,KAAA;IAC7CH,cAAc,CAACI,KAAK,IAAIT,QAAQ,CAAC;EACnC,CAAC,EAAE,EAAE,CAAC;EAENH,iBAAiB,CAAC;IAChBS,GAAG;IACHC;EACF,CAAC,CAAC;EAEF,OACEf,KAAA,CAAAkB,aAAA;IACEJ,GAAG,EAAEA,GAAI;IACTH,SAAS,EAAEZ,UAAU,CAAC,+BAA+B,EAAEY,SAAS,CAAE;IAClE,eAAY,UAAU;IACtB,wBAAsBF,IAAK;IAC3B,mBAAiBG,WAAW,GAAGF,SAAS,GAAGS,SAAU;IACrDC,KAAK,EAAE;MAAEZ,QAAQ,EAAE,GAAGA,QAAQ;IAAK;EAAE,GAEpCC,IACG,CAAC;AAEX,CACF,CAAC;AAEDH,QAAQ,CAACe,WAAW,GAAG,UAAU;AAEjC,SAASf,QAAQ","ignoreList":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@oanda/labs-widget-common",
3
- "version": "1.0.213",
3
+ "version": "1.0.214",
4
4
  "description": "Labs Widget Common",
5
5
  "main": "dist/main/index.js",
6
6
  "module": "dist/module/index.js",
@@ -21,5 +21,5 @@
21
21
  "tailwind-merge": "2.2.2",
22
22
  "usehooks-ts": "3.0.2"
23
23
  },
24
- "gitHead": "1853da87eb42d5ffb0c4f9c2ecdc98450c068f9c"
24
+ "gitHead": "a23750aa48956806673092c040ba5df282b4de0d"
25
25
  }
@@ -18,7 +18,6 @@ const InstrumentRate = ({
18
18
  const { isDark } = useLayoutProvider();
19
19
  const checkLoading = (id: string) => !isError && record?.[id] === undefined;
20
20
  const isExpanded = size === 'full' || size === 'fullWithChart';
21
- const isCompact = size === 'compact';
22
21
 
23
22
  return (
24
23
  <div
@@ -27,9 +26,9 @@ const InstrumentRate = ({
27
26
  >
28
27
  <div
29
28
  className={cn(
30
- 'lw-flex lw-gap-x-2',
31
- isExpanded && 'lw-h-1/2 lw-pt-3',
32
- !slim && isCompact && 'lw-py-3',
29
+ 'lw-flex lw-gap-x-2 lw-text-xl',
30
+ isExpanded && 'lw-h-1/2',
31
+ !slim && 'lw-py-2',
33
32
  slim && 'lw-py-1'
34
33
  )}
35
34
  data-testid="instrument-rate-wrapper-label"
@@ -39,7 +38,7 @@ const InstrumentRate = ({
39
38
  isLoading={checkLoading('instrument')}
40
39
  size={LabelSize.lg}
41
40
  >
42
- <span className="lw-text-xl lw-font-bold">
41
+ <span className="lw-font-bold">
43
42
  <Truncate
44
43
  maxWidth={100}
45
44
  text={record.displayName}
@@ -52,7 +51,7 @@ const InstrumentRate = ({
52
51
  isLoading={checkLoading('buy')}
53
52
  size={LabelSize.lg}
54
53
  >
55
- <div className="lw-text-xl lw-font-bold">
54
+ <div className="lw-font-bold">
56
55
  <Price
57
56
  movementIndicator="text"
58
57
  priceMovement={record.buyPriceMovement}
@@ -65,10 +64,11 @@ const InstrumentRate = ({
65
64
  {isExpanded && (
66
65
  <div
67
66
  className={cn(
68
- 'lw-flex lw-h-1/2 lw-w-fit lw-items-center lw-gap-x-2 lw-py-2.5 lw-pr-2.5',
67
+ 'lw-flex lw-h-1/2 lw-w-fit lw-items-center lw-gap-x-2 lw-pr-2.5',
69
68
  !isDark && 'lw-bg-whiteOpacity',
70
69
  isDark && 'lw-bg-blackOpacity',
71
- slim && 'lw-py-1.5'
70
+ !slim && 'lw-py-1',
71
+ slim && 'lw-pb-1'
72
72
  )}
73
73
  data-testid="instrument-rate-wrapper-expanded"
74
74
  >
@@ -15,11 +15,14 @@ const LabelWrapper = ({
15
15
  withoutLoader = false,
16
16
  }: LabelWrapperProps) => (
17
17
  <div
18
- className={classnames('lw-h-[inherit] lw-py-0 lw-font-sans', {
19
- 'lw-min-w-[100px]': size === LabelSize.lg,
20
- 'lw-min-w-[70px]': size === LabelSize.md,
21
- 'lw-min-w-[50px]': size === LabelSize.sm,
22
- })}
18
+ className={classnames(
19
+ 'lw-flex lw-h-[inherit] lw-min-h-[28px] lw-items-center lw-py-0 lw-font-sans',
20
+ {
21
+ 'lw-min-w-[100px]': size === LabelSize.lg,
22
+ 'lw-min-w-[70px]': size === LabelSize.md,
23
+ 'lw-min-w-[50px]': size === LabelSize.sm,
24
+ }
25
+ )}
23
26
  data-testid="label-wrapper"
24
27
  >
25
28
  <div className={classnames('lw-flex lw-h-[inherit] lw-items-center')}>
@@ -19,8 +19,7 @@ const Truncate = memo(
19
19
  });
20
20
 
21
21
  return (
22
- // eslint-disable-next-line jsx-a11y/anchor-is-valid
23
- <a
22
+ <span
24
23
  ref={ref}
25
24
  className={classnames('lw-block lw-w-max lw-truncate', className)}
26
25
  data-testid="truncate"
@@ -29,7 +28,7 @@ const Truncate = memo(
29
28
  style={{ maxWidth: `${maxWidth}px` }}
30
29
  >
31
30
  {text}
32
- </a>
31
+ </span>
33
32
  );
34
33
  }
35
34
  );
@@ -56,7 +56,7 @@ describe('InstrumentRate components', () => {
56
56
  expect(wrapper).toBeInTheDocument();
57
57
  expect(wrapper).toHaveClass('lw-flex', 'lw-flex-col');
58
58
  expect(wrapper).not.toHaveClass('lw-h-full');
59
- expect(getByTestId('instrument-rate-wrapper-label')).toHaveClass('lw-py-3');
59
+ expect(getByTestId('instrument-rate-wrapper-label')).toHaveClass('lw-py-2');
60
60
  });
61
61
 
62
62
  it('renders with full size', () => {
@@ -66,7 +66,7 @@ describe('InstrumentRate components', () => {
66
66
  expect(wrapper).toHaveClass('lw-flex', 'lw-flex-col', 'lw-h-full');
67
67
  expect(getByTestId('instrument-rate-wrapper-label')).toHaveClass(
68
68
  'lw-h-1/2',
69
- 'lw-pt-3'
69
+ 'lw-py-2'
70
70
  );
71
71
  });
72
72
 
@@ -77,7 +77,7 @@ describe('InstrumentRate components', () => {
77
77
  expect(wrapper).toHaveClass('lw-flex', 'lw-flex-col', 'lw-h-full');
78
78
  expect(getByTestId('instrument-rate-wrapper-label')).toHaveClass(
79
79
  'lw-h-1/2',
80
- 'lw-pt-3'
80
+ 'lw-py-2'
81
81
  );
82
82
  });
83
83