From e2fd62ead868712634c80d75bc47953fc423f6df Mon Sep 17 00:00:00 2001 From: Olivia Guyot Date: Tue, 21 Nov 2023 17:15:20 +0100 Subject: [PATCH] doc(package): add instruction for missing peer dependencies, disable SSR and put gn-ui package last --- docs/guide/custom-app.md | 43 ++++++++++++++++++++++++++-------------- package/package.json | 6 ++---- 2 files changed, 30 insertions(+), 19 deletions(-) diff --git a/docs/guide/custom-app.md b/docs/guide/custom-app.md index 2913a04514..2d9f3f837b 100644 --- a/docs/guide/custom-app.md +++ b/docs/guide/custom-app.md @@ -55,20 +55,14 @@ Setting up a Custom Application requires precisely following several steps. This can be done in several ways, see for instance [Angular Setup Guide](https://angular.io/guide/setup-local). ::: tip -If using Angular 17+, make sure to create a **non-standalone app** using the `--no-standalone` flag +GeoNetwork-UI as an NPM package is **not compatible with Server-Side Rendering!** use the `--ssr false` flag ::: -### Step 2: Install the `geonetwork-ui` package - -Run: - -```shell -npm install --save geonetwork-ui -``` - -> **Note:** because of the large amount of dependencies that geonetwork-ui uses, this command might fail with various errors; in that case please try again with the `--force` command flag +::: tip +If using Angular 17+, make sure to create a **non-standalone app** using the `--no-standalone` flag +::: -### Step 3: Adjust the Typescript configuration +### Step 2: Adjust the Typescript configuration Add the following settings to the `tsconfig.json` file at the root of your project: @@ -99,7 +93,7 @@ Add the following settings to the `tsconfig.json` file at the root of your proje This is necessary mostly because GeoNetwork-UI will not compile under Typescript strict mode. -### Step 4: Adjust the Angular configuration +### Step 3: Adjust the Angular configuration Some dependencies of GeoNetwork-UI will trigger a warning by the Angular compiler. To suppress these warnings, add the following settings to the `angular.json` file at the root of your project: @@ -139,7 +133,7 @@ the following settings to the `angular.json` file at the root of your project: The `preserveSymlinks` setting is also important if you're working in dev mode and use a symbolic link to point to a dev build of GeoNetwork-UI. -### Step 5: Install Tailwind +### Step 4: Install Tailwind [Tailwind CSS](https://tailwindcss.com/) is used for styling across the whole of GeoNetwork-UI, and is a mandatory dependency. @@ -166,14 +160,33 @@ export default { Here we are inheriting from the GeoNetwork-UI base Tailwind config, which provides many essential things like theme colors etc. -### Step 6: Install other mandatory dependencies +### Step 5: Install other mandatory dependencies [Angular Material](https://material.angular.io/) and [ngx-translate](https://github.com/ngx-translate/core) are other dependencies essential for many GeoNetwork-UI components. To install them: ```shell -npm install --save @angular/material @angular/material-moment-adapter @ngx-translate/core @ngx-translate/http-loader +npm install --save \ + @angular/material \ + @angular/material-moment-adapter \ + @angular/cdk \ + @ngrx/component \ + @ngrx/effects \ + @ngrx/router-store \ + @ngrx/store \ + @ngrx/store-devtools \ + @ngx-translate/core \ + @ngx-translate/http-loader ``` +### Step 6: Install the `geonetwork-ui` package + +Run: + +```shell +npm install --save geonetwork-ui +``` + + ### Step 7: Include the required fonts The root `index.html` file of your application should include the Material Symbols font for icons. Add these lines to itS `` section: diff --git a/package/package.json b/package/package.json index f00ea6c0f1..a9d7530cf6 100644 --- a/package/package.json +++ b/package/package.json @@ -19,25 +19,23 @@ "@angular/common": "16.x || 17.x", "@angular/compiler": "16.x || 17.x", "@angular/core": "16.x || 17.x", - "@angular/elements": "16.x || 17.x", "@angular/forms": "16.x || 17.x", "@angular/material": "16.x || 17.x", "@angular/material-moment-adapter": "16.x || 17.x", "@angular/platform-browser": "16.x || 17.x", "@angular/platform-browser-dynamic": "16.x || 17.x", - "@angular/platform-server": "16.x || 17.x", "@angular/router": "16.x || 17.x", "@ngrx/component": "16.x || 17.x", "@ngrx/effects": "16.x || 17.x", "@ngrx/router-store": "16.x || 17.x", - "@ngrx/schematics": "16.x || 17.x", "@ngrx/store": "16.x || 17.x", "@ngrx/store-devtools": "16.x || 17.x", "@nguniversal/express-engine": "16.x || 17.x", "@ngx-translate/core": "14.x", "@ngx-translate/http-loader": "7.x", "rxjs": "7.x", - "zone.js": "*" + "zone.js": "*", + "tailwindcss": "3.x" }, "dependencies": { "@camptocamp/ogc-client": "^0.4.0",