mirror of
https://github.com/enso-org/enso.git
synced 2024-12-23 08:21:49 +03:00
4a249688e8
Fixes #10668 Fixes #8484 Summary of changes: * `gui2` and `dashboard` are merged to `gui` directory. Various configs were merged (package.json, playwrigth, TS...). The src and e2e directories are split to `dashboard` and `project-view` for now. * E2E tests run two servers on different ports. The tests are organized in projects. This is also to be changed soon, as we plan to [use better mocking in GUI/ProjectView](#9726) * ESlint configs were merged to central `eslint.config.mjs`, and that file was moved to repository root. We kept the dashboard lints, but they can be relaxed. The dashboard code was changed to meet GUI lints. * Also, the versions of linter plugins were bumped, and code fixed. * The ide-desktop/client no longer has `dashboard` dependency - the only type used there was moved to common package. * `common` package moved to `app`.
79 lines
2.0 KiB
TypeScript
79 lines
2.0 KiB
TypeScript
/** @file This module contains the logic for the detection of user-specific desktop environment attributes. */
|
|
import * as childProcess from 'node:child_process'
|
|
import * as os from 'node:os'
|
|
import * as path from 'node:path'
|
|
|
|
export const DOCUMENTS = getDocumentsPath()
|
|
|
|
const CHILD_PROCESS_TIMEOUT = 3000
|
|
|
|
/**
|
|
* Detects path of the user documents directory depending on the operating system.
|
|
*/
|
|
function getDocumentsPath(): string | undefined {
|
|
if (process.platform === 'linux') {
|
|
return getLinuxDocumentsPath()
|
|
} else if (process.platform === 'darwin') {
|
|
return getMacOsDocumentsPath()
|
|
} else if (process.platform === 'win32') {
|
|
return getWindowsDocumentsPath()
|
|
} else {
|
|
return
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns the user documents path on Linux.
|
|
*/
|
|
function getLinuxDocumentsPath(): string {
|
|
const xdgDocumentsPath = getXdgDocumentsPath()
|
|
|
|
return xdgDocumentsPath ?? path.join(os.homedir(), 'enso')
|
|
}
|
|
|
|
/**
|
|
* Gets the documents directory from the XDG directory management system.
|
|
*/
|
|
function getXdgDocumentsPath(): string | undefined {
|
|
const out = childProcess.spawnSync('xdg-user-dir', ['DOCUMENTS'], {
|
|
timeout: CHILD_PROCESS_TIMEOUT,
|
|
})
|
|
|
|
if (out.error !== undefined) {
|
|
return
|
|
} else {
|
|
return out.stdout.toString().trim()
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get the user documents path. On macOS, `Documents` acts as a symlink pointing to the
|
|
* real locale-specific user documents directory.
|
|
*/
|
|
function getMacOsDocumentsPath(): string {
|
|
return path.join(os.homedir(), 'Documents')
|
|
}
|
|
|
|
/**
|
|
* Get the path to the `My Documents` Windows directory.
|
|
*/
|
|
function getWindowsDocumentsPath(): string | undefined {
|
|
const out = childProcess.spawnSync(
|
|
'reg',
|
|
[
|
|
'query',
|
|
'HKCU\\Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\Shell Folders',
|
|
'/v',
|
|
'personal',
|
|
],
|
|
{ timeout: CHILD_PROCESS_TIMEOUT },
|
|
)
|
|
|
|
if (out.error !== undefined) {
|
|
return
|
|
} else {
|
|
const stdoutString = out.stdout.toString()
|
|
return stdoutString.split(/\s\s+/)[4]
|
|
}
|
|
}
|