commit
f8fd5dc2a3
3 changed files with 44 additions and 1 deletions
|
@ -60,6 +60,11 @@ void Write(const mate::Dictionary& data,
|
|||
if (data.Get("text", &text))
|
||||
writer.WriteText(text);
|
||||
|
||||
if (data.Get("rtf", &text)) {
|
||||
std::string rtf = base::UTF16ToUTF8(text);
|
||||
writer.WriteRTF(rtf);
|
||||
}
|
||||
|
||||
if (data.Get("html", &html))
|
||||
writer.WriteHTML(html, std::string());
|
||||
|
||||
|
@ -88,6 +93,18 @@ void WriteText(const base::string16& text, mate::Arguments* args) {
|
|||
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 data;
|
||||
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("readText", &ReadText);
|
||||
dict.SetMethod("writeText", &WriteText);
|
||||
dict.SetMethod("readRtf", &ReadRtf);
|
||||
dict.SetMethod("writeRtf", &WriteRtf);
|
||||
dict.SetMethod("readHtml", &ReadHtml);
|
||||
dict.SetMethod("writeHtml", &WriteHtml);
|
||||
dict.SetMethod("readImage", &ReadImage);
|
||||
|
|
|
@ -61,6 +61,20 @@ Returns the content in the clipboard as a [NativeImage](native-image.md).
|
|||
|
||||
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])`
|
||||
|
||||
* `type` String (optional)
|
||||
|
|
|
@ -35,20 +35,30 @@ describe('clipboard module', function() {
|
|||
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 it('returns data correctly', function() {
|
||||
var i, markup, p, text;
|
||||
var i, markup, p, text, rtf;
|
||||
text = 'test';
|
||||
rtf = '{\\rtf1\\utf8 text}';
|
||||
p = path.join(fixtures, 'assets', 'logo.png');
|
||||
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>';
|
||||
clipboard.write({
|
||||
text: "test",
|
||||
html: '<b>Hi</b>',
|
||||
rtf: '{\\rtf1\\utf8 text}',
|
||||
image: p
|
||||
});
|
||||
assert.equal(clipboard.readText(), text);
|
||||
assert.equal(clipboard.readHtml(), markup);
|
||||
assert.equal(clipboard.readRtf(), rtf);
|
||||
return assert.equal(clipboard.readImage().toDataURL(), i.toDataURL());
|
||||
});
|
||||
});
|
||||
|
|
Loading…
Reference in a new issue