Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Error when creating licensed project with ng new with igniteui/angular-schematics #1349

Open
valadzhov opened this issue Nov 26, 2024 · 2 comments

Comments

@valadzhov
Copy link
Contributor

Description

Describe the issue.

  • Ignite UI CLI version: 14.3.x and 14.2.x
  • Framework: Angular
  • Project type: igx-ts

Steps to reproduce

  1. Install the latest igniteui/angular-schematics
  2. Create a new project with ng new --collection="@igniteui/angular-schematics"
  3. Create a project (doesn't matter what).
  4. Run the project and choose to upgrade the license feed.

Result

There is an error:
image

Expected result

There shouldn't be an error when the license feed is chosen.

@valadzhov
Copy link
Contributor Author

Once this issue is resolved the information about it in the Wiki should be deleted ("Currently there is an issue when executing the command...").

@jackofdiamond5
Copy link
Member

jackofdiamond5 commented Nov 28, 2024

The reason why this error occurs is because currently the upgrade logic relies on the existence of an ignite-ui-cli.json. Let me try to shed some light on what's happening.

First, the ng new igniteui/angular-schematics is executed and following the spawned prompt session a project is generated.

Then if the user has chosen to apply licensing, the following logic is executed:
image

In this context, the projTemplate can either point to packages\igx-templates\igx-ts\projects\_base\index.ts or packages\igx-templates\igx-ts-legacy\projects\_base\index.ts but these two files are more or less identical and they both define a upgradeIgniteUIPackages.
image

upgradeIgniteUIPackages will in turn execute updateWorkspace which points to packages/core/update/Update.ts. The logic in the updateWorkspace method attempts to load a config file, which refers to the ignite-ui-cli.json file. It does so because later it wants to find the framework which the update is called for as the logic was written with the mindset of supporting multiple platforms.

This is where the throw occurs:
image

When executing ng new igniteui/angular-schematics the config file does not yet exist, so the update logic cannot read the framework. Moreover, executing an Angular schematic should not have to rely on the existence of a config file, since the schematic can be executed outside of the CLI's context. One easy fix here is to just allow upgradeIgniteUIPackages to send the framework when we run the ng-new schematic, as we definitely know we are dealing with the Angular framework.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants