yarle-evernote-to-md
Version:
Yet Another Rope Ladder from Evernote
64 lines • 2.95 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.updateFileContentSafely = exports.writeFile = void 0;
const fs = __importStar(require("fs"));
const content_utils_1 = require("./content-utils");
const logger_1 = require("./../utils/logger");
const yarle_1 = require("./../yarle");
const is_logseq_journal_1 = require("./is-logseq-journal");
const content_utils_2 = require("./content-utils");
const writeFile = (absFilePath, noteContent, pureNoteData) => {
try {
if ((0, is_logseq_journal_1.isLogseqJournal)(yarle_1.yarleOptions) && fs.existsSync(absFilePath)) {
// put the title as a first line
const compoundJournalNoteTitle = `# Journal Note for ${(0, content_utils_2.getCreationTime)(pureNoteData)}`;
const currentContent = fs.readFileSync(absFilePath, 'UTF-8');
if (!currentContent.startsWith(compoundJournalNoteTitle)) {
const updatedContent = `${compoundJournalNoteTitle}\n\n${currentContent}`;
fs.writeFileSync(absFilePath, updatedContent);
}
fs.appendFileSync(absFilePath, noteContent);
}
else {
fs.writeFileSync(absFilePath, noteContent);
(0, content_utils_1.setFileDates)(absFilePath, pureNoteData.created, pureNoteData.updated);
}
}
catch (e) {
// tslint:disable-next-line: no-console
logger_1.logger.error('Cannot write file ', e);
throw e;
}
};
exports.writeFile = writeFile;
const updateFileContentSafely = (filePath, updatedContent) => {
const { birthtime, mtime } = fs.statSync(filePath);
console.log(`replaced output written to: ${filePath}`);
fs.writeFileSync(filePath, updatedContent);
(0, content_utils_1.setFileDates)(filePath, birthtime, mtime);
};
exports.updateFileContentSafely = updateFileContentSafely;
//# sourceMappingURL=file-utils.js.map