Skip to content

Commit

Permalink
Use Helper function to copy to clipboard
Browse files Browse the repository at this point in the history
  • Loading branch information
Yamaguchi committed Oct 28, 2023
1 parent d59cacb commit 7744e09
Show file tree
Hide file tree
Showing 7 changed files with 17 additions and 80 deletions.
23 changes: 4 additions & 19 deletions frontend/src/app/address/address.page.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
import { Component, OnInit } from '@angular/core';
import { ActivatedRoute } from '@angular/router';
import { NavController } from '@ionic/angular';
import { NavController, ToastController } from '@ionic/angular';

import { BackendService } from '../backend.service';
import { AppConst } from '../app.const';
import Helper from '../app.helper';

@Component({
selector: 'app-address',
Expand Down Expand Up @@ -34,6 +35,7 @@ export class AddressPage implements OnInit {
constructor(
private activatedRoute: ActivatedRoute,
private navCtrl: NavController,
private toastController: ToastController,
private backendService: BackendService
) {}

Expand All @@ -56,24 +58,7 @@ export class AddressPage implements OnInit {
}

copyAddress() {
const textArea = document.createElement('textarea');
textArea.value = this.address;

document.body.appendChild(textArea);
textArea.focus();
textArea.select();

try {
document.execCommand('copy');
this.copied = true;
setTimeout(() => {
this.copied = false;
}, 800);
} catch (err) {
console.error('Fallback: Oops, unable to copy', err);
}

document.body.removeChild(textArea);
Helper.copy(this.toastController, this.address);
}

onNextPage() {
Expand Down
1 change: 0 additions & 1 deletion frontend/src/app/app.helper.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ import { Component, Injectable } from '@angular/core';
import { ToastController } from '@ionic/angular';

export default class Helper {
@Injectable()
static async copy(toastController: ToastController, text: string) {
navigator.clipboard.writeText(text);
const toast = await toastController.create({
Expand Down
8 changes: 0 additions & 8 deletions frontend/src/app/block-rawdata/block-rawdata.page.html
Original file line number Diff line number Diff line change
Expand Up @@ -12,16 +12,8 @@
<ion-icon name="copy-outline" color="primary" id="copy-icon"></ion-icon>
Copy Raw Data
</ion-button>
<b *ngIf="copied" id="copied-text">Copied !</b>
</div>
<div class="ion-padding ion-margin" id="copy-content">
<p id="myInput" class="text-color">{{ blockRawData }}</p>
</div>
<div class="ion-text-center block-md">
<ion-button (click)="copyBlockRawData()">
<ion-icon name="copy-outline" color="primary" id="copy-icon"></ion-icon>
Copy Raw Data </ion-button
><br />
<b *ngIf="copied" id="copied-text-md">Copied !</b>
</div>
</ion-content>
5 changes: 3 additions & 2 deletions frontend/src/app/block-rawdata/block-rawdata.page.spec.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
import { IonicModule } from '@ionic/angular';
import { IonicModule, NavParams } from '@ionic/angular';

import { BlockRawdataPage } from './block-rawdata.page';
import { HttpClientTestingModule } from '@angular/common/http/testing';
Expand All @@ -11,7 +11,8 @@ describe('BlockRawdataPage', () => {
beforeEach(waitForAsync(() => {
TestBed.configureTestingModule({
declarations: [BlockRawdataPage],
imports: [IonicModule.forRoot(), HttpClientTestingModule]
imports: [IonicModule.forRoot(), HttpClientTestingModule],
providers: [NavParams]
}).compileComponents();

fixture = TestBed.createComponent(BlockRawdataPage);
Expand Down
26 changes: 5 additions & 21 deletions frontend/src/app/block-rawdata/block-rawdata.page.ts
Original file line number Diff line number Diff line change
@@ -1,24 +1,25 @@
import { Component, OnInit, Input } from '@angular/core';
import { NavParams, ModalController } from '@ionic/angular';
import { NavParams, ModalController, ToastController } from '@ionic/angular';
import { HttpClient } from '@angular/common/http';

import { BackendService } from '../backend.service';
import Helper from '../app.helper';

@Component({
selector: 'app-block-rawdata',
templateUrl: './block-rawdata.page.html',
styleUrls: ['./block-rawdata.page.scss'],
providers: [BackendService, NavParams]
providers: [BackendService]
})
export class BlockRawdataPage implements OnInit {
@Input() blockHash: string;
blockRawData = '';
copied = false;

constructor(
private navParams: NavParams,
private httpClient: HttpClient,
private modalCtrl: ModalController,
private toastController: ToastController,
private backendService: BackendService
) {}

Expand All @@ -40,24 +41,7 @@ export class BlockRawdataPage implements OnInit {
}

copyBlockRawData() {
const textArea = document.createElement('textarea');
textArea.value = this.blockRawData;

document.body.appendChild(textArea);
textArea.focus();
textArea.select();

try {
document.execCommand('copy');
this.copied = true;
setTimeout(() => {
this.copied = false;
}, 800);
} catch (err) {
console.error('Fallback: Oops, unable to copy', err);
}

document.body.removeChild(textArea);
Helper.copy(this.toastController, this.blockRawData);
}

dismiss() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,16 +12,8 @@
<ion-icon name="copy-outline" color="primary" id="copy-icon"></ion-icon>
Copy Raw Data
</ion-button>
<b *ngIf="copied" id="copied-text">Copied !</b>
</div>
<div class="ion-padding ion-margin" id="copy-content">
<p id="myInput" class="text-color">{{ txRawData }}</p>
</div>
<div class="ion-text-center block-md">
<ion-button (click)="copyTxRawData()">
<ion-icon name="copy-outline" color="primary" id="copy-icon"></ion-icon>
Copy Raw Data </ion-button
><br />
<b *ngIf="copied" id="copied-text-md">Copied !</b>
</div>
</ion-content>
26 changes: 5 additions & 21 deletions frontend/src/app/transaction-rawdata/transaction-rawdata.page.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
import { Component, OnInit, Input } from '@angular/core';
import { NavParams, ModalController } from '@ionic/angular';
import { NavParams, ModalController, ToastController } from '@ionic/angular';
import { HttpClient } from '@angular/common/http';

import { BackendService } from '../backend.service';
import Helper from '../app.helper';

@Component({
selector: 'app-transaction-rawdata',
Expand All @@ -13,12 +14,12 @@ import { BackendService } from '../backend.service';
export class TransactionRawdataPage implements OnInit {
@Input() txid: string;
txRawData = '';
copied = false;

constructor(
private navParams: NavParams,
private httpClient: HttpClient,
private modalCtrl: ModalController,
private toastController: ToastController,
private backendService: BackendService
) {}

Expand All @@ -39,25 +40,8 @@ export class TransactionRawdataPage implements OnInit {
);
}

copyTxRawData() {
const textArea = document.createElement('textarea');
textArea.value = this.txRawData;

document.body.appendChild(textArea);
textArea.focus();
textArea.select();

try {
document.execCommand('copy');
this.copied = true;
setTimeout(() => {
this.copied = false;
}, 800);
} catch (err) {
console.error('Fallback: Oops, unable to copy', err);
}

document.body.removeChild(textArea);
async copyTxRawData() {
Helper.copy(this.toastController, this.txRawData);
}

dismiss() {
Expand Down

0 comments on commit 7744e09

Please sign in to comment.