Skip to content

Migrate project to TypeScript with build system#3

Draft
Copilot wants to merge 5 commits intomainfrom
copilot/fix-2
Draft

Migrate project to TypeScript with build system#3
Copilot wants to merge 5 commits intomainfrom
copilot/fix-2

Conversation

Copy link

Copilot AI commented May 21, 2025

This PR migrates the entire project from JavaScript to TypeScript, including creating a build system to compile TypeScript applications. The TypeScript implementation maintains full feature parity with the JavaScript version.

What Changed

  • Created TypeScript folder structure mirroring the JavaScript layout
  • Developed type definitions for the io.Connect Desktop API
  • Converted all JavaScript files to TypeScript with proper type annotations
  • Set up webpack for building TypeScript applications
  • Configured tsconfig.json with appropriate options
  • Added npm scripts for building and installation
  • Copied library files, app definitions, and workspace layouts to maintain compatibility
  • Updated README.md with documentation on the TypeScript migration

Implementation Details

The implementation creates two parallel paths:

  1. The original JavaScript version remains untouched
  2. A new TypeScript version with identical functionality but with static typing

Structure

typescript/
├── solution/           # Solution applications
│   ├── clients/
│   ├── stocks/
│   ├── client-details/
│   └── portfolio-downloader/
├── start/              # Starter applications
│   ├── clients/
│   ├── stocks/
│   ├── client-details/
│   └── portfolio-downloader/
└── types/              # Type definitions
    └── io-connect.d.ts # Types for io.Connect Desktop API

Building TypeScript Applications

Each application has its own webpack configuration and can be built independently or together. The build system compiles TypeScript code and copies necessary HTML and library files to the distribution folder.

# Install dependencies for both start and solution
cd typescript && npm run install:all

# Build all applications
npm run build

# Build specific versions
npm run build:solution
npm run build:start

Fixes #2.

Warning

Firewall rules blocked me from connecting to one or more addresses

I tried to connect to the following addresses, but was blocked by firewall rules:

  • cdn.fwupd.org
    • Triggering command: /usr/bin/fwupdmgr refresh (dns block)

If you need me to access, download, or install something from one of these locations, you can either:


💡 You can make Copilot smarter by setting up custom instructions, customizing its development environment and configuring Model Context Protocol (MCP) servers. Learn more Copilot coding agent tips in the docs.

Copilot AI and others added 2 commits May 21, 2025 12:47
Co-authored-by: kirilpopov <6021897+kirilpopov@users.noreply.github.com>
Co-authored-by: kirilpopov <6021897+kirilpopov@users.noreply.github.com>
Copilot AI changed the title [WIP] Move the project to typescript Migrate project to TypeScript with build system May 21, 2025
Copilot AI requested a review from kirilpopov May 21, 2025 12:50
@kirilpopov
Copy link

I don't want to use webpack, move to esbuild. Also out files should go to dist folder for each app and http-server should server from there

Copilot AI and others added 2 commits May 21, 2025 21:51
Co-authored-by: kirilpopov <6021897+kirilpopov@users.noreply.github.com>
Co-authored-by: kirilpopov <6021897+kirilpopov@users.noreply.github.com>
Copy link
Author

Copilot AI commented May 21, 2025

I don't want to use webpack, move to esbuild. Also out files should go to dist folder for each app and http-server should server from there

I've replaced webpack with esbuild as requested. Each app now uses an esbuild.js configuration file which builds TypeScript and copies static assets to the dist folder. I verified the build process works correctly for all applications. HTTP server was already configured to serve from the dist directories. Commit 30b7d0e contains the complete implementation.

@arjunah arjunah closed this May 22, 2025
@arjunah arjunah reopened this May 22, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Move the project to typescript

3 participants

Comments