123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156 |
- const parseArgs = require('minimist')
- const inquirer = require('inquirer')
- const {
- resolve
- } = require('path')
- const {
- readFileSync,
- writeFileSync
- } = require('fs')
- const {
- merge
- } = require('lodash')
- const toml = require('@tauri-apps/toml')
- /**
- * @type {object}
- * @property {boolean} h
- * @property {boolean} help
- * @property {string|boolean} f
- * @property {string|boolean} force
- * @property {boolean} l
- * @property {boolean} log
- * @property {boolean} d
- * @property {boolean} directory
- */
- const argv = parseArgs(process.argv.slice(2), {
- alias: {
- h: 'help',
- f: 'force',
- l: 'log',
- d: 'directory',
- t: 'tauri-path',
- A: 'app-name',
- W: 'window-title',
- D: 'dist-dir',
- P: 'dev-path'
- },
- boolean: ['h', 'l', 'ci']
- })
- if (argv.help) {
- console.log(`
- Description
- Inits the Tauri template. If Tauri cannot find the tauri.conf.json
- it will create one.
- Usage
- $ tauri init
- Options
- --help, -h Displays this message
- --ci Skip prompts
- --force, -f Force init to overwrite [conf|template|all]
- --log, -l Logging [boolean]
- --directory, -d Set target directory for init
- --tauri-path, -t Path of the Tauri project to use (relative to the cwd)
- --app-name, -A Name of your Tauri application
- --window-title, -W Window title of your Tauri application
- --dist-dir, -D Web assets location, relative to <project-dir>/src-tauri
- --dev-path, -P Url of your dev server
- `)
- process.exit(0)
- }
- let appName = argv.A
- if (!appName) {
- try {
- const packageJson = JSON.parse(readFileSync(resolve(process.cwd(), 'package.json')).toString())
- appName = packageJson.displayName || packageJson.name
- } catch {}
- }
- if (argv.ci) {
- runInit()
- } else {
- inquirer
- .prompt([{
- type: 'input',
- name: 'appName',
- message: 'What is your app name?',
- default: appName
- }, {
- type: 'input',
- name: 'tauri.window.title',
- message: 'What should the window title be?',
- default: 'Tauri App',
- when: () => !argv.W
- },
- {
- type: 'input',
- name: 'build.distDir',
- message: 'Where are your web assets (HTML/CSS/JS) located, relative to the "<current dir>/src-tauri" folder that will be created?',
- default: '../dist',
- when: () => !argv.D
- },
- {
- type: 'input',
- name: 'build.devPath',
- message: 'What is the url of your dev server?',
- default: 'http://localhost:4000',
- when: () => !argv.P
- }
- ])
- .then(answers => {
- runInit(answers)
- })
- .catch(error => {
- if (error.isTtyError) {
- // Prompt couldn't be rendered in the current environment
- console.log(
- 'It appears your terminal does not support interactive prompts. Using default values.'
- )
- runInit()
- } else {
- // Something else when wrong
- console.error('An unknown error occurred:', error)
- }
- })
- }
- function runInit(config = {}) {
- const {
- appName,
- ...configOptions
- } = config
- const init = require('../dist/api/init')
- const directory = argv.d || process.cwd()
- init({
- directory,
- force: argv.f || null,
- logging: argv.l || null,
- tauriPath: argv.t || null,
- customConfig: merge(configOptions, {
- build: {
- distDir: argv.D,
- devPath: argv.p
- },
- tauri: {
- window: {
- title: argv.w
- }
- }
- })
- })
- if (appName || argv.A) {
- const manifestPath = resolve(directory, 'src-tauri/Cargo.toml')
- const cargoManifest = toml.parse(readFileSync(manifestPath).toString())
- let binName = (appName || argv.A).replace(/ /g, '-')
- cargoManifest.package.name = binName
- cargoManifest.package['default-run'] = binName
- if (cargoManifest.bin && cargoManifest.bin.length) {
- cargoManifest.bin[0].name = binName
- }
- writeFileSync(manifestPath, toml.stringify(cargoManifest))
- }
- }
|