mirror of
https://github.com/Jermolene/TiddlyWiki5
synced 2024-12-30 20:10:28 +00:00
0c328a1696
* Rename markdown to markdown-legacy * Change how default renderWikiTextPragma value is displayed To prevent out-of-sync, dynamically display the default value of renderWikiTextPragma from the shadow tiddler instead of hard coding the text in the "usage.tid". * Repackage remarkable-based markdown plugin as markdown-legacy - Rename plugin title to $:/plugins/tiddlywiki/markdown-legacy - Add support for "text/markdown" MIME type and set that as the default when creating new markdown tiddlers * Create new markdown plugin * add support to text/markdown MIME type * remove linkify and linkNewWindow config options - linkify feature should be controlled by "extlink" TW parser rule; enabling markdown's linkify option will interfere with parsing - remove the possibility to open external links in the same tab/window to match TW's behavior * Ignore latex-parser wikirule in rednerWikiTextPragma * Prevent camel-case link text from generating a link * Update editions/markdowndemo * Produce better parse tree * Improve markdown/tiddlywiki integration - widget block should not interrupt paragraph - ignore tw-syntax links inside markdown-syntax links - remove repeated renderWikiTextPragma parsing - more efficient findNextMatch when examining tw rules * Update user docs * Replace includes() with indexOf() for legacy browsers
38 lines
1.2 KiB
JavaScript
38 lines
1.2 KiB
JavaScript
/*\
|
|
title: $:/plugins/tiddlywiki/markdown-legacy/editor-operations/make-markdown-link.js
|
|
type: application/javascript
|
|
module-type: texteditoroperation
|
|
|
|
Text editor operation to make a markdown link
|
|
|
|
\*/
|
|
(function(){
|
|
|
|
/*jslint node: true, browser: true */
|
|
/*global $tw: false */
|
|
"use strict";
|
|
|
|
exports["make-markdown-link"] = function(event,operation) {
|
|
if(operation.selection) {
|
|
if(event.paramObject.text.indexOf("://") !== -1) {
|
|
operation.replacement = "[" + operation.selection + "](" + event.paramObject.text + ")";
|
|
} else {
|
|
operation.replacement = "[" + operation.selection + "](#" + event.paramObject.text.replaceAll(" ", "%20") + ")";
|
|
}
|
|
operation.cutStart = operation.selStart;
|
|
operation.cutEnd = operation.selEnd;
|
|
} else {
|
|
if(event.paramObject.text.indexOf("://") !== -1) {
|
|
operation.replacement = "<" + event.paramObject.text + ">";
|
|
} else {
|
|
operation.replacement = "[](#" + event.paramObject.text.replaceAll(" ", "%20") + ")";
|
|
}
|
|
operation.cutStart = operation.selStart;
|
|
operation.cutEnd = operation.selEnd;
|
|
}
|
|
operation.newSelStart = operation.selStart + operation.replacement.length;
|
|
operation.newSelEnd = operation.newSelStart;
|
|
};
|
|
|
|
})();
|