2017-09-27 16:40:59 +00:00
|
|
|
/**
|
|
|
|
* This class is based on the code in the following projects:
|
|
|
|
*
|
|
|
|
* - https://github.com/zenorocha/select
|
|
|
|
* - https://github.com/zenorocha/clipboard.js/
|
|
|
|
*
|
|
|
|
* Both released under MIT license - © Zeno Rocha
|
|
|
|
*/
|
2017-10-10 13:37:14 +00:00
|
|
|
import { Injectable } from '@angular/core';
|
2017-09-27 16:40:59 +00:00
|
|
|
|
|
|
|
@Injectable()
|
2017-10-10 13:37:14 +00:00
|
|
|
export class CopierService
|
|
|
|
{
|
2017-09-27 16:40:59 +00:00
|
|
|
|
2017-10-10 13:37:14 +00:00
|
|
|
private textarea: HTMLTextAreaElement;
|
2017-09-27 16:40:59 +00:00
|
|
|
|
2017-10-10 13:37:14 +00:00
|
|
|
/** Copy the text value to the clipboard. */
|
|
|
|
copyText(text: string): boolean
|
|
|
|
{
|
|
|
|
this.createTextareaAndSelect(text);
|
2017-09-27 16:40:59 +00:00
|
|
|
|
2017-10-10 13:37:14 +00:00
|
|
|
const copySuccessful = document.execCommand('copy');
|
|
|
|
this.removeFake();
|
2017-09-27 16:40:59 +00:00
|
|
|
|
2017-10-10 13:37:14 +00:00
|
|
|
return copySuccessful;
|
|
|
|
}
|
2017-09-27 16:40:59 +00:00
|
|
|
|
2017-10-10 13:37:14 +00:00
|
|
|
/**
|
|
|
|
* Creates a hidden textarea element, sets its value from `text` property,
|
|
|
|
* and makes a selection on it.
|
|
|
|
*/
|
|
|
|
private createTextareaAndSelect(text: string)
|
|
|
|
{
|
|
|
|
// Create a fake element to hold the contents to copy
|
|
|
|
this.textarea = document.createElement('textarea');
|
2017-09-27 16:40:59 +00:00
|
|
|
|
2017-10-10 13:37:14 +00:00
|
|
|
// Prevent zooming on iOS
|
|
|
|
this.textarea.style.fontSize = '12pt';
|
2017-09-27 16:40:59 +00:00
|
|
|
|
2017-10-10 13:37:14 +00:00
|
|
|
// Hide the element
|
|
|
|
this.textarea.classList.add('cdk-visually-hidden');
|
2017-09-27 16:40:59 +00:00
|
|
|
|
2017-10-10 13:37:14 +00:00
|
|
|
// Move element to the same position vertically
|
|
|
|
const yPosition = window.pageYOffset || document.documentElement.scrollTop;
|
|
|
|
this.textarea.style.top = yPosition + 'px';
|
2017-09-27 16:40:59 +00:00
|
|
|
|
2017-10-10 13:37:14 +00:00
|
|
|
this.textarea.setAttribute('readonly', '');
|
|
|
|
this.textarea.value = text;
|
2017-09-27 16:40:59 +00:00
|
|
|
|
2017-10-10 13:37:14 +00:00
|
|
|
document.body.appendChild(this.textarea);
|
2017-09-27 16:40:59 +00:00
|
|
|
|
2017-10-10 13:37:14 +00:00
|
|
|
this.textarea.select();
|
|
|
|
this.textarea.setSelectionRange(0, this.textarea.value.length);
|
|
|
|
}
|
2017-09-27 16:40:59 +00:00
|
|
|
|
2017-10-10 13:37:14 +00:00
|
|
|
/** Remove the text area from the DOM. */
|
|
|
|
private removeFake()
|
|
|
|
{
|
|
|
|
if ( this.textarea )
|
|
|
|
{
|
|
|
|
document.body.removeChild(this.textarea);
|
|
|
|
this.textarea = null;
|
|
|
|
}
|
2017-09-27 16:40:59 +00:00
|
|
|
}
|
|
|
|
}
|