|
1 | 1 | <script setup> |
| 2 | +/** Vendor */ |
| 3 | +import { DateTime } from "luxon" |
| 4 | +
|
2 | 5 | /** UI */ |
3 | 6 | import Tooltip from "~/components/ui/Tooltip.vue" |
4 | 7 | import Button from "~/components/ui/Button.vue" |
@@ -42,7 +45,13 @@ const EventIconMapping = { |
42 | 45 | commission: "coins_down", |
43 | 46 | rewards: "coins_down", |
44 | 47 | mint: "coins_down", |
45 | | - coinbase: "coins_down" |
| 48 | + coinbase: "coins_down", |
| 49 | + unbond: "arrow-circle-right-up", |
| 50 | + redelegate: "arrow-circle-right-up", |
| 51 | + complete_unbonding: "coins_down", |
| 52 | + complete_redelegation: "arrow-circle-right-up", |
| 53 | + slash: "arrow-circle-right-up", |
| 54 | + cancel_unbonding_delegation: "arrow-circle-right-up", |
46 | 55 | } |
47 | 56 |
|
48 | 57 | const getEvents = async () => { |
@@ -465,6 +474,202 @@ watch( |
465 | 474 |
|
466 | 475 | <Text size="12" weight="500" color="secondary">was minted</Text> |
467 | 476 | </Flex> |
| 477 | + <!-- Event: undond --> |
| 478 | + <Flex v-else-if="event.type === 'unbond'" align="center" gap="4" color="secondary" :class="$style.text"> |
| 479 | + <Text size="12" weight="500" color="primary" mono no-wrap> |
| 480 | + {{ event.data.amount ? tia(event.data.amount.replace("utia", "")) : 0 }} TIA</Text |
| 481 | + > |
| 482 | + |
| 483 | + <Text size="12" weight="500" color="secondary">will unbond from</Text> |
| 484 | + |
| 485 | + <Tooltip :class="$style.tooltip"> |
| 486 | + <NuxtLink :to="`/address/${event.data.validator}`" @click.stop> |
| 487 | + <Text size="12" weight="500" color="primary" mono> |
| 488 | + {{ splitAddress(event.data.validator) }} |
| 489 | + </Text> |
| 490 | + </NuxtLink> |
| 491 | + |
| 492 | + <template #content> |
| 493 | + {{ event.data.validator }} |
| 494 | + </template> |
| 495 | + </Tooltip> |
| 496 | + |
| 497 | + <Text size="12" weight="500" color="secondary">at</Text> |
| 498 | + |
| 499 | + <Tooltip :class="$style.tooltip"> |
| 500 | + <Text size="12" weight="500" color="primary" mono> |
| 501 | + {{ DateTime.fromISO(event.data.completion_time).setLocale("en").toFormat("MMMM d h:mm a") }} |
| 502 | + </Text> |
| 503 | + |
| 504 | + <template #content> |
| 505 | + {{ DateTime.fromISO(event.data.completion_time).setLocale("en").toFormat("ff") }} |
| 506 | + </template> |
| 507 | + </Tooltip> |
| 508 | + </Flex> |
| 509 | + <!-- Event: redelegate --> |
| 510 | + <Flex v-else-if="event.type === 'redelegate'" align="center" gap="4" color="secondary" :class="$style.text"> |
| 511 | + <Text size="12" weight="500" color="primary" mono no-wrap> |
| 512 | + {{ event.data.amount ? tia(event.data.amount.replace("utia", "")) : 0 }} TIA</Text |
| 513 | + > |
| 514 | + |
| 515 | + <Text size="12" weight="500" color="secondary">will redelegate from</Text> |
| 516 | + |
| 517 | + <Tooltip :class="$style.tooltip"> |
| 518 | + <NuxtLink :to="`/address/${event.data.source_validator}`" @click.stop> |
| 519 | + <Text size="12" weight="500" color="primary" mono> |
| 520 | + {{ splitAddress(event.data.source_validator) }} |
| 521 | + </Text> |
| 522 | + </NuxtLink> |
| 523 | + |
| 524 | + <template #content> |
| 525 | + {{ event.data.source_validator }} |
| 526 | + </template> |
| 527 | + </Tooltip> |
| 528 | + |
| 529 | + <Text size="12" weight="500" color="secondary">to</Text> |
| 530 | + |
| 531 | + <Tooltip :class="$style.tooltip"> |
| 532 | + <NuxtLink :to="`/address/${event.data.destination_validator}`" @click.stop> |
| 533 | + <Text size="12" weight="500" color="primary" mono> |
| 534 | + {{ splitAddress(event.data.destination_validator) }} |
| 535 | + </Text> |
| 536 | + </NuxtLink> |
| 537 | + |
| 538 | + <template #content> |
| 539 | + {{ event.data.destination_validator }} |
| 540 | + </template> |
| 541 | + </Tooltip> |
| 542 | + |
| 543 | + <Text size="12" weight="500" color="secondary">at</Text> |
| 544 | + |
| 545 | + <Tooltip :class="$style.tooltip"> |
| 546 | + <Text size="12" weight="500" color="primary" mono> |
| 547 | + {{ DateTime.fromISO(event.data.completion_time).setLocale("en").toFormat("MMMM d h:mm a") }} |
| 548 | + </Text> |
| 549 | + |
| 550 | + <template #content> |
| 551 | + {{ DateTime.fromISO(event.data.completion_time).setLocale("en").toFormat("ff") }} |
| 552 | + </template> |
| 553 | + </Tooltip> |
| 554 | + </Flex> |
| 555 | + <!-- Event: complete_unbonding --> |
| 556 | + <Flex v-else-if="event.type === 'complete_unbonding'" align="center" gap="4" color="secondary" :class="$style.text"> |
| 557 | + <Text size="12" weight="500" color="primary" mono no-wrap> |
| 558 | + {{ event.data.amount ? tia(event.data.amount.replace("utia", "")) : 0 }} TIA</Text |
| 559 | + > |
| 560 | + |
| 561 | + <Text size="12" weight="500" color="secondary">was unbonded from</Text> |
| 562 | + |
| 563 | + <Tooltip :class="$style.tooltip"> |
| 564 | + <NuxtLink :to="`/address/${event.data.validator}`" @click.stop> |
| 565 | + <Text size="12" weight="500" color="primary" mono> |
| 566 | + {{ splitAddress(event.data.validator) }} |
| 567 | + </Text> |
| 568 | + </NuxtLink> |
| 569 | + |
| 570 | + <template #content> |
| 571 | + {{ event.data.validator }} |
| 572 | + </template> |
| 573 | + </Tooltip> |
| 574 | + |
| 575 | + <Text size="12" weight="500" color="secondary">to</Text> |
| 576 | + |
| 577 | + <Tooltip :class="$style.tooltip"> |
| 578 | + <NuxtLink :to="`/address/${event.data.delegator}`" @click.stop> |
| 579 | + <Text size="12" weight="500" color="primary" mono> |
| 580 | + {{ splitAddress(event.data.delegator) }} |
| 581 | + </Text> |
| 582 | + </NuxtLink> |
| 583 | + |
| 584 | + <template #content> |
| 585 | + {{ event.data.delegator }} |
| 586 | + </template> |
| 587 | + </Tooltip> |
| 588 | + </Flex> |
| 589 | + <!-- Event: complete_redelegation --> |
| 590 | + <Flex v-else-if="event.type === 'complete_redelegation'" align="center" gap="4" color="secondary" :class="$style.text"> |
| 591 | + <Text size="12" weight="500" color="primary" mono no-wrap> |
| 592 | + {{ event.data.amount ? tia(event.data.amount.replace("utia", "")) : 0 }} TIA</Text |
| 593 | + > |
| 594 | + |
| 595 | + <Text size="12" weight="500" color="secondary">was redelegated from</Text> |
| 596 | + |
| 597 | + <Tooltip :class="$style.tooltip"> |
| 598 | + <NuxtLink :to="`/address/${event.data.source_validator}`" @click.stop> |
| 599 | + <Text size="12" weight="500" color="primary" mono> |
| 600 | + {{ splitAddress(event.data.source_validator) }} |
| 601 | + </Text> |
| 602 | + </NuxtLink> |
| 603 | + |
| 604 | + <template #content> |
| 605 | + {{ event.data.source_validator }} |
| 606 | + </template> |
| 607 | + </Tooltip> |
| 608 | + |
| 609 | + <Text size="12" weight="500" color="secondary">to</Text> |
| 610 | + |
| 611 | + <Tooltip :class="$style.tooltip"> |
| 612 | + <NuxtLink :to="`/address/${event.data.destination_validator}`" @click.stop> |
| 613 | + <Text size="12" weight="500" color="primary" mono> |
| 614 | + {{ splitAddress(event.data.destination_validator) }} |
| 615 | + </Text> |
| 616 | + </NuxtLink> |
| 617 | + |
| 618 | + <template #content> |
| 619 | + {{ event.data.destination_validator }} |
| 620 | + </template> |
| 621 | + </Tooltip> |
| 622 | + </Flex> |
| 623 | + <!-- Event: slash --> |
| 624 | + <Flex v-else-if="event.type === 'slash'" align="center" gap="4" color="secondary" :class="$style.text"> |
| 625 | + <Tooltip :class="$style.tooltip"> |
| 626 | + <NuxtLink :to="`/address/${event.data.jailed}`" @click.stop> |
| 627 | + <Text size="12" weight="500" color="primary" mono> |
| 628 | + {{ splitAddress(event.data.jailed) }} |
| 629 | + </Text> |
| 630 | + </NuxtLink> |
| 631 | + |
| 632 | + <template #content> |
| 633 | + {{ event.data.jailed }} |
| 634 | + </template> |
| 635 | + </Tooltip> |
| 636 | + |
| 637 | + <Text size="12" weight="500" color="secondary">was jailed for</Text> |
| 638 | + |
| 639 | + <Tooltip :class="$style.tooltip"> |
| 640 | + <Text size="12" weight="500" color="primary" mono> |
| 641 | + {{ event.data.reason }} |
| 642 | + </Text> |
| 643 | + |
| 644 | + <template #content> |
| 645 | + {{ event.data.reason }} |
| 646 | + </template> |
| 647 | + </Tooltip> |
| 648 | + </Flex> |
| 649 | + <!-- Event: cancel_unbonding_delegation --> |
| 650 | + <Flex v-else-if="event.type === 'cancel_unbonding_delegation'" align="center" gap="4" color="secondary" :class="$style.text"> |
| 651 | + <Text size="12" weight="500" color="secondary">Unbonding</Text> |
| 652 | + |
| 653 | + <Text size="12" weight="500" color="primary" mono no-wrap> |
| 654 | + {{ event.data.amount ? tia(event.data.amount.replace("utia", "")) : 0 }} TIA</Text |
| 655 | + > |
| 656 | + |
| 657 | + <Text size="12" weight="500" color="secondary">from</Text> |
| 658 | + |
| 659 | + <Tooltip :class="$style.tooltip"> |
| 660 | + <NuxtLink :to="`/address/${event.data.validator}`" @click.stop> |
| 661 | + <Text size="12" weight="500" color="primary" mono> |
| 662 | + {{ splitAddress(event.data.validator) }} |
| 663 | + </Text> |
| 664 | + </NuxtLink> |
| 665 | + |
| 666 | + <template #content> |
| 667 | + {{ event.data.validator }} |
| 668 | + </template> |
| 669 | + </Tooltip> |
| 670 | + |
| 671 | + <Text size="12" weight="500" color="secondary">was canceled</Text> |
| 672 | + </Flex> |
468 | 673 |
|
469 | 674 | <Text size="12" weight="600" color="tertiary" mono> |
470 | 675 | {{ event.type }} |
|
0 commit comments