You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
802 lines
164 KiB
802 lines
164 KiB
'use strict';
|
|
|
|
var obsidian = require('obsidian');
|
|
|
|
/******************************************************************************
|
|
Copyright (c) Microsoft Corporation.
|
|
|
|
Permission to use, copy, modify, and/or distribute this software for any
|
|
purpose with or without fee is hereby granted.
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
|
|
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
|
|
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
|
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
|
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
PERFORMANCE OF THIS SOFTWARE.
|
|
***************************************************************************** */
|
|
|
|
function __awaiter(thisArg, _arguments, P, generator) {
|
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
});
|
|
}
|
|
|
|
function getAllExpandersQuery(content) {
|
|
let accum = [];
|
|
for (var i = 0; i < content.length; i++) {
|
|
const line = content[i];
|
|
if (line === '```expander') {
|
|
for (var e = 0; e < content.length - i; e++) {
|
|
const nextline = content[i + e];
|
|
if (nextline === '```') {
|
|
accum.push({
|
|
start: i,
|
|
end: i + e,
|
|
query: content[i + 1],
|
|
template: e > 2 ? content.slice(i + 2, i + e).join('\n') : ''
|
|
});
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return accum;
|
|
}
|
|
function getClosestQuery(queries, lineNumber) {
|
|
if (queries.length === 0) {
|
|
return undefined;
|
|
}
|
|
return queries.reduce((a, b) => {
|
|
return Math.abs(b.start - lineNumber) < Math.abs(a.start - lineNumber) ? b : a;
|
|
});
|
|
}
|
|
function getLastLineToReplace(content, query, endline) {
|
|
const lineFrom = query.end;
|
|
for (var i = lineFrom + 1; i < content.length; i++) {
|
|
if (content[i] === endline) {
|
|
return i;
|
|
}
|
|
}
|
|
return lineFrom + 1;
|
|
}
|
|
const pick = (obj, arr) => arr.reduce((acc, curr) => {
|
|
return (curr in obj)
|
|
? Object.assign({}, acc, { [curr]: obj[curr] })
|
|
: acc;
|
|
}, {});
|
|
|
|
// Functions for string processing
|
|
function splitByLines(content) {
|
|
return content.split('\n');
|
|
}
|
|
function removeEmptyLines(s) {
|
|
const lines = s.split('\n').map(e => e.trim());
|
|
if (lines.length < 2) {
|
|
return s;
|
|
}
|
|
else if (lines.indexOf('') === 0) {
|
|
return removeEmptyLines(lines.slice(1).join('\n'));
|
|
}
|
|
return s;
|
|
}
|
|
function removeFrontMatter(s, lookEnding = false) {
|
|
const lines = s.split('\n');
|
|
if (lookEnding && lines.indexOf('---') === 0) {
|
|
return lines.slice(1).join('\n');
|
|
}
|
|
else if (lookEnding) {
|
|
return removeFrontMatter(lines.slice(1).join('\n'), true);
|
|
}
|
|
else if (lines.indexOf('---') === 0) {
|
|
return removeFrontMatter(lines.slice(1).join('\n'), true);
|
|
}
|
|
return s;
|
|
}
|
|
function trimContent(content) {
|
|
return removeFrontMatter(removeEmptyLines(content));
|
|
}
|
|
|
|
function getFrontMatter(file, plugin, s) {
|
|
const { frontmatter = null } = plugin.app.metadataCache.getCache(file.path);
|
|
if (frontmatter) {
|
|
return frontmatter[s.split(':')[1]] || '';
|
|
}
|
|
return '';
|
|
}
|
|
function getFileInfo(plugin, file) {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
const info = Object.assign({}, file, {
|
|
content: file.extension === 'md' ? yield plugin.app.vault.cachedRead(file) : '',
|
|
link: plugin.app.fileManager.generateMarkdownLink(file, file.name).replace(/^!/, '')
|
|
}, plugin.app.metadataCache.getFileCache(file));
|
|
return pick(info, [
|
|
'basename',
|
|
'content',
|
|
'extension',
|
|
'headings',
|
|
'link', 'name',
|
|
'path', 'sections', 'stat',
|
|
'frontmatter',
|
|
'links',
|
|
'listItems'
|
|
]);
|
|
});
|
|
}
|
|
|
|
function highlight(lineStart, lineEnd, matchStart, matchEnd, lineContent) {
|
|
return [
|
|
...lineContent.slice(0, matchStart - lineStart),
|
|
'==',
|
|
...lineContent.slice(matchStart - lineStart, (matchStart - lineStart) + (matchEnd - matchStart)),
|
|
'==',
|
|
...lineContent.slice((matchStart - lineStart) + (matchEnd - matchStart)),
|
|
].join('');
|
|
}
|
|
const sequences = [
|
|
{
|
|
name: '\\$count',
|
|
loop: true,
|
|
format: (_p, _s, _content, _file, _d, index) => index ? String(index + 1) : String(1),
|
|
desc: 'add index number to each produced file'
|
|
},
|
|
{
|
|
name: '\\$filename',
|
|
loop: true,
|
|
format: (_p, _s, _content, file) => file.basename,
|
|
desc: 'name of the founded file'
|
|
},
|
|
{
|
|
name: '\\$link',
|
|
loop: true,
|
|
format: (p, _s, _content, file) => p.app.fileManager.generateMarkdownLink(file, file.path).replace('![[', '[['),
|
|
desc: 'link based on Obsidian settings'
|
|
},
|
|
{
|
|
name: '\\$lines:\\d+',
|
|
loop: true,
|
|
readContent: true,
|
|
format: (p, s, content, _file) => {
|
|
const digits = Number(s.split(':')[1]);
|
|
return trimContent(content)
|
|
.split('\n')
|
|
.filter((_, i) => i < digits)
|
|
.join('\n')
|
|
.replace(new RegExp(p.config.lineEnding, 'g'), '');
|
|
},
|
|
desc: 'specified count of lines from the found file'
|
|
},
|
|
{
|
|
name: '\\$characters:\\d+',
|
|
loop: true,
|
|
readContent: true,
|
|
format: (p, s, content, _file) => {
|
|
const digits = Number(s.split(':')[1]);
|
|
return trimContent(content)
|
|
.split('')
|
|
.filter((_, i) => i < digits)
|
|
.join('')
|
|
.replace(new RegExp(p.config.lineEnding, 'g'), '');
|
|
},
|
|
desc: 'specified count of lines from the found file'
|
|
},
|
|
{
|
|
name: '\\$frontmatter:[\\p\{L\}_-]+',
|
|
loop: true,
|
|
format: (p, s, _content, file) => getFrontMatter(file, p, s),
|
|
desc: 'value from the frontmatter key in the found file'
|
|
},
|
|
{
|
|
name: '\\$lines+',
|
|
loop: true,
|
|
readContent: true,
|
|
format: (p, s, content, _file) => content.replace(new RegExp(p.config.lineEnding, 'g'), ''),
|
|
desc: 'all content from the found file'
|
|
},
|
|
{
|
|
name: '\\$ext',
|
|
loop: true,
|
|
format: (_p, s, content, file) => file.extension,
|
|
desc: 'return file extension'
|
|
},
|
|
{
|
|
name: '\\$created:format:date',
|
|
loop: true,
|
|
format: (_p, s, content, file) => String(new Date(file.stat.ctime).toISOString()).split('T')[0],
|
|
desc: 'created time formatted'
|
|
},
|
|
{
|
|
name: '\\$created:format:time',
|
|
loop: true,
|
|
format: (_p, s, content, file) => String(new Date(file.stat.ctime).toISOString()).split(/([.T])/)[2],
|
|
desc: 'created time formatted'
|
|
},
|
|
{
|
|
name: '\\$created:format',
|
|
loop: true,
|
|
format: (_p, s, content, file) => String(new Date(file.stat.ctime).toISOString()),
|
|
desc: 'created time formatted'
|
|
},
|
|
{
|
|
name: '\\$created',
|
|
loop: true,
|
|
format: (_p, s, content, file) => String(file.stat.ctime),
|
|
desc: 'created time'
|
|
},
|
|
{
|
|
name: '\\$size',
|
|
loop: true,
|
|
format: (_p, s, content, file) => String(file.stat.size),
|
|
desc: 'size of the file'
|
|
},
|
|
{
|
|
name: '\\$path',
|
|
loop: true,
|
|
format: (_p, s, content, file) => file.path,
|
|
desc: 'path to the found file'
|
|
},
|
|
{
|
|
name: '\\$parent',
|
|
loop: true,
|
|
format: (_p, s, content, file) => file.parent.name,
|
|
desc: 'parent folder name'
|
|
},
|
|
{
|
|
name: '^(.+|)\\$header:.+',
|
|
loop: true,
|
|
format: (p, s, content, file) => {
|
|
var _a;
|
|
const prefix = s.slice(0, s.indexOf('$'));
|
|
const header = s.slice(s.indexOf('$')).replace('$header:', '').replace(/"/g, '');
|
|
const neededLevel = header.split("#").length - 1;
|
|
const neededTitle = header.replace(/^#+/g, '').trim();
|
|
const metadata = p.app.metadataCache.getFileCache(file);
|
|
return ((_a = metadata.headings) === null || _a === void 0 ? void 0 : _a.filter(e => {
|
|
const tests = [
|
|
[neededTitle, e.heading.includes(neededTitle)],
|
|
[neededLevel, e.level === neededLevel]
|
|
].filter(e => e[0]);
|
|
if (tests.length) {
|
|
return tests.map(e => e[1]).every(e => e === true);
|
|
}
|
|
return true;
|
|
}).map(h => p.app.fileManager.generateMarkdownLink(file, file.basename, '#' + h.heading)).map(link => prefix + link).join('\n')) || '';
|
|
},
|
|
desc: 'headings from founded files. $header:## - return all level 2 headings. $header:Title - return all heading which match the string. Can be prepended like: - !$header:## to transclude the headings.'
|
|
},
|
|
{
|
|
name: '^(.+|)\\$blocks',
|
|
readContent: true,
|
|
loop: true,
|
|
format: (p, s, content, file) => {
|
|
const prefix = s.slice(0, s.indexOf('$'));
|
|
return content
|
|
.split('\n')
|
|
.filter(e => /\^\w+$/.test(e))
|
|
.map(e => prefix + p.app.fileManager.generateMarkdownLink(file, file.basename, '#' + e.replace(/^.+?(\^\w+$)/, '$1')))
|
|
.join('\n');
|
|
},
|
|
desc: 'block ids from the found files. Can be prepended.'
|
|
},
|
|
{
|
|
name: '^(.+|)\\$match:header', loop: true, format: (p, s, content, file, results) => {
|
|
var _a;
|
|
const prefix = s.slice(0, s.indexOf('$'));
|
|
const metadata = p.app.metadataCache.getFileCache(file);
|
|
const headings = (_a = metadata.headings) === null || _a === void 0 ? void 0 : _a.filter(h => results.result.content.filter(c => h.position.end.offset < c[0]).some(e => e)).slice(-1);
|
|
return headings
|
|
.map(h => p.app.fileManager.generateMarkdownLink(file, file.basename, '#' + h.heading))
|
|
.map(link => prefix + link)
|
|
.join('\n') || '';
|
|
}, desc: 'extract found selections'
|
|
},
|
|
{
|
|
name: '^(.+|)\\$matchline(:(\\+|-|)\\d+:\\d+|:(\\+|-|)\\d+|)',
|
|
loop: true,
|
|
format: (_p, s, content, file, results) => {
|
|
const prefix = s.slice(0, s.indexOf('$matchline'));
|
|
const [keyword, context, limit] = s.slice(s.indexOf('$matchline')).split(':');
|
|
const value = context || '';
|
|
const limitValue = Number(limit);
|
|
const isPlus = value.contains('+');
|
|
const isMinus = value.contains('-');
|
|
const isContext = !isPlus && !isMinus;
|
|
const offset = Number(value.replace(/[+-]/, ''));
|
|
const lines = results.content.split('\n');
|
|
// Grab info about line content, index, text length and start/end character position
|
|
const lineInfos = [];
|
|
for (let i = 0; i < lines.length; i++) {
|
|
const text = lines[i];
|
|
if (i === 0) {
|
|
lineInfos.push({
|
|
num: 0,
|
|
start: 0,
|
|
end: text.length,
|
|
text
|
|
});
|
|
continue;
|
|
}
|
|
const start = lineInfos[i - 1].end + 1;
|
|
lineInfos.push({
|
|
num: i,
|
|
start,
|
|
text,
|
|
end: text.length + start
|
|
});
|
|
}
|
|
return results.result.content.map(([from, to]) => {
|
|
const matchedLines = lineInfos
|
|
.filter(({ start, end }) => start <= from && end >= to)
|
|
.map((line) => {
|
|
return Object.assign(Object.assign({}, line), { text: highlight(line.start, line.end, from, to, line.text) });
|
|
});
|
|
const resultLines = [];
|
|
for (const matchedLine of matchedLines) {
|
|
const prevLines = isMinus || isContext
|
|
? lineInfos.filter(l => matchedLine.num - l.num > 0 && matchedLine.num - l.num < offset)
|
|
: [];
|
|
const nextLines = isPlus || isContext
|
|
? lineInfos.filter(l => l.num - matchedLine.num > 0 && l.num - matchedLine.num < offset)
|
|
: [];
|
|
resultLines.push(...prevLines, matchedLine, ...nextLines);
|
|
}
|
|
return prefix + resultLines.map(e => e.text).join('\n');
|
|
}).map(line => limitValue ? line.slice(0, limitValue) : line).join('\n');
|
|
}, desc: 'extract line with matches'
|
|
},
|
|
{
|
|
name: '^(.+|)\\$searchresult',
|
|
loop: true,
|
|
desc: '',
|
|
format: (_p, s, content, file, results) => {
|
|
const prefix = s.slice(0, s.indexOf('$searchresult'));
|
|
return results.children.map(matchedFile => {
|
|
return prefix + matchedFile.el.innerText;
|
|
}).join('\n');
|
|
}
|
|
},
|
|
{
|
|
name: '^(.+|)\\$match', loop: true, format: (_p, s, content, file, results) => {
|
|
if (!results.result.content) {
|
|
console.warn('There is no content in results');
|
|
return '';
|
|
}
|
|
function appendPrefix(prefix, line) {
|
|
return prefix + line;
|
|
}
|
|
const prefixContent = s.slice(0, s.indexOf('$'));
|
|
return results.result.content
|
|
.map(([from, to]) => results.content.slice(from, to))
|
|
.map(line => appendPrefix(prefixContent, line))
|
|
.join('\n');
|
|
}, desc: 'extract found selections'
|
|
},
|
|
];
|
|
|
|
function extractFilesFromSearchResults(searchResults, currentFileName, excludeCurrent = true) {
|
|
const files = Array.from(searchResults.keys());
|
|
return excludeCurrent
|
|
? files.filter(file => file.basename !== currentFileName)
|
|
: files;
|
|
}
|
|
|
|
var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
|
|
|
|
function createCommonjsModule(fn, basedir, module) {
|
|
return module = {
|
|
path: basedir,
|
|
exports: {},
|
|
require: function (path, base) {
|
|
return commonjsRequire(path, (base === undefined || base === null) ? module.path : base);
|
|
}
|
|
}, fn(module, module.exports), module.exports;
|
|
}
|
|
|
|
function commonjsRequire () {
|
|
throw new Error('Dynamic requires are not currently supported by @rollup/plugin-commonjs');
|
|
}
|
|
|
|
var eta_min = createCommonjsModule(function (module, exports) {
|
|
!function(e,n){n(exports);}(commonjsGlobal,(function(e){function n(e){var t,r,i=new Error(e);return t=i,r=n.prototype,Object.setPrototypeOf?Object.setPrototypeOf(t,r):t.__proto__=r,i}function t(e,t,r){var i=t.slice(0,r).split(/\n/),a=i.length,o=i[a-1].length+1;throw n(e+=" at line "+a+" col "+o+":\n\n "+t.split(/\n/)[a-1]+"\n "+Array(o).join(" ")+"^")}n.prototype=Object.create(Error.prototype,{name:{value:"Eta Error",enumerable:!1}});var r=new Function("return this")().Promise;function i(e,n){for(var t in n)r=n,i=t,Object.prototype.hasOwnProperty.call(r,i)&&(e[t]=n[t]);var r,i;return e}function a(e,n,t,r){var i,a;return Array.isArray(n.autoTrim)?(i=n.autoTrim[1],a=n.autoTrim[0]):i=a=n.autoTrim,(t||!1===t)&&(i=t),(r||!1===r)&&(a=r),a||i?"slurp"===i&&"slurp"===a?e.trim():("_"===i||"slurp"===i?e=function(e){return String.prototype.trimLeft?e.trimLeft():e.replace(/^\s+/,"")}(e):"-"!==i&&"nl"!==i||(e=e.replace(/^(?:\r\n|\n|\r)/,"")),"_"===a||"slurp"===a?e=function(e){return String.prototype.trimRight?e.trimRight():e.replace(/\s+$/,"")}(e):"-"!==a&&"nl"!==a||(e=e.replace(/(?:\r\n|\n|\r)$/,"")),e):e}var o={"&":"&","<":"<",">":">",'"':""","'":"'"};function c(e){return o[e]}var s=/`(?:\\[\s\S]|\${(?:[^{}]|{(?:[^{}]|{[^}]*})*})*}|(?!\${)[^\\`])*`/g,l=/'(?:\\[\s\w"'\\`]|[^\n\r'\\])*?'/g,u=/"(?:\\[\s\w"'\\`]|[^\n\r"\\])*?"/g;function p(e){return e.replace(/[.*+\-?^${}()|[\]\\]/g,"\\$&")}function f(e,n){var r=[],i=!1,o=0,c=n.parse;if(n.plugins)for(var f=0;f<n.plugins.length;f++){(T=n.plugins[f]).processTemplate&&(e=T.processTemplate(e,n));}function d(e,t){e&&(e=a(e,n,i,t))&&(e=e.replace(/\\|'/g,"\\$&").replace(/\r\n|\n|\r/g,"\\n"),r.push(e));}n.rmWhitespace&&(e=e.replace(/[\r\n]+/g,"\n").replace(/^\s+|\s+$/gm,"")),s.lastIndex=0,l.lastIndex=0,u.lastIndex=0;for(var g,h=[c.exec,c.interpolate,c.raw].reduce((function(e,n){return e&&n?e+"|"+p(n):n?p(n):e}),""),m=new RegExp("([^]*?)"+p(n.tags[0])+"(-|_)?\\s*("+h+")?\\s*","g"),v=new RegExp("'|\"|`|\\/\\*|(\\s*(-|_)?"+p(n.tags[1])+")","g");g=m.exec(e);){o=g[0].length+g.index;var y=g[1],x=g[2],_=g[3]||"";d(y,x),v.lastIndex=o;for(var w=void 0,b=!1;w=v.exec(e);){if(w[1]){var E=e.slice(o,w.index);m.lastIndex=o=v.lastIndex,i=w[2],b={t:_===c.exec?"e":_===c.raw?"r":_===c.interpolate?"i":"",val:E};break}var I=w[0];if("/*"===I){var R=e.indexOf("*/",v.lastIndex);-1===R&&t("unclosed comment",e,w.index),v.lastIndex=R;}else if("'"===I){l.lastIndex=w.index,l.exec(e)?v.lastIndex=l.lastIndex:t("unclosed string",e,w.index);}else if('"'===I){u.lastIndex=w.index,u.exec(e)?v.lastIndex=u.lastIndex:t("unclosed string",e,w.index);}else if("`"===I){s.lastIndex=w.index,s.exec(e)?v.lastIndex=s.lastIndex:t("unclosed string",e,w.index);}}b?r.push(b):t("unclosed tag",e,g.index+y.length);}if(d(e.slice(o,e.length),!1),n.plugins)for(f=0;f<n.plugins.length;f++){var T;(T=n.plugins[f]).processAST&&(r=T.processAST(r,n));}return r}function d(e,n){var t=f(e,n),r="var tR='',__l,__lP"+(n.include?",include=E.include.bind(E)":"")+(n.includeFile?",includeFile=E.includeFile.bind(E)":"")+"\nfunction layout(p,d){__l=p;__lP=d}\n"+(n.useWith?"with("+n.varName+"||{}){":"")+function(e,n){var t=0,r=e.length,i="";for(;t<r;t++){var a=e[t];if("string"==typeof a){i+="tR+='"+a+"'\n";}else {var o=a.t,c=a.val||"";"r"===o?(n.filter&&(c="E.filter("+c+")"),i+="tR+="+c+"\n"):"i"===o?(n.filter&&(c="E.filter("+c+")"),n.autoEscape&&(c="E.e("+c+")"),i+="tR+="+c+"\n"):"e"===o&&(i+=c+"\n");}}return i}(t,n)+(n.includeFile?"if(__l)tR="+(n.async?"await ":"")+"includeFile(__l,Object.assign("+n.varName+",{body:tR},__lP))\n":n.include?"if(__l)tR="+(n.async?"await ":"")+"include(__l,Object.assign("+n.varName+",{body:tR},__lP))\n":"")+"if(cb){cb(null,tR)} return tR"+(n.useWith?"}":"");if(n.plugins)for(var i=0;i<n.plugins.length;i++){var a=n.plugins[i];a.processFnString&&(r=a.processFnString(r,n));}return r}var g=new(function(){function e(e){this.cache=e;}return e.prototype.define=function(e,n){this.cache[e]=n;},e.prototype.get=function(e){return this.cache[e]},e.prototype.remove=function(e){delete this.cache[e];},e.prototype.reset=function(){this.cache={};},e.prototype.load=function(e){i(this.cache,e);},e}())({});var h={async:!1,autoEscape:!0,autoTrim:[!1,"nl"],cache:!1,e:function(e){var n=String(e);return /[&<>"']/.test(n)?n.replace(/[&<>"']/g,c):n},include:function(e,t){var r=this.templates.get(e);if(!r)throw n('Could not fetch template "'+e+'"');return r(t,this)},parse:{exec:"",interpolate:"=",raw:"~"},plugins:[],rmWhitespace:!1,tags:["<%","%>"],templates:g,useWith:!1,varName:"it"};function m(e,n){var t={};return i(t,h),n&&i(t,n),e&&i(t,e),t}function v(e,t){var r=m(t||{}),i=r.async?function(){try{return new Function("return (async function(){}).constructor")()}catch(e){throw e instanceof SyntaxError?n("This environment doesn't support async/await"):e}}():Function;try{return new i(r.varName,"E","cb",d(e,r))}catch(t){throw t instanceof SyntaxError?n("Bad template syntax\n\n"+t.message+"\n"+Array(t.message.length+1).join("=")+"\n"+d(e,r)+"\n"):t}}function y(e,n){if(n.cache&&n.name&&n.templates.get(n.name))return n.templates.get(n.name);var t="function"==typeof e?e:v(e,n);return n.cache&&n.name&&n.templates.define(n.name,t),t}function x(e,t,i,a){var o=m(i||{});if(!o.async)return y(e,o)(t,o);if(!a){if("function"==typeof r)return new r((function(n,r){try{n(y(e,o)(t,o));}catch(e){r(e);}}));throw n("Please provide a callback function, this env doesn't support Promises")}try{y(e,o)(t,o,a);}catch(e){return a(e)}}e.compile=v,e.compileToString=d,e.config=h,e.configure=function(e){return i(h,e)},e.defaultConfig=h,e.getConfig=m,e.parse=f,e.render=x,e.renderAsync=function(e,n,t,r){return x(e,n,Object.assign({},t,{async:!0}),r)},e.templates=g,Object.defineProperty(e,"__esModule",{value:!0});}));
|
|
|
|
});
|
|
|
|
class TextExpander extends obsidian.Plugin {
|
|
constructor(app, plugin) {
|
|
super(app, plugin);
|
|
this.config = {
|
|
autoExpand: false,
|
|
defaultTemplate: '- $link',
|
|
delay: 300,
|
|
excludeCurrent: true,
|
|
lineEnding: '<-->',
|
|
prefixes: {
|
|
header: '^',
|
|
footer: '>'
|
|
}
|
|
};
|
|
this.seqs = sequences;
|
|
this.leftPanelInfo = {
|
|
collapsed: false,
|
|
tab: 0,
|
|
text: ''
|
|
};
|
|
this.search = this.search.bind(this);
|
|
this.init = this.init.bind(this);
|
|
this.autoExpand = this.autoExpand.bind(this);
|
|
}
|
|
autoExpand() {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
if (!this.config.autoExpand) {
|
|
return;
|
|
}
|
|
const activeLeaf = this.app.workspace.activeLeaf;
|
|
if (!activeLeaf) {
|
|
return;
|
|
}
|
|
const activeView = activeLeaf.view;
|
|
const isAllowedView = activeView instanceof obsidian.MarkdownView;
|
|
if (!isAllowedView) {
|
|
return;
|
|
}
|
|
yield this.init(true);
|
|
});
|
|
}
|
|
onload() {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
this.addSettingTab(new SettingTab(this.app, this));
|
|
this.registerMarkdownCodeBlockProcessor('expander', (source, el, ctx) => {
|
|
el
|
|
.createDiv()
|
|
.createEl('button', { text: 'Run expand query' })
|
|
.addEventListener('click', this.init.bind(this, false, ctx.getSectionInfo(el).lineStart));
|
|
});
|
|
this.addCommand({
|
|
id: 'editor-expand',
|
|
name: 'expand',
|
|
callback: this.init,
|
|
hotkeys: []
|
|
});
|
|
this.addCommand({
|
|
id: 'editor-expand-all',
|
|
name: 'expand all',
|
|
callback: () => this.init(true),
|
|
hotkeys: []
|
|
});
|
|
this.app.workspace.on('file-open', this.autoExpand);
|
|
const data = yield this.loadData();
|
|
if (data) {
|
|
this.config = Object.assign(Object.assign({}, this.config), data);
|
|
}
|
|
});
|
|
}
|
|
onunload() {
|
|
console.log('unloading plugin');
|
|
this.app.workspace.off('file-open', this.autoExpand);
|
|
}
|
|
saveSettings() {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
yield this.saveData(this.config);
|
|
});
|
|
}
|
|
init(proceedAllQueriesOnPage = false, lineToStart) {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
const currentView = this.app.workspace.activeLeaf.view;
|
|
// Is on editable view
|
|
if (!(currentView instanceof obsidian.MarkdownView)) {
|
|
return;
|
|
}
|
|
const cmDoc = this.cm = currentView.editor;
|
|
const curNum = lineToStart || cmDoc.getCursor().line;
|
|
const content = cmDoc.getValue();
|
|
if (lineToStart) {
|
|
cmDoc.setCursor(lineToStart ? lineToStart - 1 : 0);
|
|
}
|
|
const formatted = splitByLines(content);
|
|
const findQueries = getAllExpandersQuery(formatted);
|
|
const closestQuery = getClosestQuery(findQueries, curNum);
|
|
if (proceedAllQueriesOnPage) {
|
|
yield findQueries.reduce((promise, query, i) => promise.then(() => {
|
|
const newContent = splitByLines(cmDoc.getValue());
|
|
const updatedQueries = getAllExpandersQuery(newContent);
|
|
return this.runExpanderCodeBlock(updatedQueries[i], newContent, currentView);
|
|
}), Promise.resolve());
|
|
}
|
|
else {
|
|
yield this.runExpanderCodeBlock(closestQuery, formatted, currentView);
|
|
}
|
|
});
|
|
}
|
|
runExpanderCodeBlock(query, content, view) {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
const { lineEnding, prefixes } = this.config;
|
|
if (!query) {
|
|
new Notification('Expand query not found');
|
|
return Promise.resolve();
|
|
}
|
|
this.clearOldResultsInFile(content, query, lineEnding);
|
|
const newContent = splitByLines(this.cm.getValue());
|
|
if (query.query !== '') {
|
|
this.search(query.query);
|
|
}
|
|
return yield this.runTemplateProcessing(query, getLastLineToReplace(newContent, query, this.config.lineEnding), prefixes, view);
|
|
});
|
|
}
|
|
runTemplateProcessing(query, lastLine, prefixes, currentView) {
|
|
var _a;
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
let currentFileName = '';
|
|
const templateContent = query.template.split('\n');
|
|
const { heading, footer, repeatableContent } = this.parseTemplate(prefixes, templateContent);
|
|
if (currentView instanceof obsidian.FileView) {
|
|
currentFileName = currentView.file.basename;
|
|
}
|
|
this.saveLeftPanelState();
|
|
const searchResults = yield this.getFoundAfterDelay(query.query === '');
|
|
const files = extractFilesFromSearchResults(searchResults, currentFileName, this.config.excludeCurrent);
|
|
this.restoreLeftPanelState();
|
|
currentView.editor.focus();
|
|
const currentFileInfo = (currentView instanceof obsidian.FileView)
|
|
? yield getFileInfo(this, currentView.file)
|
|
: {};
|
|
const filesInfo = yield Promise.all(files.map(file => getFileInfo(this, file)));
|
|
let changed;
|
|
if (query.template.contains("<%")) {
|
|
const templateToRender = repeatableContent.join('\n');
|
|
const dataToRender = {
|
|
current: currentFileInfo,
|
|
files: filesInfo
|
|
};
|
|
changed = yield eta_min.render(templateToRender, dataToRender, { autoEscape: false });
|
|
// changed = doT.template(templateToRender, {strip: false})(dataToRender)
|
|
}
|
|
else {
|
|
changed = yield this.generateTemplateFromSequences(files, repeatableContent, searchResults);
|
|
}
|
|
let result = [
|
|
heading,
|
|
changed,
|
|
footer,
|
|
this.config.lineEnding
|
|
].filter(e => e).join('\n');
|
|
// Do not paste generated content if used changed activeLeaf
|
|
const viewBeforeReplace = this.app.workspace.activeLeaf.view;
|
|
if (!(viewBeforeReplace instanceof obsidian.MarkdownView) || viewBeforeReplace.file.basename !== currentFileName) {
|
|
return;
|
|
}
|
|
currentView.editor.replaceRange(result, { line: query.end + 1, ch: 0 }, { line: lastLine, ch: ((_a = this.cm.getLine(lastLine)) === null || _a === void 0 ? void 0 : _a.length) || 0 });
|
|
return Promise.resolve();
|
|
});
|
|
}
|
|
generateTemplateFromSequences(files, repeatableContent, searchResults) {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
if (!searchResults) {
|
|
return '';
|
|
}
|
|
const changed = yield Promise.all(files
|
|
.map((file, i) => __awaiter(this, void 0, void 0, function* () {
|
|
const result = yield Promise.all(repeatableContent.map((s) => __awaiter(this, void 0, void 0, function* () { return yield this.applyTemplateToSearchResults(searchResults, file, s, i); })));
|
|
return result.join('\n');
|
|
})));
|
|
return changed.join('\n');
|
|
});
|
|
}
|
|
parseTemplate(prefixes, templateContent) {
|
|
const isHeader = (line) => line.startsWith(prefixes.header);
|
|
const isFooter = (line) => line.startsWith(prefixes.footer);
|
|
const isRepeat = (line) => !isHeader(line) && !isFooter(line);
|
|
const heading = templateContent.filter(isHeader).map((s) => s.slice(1)).join('\n');
|
|
const footer = templateContent.filter(isFooter).map((s) => s.slice(1)).join('\n');
|
|
const repeatableContent = templateContent.filter(isRepeat).filter(e => e).length === 0
|
|
? [this.config.defaultTemplate]
|
|
: templateContent.filter(isRepeat).filter(e => e);
|
|
return { heading, footer, repeatableContent };
|
|
}
|
|
saveLeftPanelState() {
|
|
this.leftPanelInfo = {
|
|
collapsed: this.app.workspace.leftSplit.collapsed,
|
|
tab: this.getSearchTabIndex(),
|
|
text: this.getSearchValue(),
|
|
};
|
|
}
|
|
restoreLeftPanelState() {
|
|
const { collapsed, tab, text } = this.leftPanelInfo;
|
|
const splitChildren = this.getLeftSplitElement();
|
|
this.getSearchView().searchComponent.setValue(text);
|
|
if (tab !== splitChildren.currentTab) {
|
|
splitChildren.selectTabIndex(tab);
|
|
}
|
|
if (collapsed) {
|
|
this.app.workspace.leftSplit.collapse();
|
|
}
|
|
}
|
|
search(s) {
|
|
// @ts-ignore
|
|
const globalSearchFn = this.app.internalPlugins.getPluginById('global-search').instance.openGlobalSearch.bind(this);
|
|
const search = (query) => globalSearchFn(query);
|
|
search(s);
|
|
}
|
|
getLeftSplitElement() {
|
|
// @ts-ignore
|
|
return this.app.workspace.leftSplit.children[0];
|
|
}
|
|
getSearchView() {
|
|
const view = this.getLeftSplitElement().children.filter(e => e.getViewState().type === 'search')[0].view;
|
|
if ('searchComponent' in view) {
|
|
return view;
|
|
}
|
|
return undefined;
|
|
}
|
|
getSearchValue() {
|
|
const view = this.getSearchView();
|
|
if (view) {
|
|
return view.searchComponent.getValue();
|
|
}
|
|
return '';
|
|
}
|
|
getSearchTabIndex() {
|
|
const leftTabs = this.getLeftSplitElement().children;
|
|
let searchTabId;
|
|
this.app.workspace.iterateAllLeaves((leaf) => {
|
|
if (leaf.getViewState().type == "search") {
|
|
searchTabId = leaf.id;
|
|
}
|
|
});
|
|
return leftTabs.findIndex((item, _index, _array) => {
|
|
if (item.id == searchTabId) {
|
|
return true;
|
|
}
|
|
});
|
|
}
|
|
;
|
|
getFoundAfterDelay(immediate) {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
const searchLeaf = this.app.workspace.getLeavesOfType('search')[0];
|
|
const view = yield searchLeaf.open(searchLeaf.view);
|
|
if (immediate) {
|
|
// @ts-ignore
|
|
return Promise.resolve(view.dom.resultDomLookup);
|
|
}
|
|
return new Promise(resolve => {
|
|
setTimeout(() => {
|
|
// @ts-ignore
|
|
return resolve(view.dom.resultDomLookup);
|
|
}, this.config.delay);
|
|
});
|
|
});
|
|
}
|
|
applyTemplateToSearchResults(searchResults, file, template, index) {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
const fileContent = (new RegExp(this.seqs.filter(e => e.readContent).map(e => e.name).join('|')).test(template))
|
|
? yield this.app.vault.cachedRead(file)
|
|
: '';
|
|
return this.seqs.reduce((acc, seq) => acc.replace(new RegExp(seq.name, 'gu'), replace => seq.format(this, replace, fileContent, file, searchResults.get(file), index)), template);
|
|
});
|
|
}
|
|
clearOldResultsInFile(content, query, lineEnding) {
|
|
var _a;
|
|
const lastLine = getLastLineToReplace(content, query, this.config.lineEnding);
|
|
this.cm.replaceRange('\n' + lineEnding, { line: query.end + 1, ch: 0 }, { line: lastLine, ch: ((_a = this.cm.getLine(lastLine)) === null || _a === void 0 ? void 0 : _a.length) || 0 });
|
|
}
|
|
}
|
|
class SettingTab extends obsidian.PluginSettingTab {
|
|
constructor(app, plugin) {
|
|
super(app, plugin);
|
|
this.app = app;
|
|
this.plugin = plugin;
|
|
}
|
|
display() {
|
|
let { containerEl } = this;
|
|
containerEl.empty();
|
|
containerEl.createEl('h2', { text: 'Settings for Text Expander' });
|
|
new obsidian.Setting(containerEl)
|
|
.setName('Auto Expand')
|
|
.setDesc('Expand all queries in a file once you open it')
|
|
.addToggle(toggle => {
|
|
toggle
|
|
.setValue(this.plugin.config.autoExpand)
|
|
.onChange(value => {
|
|
this.plugin.config.autoExpand = value;
|
|
this.plugin.saveSettings();
|
|
});
|
|
});
|
|
new obsidian.Setting(containerEl)
|
|
.setName('Delay')
|
|
.setDesc('Text expander don\' wait until search completed. It waits for a delay and paste result after that.')
|
|
.addSlider(slider => {
|
|
slider.setLimits(100, 10000, 100);
|
|
slider.setValue(this.plugin.config.delay);
|
|
slider.onChange(value => {
|
|
this.plugin.config.delay = value;
|
|
this.plugin.saveSettings();
|
|
});
|
|
slider.setDynamicTooltip();
|
|
});
|
|
new obsidian.Setting(containerEl)
|
|
.setName('Line ending')
|
|
.setDesc('You can specify the text which will appear at the bottom of the generated text.')
|
|
.addText(text => {
|
|
text.setValue(this.plugin.config.lineEnding)
|
|
.onChange(val => {
|
|
this.plugin.config.lineEnding = val;
|
|
this.plugin.saveSettings();
|
|
});
|
|
});
|
|
new obsidian.Setting(containerEl)
|
|
.setName('Default template')
|
|
.setDesc('You can specify default template')
|
|
.addTextArea(text => {
|
|
text.setValue(this.plugin.config.defaultTemplate)
|
|
.onChange(val => {
|
|
this.plugin.config.defaultTemplate = val;
|
|
this.plugin.saveSettings();
|
|
});
|
|
});
|
|
new obsidian.Setting(containerEl)
|
|
.setName('Exclude current file')
|
|
.setDesc('You can specify should text expander exclude results from current file or not')
|
|
.addToggle(toggle => {
|
|
toggle
|
|
.setValue(this.plugin.config.excludeCurrent)
|
|
.onChange(value => {
|
|
this.plugin.config.excludeCurrent = value;
|
|
this.plugin.saveSettings();
|
|
});
|
|
});
|
|
new obsidian.Setting(containerEl)
|
|
.setHeading()
|
|
.setName('Prefixes');
|
|
new obsidian.Setting(containerEl)
|
|
.setName('Header')
|
|
.setDesc('Line prefixed by this symbol will be recognized as header')
|
|
.addText(text => {
|
|
text.setValue(this.plugin.config.prefixes.header)
|
|
.onChange(val => {
|
|
this.plugin.config.prefixes.header = val;
|
|
this.plugin.saveSettings();
|
|
});
|
|
});
|
|
new obsidian.Setting(containerEl)
|
|
.setName('Footer')
|
|
.setDesc('Line prefixed by this symbol will be recognized as footer')
|
|
.addText(text => {
|
|
text.setValue(this.plugin.config.prefixes.footer)
|
|
.onChange(val => {
|
|
this.plugin.config.prefixes.footer = val;
|
|
this.plugin.saveSettings();
|
|
});
|
|
});
|
|
new obsidian.Setting(containerEl)
|
|
.setName('Sequences')
|
|
.setDesc('REGEXP - DESCRIPTION')
|
|
.setDesc((() => {
|
|
const fragment = new DocumentFragment();
|
|
const div = fragment.createEl('div');
|
|
this.plugin.seqs
|
|
.map(e => e.name + ' - ' + (e.desc || ''))
|
|
.map(e => {
|
|
const el = fragment.createEl('div');
|
|
el.setText(e);
|
|
el.setAttribute('style', `
|
|
border-bottom: 1px solid rgba(255, 255, 255, 0.1);
|
|
margin-bottom: 0.5rem;
|
|
padding-bottom: 0.5rem;
|
|
`);
|
|
return el;
|
|
}).forEach(el => {
|
|
div.appendChild(el);
|
|
});
|
|
fragment.appendChild(div);
|
|
return fragment;
|
|
})());
|
|
}
|
|
}
|
|
|
|
module.exports = TextExpander;
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"main.js","sources":["node_modules/tslib/tslib.es6.js","src/helpers/helpers.ts","src/helpers/string.ts","src/helpers/tfile.ts","src/sequences/sequences.ts","src/helpers/search-results.ts","node_modules/eta/dist/browser/eta.min.js","src/main.ts"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n    extendStatics = Object.setPrototypeOf ||\r\n        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n        function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n    return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n    if (typeof b !== \"function\" && b !== null)\r\n        throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n    __assign = Object.assign || function __assign(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n        }\r\n        return t;\r\n    }\r\n    return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n                t[p[i]] = s[p[i]];\r\n        }\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n    return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (_) try {\r\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [op[0] & 2, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    var desc = Object.getOwnPropertyDescriptor(m, k);\r\n    if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n        desc = { enumerable: true, get: function() { return m[k]; } };\r\n    }\r\n    Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n    for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n    var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n    if (m) return m.call(o);\r\n    if (o && typeof o.length === \"number\") return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n    throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n            r[k] = a[j];\r\n    return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n    if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n        if (ar || !(i in from)) {\r\n            if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n            ar[i] = from[i];\r\n        }\r\n    }\r\n    return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator], i;\r\n    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n    function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n    function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n    Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n    o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n    __setModuleDefault(result, mod);\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n    return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n    if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n    return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n    if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n    return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","export interface ExpanderQuery {\n    start: number\n    end: number\n    template: string\n    query: string\n}\n\nexport function getAllExpandersQuery(content: string[]): ExpanderQuery[] {\n    let accum: ExpanderQuery[] = []\n    for (var i = 0; i < content.length; i++) {\n        const line = content[i]\n\n        if (line === '```expander') {\n            for (var e = 0; e < content.length - i; e++) {\n                const nextline = content[i + e]\n                if (nextline === '```') {\n                    accum.push(\n                        {\n                            start: i,\n                            end: i + e,\n                            query: content[i + 1],\n                            template: e > 2 ? content.slice(i + 2, i + e).join('\\n') : ''\n                        }\n                    )\n                    break\n                }\n            }\n        }\n    }\n\n    return accum\n}\n\nexport function getClosestQuery(queries: ExpanderQuery[], lineNumber: number): ExpanderQuery | undefined {\n    if (queries.length === 0) {\n        return undefined\n    }\n\n    return queries.reduce((a, b) => {\n        return Math.abs(b.start - lineNumber) < Math.abs(a.start - lineNumber) ? b : a;\n    });\n}\n\nexport function getLastLineToReplace(content: string[], query: ExpanderQuery, endline: string) {\n    const lineFrom = query.end\n\n    for (var i = lineFrom + 1; i < content.length; i++) {\n        if (content[i] === endline) {\n            return i\n        }\n    }\n\n    return lineFrom + 1\n}\n\ntype LooseObject<T = any> = { [key: string]: T }\n\nexport const pick = (obj: {[k: string]: any}, arr: string[]) =>\n    arr.reduce((acc, curr) => {\n        return (curr in obj)\n            ? Object.assign({}, acc, { [curr]: obj[curr] })\n            : acc\n    }, <LooseObject>{});\n\n\n","// Functions for string processing\nexport function splitByLines(content: string): string[] {\n    return content.split('\\n')\n}\n\nfunction removeEmptyLines(s: string): string  {\n        const lines = s.split('\\n').map(e => e.trim())\n\n        if (lines.length < 2) {\n            return s\n        } else if (lines.indexOf('') === 0) {\n            return removeEmptyLines(lines.slice(1).join('\\n'))\n        }\n\n        return s\n}\n\nfunction removeFrontMatter (s: string, lookEnding: boolean = false): string {\n    const lines = s.split('\\n')\n\n    if (lookEnding && lines.indexOf('---') === 0) {\n        return lines.slice(1).join('\\n')\n    } else if (lookEnding) {\n        return removeFrontMatter(lines.slice(1).join('\\n'), true)\n    } else if (lines.indexOf('---') === 0) {\n        return removeFrontMatter(lines.slice(1).join('\\n'), true)\n    }\n\n    return s\n}\n\nexport function trimContent(content: string): string {\n    return removeFrontMatter(removeEmptyLines(content))\n}\n","import {Plugin, TFile} from \"obsidian\";\nimport {pick} from \"./helpers\";\nimport {FileParameters} from \"../main\";\n\nexport function getFrontMatter(file: TFile, plugin: Plugin, s: string) {\n    const {frontmatter = null} = plugin.app.metadataCache.getCache(file.path)\n\n    if (frontmatter) {\n        return frontmatter[s.split(':')[1]] || '';\n    }\n\n    return ''\n}\n\nexport async function getFileInfo(this: void, plugin: Plugin, file: TFile): Promise<FileParameters> {\n    const info = Object.assign({}, file, {\n            content: file.extension === 'md' ? await plugin.app.vault.cachedRead(file) : '',\n            link: plugin.app.fileManager.generateMarkdownLink(file, file.name).replace(/^!/, '')\n        },\n        plugin.app.metadataCache.getFileCache(file)\n    )\n    return pick(info, [\n        'basename',\n        'content',\n        'extension',\n        'headings',\n        'link', 'name',\n        'path', 'sections', 'stat',\n        'frontmatter',\n        'links',\n        'listItems'\n    ])\n}","import {TFile} from \"obsidian\";\nimport TextExpander, {SearchDetails} from \"../main\";\nimport {trimContent} from \"../helpers/string\";\nimport {getFrontMatter} from \"../helpers/tfile\";\n\nexport interface Sequences {\n    loop: boolean\n    name: string\n    format: (plugin: TextExpander, s: string, content: string, file: TFile, results?: SearchDetails, index?: number) => string\n    desc: string\n    readContent?: boolean\n    usingSearch?: boolean\n}\n\ninterface LineInfo {\n    text: string\n    num: number\n    start: number\n    end: number\n}\n\nfunction highlight(lineStart: number, lineEnd: number, matchStart: number, matchEnd: number, lineContent: string) {\n    return [\n        ...lineContent.slice(0, matchStart - lineStart),\n        '==',\n        ...lineContent.slice(matchStart - lineStart, (matchStart - lineStart) + (matchEnd - matchStart)),\n        '==',\n        ...lineContent.slice((matchStart - lineStart) + (matchEnd - matchStart)),\n    ].join('')\n}\n\nconst sequences: Sequences[] = [\n    {\n        name: '\\\\$count',\n        loop: true,\n        format: (_p, _s: string, _content: string, _file: TFile, _d, index) => index ? String(index + 1) : String(1),\n        desc: 'add index number to each produced file'\n    },\n    {\n        name: '\\\\$filename',\n        loop: true,\n        format: (_p, _s: string, _content: string, file: TFile) => file.basename,\n        desc: 'name of the founded file'\n    },\n    {\n        name: '\\\\$link',\n        loop: true,\n        format: (p, _s: string, _content: string, file: TFile) => p.app.fileManager.generateMarkdownLink(file, file.path).replace('![[', '[['),\n        desc: 'link based on Obsidian settings'\n    },\n    {\n        name: '\\\\$lines:\\\\d+',\n        loop: true,\n        readContent: true,\n        format: (p, s: string, content: string, _file: TFile) => {\n            const digits = Number(s.split(':')[1])\n\n            return trimContent(content)\n                .split('\\n')\n                .filter((_: string, i: number) => i < digits)\n                .join('\\n')\n                .replace(new RegExp(p.config.lineEnding, 'g'), '')\n        },\n        desc: 'specified count of lines from the found file'\n    },\n    {\n        name: '\\\\$characters:\\\\d+',\n        loop: true,\n        readContent: true,\n        format: (p, s: string, content: string, _file: TFile) => {\n            const digits = Number(s.split(':')[1])\n\n            return trimContent(content)\n                .split('')\n                .filter((_: string, i: number) => i < digits)\n                .join('')\n                .replace(new RegExp(p.config.lineEnding, 'g'), '')\n        },\n        desc: 'specified count of lines from the found file'\n    },\n    {\n        name: '\\\\$frontmatter:[\\\\p\\{L\\}_-]+',\n        loop: true,\n        format: (p, s: string, _content: string, file: TFile) => getFrontMatter(file, p, s),\n        desc: 'value from the frontmatter key in the found file'\n    },\n    {\n        name: '\\\\$lines+',\n        loop: true,\n        readContent: true,\n        format: (p, s: string, content: string, _file: TFile) => content.replace(new RegExp(p.config.lineEnding, 'g'), ''),\n        desc: 'all content from the found file'\n    },\n    {\n        name: '\\\\$ext',\n        loop: true,\n        format: (_p, s: string, content: string, file: TFile) => file.extension,\n        desc: 'return file extension'\n    },\n    {\n        name: '\\\\$created:format:date',\n        loop: true,\n        format: (_p, s: string, content: string, file: TFile) => String(new Date(file.stat.ctime).toISOString()).split('T')[0],\n        desc: 'created time formatted'\n    },\n    {\n        name: '\\\\$created:format:time',\n        loop: true,\n        format: (_p, s: string, content: string, file: TFile) => String(new Date(file.stat.ctime).toISOString()).split(/([.T])/)[2],\n        desc: 'created time formatted'\n    },\n    {\n        name: '\\\\$created:format',\n        loop: true,\n        format: (_p, s: string, content: string, file: TFile) => String(new Date(file.stat.ctime).toISOString()),\n        desc: 'created time formatted'\n    },\n    {\n        name: '\\\\$created',\n        loop: true,\n        format: (_p, s: string, content: string, file: TFile) => String(file.stat.ctime),\n        desc: 'created time'\n    },\n    {\n        name: '\\\\$size',\n        loop: true,\n        format: (_p, s: string, content: string, file: TFile) => String(file.stat.size),\n        desc: 'size of the file'\n    },\n    {\n        name: '\\\\$path',\n        loop: true,\n        format: (_p, s: string, content: string, file: TFile) => file.path,\n        desc: 'path to the found file'\n    },\n    {\n        name: '\\\\$parent',\n        loop: true,\n        format: (_p, s: string, content: string, file: TFile) => file.parent.name,\n        desc: 'parent folder name'\n    },\n    {\n        name: '^(.+|)\\\\$header:.+',\n        loop: true,\n        format: (p, s: string, content: string, file: TFile) => {\n            const prefix = s.slice(0, s.indexOf('$'))\n            const header = s.slice(s.indexOf('$')).replace('$header:', '').replace(/\"/g, '')\n            const neededLevel = header.split(\"#\").length - 1\n            const neededTitle = header.replace(/^#+/g, '').trim()\n\n            const metadata = p.app.metadataCache.getFileCache(file)\n\n            return metadata.headings?.filter(e => {\n                const tests = [\n                    [neededTitle, e.heading.includes(neededTitle)],\n                    [neededLevel, e.level === neededLevel]\n                ].filter(e => e[0])\n\n                if (tests.length) {\n                    return tests.map(e => e[1]).every(e => e === true)\n                }\n\n                return true\n            })\n                .map(h => p.app.fileManager.generateMarkdownLink(file, file.basename, '#' + h.heading))\n                .map(link => prefix + link)\n                .join('\\n') || ''\n\n        },\n        desc: 'headings from founded files. $header:## - return all level 2 headings. $header:Title - return all heading which match the string. Can be prepended like: - !$header:## to transclude the headings.'\n    },\n    {\n        name: '^(.+|)\\\\$blocks',\n        readContent: true,\n        loop: true,\n        format: (p, s: string, content: string, file: TFile) => {\n            const prefix = s.slice(0, s.indexOf('$'))\n\n            return content\n                .split('\\n')\n                .filter(e => /\\^\\w+$/.test(e))\n                .map(e =>\n                    prefix + p.app.fileManager.generateMarkdownLink(file, file.basename, '#' + e.replace(/^.+?(\\^\\w+$)/, '$1'))\n                )\n                .join('\\n')\n        },\n        desc: 'block ids from the found files. Can be prepended.'\n    },\n    {\n        name: '^(.+|)\\\\$match:header', loop: true, format: (p, s: string, content: string, file: TFile, results) => {\n            const prefix = s.slice(0, s.indexOf('$'))\n            const metadata = p.app.metadataCache.getFileCache(file)\n\n            const headings = metadata.headings\n                ?.filter(h => results.result.content.filter(c => h.position.end.offset < c[0]).some(e => e))\n                .slice(-1)\n\n            return headings\n                .map(h => p.app.fileManager.generateMarkdownLink(file, file.basename, '#' + h.heading))\n                .map(link => prefix + link)\n                .join('\\n') || ''\n        }, desc: 'extract found selections'\n    },\n    {\n        name: '^(.+|)\\\\$matchline(:(\\\\+|-|)\\\\d+:\\\\d+|:(\\\\+|-|)\\\\d+|)',\n        loop: true,\n        format: (_p, s: string, content: string, file: TFile, results) => {\n            const prefix = s.slice(0, s.indexOf('$matchline'));\n            const [keyword, context, limit] = s.slice(s.indexOf('$matchline')).split(':')\n            const value = context || '';\n            const limitValue = Number(limit)\n            const isPlus = value.contains('+');\n            const isMinus = value.contains('-');\n            const isContext = !isPlus && !isMinus;\n            const offset = Number(value.replace(/[+-]/, ''));\n\n            const lines = results.content.split('\\n');\n\n            // Grab info about line content, index, text length and start/end character position\n            const lineInfos: Array<LineInfo> = []\n            for (let i = 0; i < lines.length; i++) {\n                const text = lines[i]\n\n                if (i === 0) {\n                    lineInfos.push({\n                        num: 0,\n                        start: 0,\n                        end: text.length,\n                        text\n                    })\n\n                    continue\n                }\n\n                const start = lineInfos[i-1].end + 1\n                lineInfos.push({\n                    num: i,\n                    start,\n                    text,\n                    end: text.length + start\n                })\n            }\n\n            return results.result.content.map(([from, to]) => {\n                const matchedLines = lineInfos\n                    .filter(({ start, end }) => start <= from && end >= to)\n                    .map((line) => {\n                        return {\n                            ...line,\n                            text: highlight(line.start, line.end, from, to, line.text)\n                        }\n                    })\n\n                const resultLines: LineInfo[] = []\n                for (const matchedLine of matchedLines) {\n                    const prevLines = isMinus || isContext\n                                ? lineInfos.filter(l => matchedLine.num - l.num > 0 && matchedLine.num - l.num < offset)\n                                : []\n                    const nextLines = isPlus || isContext\n                                ? lineInfos.filter(l => l.num - matchedLine.num > 0 && l.num - matchedLine.num < offset)\n                                : []\n\n                    resultLines.push( ...prevLines, matchedLine, ...nextLines )\n                }\n\n                return prefix + resultLines.map(e => e.text).join('\\n')\n            }).map(line => limitValue ? line.slice(0, limitValue) : line).join('\\n')\n        }, desc: 'extract line with matches'\n    },\n    {\n        name: '^(.+|)\\\\$searchresult',\n        loop: true,\n        desc: '',\n        format: (_p, s: string, content: string, file: TFile, results) => {\n            const prefix = s.slice(0, s.indexOf('$searchresult'));\n            return results.children.map(matchedFile => {\n                return prefix + matchedFile.el.innerText\n            }).join('\\n')\n        }\n    },\n    {\n        name: '^(.+|)\\\\$match', loop: true, format: (_p, s: string, content: string, file: TFile, results) => {\n\n            if (!results.result.content) {\n                console.warn('There is no content in results')\n                return ''\n            }\n\n            function appendPrefix(prefix: string, line: string) {\n                return prefix + line;\n            }\n\n            const prefixContent = s.slice(0, s.indexOf('$'))\n            return results.result.content\n                .map(([from, to]) => results.content.slice(from, to))\n                .map(line => appendPrefix(prefixContent, line))\n                .join('\\n')\n        }, desc: 'extract found selections'\n    },\n]\n\nexport default sequences","import {TFile} from \"obsidian\";\nimport {SearchDetails} from \"../main\";\n\nexport function extractFilesFromSearchResults(searchResults: Map<TFile, SearchDetails>, currentFileName: string, excludeCurrent: boolean = true) {\n    const files = Array.from(searchResults.keys())\n\n    return excludeCurrent\n        ? files.filter(file => file.basename !== currentFileName)\n        : files;\n}","!function(e,n){\"object\"==typeof exports&&\"undefined\"!=typeof module?n(exports):\"function\"==typeof define&&define.amd?define([\"exports\"],n):n((e=\"undefined\"!=typeof globalThis?globalThis:e||self).Eta={})}(this,(function(e){\"use strict\";function n(e){var t,r,i=new Error(e);return t=i,r=n.prototype,Object.setPrototypeOf?Object.setPrototypeOf(t,r):t.__proto__=r,i}function t(e,t,r){var i=t.slice(0,r).split(/\\n/),a=i.length,o=i[a-1].length+1;throw n(e+=\" at line \"+a+\" col \"+o+\":\\n\\n  \"+t.split(/\\n/)[a-1]+\"\\n  \"+Array(o).join(\" \")+\"^\")}n.prototype=Object.create(Error.prototype,{name:{value:\"Eta Error\",enumerable:!1}});var r=new Function(\"return this\")().Promise;function i(e,n){for(var t in n)r=n,i=t,Object.prototype.hasOwnProperty.call(r,i)&&(e[t]=n[t]);var r,i;return e}function a(e,n,t,r){var i,a;return Array.isArray(n.autoTrim)?(i=n.autoTrim[1],a=n.autoTrim[0]):i=a=n.autoTrim,(t||!1===t)&&(i=t),(r||!1===r)&&(a=r),a||i?\"slurp\"===i&&\"slurp\"===a?e.trim():(\"_\"===i||\"slurp\"===i?e=function(e){return String.prototype.trimLeft?e.trimLeft():e.replace(/^\\s+/,\"\")}(e):\"-\"!==i&&\"nl\"!==i||(e=e.replace(/^(?:\\r\\n|\\n|\\r)/,\"\")),\"_\"===a||\"slurp\"===a?e=function(e){return String.prototype.trimRight?e.trimRight():e.replace(/\\s+$/,\"\")}(e):\"-\"!==a&&\"nl\"!==a||(e=e.replace(/(?:\\r\\n|\\n|\\r)$/,\"\")),e):e}var o={\"&\":\"&amp;\",\"<\":\"&lt;\",\">\":\"&gt;\",'\"':\"&quot;\",\"'\":\"&#39;\"};function c(e){return o[e]}var s=/`(?:\\\\[\\s\\S]|\\${(?:[^{}]|{(?:[^{}]|{[^}]*})*})*}|(?!\\${)[^\\\\`])*`/g,l=/'(?:\\\\[\\s\\w\"'\\\\`]|[^\\n\\r'\\\\])*?'/g,u=/\"(?:\\\\[\\s\\w\"'\\\\`]|[^\\n\\r\"\\\\])*?\"/g;function p(e){return e.replace(/[.*+\\-?^${}()|[\\]\\\\]/g,\"\\\\$&\")}function f(e,n){var r=[],i=!1,o=0,c=n.parse;if(n.plugins)for(var f=0;f<n.plugins.length;f++){(T=n.plugins[f]).processTemplate&&(e=T.processTemplate(e,n))}function d(e,t){e&&(e=a(e,n,i,t))&&(e=e.replace(/\\\\|'/g,\"\\\\$&\").replace(/\\r\\n|\\n|\\r/g,\"\\\\n\"),r.push(e))}n.rmWhitespace&&(e=e.replace(/[\\r\\n]+/g,\"\\n\").replace(/^\\s+|\\s+$/gm,\"\")),s.lastIndex=0,l.lastIndex=0,u.lastIndex=0;for(var g,h=[c.exec,c.interpolate,c.raw].reduce((function(e,n){return e&&n?e+\"|\"+p(n):n?p(n):e}),\"\"),m=new RegExp(\"([^]*?)\"+p(n.tags[0])+\"(-|_)?\\\\s*(\"+h+\")?\\\\s*\",\"g\"),v=new RegExp(\"'|\\\"|`|\\\\/\\\\*|(\\\\s*(-|_)?\"+p(n.tags[1])+\")\",\"g\");g=m.exec(e);){o=g[0].length+g.index;var y=g[1],x=g[2],_=g[3]||\"\";d(y,x),v.lastIndex=o;for(var w=void 0,b=!1;w=v.exec(e);){if(w[1]){var E=e.slice(o,w.index);m.lastIndex=o=v.lastIndex,i=w[2],b={t:_===c.exec?\"e\":_===c.raw?\"r\":_===c.interpolate?\"i\":\"\",val:E};break}var I=w[0];if(\"/*\"===I){var R=e.indexOf(\"*/\",v.lastIndex);-1===R&&t(\"unclosed comment\",e,w.index),v.lastIndex=R}else if(\"'\"===I){l.lastIndex=w.index,l.exec(e)?v.lastIndex=l.lastIndex:t(\"unclosed string\",e,w.index)}else if('\"'===I){u.lastIndex=w.index,u.exec(e)?v.lastIndex=u.lastIndex:t(\"unclosed string\",e,w.index)}else if(\"`\"===I){s.lastIndex=w.index,s.exec(e)?v.lastIndex=s.lastIndex:t(\"unclosed string\",e,w.index)}}b?r.push(b):t(\"unclosed tag\",e,g.index+y.length)}if(d(e.slice(o,e.length),!1),n.plugins)for(f=0;f<n.plugins.length;f++){var T;(T=n.plugins[f]).processAST&&(r=T.processAST(r,n))}return r}function d(e,n){var t=f(e,n),r=\"var tR='',__l,__lP\"+(n.include?\",include=E.include.bind(E)\":\"\")+(n.includeFile?\",includeFile=E.includeFile.bind(E)\":\"\")+\"\\nfunction layout(p,d){__l=p;__lP=d}\\n\"+(n.useWith?\"with(\"+n.varName+\"||{}){\":\"\")+function(e,n){var t=0,r=e.length,i=\"\";for(;t<r;t++){var a=e[t];if(\"string\"==typeof a){i+=\"tR+='\"+a+\"'\\n\"}else{var o=a.t,c=a.val||\"\";\"r\"===o?(n.filter&&(c=\"E.filter(\"+c+\")\"),i+=\"tR+=\"+c+\"\\n\"):\"i\"===o?(n.filter&&(c=\"E.filter(\"+c+\")\"),n.autoEscape&&(c=\"E.e(\"+c+\")\"),i+=\"tR+=\"+c+\"\\n\"):\"e\"===o&&(i+=c+\"\\n\")}}return i}(t,n)+(n.includeFile?\"if(__l)tR=\"+(n.async?\"await \":\"\")+\"includeFile(__l,Object.assign(\"+n.varName+\",{body:tR},__lP))\\n\":n.include?\"if(__l)tR=\"+(n.async?\"await \":\"\")+\"include(__l,Object.assign(\"+n.varName+\",{body:tR},__lP))\\n\":\"\")+\"if(cb){cb(null,tR)} return tR\"+(n.useWith?\"}\":\"\");if(n.plugins)for(var i=0;i<n.plugins.length;i++){var a=n.plugins[i];a.processFnString&&(r=a.processFnString(r,n))}return r}var g=new(function(){function e(e){this.cache=e}return e.prototype.define=function(e,n){this.cache[e]=n},e.prototype.get=function(e){return this.cache[e]},e.prototype.remove=function(e){delete this.cache[e]},e.prototype.reset=function(){this.cache={}},e.prototype.load=function(e){i(this.cache,e)},e}())({});var h={async:!1,autoEscape:!0,autoTrim:[!1,\"nl\"],cache:!1,e:function(e){var n=String(e);return/[&<>\"']/.test(n)?n.replace(/[&<>\"']/g,c):n},include:function(e,t){var r=this.templates.get(e);if(!r)throw n('Could not fetch template \"'+e+'\"');return r(t,this)},parse:{exec:\"\",interpolate:\"=\",raw:\"~\"},plugins:[],rmWhitespace:!1,tags:[\"<%\",\"%>\"],templates:g,useWith:!1,varName:\"it\"};function m(e,n){var t={};return i(t,h),n&&i(t,n),e&&i(t,e),t}function v(e,t){var r=m(t||{}),i=r.async?function(){try{return new Function(\"return (async function(){}).constructor\")()}catch(e){throw e instanceof SyntaxError?n(\"This environment doesn't support async/await\"):e}}():Function;try{return new i(r.varName,\"E\",\"cb\",d(e,r))}catch(t){throw t instanceof SyntaxError?n(\"Bad template syntax\\n\\n\"+t.message+\"\\n\"+Array(t.message.length+1).join(\"=\")+\"\\n\"+d(e,r)+\"\\n\"):t}}function y(e,n){if(n.cache&&n.name&&n.templates.get(n.name))return n.templates.get(n.name);var t=\"function\"==typeof e?e:v(e,n);return n.cache&&n.name&&n.templates.define(n.name,t),t}function x(e,t,i,a){var o=m(i||{});if(!o.async)return y(e,o)(t,o);if(!a){if(\"function\"==typeof r)return new r((function(n,r){try{n(y(e,o)(t,o))}catch(e){r(e)}}));throw n(\"Please provide a callback function, this env doesn't support Promises\")}try{y(e,o)(t,o,a)}catch(e){return a(e)}}e.compile=v,e.compileToString=d,e.config=h,e.configure=function(e){return i(h,e)},e.defaultConfig=h,e.getConfig=m,e.parse=f,e.render=x,e.renderAsync=function(e,n,t,r){return x(e,n,Object.assign({},t,{async:!0}),r)},e.templates=g,Object.defineProperty(e,\"__esModule\",{value:!0})}));\n//# sourceMappingURL=eta.min.js.map\n","import {\n    ExpanderQuery,\n    getAllExpandersQuery,\n    getClosestQuery,\n    getLastLineToReplace\n} from 'src/helpers/helpers';\nimport {\n    App, Editor,\n    FileView,\n    MarkdownView,\n    Plugin,\n    PluginManifest,\n    PluginSettingTab,\n    Setting,\n    TFile, View, WorkspaceLeaf\n} from 'obsidian';\nimport sequences, {Sequences} from \"./sequences/sequences\";\nimport {splitByLines} from \"./helpers/string\";\nimport {extractFilesFromSearchResults} from \"./helpers/search-results\";\nimport {render} from \"eta\";\nimport {getFileInfo} from \"./helpers/tfile\";\n\ninterface PluginSettings {\n    delay: number\n    lineEnding: string\n    defaultTemplate: string\n    excludeCurrent: boolean\n    autoExpand: boolean\n    prefixes: {\n        header: string\n        footer: string\n    }\n}\n\ninterface SearchLeaf extends WorkspaceLeaf {\n    view: View & {\n        searchComponent: {\n            getValue: () => string\n            setValue: (s: string) => void\n        }\n    }\n}\n\nexport interface FileParameters {\n    basename: string\n    content: string\n    extension: string\n    headings: Array<any>\n    link: string\n    name: string\n    path: string\n    sections: Array<any>\n    stat: {}\n    frontmatter: { [k: string]: any }\n    links: Array<any>\n    listItems: Array<any>\n}\n\ntype NumberTuple = [number, number]\n\nexport interface SearchDetails {\n    app: App\n    children: any[]\n    childrenEl: HTMLElement\n    collapseEl: HTMLElement\n    collapsed: boolean\n    collapsible: boolean\n    containerEl: HTMLElement\n    content: string\n    dom: any\n    el: HTMLElement\n    extraContext: () => boolean\n    file: TFile\n    info: any\n    onMatchRender: any\n    pusherEl: HTMLElement\n    result: {\n        filename?: NumberTuple[]\n        content?: NumberTuple[]\n    }\n}\n\nexport default class TextExpander extends Plugin {\n    cm: Editor\n\n    config: PluginSettings = {\n        autoExpand: false,\n        defaultTemplate: '- $link',\n        delay: 300,\n        excludeCurrent: true,\n        lineEnding: '<-->',\n        prefixes: {\n            header: '^',\n            footer: '>'\n        }\n    }\n\n    seqs: Sequences[] = sequences\n\n    leftPanelInfo: {\n        collapsed: boolean\n        tab: number\n        text: string\n    } = {\n        collapsed: false,\n        tab: 0,\n        text: ''\n    }\n\n    constructor(app: App, plugin: PluginManifest) {\n        super(app, plugin);\n\n        this.search = this.search.bind(this);\n        this.init = this.init.bind(this);\n        this.autoExpand = this.autoExpand.bind(this);\n    }\n\n    async autoExpand() {\n        if (!this.config.autoExpand) {\n            return\n        }\n\n        const activeLeaf = this.app.workspace.activeLeaf\n        if (!activeLeaf) {\n            return\n        }\n\n        const activeView = activeLeaf.view\n        const isAllowedView = activeView instanceof MarkdownView\n        if (!isAllowedView) {\n            return\n        }\n\n        await this.init(true)\n    }\n\n    async onload() {\n        this.addSettingTab(new SettingTab(this.app, this));\n\n        this.registerMarkdownCodeBlockProcessor('expander', (source, el, ctx) => {\n            el\n                .createDiv()\n                .createEl('button', {text: 'Run expand query'})\n                .addEventListener('click', this.init.bind(this, false, ctx.getSectionInfo(el).lineStart))\n        });\n\n        this.addCommand({\n            id: 'editor-expand',\n            name: 'expand',\n            callback: this.init,\n            hotkeys: []\n        });\n\n        this.addCommand({\n            id: 'editor-expand-all',\n            name: 'expand all',\n            callback: () => this.init(true),\n            hotkeys: []\n        });\n\n        this.app.workspace.on('file-open', this.autoExpand);\n\n        const data = await this.loadData() as PluginSettings\n        if (data) {\n            this.config = {\n                ...this.config,\n                ...data\n            }\n        }\n    }\n\n    onunload() {\n        console.log('unloading plugin');\n        this.app.workspace.off('file-open', this.autoExpand);\n    }\n\n    async saveSettings() {\n        await this.saveData(this.config)\n    }\n\n    private async init(proceedAllQueriesOnPage = false, lineToStart?: number) {\n        const currentView = this.app.workspace.activeLeaf.view\n\n        // Is on editable view\n        if (!(currentView instanceof MarkdownView)) {\n            return\n        }\n\n        const cmDoc: Editor = this.cm = currentView.editor\n\n        const curNum = lineToStart || cmDoc.getCursor().line\n        const content = cmDoc.getValue()\n\n        if (lineToStart) {\n            cmDoc.setCursor(lineToStart ? lineToStart - 1 : 0)\n        }\n\n        const formatted = splitByLines(content)\n        const findQueries = getAllExpandersQuery(formatted)\n        const closestQuery = getClosestQuery(findQueries, curNum)\n\n        if (proceedAllQueriesOnPage) {\n            await findQueries.reduce((promise, query, i) =>\n                promise.then(() => {\n                    const newContent = splitByLines(cmDoc.getValue())\n                    const updatedQueries = getAllExpandersQuery(newContent)\n\n                    return this.runExpanderCodeBlock(updatedQueries[i], newContent, currentView)\n                }), Promise.resolve()\n            )\n        } else {\n            await this.runExpanderCodeBlock(closestQuery, formatted, currentView)\n        }\n    }\n\n    private async runExpanderCodeBlock(query: ExpanderQuery, content: string[], view: MarkdownView) {\n        const {lineEnding, prefixes} = this.config\n\n        if (!query) {\n            new Notification('Expand query not found')\n            return Promise.resolve()\n        }\n\n        this.clearOldResultsInFile(content, query, lineEnding);\n\n        const newContent = splitByLines(this.cm.getValue());\n\n        if (query.query !== '') {\n            this.search(query.query)\n        }\n        return await this.runTemplateProcessing(query, getLastLineToReplace(newContent, query, this.config.lineEnding), prefixes, view)\n    }\n\n    private async runTemplateProcessing(query: ExpanderQuery, lastLine: number, prefixes: PluginSettings[\"prefixes\"], currentView: MarkdownView) {\n        let currentFileName = ''\n\n        const templateContent = query.template.split('\\n')\n\n        const {heading, footer, repeatableContent} = this.parseTemplate(prefixes, templateContent);\n\n        if (currentView instanceof FileView) {\n            currentFileName = currentView.file.basename\n        }\n\n        this.saveLeftPanelState();\n\n        const searchResults = await this.getFoundAfterDelay(query.query === '');\n        const files = extractFilesFromSearchResults(searchResults, currentFileName, this.config.excludeCurrent);\n\n        this.restoreLeftPanelState();\n\n        currentView.editor.focus();\n\n        const currentFileInfo: {} = (currentView instanceof FileView)\n            ? await getFileInfo(this, currentView.file)\n            : {}\n        const filesInfo = await Promise.all(\n            files.map(file => getFileInfo(this, file))\n        )\n\n        let changed;\n\n        if (query.template.contains(\"<%\")) {\n            const templateToRender = repeatableContent.join('\\n')\n            const dataToRender = {\n                current: currentFileInfo,\n                files: filesInfo\n            }\n\n            changed = await render(templateToRender, dataToRender, {autoEscape: false})\n            // changed = doT.template(templateToRender, {strip: false})(dataToRender)\n        } else {\n            changed = await this.generateTemplateFromSequences(files, repeatableContent, searchResults);\n        }\n\n        let result = [\n            heading,\n            changed,\n            footer,\n            this.config.lineEnding\n        ].filter(e => e).join('\\n')\n\n        // Do not paste generated content if used changed activeLeaf\n        const viewBeforeReplace = this.app.workspace.activeLeaf.view\n        if (!(viewBeforeReplace instanceof MarkdownView) || viewBeforeReplace.file.basename !== currentFileName) {\n            return\n        }\n\n        currentView.editor.replaceRange(result,\n            {line: query.end + 1, ch: 0},\n            {line: lastLine, ch: this.cm.getLine(lastLine)?.length || 0})\n\n        return Promise.resolve()\n    }\n\n    private async generateTemplateFromSequences(files: TFile[], repeatableContent: string[], searchResults?: Map<TFile, SearchDetails>): Promise<string> {\n        if (!searchResults) {\n            return ''\n        }\n\n        const changed = await Promise.all(\n            files\n                .map(async (file, i) => {\n                    const result = await Promise.all(repeatableContent.map(async (s) => await this.applyTemplateToSearchResults(searchResults, file, s, i)))\n                    return result.join('\\n')\n                })\n        )\n\n        return changed.join('\\n');\n    }\n\n    private parseTemplate(prefixes: { header: string; footer: string }, templateContent: string[]) {\n        const isHeader = (line: string) => line.startsWith(prefixes.header)\n        const isFooter = (line: string) => line.startsWith(prefixes.footer)\n        const isRepeat = (line: string) => !isHeader(line) && !isFooter(line)\n\n        const heading = templateContent.filter(isHeader).map((s) => s.slice(1)).join('\\n')\n        const footer = templateContent.filter(isFooter).map((s) => s.slice(1)).join('\\n')\n        const repeatableContent =\n            templateContent.filter(isRepeat).filter(e => e).length === 0\n                ? [this.config.defaultTemplate]\n                : templateContent.filter(isRepeat).filter(e => e)\n        return {heading, footer, repeatableContent};\n    }\n\n    private saveLeftPanelState(): void {\n        this.leftPanelInfo = {\n            collapsed: this.app.workspace.leftSplit.collapsed,\n            tab: this.getSearchTabIndex(),\n            text: this.getSearchValue(),\n        }\n    }\n\n    private restoreLeftPanelState() {\n        const {collapsed, tab, text} = this.leftPanelInfo;\n        const splitChildren = this.getLeftSplitElement()\n\n        this.getSearchView().searchComponent.setValue(text)\n\n        if (tab !== splitChildren.currentTab) {\n            splitChildren.selectTabIndex(tab)\n        }\n\n        if (collapsed) {\n            this.app.workspace.leftSplit.collapse()\n        }\n    }\n\n    private search(s: string) {\n        // @ts-ignore\n        const globalSearchFn = this.app.internalPlugins.getPluginById('global-search').instance.openGlobalSearch.bind(this)\n        const search = (query: string) => globalSearchFn(query)\n\n        search(s)\n    }\n\n    private getLeftSplitElement(): {\n        currentTab: number\n        selectTabIndex: (n: number) => void\n        children: Array<WorkspaceLeaf | SearchLeaf>\n    } {\n        // @ts-ignore\n        return this.app.workspace.leftSplit.children[0];\n    }\n\n    private getSearchView(): SearchLeaf['view'] {\n        const view = this.getLeftSplitElement().children.filter(e => e.getViewState().type === 'search')[0].view\n\n        if ('searchComponent' in view) {\n            return view;\n        }\n\n        return undefined;\n    }\n\n    private getSearchValue(): string {\n        const view = this.getSearchView();\n\n        if (view) {\n            return view.searchComponent.getValue()\n        }\n\n        return ''\n    }\n\n    private getSearchTabIndex(): number {\n        const leftTabs = this.getLeftSplitElement().children;\n        let searchTabId: string;\n\n        this.app.workspace.iterateAllLeaves((leaf: WorkspaceLeaf & { id: string }) => {\n            if (leaf.getViewState().type == \"search\") {\n                searchTabId = leaf.id;\n            }\n        });\n        return leftTabs.findIndex((item: any, _index: number, _array: any[]) => {\n            if (item.id == searchTabId) {\n                return true;\n            }\n        });\n    };\n\n    private async getFoundAfterDelay(immediate: boolean): Promise<Map<TFile, SearchDetails>> {\n        const searchLeaf = this.app.workspace.getLeavesOfType('search')[0]\n        const view = await searchLeaf.open(searchLeaf.view)\n\n        if (immediate) {\n            // @ts-ignore\n            return Promise.resolve(view.dom.resultDomLookup as Map<TFile, SearchDetails>);\n        }\n\n        return new Promise(resolve => {\n            setTimeout(() => {\n                // @ts-ignore\n                return resolve(view.dom.resultDomLookup as Map<TFile, SearchDetails>)\n            }, this.config.delay)\n        })\n    }\n\n    private async applyTemplateToSearchResults(searchResults: Map<TFile, SearchDetails>, file: TFile, template: string, index: number) {\n        const fileContent = (new RegExp(this.seqs.filter(e => e.readContent).map(e => e.name).join('|')).test(template))\n            ? await this.app.vault.cachedRead(file)\n            : ''\n\n        return this.seqs.reduce((acc, seq) =>\n            acc.replace(new RegExp(seq.name, 'gu'), replace => seq.format(this, replace, fileContent, file, searchResults.get(file), index)), template)\n    }\n\n    private clearOldResultsInFile(content: string[], query: ExpanderQuery, lineEnding: string) {\n        const lastLine = getLastLineToReplace(content, query, this.config.lineEnding)\n        this.cm.replaceRange('\\n' + lineEnding,\n            {line: query.end + 1, ch: 0},\n            {line: lastLine, ch: this.cm.getLine(lastLine)?.length || 0})\n    }\n}\n\nclass SettingTab extends PluginSettingTab {\n    plugin: TextExpander\n\n    constructor(app: App, plugin: TextExpander) {\n        super(app, plugin);\n\n        this.app = app\n        this.plugin = plugin\n    }\n\n    display(): void {\n        let {containerEl} = this;\n\n        containerEl.empty();\n\n        containerEl.createEl('h2', {text: 'Settings for Text Expander'});\n\n        new Setting(containerEl)\n            .setName('Auto Expand')\n            .setDesc('Expand all queries in a file once you open it')\n            .addToggle(toggle => {\n                toggle\n                    .setValue(this.plugin.config.autoExpand)\n                    .onChange(value => {\n                        this.plugin.config.autoExpand = value\n                        this.plugin.saveSettings()\n                    })\n            })\n\n        new Setting(containerEl)\n            .setName('Delay')\n            .setDesc('Text expander don\\' wait until search completed. It waits for a delay and paste result after that.')\n            .addSlider(slider => {\n                slider.setLimits(100, 10000, 100)\n                slider.setValue(this.plugin.config.delay)\n                slider.onChange(value => {\n                    this.plugin.config.delay = value\n                    this.plugin.saveSettings()\n                })\n                slider.setDynamicTooltip()\n            })\n\n        new Setting(containerEl)\n            .setName('Line ending')\n            .setDesc('You can specify the text which will appear at the bottom of the generated text.')\n            .addText(text => {\n                text.setValue(this.plugin.config.lineEnding)\n                    .onChange(val => {\n                        this.plugin.config.lineEnding = val\n                        this.plugin.saveSettings()\n                    })\n            })\n\n        new Setting(containerEl)\n            .setName('Default template')\n            .setDesc('You can specify default template')\n            .addTextArea(text => {\n                text.setValue(this.plugin.config.defaultTemplate)\n                    .onChange(val => {\n                        this.plugin.config.defaultTemplate = val\n                        this.plugin.saveSettings()\n                    })\n            })\n\n        new Setting(containerEl)\n            .setName('Exclude current file')\n            .setDesc('You can specify should text expander exclude results from current file or not')\n            .addToggle(toggle => {\n                toggle\n                    .setValue(this.plugin.config.excludeCurrent)\n                    .onChange(value => {\n                        this.plugin.config.excludeCurrent = value\n                        this.plugin.saveSettings()\n                    })\n            })\n\n        new Setting(containerEl)\n            .setHeading()\n            .setName('Prefixes')\n\n        new Setting(containerEl)\n            .setName('Header')\n            .setDesc('Line prefixed by this symbol will be recognized as header')\n            .addText(text => {\n                text.setValue(this.plugin.config.prefixes.header)\n                    .onChange(val => {\n                        this.plugin.config.prefixes.header = val\n                        this.plugin.saveSettings()\n                    })\n            })\n\n        new Setting(containerEl)\n            .setName('Footer')\n            .setDesc('Line prefixed by this symbol will be recognized as footer')\n            .addText(text => {\n                text.setValue(this.plugin.config.prefixes.footer)\n                    .onChange(val => {\n                        this.plugin.config.prefixes.footer = val\n                        this.plugin.saveSettings()\n                    })\n            })\n\n        new Setting(containerEl)\n            .setName('Sequences')\n            .setDesc('REGEXP - DESCRIPTION')\n            .setDesc(\n                (() => {\n                    const fragment = new DocumentFragment()\n                    const div = fragment.createEl('div')\n                    this.plugin.seqs\n                        .map(e => e.name + ' - ' + (e.desc || ''))\n                        .map(e => {\n                            const el = fragment.createEl('div')\n                            el.setText(e)\n                            el.setAttribute('style', `\n                                border-bottom: 1px solid rgba(255, 255, 255, 0.1);\n                                margin-bottom: 0.5rem;\n                                padding-bottom: 0.5rem;\n                            `)\n                            return el\n                        }).forEach(el => {\n                        div.appendChild(el)\n                    })\n                    fragment.appendChild(div)\n\n                    return fragment\n                })()\n            )\n    }\n}\n"],"names":["this","Plugin","MarkdownView","FileView","render","PluginSettingTab","Setting"],"mappings":"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"}
|