mirror of
https://github.com/heyman/heynote.git
synced 2024-12-27 17:18:53 +01:00
d0d8f872a6
* Add functionality to insert new block after the last block - Update key bindings in `initial-content.ts` to include `Alt + Enter` for adding a new block after the last block. - Implement `getLastNoteBlock` function in `block.js` to retrieve the last block in the note. - Add `addNewBlockAfterLast` command in `commands.js` to handle the insertion of a new block after the last one. - Integrate `addNewBlockAfterLast` command into the keymap in `keymap.js`. * Add block insertion before/after current, before first and after last. Also, tests. - Added `getFirstNoteBlock` in `block.js` for accessing the first text block. - Implemented new functions in `commands.js` like `addNewBlockBeforeCurrent` and `addNewBlockBeforeFirst`. - Updated `keymap.js` with new key bindings to facilitate block creation. - Introduced `block-creation.spec.js` for testing the new block manipulation features. * Fix visual bug when inserting new block at the top * Update help text and Readme * Fix wrong cursor position after inserting new blocks at the top of the buffer, when the previous first block's delimiter is long (e.g. Markdown) * Make RegEx more generic * Fix import * Auto-generate the README.md and initial-content documentation - Add a documentation generator - Add an option to force the initial content to be erased with an env variable * Add more specific tests * Fix Mod key on Mac in test --------- Co-authored-by: Jonatan Heyman <jonatan@heyman.info>
140 lines
3.5 KiB
TypeScript
140 lines
3.5 KiB
TypeScript
import { rmSync } from 'node:fs'
|
|
import { join } from 'node:path'
|
|
import { defineConfig } from 'vite'
|
|
import vue from '@vitejs/plugin-vue'
|
|
import electron from 'vite-plugin-electron'
|
|
import renderer from 'vite-plugin-electron-renderer'
|
|
import license from 'rollup-plugin-license'
|
|
import pkg from './package.json'
|
|
import path from 'path'
|
|
|
|
import { keyHelpStr } from "./shared-utils/key-helper";
|
|
|
|
rmSync('dist-electron', { recursive: true, force: true })
|
|
|
|
const isDevelopment = process.env.NODE_ENV === "development" || !!process.env.VSCODE_DEBUG
|
|
const isProduction = process.env.NODE_ENV === "production"
|
|
|
|
const updateReadmeKeybinds = async () => {
|
|
const fs = require('fs')
|
|
const path = require('path')
|
|
const readmePath = path.resolve(__dirname, 'README.md')
|
|
let readme = fs.readFileSync(readmePath, 'utf-8')
|
|
const keybindsRegex = /^(### What are the default keyboard shortcuts\?\s*).*?^(```\s+#)/gms
|
|
const shortcuts = `$1**On Mac**
|
|
|
|
\`\`\`
|
|
${keyHelpStr('darwin')}
|
|
\`\`\`
|
|
|
|
**On Windows and Linux**
|
|
|
|
\`\`\`
|
|
${keyHelpStr('win32')}
|
|
$2`
|
|
|
|
readme = readme.replace(keybindsRegex, shortcuts)
|
|
fs.writeFileSync(readmePath, readme)
|
|
}
|
|
|
|
// https://vitejs.dev/config/
|
|
export default defineConfig({
|
|
resolve: {
|
|
alias: {
|
|
'@': path.resolve(__dirname),
|
|
},
|
|
},
|
|
|
|
plugins: [
|
|
vue(),
|
|
updateReadmeKeybinds(),
|
|
electron([
|
|
{
|
|
// Main-Process entry file of the Electron App.
|
|
entry: 'electron/main/index.ts',
|
|
onstart(options) {
|
|
if (process.env.VSCODE_DEBUG) {
|
|
console.log(/* For `.vscode/.debug.script.mjs` */'[startup] Electron App')
|
|
} else {
|
|
options.startup()
|
|
}
|
|
},
|
|
vite: {
|
|
build: {
|
|
sourcemap: isDevelopment,
|
|
minify: isProduction,
|
|
outDir: 'dist-electron/main',
|
|
rollupOptions: {
|
|
external: Object.keys("dependencies" in pkg ? pkg.dependencies : {}),
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
entry: 'electron/preload/index.ts',
|
|
onstart(options) {
|
|
// Notify the Renderer-Process to reload the page when the Preload-Scripts build is complete,
|
|
// instead of restarting the entire Electron App.
|
|
options.reload()
|
|
},
|
|
vite: {
|
|
build: {
|
|
sourcemap: isDevelopment,
|
|
minify: isProduction,
|
|
outDir: 'dist-electron/preload',
|
|
rollupOptions: {
|
|
external: Object.keys("dependencies" in pkg ? pkg.dependencies : {}),
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
entry: 'electron/preload/about-preload.js',
|
|
onstart(options) {
|
|
// Notify the Renderer-Process to reload the page when the Preload-Scripts build is complete,
|
|
// instead of restarting the entire Electron App.
|
|
options.reload()
|
|
},
|
|
vite: {
|
|
build: {
|
|
sourcemap: isDevelopment,
|
|
minify: isProduction,
|
|
outDir: 'dist-electron/preload',
|
|
rollupOptions: {
|
|
external: Object.keys("dependencies" in pkg ? pkg.dependencies : {}),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
]),
|
|
// Use Node.js API in the Renderer-process
|
|
renderer({
|
|
nodeIntegration: false, // turning this on will break Math.js
|
|
}),
|
|
|
|
// Add license header to the built files
|
|
license({thirdParty: {
|
|
output: join(__dirname, 'dist', 'dependencies.txt'),
|
|
includePrivate: true, // Default is false.
|
|
},
|
|
})
|
|
],
|
|
css: {
|
|
preprocessorOptions: {
|
|
sass: {
|
|
additionalData: `
|
|
@import "./src/css/include.sass"
|
|
`
|
|
}
|
|
}
|
|
},
|
|
server: !!process.env.VSCODE_DEBUG ? (() => {
|
|
const url = new URL(pkg.debug.env.VITE_DEV_SERVER_URL)
|
|
return {
|
|
host: url.hostname,
|
|
port: +url.port,
|
|
}
|
|
})() : undefined,
|
|
clearScreen: false,
|
|
})
|