Merge pull request #4363 from Vj3k0/master

Adding support to write RTF to clipboard.
This commit is contained in:
Kevin Sawicki 2016-02-09 13:23:47 -08:00
commit 3af20729bd
3 changed files with 44 additions and 1 deletions

View file

@ -60,6 +60,11 @@ void Write(const mate::Dictionary& data,
if (data.Get("text", &text)) if (data.Get("text", &text))
writer.WriteText(text); writer.WriteText(text);
if (data.Get("rtf", &text)) {
std::string rtf = base::UTF16ToUTF8(text);
writer.WriteRTF(rtf);
}
if (data.Get("html", &html)) if (data.Get("html", &html))
writer.WriteHTML(html, std::string()); writer.WriteHTML(html, std::string());
@ -88,6 +93,18 @@ void WriteText(const base::string16& text, mate::Arguments* args) {
writer.WriteText(text); writer.WriteText(text);
} }
base::string16 ReadRtf(mate::Arguments* args) {
std::string data;
ui::Clipboard* clipboard = ui::Clipboard::GetForCurrentThread();
clipboard->ReadRTF(GetClipboardType(args), &data);
return base::UTF8ToUTF16(data);
}
void WriteRtf(const std::string& text, mate::Arguments* args) {
ui::ScopedClipboardWriter writer(GetClipboardType(args));
writer.WriteRTF(text);
}
base::string16 ReadHtml(mate::Arguments* args) { base::string16 ReadHtml(mate::Arguments* args) {
base::string16 data; base::string16 data;
base::string16 html; base::string16 html;
@ -129,6 +146,8 @@ void Initialize(v8::Local<v8::Object> exports, v8::Local<v8::Value> unused,
dict.SetMethod("write", &Write); dict.SetMethod("write", &Write);
dict.SetMethod("readText", &ReadText); dict.SetMethod("readText", &ReadText);
dict.SetMethod("writeText", &WriteText); dict.SetMethod("writeText", &WriteText);
dict.SetMethod("readRtf", &ReadRtf);
dict.SetMethod("writeRtf", &WriteRtf);
dict.SetMethod("readHtml", &ReadHtml); dict.SetMethod("readHtml", &ReadHtml);
dict.SetMethod("writeHtml", &WriteHtml); dict.SetMethod("writeHtml", &WriteHtml);
dict.SetMethod("readImage", &ReadImage); dict.SetMethod("readImage", &ReadImage);

View file

@ -61,6 +61,20 @@ Returns the content in the clipboard as a [NativeImage](native-image.md).
Writes `image` to the clipboard. Writes `image` to the clipboard.
### `clipboard.readRtf([type])`
* `type` String (optional)
Returns the content in the clipboard as RTF.
### `clipboard.writeRtf(text[, type])`
* `text` String
* `type` String (optional)
Writes the `text` into the clipboard in RTF.
### `clipboard.clear([type])` ### `clipboard.clear([type])`
* `type` String (optional) * `type` String (optional)

View file

@ -35,20 +35,30 @@ describe('clipboard module', function() {
return assert.equal(clipboard.readHtml(), markup); return assert.equal(clipboard.readHtml(), markup);
}); });
}); });
describe('clipboard.readRtf', function() {
return it('returns rtf text correctly', function() {
var rtf = "{\\rtf1\\ansi{\\fonttbl\\f0\\fswiss Helvetica;}\\f0\\pard\nThis is some {\\b bold} text.\\par\n}";
clipboard.writeRtf(rtf);
return assert.equal(clipboard.readRtf(), rtf);
});
});
return describe('clipboard.write()', function() { return describe('clipboard.write()', function() {
return it('returns data correctly', function() { return it('returns data correctly', function() {
var i, markup, p, text; var i, markup, p, text, rtf;
text = 'test'; text = 'test';
rtf = '{\\rtf1\\utf8 text}';
p = path.join(fixtures, 'assets', 'logo.png'); p = path.join(fixtures, 'assets', 'logo.png');
i = nativeImage.createFromPath(p); i = nativeImage.createFromPath(p);
markup = process.platform === 'darwin' ? '<meta charset=\'utf-8\'><b>Hi</b>' : process.platform === 'linux' ? '<meta http-equiv="content-type" ' + 'content="text/html; charset=utf-8"><b>Hi</b>' : '<b>Hi</b>'; markup = process.platform === 'darwin' ? '<meta charset=\'utf-8\'><b>Hi</b>' : process.platform === 'linux' ? '<meta http-equiv="content-type" ' + 'content="text/html; charset=utf-8"><b>Hi</b>' : '<b>Hi</b>';
clipboard.write({ clipboard.write({
text: "test", text: "test",
html: '<b>Hi</b>', html: '<b>Hi</b>',
rtf: '{\\rtf1\\utf8 text}',
image: p image: p
}); });
assert.equal(clipboard.readText(), text); assert.equal(clipboard.readText(), text);
assert.equal(clipboard.readHtml(), markup); assert.equal(clipboard.readHtml(), markup);
assert.equal(clipboard.readRtf(), rtf);
return assert.equal(clipboard.readImage().toDataURL(), i.toDataURL()); return assert.equal(clipboard.readImage().toDataURL(), i.toDataURL());
}); });
}); });