From 2118eebbca26d0f6ffdac4333880b794d42239e6 Mon Sep 17 00:00:00 2001 From: blakeoxx <14984839+blakeoxx@users.noreply.github.com> Date: Wed, 15 May 2024 15:43:48 -0500 Subject: [PATCH] feat(readme): updates SSR injection token instructions --- README.md | 40 +++++++++++------------ projects/ngx-cookie-service-ssr/README.md | 36 ++++++++++---------- projects/ngx-cookie-service/README.md | 36 ++++++++++---------- 3 files changed, 55 insertions(+), 57 deletions(-) diff --git a/README.md b/README.md index 5910fca..d9c0384 100644 --- a/README.md +++ b/README.md @@ -94,35 +94,33 @@ Only install `ngx-cookie-service-ssr` library (and skip `ngx-cookie-service`) fo 2. By default, browser cookies are not available in SSR because `document` object is not available. To overcome this, navigate to `server.ts` file in your - SSR - project, and replace the following code - + SSR project, and add the provided exported tokens to the following code's providers array (also applicable to `commonEngine.render` providers): + ```typescript server.get('*', (req, res) => { res.render(indexHtml, { req, providers: [{ provide: APP_BASE_HREF, useValue: req.baseUrl }] }); }); ``` -with this + like so: -```typescript -import { REQUEST as SSR_REQUEST } from "ngx-cookie-service-ssr"; - -server.get('*', (req, res) => { - res.render(indexHtml, { - req, - providers: [ - { provide: APP_BASE_HREF, useValue: req.baseUrl }, - { provide: SSR_REQUEST, useValue: req }, - { provide: 'RESPONSE', useValue: res }, - ], - }); -}); -``` + ```typescript + import { REQUEST as COOKIE_SERVICE_REQ, RESPONSE as COOKIE_SERVICE_RES } from '@ngx-cookie-service-ssr'; + // ... + server.get('*', (req, res) => { + res.render(indexHtml, { + req, + providers: [ + { provide: APP_BASE_HREF, useValue: req.baseUrl }, + { provide: COOKIE_SERVICE_REQ, useValue: req }, + { provide: COOKIE_SERVICE_RES, useValue: res }, + ], + }); + }); + ``` -3. This will make sure the cookies are available in `REQUEST` object, and the `ngx-cookie-service-ssr` can - use `REQUEST.cookies` to access the - cookies in SSR. Then proceed to use `ngx-cookie-service` as usual. +3. This will ensure cookies are available in the `REQUEST` and `RESPONSE` objects for `ngx-cookie-service-ssr` to access + via `REQUEST.cookies`/`RESPONSE.cookies` in SSR. Then proceed to use `ngx-cookie-service` as usual. 4. See the [sample repo](https://github.com/pavankjadda/angular-ssr-docker) for more details. ## Supported Versions diff --git a/projects/ngx-cookie-service-ssr/README.md b/projects/ngx-cookie-service-ssr/README.md index 5b33428..38d7d43 100644 --- a/projects/ngx-cookie-service-ssr/README.md +++ b/projects/ngx-cookie-service-ssr/README.md @@ -120,8 +120,7 @@ Only install `ngx-cookie-service-ssr` library (and skip `ngx-cookie-service`) fo 2. By default, browser cookies are not available in SSR because `document` object is not available. To overcome this, navigate to `server.ts` file in your - SSR - project, and replace the following code + SSR project, and add the provided exported tokens to the following code's providers array (also applicable to `commonEngine.render` providers): ```typescript server.get('*', (req, res) => { @@ -129,24 +128,25 @@ Only install `ngx-cookie-service-ssr` library (and skip `ngx-cookie-service`) fo }); ``` -with this + like so: -```typescript -server.get('*', (req, res) => { - res.render(indexHtml, { - req, - providers: [ - { provide: APP_BASE_HREF, useValue: req.baseUrl }, - { provide: 'REQUEST', useValue: req }, - { provide: 'RESPONSE', useValue: res }, - ], - }); -}); -``` + ```typescript + import { REQUEST as COOKIE_SERVICE_REQ, RESPONSE as COOKIE_SERVICE_RES } from '@ngx-cookie-service-ssr'; + // ... + server.get('*', (req, res) => { + res.render(indexHtml, { + req, + providers: [ + { provide: APP_BASE_HREF, useValue: req.baseUrl }, + { provide: COOKIE_SERVICE_REQ, useValue: req }, + { provide: COOKIE_SERVICE_RES, useValue: res }, + ], + }); + }); + ``` -3. This will make sure the cookies are available in `REQUEST` object, and the `ngx-cookie-service-ssr` can - use `REQUEST.cookies` to access the - cookies in SSR. Then proceed to use `ngx-cookie-service` as usual. +3. This will ensure cookies are available in the `REQUEST` and `RESPONSE` objects for `ngx-cookie-service-ssr` to access + via `REQUEST.cookies`/`RESPONSE.cookies` in SSR. Then proceed to use `ngx-cookie-service` as usual. 4. See the [sample repo](https://github.com/pavankjadda/angular-ssr-docker) for more details. ## Demo diff --git a/projects/ngx-cookie-service/README.md b/projects/ngx-cookie-service/README.md index 7788274..75a0ae9 100644 --- a/projects/ngx-cookie-service/README.md +++ b/projects/ngx-cookie-service/README.md @@ -120,8 +120,7 @@ Only install `ngx-cookie-service-ssr` library (and skip `ngx-cookie-service`) fo 2. By default, browser cookies are not available in SSR because `document` object is not available. To overcome this, navigate to `server.ts` file in your - SSR - project, and replace the following code + SSR project, and add the provided exported tokens to the following code's providers array (also applicable to `commonEngine.render` providers): ```typescript server.get('*', (req, res) => { @@ -129,24 +128,25 @@ Only install `ngx-cookie-service-ssr` library (and skip `ngx-cookie-service`) fo }); ``` -with this + like so: -```typescript -server.get('*', (req, res) => { - res.render(indexHtml, { - req, - providers: [ - { provide: APP_BASE_HREF, useValue: req.baseUrl }, - { provide: 'REQUEST', useValue: req }, - { provide: 'RESPONSE', useValue: res }, - ], - }); -}); -``` + ```typescript + import { REQUEST as COOKIE_SERVICE_REQ, RESPONSE as COOKIE_SERVICE_RES } from '@ngx-cookie-service-ssr'; + // ... + server.get('*', (req, res) => { + res.render(indexHtml, { + req, + providers: [ + { provide: APP_BASE_HREF, useValue: req.baseUrl }, + { provide: COOKIE_SERVICE_REQ, useValue: req }, + { provide: COOKIE_SERVICE_RES, useValue: res }, + ], + }); + }); + ``` -3. This will make sure the cookies are available in `REQUEST` object, and the `ngx-cookie-service-ssr` can - use `REQUEST.cookies` to access the - cookies in SSR. Then proceed to use `ngx-cookie-service` as usual. +3. This will ensure cookies are available in the `REQUEST` and `RESPONSE` objects for `ngx-cookie-service-ssr` to access + via `REQUEST.cookies`/`RESPONSE.cookies` in SSR. Then proceed to use `ngx-cookie-service` as usual. 4. See the [sample repo](https://github.com/pavankjadda/angular-ssr-docker) for more details. ## Demo