@empire-builder-kit/desktop 0.0.1-alpha.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (34) hide show
  1. package/README.md +11 -0
  2. package/dist/executors.json +3 -0
  3. package/dist/generators/app/app.d.ts +5 -0
  4. package/dist/generators/app/app.d.ts.map +1 -0
  5. package/dist/generators/app/app.js +195 -0
  6. package/dist/generators/app/files-go/README.md.template +11 -0
  7. package/dist/generators/app/files-go/frontend/index.html.template +11 -0
  8. package/dist/generators/app/files-go/go.mod.template +5 -0
  9. package/dist/generators/app/files-go/main.go.template +43 -0
  10. package/dist/generators/app/files-go/wails.json.template +12 -0
  11. package/dist/generators/app/files-python/README.md.template +11 -0
  12. package/dist/generators/app/files-python/pyproject.toml.template +15 -0
  13. package/dist/generators/app/files-python/src/main.py.template +28 -0
  14. package/dist/generators/app/files-rust/README.md.template +11 -0
  15. package/dist/generators/app/files-rust/src/index.html.template +11 -0
  16. package/dist/generators/app/files-rust/src-tauri/Cargo.toml.template +9 -0
  17. package/dist/generators/app/files-rust/src-tauri/src/main.rs.template +11 -0
  18. package/dist/generators/app/files-rust/src-tauri/tauri.conf.json.template +23 -0
  19. package/dist/generators/app/files-typescript/README.md.template +11 -0
  20. package/dist/generators/app/files-typescript/package.json.template +18 -0
  21. package/dist/generators/app/files-typescript/src/app.spec.ts.template +7 -0
  22. package/dist/generators/app/files-typescript/src/index.html.template +12 -0
  23. package/dist/generators/app/files-typescript/src/main.ts.template +22 -0
  24. package/dist/generators/app/files-typescript/src/preload.ts.template +5 -0
  25. package/dist/generators/app/files-typescript/tsconfig.json.template +16 -0
  26. package/dist/generators/app/schema.d.ts +8 -0
  27. package/dist/generators/app/schema.json +39 -0
  28. package/dist/generators.json +9 -0
  29. package/dist/index.d.ts +2 -0
  30. package/dist/index.d.ts.map +1 -0
  31. package/dist/index.js +5 -0
  32. package/executors.json +3 -0
  33. package/generators.json +9 -0
  34. package/package.json +84 -0
package/README.md ADDED
@@ -0,0 +1,11 @@
1
+ # @empire-builder-kit/desktop
2
+
3
+ Standardized Nx plugin for Empire Builder Kit workspace tooling.
4
+
5
+ ## Building
6
+
7
+ Run `pnpm nx build @empire-builder-kit/desktop` to build the library.
8
+
9
+ ## Running unit tests
10
+
11
+ Run `pnpm nx test @empire-builder-kit/desktop` to execute the unit tests via [Vitest](https://vitest.dev/).
@@ -0,0 +1,3 @@
1
+ {
2
+ "executors": {}
3
+ }
@@ -0,0 +1,5 @@
1
+ import { Tree } from '@nx/devkit';
2
+ import { AppGeneratorSchema } from './schema';
3
+ export declare function desktopAppGenerator(tree: Tree, options: AppGeneratorSchema): Promise<void>;
4
+ export default desktopAppGenerator;
5
+ //# sourceMappingURL=app.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app.d.ts","sourceRoot":"","sources":["../../../src/generators/app/app.ts"],"names":[],"mappings":"AAAA,OAAO,EAQL,IAAI,EACL,MAAM,YAAY,CAAC;AAEpB,OAAO,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AA4M9C,wBAAsB,mBAAmB,CACvC,IAAI,EAAE,IAAI,EACV,OAAO,EAAE,kBAAkB,iBAyC5B;AAED,eAAe,mBAAmB,CAAC"}
@@ -0,0 +1,195 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.desktopAppGenerator = desktopAppGenerator;
4
+ const tslib_1 = require("tslib");
5
+ const devkit_1 = require("@nx/devkit");
6
+ const path = tslib_1.__importStar(require("node:path"));
7
+ function runtimeForLanguage(language) {
8
+ switch (language) {
9
+ case 'typescript':
10
+ return 'node';
11
+ case 'rust':
12
+ return 'native';
13
+ case 'go':
14
+ return 'native';
15
+ case 'python':
16
+ return 'python';
17
+ }
18
+ }
19
+ function frameworkForLanguage(language) {
20
+ switch (language) {
21
+ case 'typescript':
22
+ return 'electron';
23
+ case 'rust':
24
+ return 'tauri';
25
+ case 'go':
26
+ return 'wails';
27
+ case 'python':
28
+ return 'pyqt';
29
+ }
30
+ }
31
+ function targetsForLanguage(language, projectRoot) {
32
+ const cwd = projectRoot;
33
+ switch (language) {
34
+ case 'typescript':
35
+ return {
36
+ build: {
37
+ executor: 'nx:run-commands',
38
+ options: { cwd, command: 'tsc -p tsconfig.json && cp src/*.html dist/' },
39
+ },
40
+ serve: {
41
+ executor: 'nx:run-commands',
42
+ options: { cwd, command: 'tsc -p tsconfig.json && cp src/*.html dist/ && electron .' },
43
+ },
44
+ lint: {
45
+ executor: 'nx:run-commands',
46
+ options: { cwd, command: 'eslint .' },
47
+ },
48
+ typecheck: {
49
+ executor: 'nx:run-commands',
50
+ options: { cwd, command: 'tsc --noEmit -p tsconfig.json' },
51
+ },
52
+ test: {
53
+ executor: 'nx:run-commands',
54
+ options: { cwd, command: 'vitest run' },
55
+ },
56
+ package: {
57
+ executor: 'nx:run-commands',
58
+ options: { cwd, command: 'tsc -p tsconfig.json && electron-builder build --publish never' },
59
+ },
60
+ };
61
+ case 'rust':
62
+ return {
63
+ build: {
64
+ executor: 'nx:run-commands',
65
+ options: { cwd: `${cwd}/src-tauri`, command: 'cargo build' },
66
+ },
67
+ serve: {
68
+ executor: 'nx:run-commands',
69
+ options: { cwd, command: 'cargo tauri dev' },
70
+ },
71
+ lint: {
72
+ executor: 'nx:run-commands',
73
+ options: { cwd: `${cwd}/src-tauri`, command: 'cargo clippy -- -D warnings' },
74
+ },
75
+ test: {
76
+ executor: 'nx:run-commands',
77
+ options: { cwd: `${cwd}/src-tauri`, command: 'cargo test' },
78
+ },
79
+ package: {
80
+ executor: 'nx:run-commands',
81
+ options: { cwd, command: 'cargo tauri build' },
82
+ },
83
+ };
84
+ case 'go':
85
+ return {
86
+ build: {
87
+ executor: 'nx:run-commands',
88
+ options: { cwd, command: 'wails build' },
89
+ },
90
+ serve: {
91
+ executor: 'nx:run-commands',
92
+ options: { cwd, command: 'wails dev' },
93
+ },
94
+ lint: {
95
+ executor: 'nx:run-commands',
96
+ options: { cwd, command: 'golangci-lint run' },
97
+ },
98
+ typecheck: {
99
+ executor: 'nx:run-commands',
100
+ options: { cwd, command: 'go vet ./...' },
101
+ },
102
+ test: {
103
+ executor: 'nx:run-commands',
104
+ options: { cwd, command: 'go test ./...' },
105
+ },
106
+ package: {
107
+ executor: 'nx:run-commands',
108
+ options: { cwd, command: 'wails build' },
109
+ },
110
+ };
111
+ case 'python':
112
+ return {
113
+ serve: {
114
+ executor: 'nx:run-commands',
115
+ options: { cwd, command: 'python src/main.py' },
116
+ },
117
+ lint: {
118
+ executor: 'nx:run-commands',
119
+ options: { cwd, command: 'ruff check .' },
120
+ },
121
+ typecheck: {
122
+ executor: 'nx:run-commands',
123
+ options: { cwd, command: 'mypy src/' },
124
+ },
125
+ test: {
126
+ executor: 'nx:run-commands',
127
+ options: { cwd, command: 'pytest' },
128
+ },
129
+ package: {
130
+ executor: 'nx:run-commands',
131
+ options: { cwd, command: 'pyinstaller --onefile src/main.py' },
132
+ },
133
+ };
134
+ }
135
+ }
136
+ function normalizeOptions(tree, options) {
137
+ const appNames = (0, devkit_1.names)(options.app);
138
+ const desktopNames = (0, devkit_1.names)(options.name);
139
+ const language = options.language ?? 'typescript';
140
+ const directory = (options.directory ?? 'packages').replace(/\\/g, '/');
141
+ const appRoot = (0, devkit_1.joinPathFragments)(directory, appNames.fileName);
142
+ const projectRoot = (0, devkit_1.joinPathFragments)(directory, appNames.fileName, 'apps', 'desktop', desktopNames.fileName);
143
+ const userTags = options.tags
144
+ ?.split(',')
145
+ .map((tag) => tag.trim())
146
+ .filter(Boolean) ?? [];
147
+ return {
148
+ app: appNames.fileName,
149
+ appRoot,
150
+ className: appNames.className,
151
+ directory,
152
+ language,
153
+ name: desktopNames.fileName,
154
+ offsetFromRoot: (0, devkit_1.offsetFromRoot)(projectRoot),
155
+ projectName: `${appNames.fileName}-desktop-${desktopNames.fileName}`,
156
+ projectRoot,
157
+ projectTitle: `${appNames.className} Desktop ${desktopNames.className}`,
158
+ skipFormat: options.skipFormat,
159
+ tags: [
160
+ `scope:${appNames.fileName}`,
161
+ 'layer:app',
162
+ 'type:desktop',
163
+ `runtime:${runtimeForLanguage(language)}`,
164
+ 'deploy:native',
165
+ 'visibility:internal',
166
+ ...userTags,
167
+ ],
168
+ };
169
+ }
170
+ async function desktopAppGenerator(tree, options) {
171
+ const normalized = normalizeOptions(tree, options);
172
+ if (!tree.exists(normalized.appRoot)) {
173
+ throw new Error(`App group "${normalized.app}" does not exist at "${normalized.appRoot}". Generate the app group first.`);
174
+ }
175
+ if (tree.exists((0, devkit_1.joinPathFragments)(normalized.projectRoot, 'project.json')) ||
176
+ tree.exists((0, devkit_1.joinPathFragments)(normalized.projectRoot, 'package.json'))) {
177
+ throw new Error(`Desktop app "${normalized.name}" already exists at "${normalized.projectRoot}".`);
178
+ }
179
+ (0, devkit_1.addProjectConfiguration)(tree, normalized.projectName, {
180
+ root: normalized.projectRoot,
181
+ projectType: 'application',
182
+ sourceRoot: `${normalized.projectRoot}/src`,
183
+ tags: normalized.tags,
184
+ targets: targetsForLanguage(normalized.language, normalized.projectRoot),
185
+ });
186
+ (0, devkit_1.generateFiles)(tree, path.join(__dirname, `files-${normalized.language}`), normalized.projectRoot, {
187
+ ...normalized,
188
+ framework: frameworkForLanguage(normalized.language),
189
+ tmpl: '',
190
+ });
191
+ if (!normalized.skipFormat) {
192
+ await (0, devkit_1.formatFiles)(tree);
193
+ }
194
+ }
195
+ exports.default = desktopAppGenerator;
@@ -0,0 +1,11 @@
1
+ # <%= projectTitle %>
2
+
3
+ Wails desktop app for the `<%= app %>` app group.
4
+
5
+ ## Commands
6
+
7
+ - `pnpm nx run <%= projectName %>:serve` — start Wails dev mode
8
+ - `pnpm nx run <%= projectName %>:build` — build for current platform
9
+ - `pnpm nx run <%= projectName %>:test` — run tests
10
+ - `pnpm nx run <%= projectName %>:lint` — run golangci-lint
11
+ - `pnpm nx run <%= projectName %>:package` — build for all platforms
@@ -0,0 +1,11 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8" />
5
+ <title><%= projectTitle %></title>
6
+ </head>
7
+ <body>
8
+ <h1><%= projectTitle %></h1>
9
+ <p>Wails desktop app for the <%= app %> app group.</p>
10
+ </body>
11
+ </html>
@@ -0,0 +1,5 @@
1
+ module github.com/org/<%= projectName %>
2
+
3
+ go 1.22
4
+
5
+ require github.com/wailsapp/wails/v2 v2.9.2
@@ -0,0 +1,43 @@
1
+ package main
2
+
3
+ import (
4
+ "embed"
5
+ "fmt"
6
+
7
+ "github.com/wailsapp/wails/v2"
8
+ "github.com/wailsapp/wails/v2/pkg/options"
9
+ "github.com/wailsapp/wails/v2/pkg/options/assetserver"
10
+ )
11
+
12
+ //go:embed frontend
13
+ var assets embed.FS
14
+
15
+ type App struct{}
16
+
17
+ func NewApp() *App {
18
+ return &App{}
19
+ }
20
+
21
+ func (a *App) Greet(name string) string {
22
+ return fmt.Sprintf("Hello, %s! From <%= projectTitle %>.", name)
23
+ }
24
+
25
+ func main() {
26
+ app := NewApp()
27
+
28
+ err := wails.Run(&options.App{
29
+ Title: "<%= projectTitle %>",
30
+ Width: 1200,
31
+ Height: 800,
32
+ AssetServer: &assetserver.Options{
33
+ Assets: assets,
34
+ },
35
+ Bind: []interface{}{
36
+ app,
37
+ },
38
+ })
39
+
40
+ if err != nil {
41
+ println("Error:", err.Error())
42
+ }
43
+ }
@@ -0,0 +1,12 @@
1
+ {
2
+ "$schema": "https://wails.io/schemas/config.v2.json",
3
+ "name": "<%= projectName %>",
4
+ "outputfilename": "<%= name %>",
5
+ "frontend:install": "",
6
+ "frontend:build": "",
7
+ "frontend:dev:watcher": "",
8
+ "frontend:dev:serverUrl": "",
9
+ "author": {
10
+ "name": "<%= app %>"
11
+ }
12
+ }
@@ -0,0 +1,11 @@
1
+ # <%= projectTitle %>
2
+
3
+ PyQt6 desktop app for the `<%= app %>` app group.
4
+
5
+ ## Commands
6
+
7
+ - `pnpm nx run <%= projectName %>:serve` — run the app
8
+ - `pnpm nx run <%= projectName %>:test` — run pytest
9
+ - `pnpm nx run <%= projectName %>:lint` — run ruff
10
+ - `pnpm nx run <%= projectName %>:typecheck` — run mypy
11
+ - `pnpm nx run <%= projectName %>:package` — build distributable with pyinstaller
@@ -0,0 +1,15 @@
1
+ [project]
2
+ name = "<%= projectName %>"
3
+ version = "0.1.0"
4
+ requires-python = ">=3.12"
5
+ dependencies = [
6
+ "PyQt6>=6.7",
7
+ ]
8
+
9
+ [project.optional-dependencies]
10
+ dev = [
11
+ "pytest>=8",
12
+ "ruff>=0.8",
13
+ "mypy>=1.13",
14
+ "pyinstaller>=6",
15
+ ]
@@ -0,0 +1,28 @@
1
+ """<%= projectTitle %> — PyQt6 desktop app for the <%= app %> app group."""
2
+
3
+ import sys
4
+ from PyQt6.QtWidgets import QApplication, QMainWindow, QLabel, QVBoxLayout, QWidget
5
+
6
+
7
+ class MainWindow(QMainWindow):
8
+ def __init__(self):
9
+ super().__init__()
10
+ self.setWindowTitle("<%= projectTitle %>")
11
+ self.setMinimumSize(800, 600)
12
+
13
+ central = QWidget()
14
+ layout = QVBoxLayout(central)
15
+ layout.addWidget(QLabel("<%= projectTitle %>"))
16
+ layout.addWidget(QLabel("PyQt6 desktop app for the <%= app %> app group."))
17
+ self.setCentralWidget(central)
18
+
19
+
20
+ def main():
21
+ app = QApplication(sys.argv)
22
+ window = MainWindow()
23
+ window.show()
24
+ sys.exit(app.exec())
25
+
26
+
27
+ if __name__ == "__main__":
28
+ main()
@@ -0,0 +1,11 @@
1
+ # <%= projectTitle %>
2
+
3
+ Tauri desktop app for the `<%= app %>` app group.
4
+
5
+ ## Commands
6
+
7
+ - `pnpm nx run <%= projectName %>:serve` — start Tauri dev mode
8
+ - `pnpm nx run <%= projectName %>:build` — build for distribution
9
+ - `pnpm nx run <%= projectName %>:test` — run tests
10
+ - `pnpm nx run <%= projectName %>:lint` — run clippy
11
+ - `pnpm nx run <%= projectName %>:package` — package for distribution
@@ -0,0 +1,11 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8" />
5
+ <title><%= projectTitle %></title>
6
+ </head>
7
+ <body>
8
+ <h1><%= projectTitle %></h1>
9
+ <p>Tauri desktop app for the <%= app %> app group.</p>
10
+ </body>
11
+ </html>
@@ -0,0 +1,9 @@
1
+ [package]
2
+ name = "<%= projectName %>"
3
+ version = "0.1.0"
4
+ edition = "2021"
5
+
6
+ [dependencies]
7
+ tauri = { version = "2", features = [] }
8
+ serde = { version = "1", features = ["derive"] }
9
+ serde_json = "1"
@@ -0,0 +1,11 @@
1
+ fn main() {
2
+ tauri::Builder::default()
3
+ .invoke_handler(tauri::generate_handler![greet])
4
+ .run(tauri::generate_context!())
5
+ .expect("error while running tauri application");
6
+ }
7
+
8
+ #[tauri::command]
9
+ fn greet(name: &str) -> String {
10
+ format!("Hello, {}! From <%= projectTitle %>.", name)
11
+ }
@@ -0,0 +1,23 @@
1
+ {
2
+ "$schema": "https://raw.githubusercontent.com/nicholasgasior/tauri-docs/master/schemas/config.schema.json",
3
+ "productName": "<%= projectTitle %>",
4
+ "version": "0.1.0",
5
+ "identifier": "com.<%= app %>.<%= name %>",
6
+ "build": {
7
+ "frontendDist": "../src"
8
+ },
9
+ "app": {
10
+ "title": "<%= projectTitle %>",
11
+ "windows": [
12
+ {
13
+ "title": "<%= projectTitle %>",
14
+ "width": 1200,
15
+ "height": 800
16
+ }
17
+ ]
18
+ },
19
+ "bundle": {
20
+ "active": true,
21
+ "targets": "all"
22
+ }
23
+ }
@@ -0,0 +1,11 @@
1
+ # <%= projectTitle %>
2
+
3
+ Electron desktop app for the `<%= app %>` app group.
4
+
5
+ ## Commands
6
+
7
+ - `pnpm nx run <%= projectName %>:serve` — launch Electron
8
+ - `pnpm nx run <%= projectName %>:build` — build distributable
9
+ - `pnpm nx run <%= projectName %>:test` — run tests
10
+ - `pnpm nx run <%= projectName %>:lint` — lint
11
+ - `pnpm nx run <%= projectName %>:package` — package for distribution
@@ -0,0 +1,18 @@
1
+ {
2
+ "name": "@org/<%= projectName %>",
3
+ "version": "0.1.0",
4
+ "private": true,
5
+ "main": "dist/main.js",
6
+ "scripts": {
7
+ "compile": "tsc -p tsconfig.json",
8
+ "start": "tsc -p tsconfig.json && electron .",
9
+ "build": "tsc -p tsconfig.json && electron-builder build --publish never"
10
+ },
11
+ "dependencies": {
12
+ "electron": "^33.0.0"
13
+ },
14
+ "devDependencies": {
15
+ "electron-builder": "^25.0.0",
16
+ "typescript": "~5.8.0"
17
+ }
18
+ }
@@ -0,0 +1,7 @@
1
+ import { describe, expect, it } from 'vitest';
2
+
3
+ describe('<%= projectName %>', () => {
4
+ it('should be configured', () => {
5
+ expect('<%= projectName %>').toBeTruthy();
6
+ });
7
+ });
@@ -0,0 +1,12 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8" />
5
+ <meta http-equiv="Content-Security-Policy" content="default-src 'self'; script-src 'self'" />
6
+ <title><%= projectTitle %></title>
7
+ </head>
8
+ <body>
9
+ <h1><%= projectTitle %></h1>
10
+ <p>Electron desktop app for the <%= app %> app group.</p>
11
+ </body>
12
+ </html>
@@ -0,0 +1,22 @@
1
+ import { app, BrowserWindow } from 'electron';
2
+ import * as path from 'path';
3
+
4
+ function createWindow() {
5
+ const win = new BrowserWindow({
6
+ width: 1200,
7
+ height: 800,
8
+ webPreferences: {
9
+ preload: path.join(__dirname, 'preload.js'),
10
+ },
11
+ });
12
+
13
+ win.loadFile(path.join(__dirname, 'index.html'));
14
+ }
15
+
16
+ app.whenReady().then(createWindow);
17
+
18
+ app.on('window-all-closed', () => {
19
+ if (process.platform !== 'darwin') {
20
+ app.quit();
21
+ }
22
+ });
@@ -0,0 +1,5 @@
1
+ import { contextBridge } from 'electron';
2
+
3
+ contextBridge.exposeInMainWorld('app', {
4
+ name: '<%= projectName %>',
5
+ });
@@ -0,0 +1,16 @@
1
+ {
2
+ "compilerOptions": {
3
+ "target": "ES2022",
4
+ "module": "commonjs",
5
+ "lib": ["ES2022"],
6
+ "outDir": "dist",
7
+ "rootDir": "src",
8
+ "strict": true,
9
+ "esModuleInterop": true,
10
+ "skipLibCheck": true,
11
+ "forceConsistentCasingInFileNames": true,
12
+ "resolveJsonModule": true
13
+ },
14
+ "include": ["src/**/*.ts"],
15
+ "exclude": ["node_modules", "dist"]
16
+ }
@@ -0,0 +1,8 @@
1
+ export interface AppGeneratorSchema {
2
+ name: string;
3
+ app: string;
4
+ language?: 'typescript' | 'rust' | 'go' | 'python';
5
+ directory?: string;
6
+ tags?: string;
7
+ skipFormat?: boolean;
8
+ }
@@ -0,0 +1,39 @@
1
+ {
2
+ "$schema": "https://json-schema.org/schema",
3
+ "$id": "DesktopAppGenerator",
4
+ "title": "Generate an EBK desktop app",
5
+ "type": "object",
6
+ "properties": {
7
+ "name": {
8
+ "type": "string",
9
+ "description": "Name for the desktop app within the app group.",
10
+ "$default": { "$source": "argv", "index": 0 },
11
+ "x-prompt": "What name should the desktop app have?"
12
+ },
13
+ "app": {
14
+ "type": "string",
15
+ "description": "Owning Empire Builder Kit app-group name.",
16
+ "x-prompt": "Which app group should receive the desktop app?"
17
+ },
18
+ "language": {
19
+ "type": "string",
20
+ "description": "Programming language and framework for the desktop app.",
21
+ "enum": ["typescript", "rust", "go", "python"],
22
+ "default": "typescript"
23
+ },
24
+ "directory": {
25
+ "type": "string",
26
+ "description": "Base directory for app groups.",
27
+ "default": "packages"
28
+ },
29
+ "tags": {
30
+ "type": "string",
31
+ "description": "Comma-separated additional tags."
32
+ },
33
+ "skipFormat": {
34
+ "type": "boolean",
35
+ "default": false
36
+ }
37
+ },
38
+ "required": ["name", "app"]
39
+ }
@@ -0,0 +1,9 @@
1
+ {
2
+ "generators": {
3
+ "app": {
4
+ "factory": "./dist/generators/app/app",
5
+ "schema": "./dist/generators/app/schema.json",
6
+ "description": "Generate app artifacts for @empire-builder-kit/desktop."
7
+ }
8
+ }
9
+ }
@@ -0,0 +1,2 @@
1
+ export { desktopAppGenerator } from './generators/app/app';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.desktopAppGenerator = void 0;
4
+ var app_1 = require("./generators/app/app");
5
+ Object.defineProperty(exports, "desktopAppGenerator", { enumerable: true, get: function () { return app_1.desktopAppGenerator; } });
package/executors.json ADDED
@@ -0,0 +1,3 @@
1
+ {
2
+ "executors": {}
3
+ }
@@ -0,0 +1,9 @@
1
+ {
2
+ "generators": {
3
+ "app": {
4
+ "factory": "./dist/generators/app/app",
5
+ "schema": "./dist/generators/app/schema.json",
6
+ "description": "Generate app artifacts for @empire-builder-kit/desktop."
7
+ }
8
+ }
9
+ }
package/package.json ADDED
@@ -0,0 +1,84 @@
1
+ {
2
+ "name": "@empire-builder-kit/desktop",
3
+ "version": "0.0.1-alpha.4",
4
+ "publishConfig": {
5
+ "access": "public",
6
+ "provenance": true
7
+ },
8
+ "main": "./dist/index.js",
9
+ "module": "./dist/index.js",
10
+ "types": "./dist/index.d.ts",
11
+ "exports": {
12
+ "./package.json": "./package.json",
13
+ ".": {
14
+ "@org/source": "./src/index.ts",
15
+ "types": "./dist/index.d.ts",
16
+ "import": "./dist/index.js",
17
+ "default": "./dist/index.js"
18
+ }
19
+ },
20
+ "nx": {
21
+ "name": "@empire-builder-kit/desktop",
22
+ "targets": {
23
+ "build": {
24
+ "executor": "@nx/js:tsc",
25
+ "outputs": [
26
+ "{options.outputPath}"
27
+ ],
28
+ "options": {
29
+ "outputPath": "packages/desktop/dist",
30
+ "main": "packages/desktop/src/index.ts",
31
+ "tsConfig": "packages/desktop/tsconfig.lib.json",
32
+ "rootDir": "packages/desktop/src",
33
+ "generatePackageJson": false,
34
+ "assets": [
35
+ {
36
+ "input": "./packages/desktop/src",
37
+ "glob": "**/!(*.ts)",
38
+ "output": "."
39
+ },
40
+ {
41
+ "input": "./packages/desktop/src",
42
+ "glob": "**/.*",
43
+ "output": "."
44
+ },
45
+ {
46
+ "input": "./packages/desktop/src",
47
+ "glob": "**/*.d.ts",
48
+ "output": "."
49
+ },
50
+ {
51
+ "input": "./packages/desktop",
52
+ "glob": "generators.json",
53
+ "output": "."
54
+ },
55
+ {
56
+ "input": "./packages/desktop",
57
+ "glob": "executors.json",
58
+ "output": "."
59
+ }
60
+ ]
61
+ }
62
+ }
63
+ },
64
+ "tags": [
65
+ "scope:workspace",
66
+ "layer:tooling",
67
+ "visibility:public",
68
+ "npm:public"
69
+ ]
70
+ },
71
+ "dependencies": {
72
+ "@nx/devkit": "22.6.5",
73
+ "tslib": "^2.3.0",
74
+ "vitest": "4.1.4"
75
+ },
76
+ "generators": "./generators.json",
77
+ "executors": "./executors.json",
78
+ "files": [
79
+ "dist",
80
+ "!**/*.tsbuildinfo",
81
+ "generators.json",
82
+ "executors.json"
83
+ ]
84
+ }