web build
This commit is contained in:
5
.github/workflows/build.yml
vendored
5
.github/workflows/build.yml
vendored
@@ -4,9 +4,8 @@ on:
|
|||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- main
|
- main
|
||||||
# pull_request:
|
tags:
|
||||||
# release:
|
- 'v*'
|
||||||
# types: [created]
|
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
|
|||||||
@@ -1,48 +1,16 @@
|
|||||||
import { resolve } from 'path'
|
import { resolve } from 'path'
|
||||||
import { defineConfig } from 'electron-vite'
|
import { defineConfig } from 'electron-vite'
|
||||||
import vue from '@vitejs/plugin-vue'
|
import { sharedConfig } from './vite.shared'
|
||||||
import { toSass } from './src/renderer/src/libs/sass-utils'
|
|
||||||
import theme from './src/renderer/src/libs/theme'
|
|
||||||
|
|
||||||
export default defineConfig({
|
export default defineConfig({
|
||||||
main: {},
|
main: {},
|
||||||
preload: {},
|
preload: {},
|
||||||
renderer: {
|
renderer: {
|
||||||
plugins: [vue()],
|
...sharedConfig,
|
||||||
resolve: {
|
resolve: {
|
||||||
alias: {
|
alias: {
|
||||||
'@': resolve('src/renderer/src'),
|
'@': resolve('src/renderer/src'),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
css: {
|
|
||||||
preprocessorOptions: {
|
|
||||||
scss: {
|
|
||||||
api: 'modern-compiler',
|
|
||||||
additionalData:
|
|
||||||
'@use "/src/styles/_functions.scss" as *; @use "/src/styles/_font-style.scss" as *;',
|
|
||||||
functions: {
|
|
||||||
'get($keys)': function (keys) {
|
|
||||||
keys = keys
|
|
||||||
.toString()
|
|
||||||
.replace(/['"]+/g, '')
|
|
||||||
.split('.')
|
|
||||||
|
|
||||||
let result = theme
|
|
||||||
for (let i = 0; i < keys.length; i++) {
|
|
||||||
result = result[keys[i]]
|
|
||||||
}
|
|
||||||
|
|
||||||
return toSass(result)
|
|
||||||
},
|
|
||||||
'getColors()': function () {
|
|
||||||
return toSass(theme.colors)
|
|
||||||
},
|
|
||||||
'getThemes()': function () {
|
|
||||||
return toSass(theme.themes)
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|||||||
102
package.json
102
package.json
@@ -1,52 +1,54 @@
|
|||||||
{
|
{
|
||||||
"name": "app.takerofnotes.com",
|
"name": "app.takerofnotes.com",
|
||||||
"version": "1.0.0",
|
"version": "1.0.0",
|
||||||
"description": "An Electron application with Vue",
|
"description": "An Electron application with Vue",
|
||||||
"main": "./out/main/index.js",
|
"main": "./out/main/index.js",
|
||||||
"author": "example.com",
|
"author": "example.com",
|
||||||
"homepage": "https://electron-vite.org",
|
"homepage": "https://electron-vite.org",
|
||||||
"prettier": {
|
"prettier": {
|
||||||
"tabWidth": 4,
|
"tabWidth": 4,
|
||||||
"semi": false,
|
"semi": false,
|
||||||
"singleQuote": true
|
"singleQuote": true
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"format": "prettier --write .",
|
"format": "prettier --write .",
|
||||||
"start": "electron-vite preview",
|
"start": "electron-vite preview",
|
||||||
"dev": "electron-vite dev",
|
"dev": "electron-vite dev",
|
||||||
"build": "electron-vite build",
|
"dev:web": "vite",
|
||||||
"postinstall": "electron-builder install-app-deps",
|
"build": "electron-vite build",
|
||||||
"build:unpack": "npm run build && electron-builder --dir",
|
"build:web": "vite build",
|
||||||
"build:win": "npm run build && electron-builder --win",
|
"postinstall": "electron-builder install-app-deps",
|
||||||
"build:mac": "npm run build && electron-builder --mac",
|
"build:unpack": "npm run build && electron-builder --dir",
|
||||||
"build:linux": "npm run build && electron-builder --linux"
|
"build:win": "npm run build && electron-builder --win",
|
||||||
},
|
"build:mac": "npm run build && electron-builder --mac",
|
||||||
"dependencies": {
|
"build:linux": "npm run build && electron-builder --linux"
|
||||||
"@electron-toolkit/preload": "^3.0.2",
|
},
|
||||||
"@electron-toolkit/utils": "^4.0.0",
|
"dependencies": {
|
||||||
"@fuzzco/font-loader": "^1.0.2",
|
"@electron-toolkit/preload": "^3.0.2",
|
||||||
"@tiptap/extension-document": "^3.19.0",
|
"@electron-toolkit/utils": "^4.0.0",
|
||||||
"@tiptap/extension-image": "^3.19.0",
|
"@fuzzco/font-loader": "^1.0.2",
|
||||||
"@tiptap/extension-table": "^3.19.0",
|
"@tiptap/extension-document": "^3.19.0",
|
||||||
"@tiptap/markdown": "^3.19.0",
|
"@tiptap/extension-image": "^3.19.0",
|
||||||
"@tiptap/starter-kit": "^3.19.0",
|
"@tiptap/extension-table": "^3.19.0",
|
||||||
"@tiptap/vue-3": "^3.19.0",
|
"@tiptap/markdown": "^3.19.0",
|
||||||
"@vueuse/core": "^14.2.1",
|
"@tiptap/starter-kit": "^3.19.0",
|
||||||
"electron-updater": "^6.3.9",
|
"@tiptap/vue-3": "^3.19.0",
|
||||||
"gsap": "^3.14.2",
|
"@vueuse/core": "^14.2.1",
|
||||||
"lenis": "^1.3.17",
|
"electron-updater": "^6.3.9",
|
||||||
"sass": "^1.97.3",
|
"gsap": "^3.14.2",
|
||||||
"sass-embedded": "^1.97.3",
|
"lenis": "^1.3.17",
|
||||||
"tempus": "^1.0.0-dev.17"
|
"sass": "^1.97.3",
|
||||||
},
|
"sass-embedded": "^1.97.3",
|
||||||
"devDependencies": {
|
"tempus": "^1.0.0-dev.17"
|
||||||
"@vitejs/plugin-vue": "^6.0.2",
|
},
|
||||||
"electron": "^39.2.6",
|
"devDependencies": {
|
||||||
"electron-builder": "^26.0.12",
|
"@vitejs/plugin-vue": "^6.0.2",
|
||||||
"electron-vite": "^5.0.0",
|
"electron": "^39.2.6",
|
||||||
"prettier": "^3.7.4",
|
"electron-builder": "^26.0.12",
|
||||||
"unplugin-vue-components": "^31.0.0",
|
"electron-vite": "^5.0.0",
|
||||||
"vite": "^7.2.6",
|
"prettier": "^3.7.4",
|
||||||
"vue": "^3.5.25"
|
"unplugin-vue-components": "^31.0.0",
|
||||||
}
|
"vite": "^7.2.6",
|
||||||
|
"vue": "^3.5.25"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
20
vite.config.js
Normal file
20
vite.config.js
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
import { fileURLToPath, URL } from 'node:url'
|
||||||
|
|
||||||
|
import { defineConfig } from 'vite'
|
||||||
|
import { sharedConfig } from './vite.shared'
|
||||||
|
|
||||||
|
export default defineConfig({
|
||||||
|
...sharedConfig,
|
||||||
|
root: 'src/renderer',
|
||||||
|
resolve: {
|
||||||
|
alias: {
|
||||||
|
'@': fileURLToPath(new URL('./src', import.meta.url)),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
server: {
|
||||||
|
port: 3000,
|
||||||
|
},
|
||||||
|
build: {
|
||||||
|
outDir: '../../dist/renderer',
|
||||||
|
},
|
||||||
|
})
|
||||||
34
vite.shared.js
Normal file
34
vite.shared.js
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
import vue from '@vitejs/plugin-vue'
|
||||||
|
import { toSass } from './src/renderer/src/libs/sass-utils'
|
||||||
|
import theme from './src/renderer/src/libs/theme'
|
||||||
|
|
||||||
|
export const sharedConfig = {
|
||||||
|
plugins: [vue()],
|
||||||
|
css: {
|
||||||
|
preprocessorOptions: {
|
||||||
|
scss: {
|
||||||
|
api: 'modern-compiler',
|
||||||
|
additionalData:
|
||||||
|
'@use "/src/styles/_functions.scss" as *; @use "/src/styles/_font-style.scss" as *;',
|
||||||
|
functions: {
|
||||||
|
'get($keys)': function (keys) {
|
||||||
|
keys = keys.toString().replace(/['"]+/g, '').split('.')
|
||||||
|
|
||||||
|
let result = theme
|
||||||
|
for (let i = 0; i < keys.length; i++) {
|
||||||
|
result = result[keys[i]]
|
||||||
|
}
|
||||||
|
|
||||||
|
return toSass(result)
|
||||||
|
},
|
||||||
|
'getColors()': function () {
|
||||||
|
return toSass(theme.colors)
|
||||||
|
},
|
||||||
|
'getThemes()': function () {
|
||||||
|
return toSass(theme.themes)
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user