Skip to content

Commit

Permalink
feat: clean up deprecated items for Otter v12
Browse files Browse the repository at this point in the history
  • Loading branch information
sdo-1A committed Jan 9, 2025
1 parent 7ff637f commit 5cb20ec
Show file tree
Hide file tree
Showing 255 changed files with 306 additions and 11,077 deletions.
2 changes: 0 additions & 2 deletions .github/ISSUE_TEMPLATE/1-O3R-ISSUE-FORM.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,6 @@ body:
core,
create,
design,
dev-tools,
dynamic-content,
eslint-config-otter,
eslint-plugin,
Expand All @@ -42,7 +41,6 @@ body:
schematics,
showcase,
store-sync,
storybook,
stylelint-plugin,
styling,
telemetry,
Expand Down
4 changes: 0 additions & 4 deletions .yarnrc.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,10 +11,6 @@ packageExtensions:
"@actions/github@^6.0.0":
dependencies:
undici: ^5.25.4
"@storybook/manager-api@*":
dependencies:
react: ^18.0.0
react-dom: ^18.0.0
"@swc-node/register@^1.9.0":
dependencies:
"@swc/types": "*"
Expand Down
3 changes: 1 addition & 2 deletions apps/chrome-devtools/src/app-components/app.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -139,8 +139,7 @@ export class AppComponent {
]).pipe(
map(([info, executions]) =>
executions.filter((execution) =>
(execution.rulesetInformation?.linkedComponent?.name === info.componentName)
|| (execution.rulesetInformation?.linkedComponents?.or.some((linkedComp) => linkedComp.name === info.componentName))
execution.rulesetInformation?.linkedComponents?.or.some((linkedComp) => linkedComp.name === info.componentName)
)
)
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -117,8 +117,7 @@ export class ComponentPanelPresComponent {
]).pipe(
map(([info, executions]) =>
executions.filter((execution) =>
(execution.rulesetInformation?.linkedComponent?.name === info.componentName)
|| (execution.rulesetInformation?.linkedComponents?.or.some((linkedComp) => linkedComp.name === info.componentName))
execution.rulesetInformation?.linkedComponents?.or.some((linkedComp) => linkedComp.name === info.componentName)
)
)
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -105,11 +105,9 @@ export class OtterComponentComponent implements OnChanges {
if (changes.rulesetExecutions) {
this.librariesLinkedToRulesetExecutions = [...(
new Set((this.rulesetExecutions || [])
.flatMap((execution) => {
const linkedComponent = execution.rulesetInformation?.linkedComponent;
const linkedComponents = execution.rulesetInformation?.linkedComponents?.or;
return (linkedComponents?.map((lc) => lc.library) || [linkedComponent?.library]).filter((lib): lib is string => !!lib);
})
.flatMap((execution) => (execution.rulesetInformation?.linkedComponents?.or || [])
.map((lc) => lc.library).filter((lib): lib is string => !!lib)
)
)
)];
}
Expand Down
26 changes: 12 additions & 14 deletions docs/README.md

Large diffs are not rendered by default.

2 changes: 0 additions & 2 deletions docs/ab-testing/AB_TESTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -261,5 +261,3 @@ You can now create A/B testing-driven rulesets .
}

```
> Note: In v10 and previously, we used `linkedComponent` property to activate a ruleset on demand. This becomes deprecated and will be removed in v12. Use `linkedComponents` instead;
5 changes: 3 additions & 2 deletions docs/components/COMPONENT_REPLACEMENT.md
Original file line number Diff line number Diff line change
Expand Up @@ -163,7 +163,8 @@ That information is expected to be a property of the **component's configuration
Since configurations **have** to have a default value, in this specific instance it must always be the **empty string**. The default presenter will be declared in the component's class.

````typescript
import { computeConfigurationName, Configuration } from '@o3r/configuration';
import { Configuration } from '@o3r/configuration';
import { computeItemIdentifier } from '@o3r/core';

export interface DummyContConfig extends Configuration {
/** Key used to identify a custom component, if provided */
Expand All @@ -174,7 +175,7 @@ export const DUMMY_CONT_DEFAULT_CONFIG: DummyContConfig = {
customDummyKey: ''
}

export const DUMMY_CONT_CONFIG_ID = computeConfigurationName('DummyContConfig', '@scope/o3r-components');
export const DUMMY_CONT_CONFIG_ID = computeItemIdentifier('DummyContConfig', '@scope/o3r-components');
````

For more information on configuration, you can check this [documentation](../configuration/OVERVIEW.md).
Expand Down
101 changes: 0 additions & 101 deletions docs/components/PLACEHOLDERS.md
Original file line number Diff line number Diff line change
Expand Up @@ -296,107 +296,6 @@ Thanks to the parameters map you can use fact variables with JSONPath in localiz
}
```

#### Variable support for localization variables (DEPRECATED)

Before, localization variables could reference facts via variables instead of parameters. This feature is currently deprecated and will be removed from Otter v12 as it is replaced by the parameters explained above.

``en-GB.json``

```json
{
"o3r-increment-key": "{increment, plural, =1 {1 second has} other {{{increment}} seconds have}} elapsed since you opened the page"
}
```

``template.json``

```json
{
"vars": {
"incrementKey": {
"type": "localisation",
"value": "o3r-increment-key",
"vars": [
"incrementVar"
]
},
"incrementVar": {
"type": "fact",
"value": "increment"
}
},
"template": "<div style=\"border-radius:10%; background:red;\"><%= incrementKey %></div>"
}
```

The 1-to-1 mapping between the fact name and the reference in the translation brings many inconveniences as explained below.

> [!CAUTION]
> **Limitations**
> Today you can only make a reference to a fact with the same name. You also cannot use JSON path to resolve your fact.
This means the following is not possible:

``ruleset.json``

```json
{
"vars": {
"incrementKey": {
"type": "localisation",
"value": "o3r-increment-key",
"vars": [
"incrementVar"
]
},
"incrementVar": {
"type": "fact",
"value": "incrementFact",
"path": "$.this.is.a.json.path"
}
},
"template": "<div style=\"border-radius:10%; background:red;\"><%= incrementKey %></div>"
}
```

> [!TIPS]
> **General notice**
Keep in mind that this feature deeply binds functional facts exposed in your application to your translations.
You will need to carefully plan the way you bind your localization key to your facts to avoid messy references.

For example, let's imagine you want a generic counter until specific events.
You will probably want to reuse your placeholder in different pages for different events:

```json
{
"vars": {
"titleKey": {
"type": "localisation",
"value": "o3r-event-title-key"
},
"contentWithCounterKey": {
"type": "localisation",
"value": "o3r-event-counter-key",
"vars": [
"increment"
]
},
"increment": {
"type": "fact",
"value": "increment"
}
},
"template": "<div style=\"fancy-style: with-many-properties;\"><span style=\"fancy-title-style: nice-properties;\"><%= titleKey %></span><div><%= contentWithCounterKey %></div></div>"
}
```

You might be tempted to use this generic template for all your events but the value of your counter parameter will
depend on the event itself (Easter or next Summer Holidays for example).
This means that ``increment`` might have a different value depending on the context of the page which might be tricky to
maintain and to debug.
Try to keep it as simple as possible.

### Multiple templates in same placeholder

You can use placeholder actions to target the same placeholderId with different template URLs.
Expand Down
1 change: 0 additions & 1 deletion docs/core/MODULE.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@ To help developers to create their own Otter compatible module, the Otter framew

- [@o3r/schematics](https://www.npmjs.com/package/@o3r/schematics): exposes helper functions to develop the module schematic features
- [@o3r/extractors](https://www.npmjs.com/package/@o3r/extractors): exposes helper functions to create code metadata extractor to help in CMS communication
- [@o3r/dev-tools](https://www.npmjs.com/package/@o3r/dev-tools): provides a collection of Command Line Interfaces which can be used in CI and build workflows

## List of Otter official modules

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# @o3r/matching-configuration-name

Ensures that the configuration interface name matches the first parameter of `computeConfigurationName` used beside the configuration interface to expose its ID (as generated by the configuration module).
Ensures that the configuration interface name matches the first parameter of `computeItemIdentifier` used beside the configuration interface to expose its ID (as generated by the configuration module).

## How to use

Expand Down
3 changes: 0 additions & 3 deletions docs/rules-engine/how-to-use/dedicated-component-ruleset.md
Original file line number Diff line number Diff line change
Expand Up @@ -89,9 +89,6 @@ prevent the execution of the Ruleset until your component is available in the pa
]
}
```
> [!INFO]
> In v10 and the previous version, the Otter framework exposed the `linkedComponent` property to activate a ruleset on demand.
> This is now deprecated and will be removed in v12. Use `linkedComponents` instead.

## How it works

Expand Down
5 changes: 1 addition & 4 deletions eslint.shared.config.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -168,10 +168,7 @@ export default [
{
allowAfterThis: true,
allow: [
'_OTTER_DEVTOOLS_',
'__OTTER_STORYBOOK_STYLE_METADATA__',
'__OTTER_STORYBOOK_LOCALIZATION_METADATA__',
'__OTTER_STORYBOOK_CONFIGURATION_METADATA__'
'_OTTER_DEVTOOLS_'
]
}
]
Expand Down
4 changes: 0 additions & 4 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,6 @@
"test-int": "yarn nx run-many --target=test-int",
"postinstall": "husky && yarn build:lint && yarn harmonize:version && yarn update-yarn-sdks",
"update-yarn-sdks": "node -e \"'pnp' !== '$(yarn config get nodeLinker)' || process.exit(1)\" || yarn dlx @yarnpkg/sdks",
"build:storybook": "yarn doc:generate:json && yarn ng run storybook:extract-style && build-storybook",
"clear": "rimraf -g './{packages,tools,apps}/{@*/,}{amaterasu/,}*/{dist,build,dist-*}/'",
"set:version": "yarn o3r-set-version --placeholder 0.0.0-placeholder --include '{apps,packages}/**/dist/{package,manifest}.json'",
"harmonize:version": "eslint '**/package.json*' '.yarnrc.yml' --quiet --fix",
Expand All @@ -38,7 +37,6 @@
"doc:generate": "rimraf ./generated-doc && yarn doc:root && yarn doc:packages && yarn doc-links --docs ./docs --generated-doc ./generated-doc",
"doc:generate:json": "yarn update-doc-summary ./docs && yarn compodoc -e json -d .",
"start:modules": "yarn run build:dev:modules && yarn run watch:modules",
"storybook": "yarn doc:generate:json && yarn ng run storybook:extract-style && start-storybook -p 6006",
"verdaccio:start": "docker run -d -it --rm --name verdaccio -p 4873:4873 -v \"$(yarn get:current-dir)/.verdaccio/conf\":/verdaccio/conf verdaccio/verdaccio",
"verdaccio:start-local": "npx --yes verdaccio --config \"$(yarn get:current-dir)/.verdaccio/conf/config-without-docker.yaml\" --listen http://127.0.0.1:4873",
"verdaccio:start-persistent": "docker run -d -it --rm --name verdaccio -p 4873:4873 -v \"$(yarn get:current-dir)/.verdaccio/conf\":/verdaccio/conf -v \"$(yarn get:current-dir)/.verdaccio/storage\":/verdaccio/storage:z verdaccio/verdaccio",
Expand Down Expand Up @@ -253,8 +251,6 @@
"postcss-scss": "~4.0.9",
"prism-themes": "^1.9.0",
"prismjs": "^1.28.0",
"react": "^18.0.0",
"react-dom": "^18.0.0",
"replace-in-files-cli": "^2.2.0",
"rimraf": "^6.0.1",
"sass": "~1.81.0",
Expand Down
3 changes: 1 addition & 2 deletions packages/@ama-sdk/client-angular/src/api-angular-client.ts
Original file line number Diff line number Diff line change
Expand Up @@ -169,8 +169,7 @@ export class ApiAngularClient implements ApiClient {
exception = new EmptyResponseError(e.message || 'Fail to Fetch', undefined, { apiName, operationId, url, origin });
}

// eslint-disable-next-line no-console -- `console.error` is supposed to be the default value if the `options` argument is not provided, can be removed in Otter v12.
const reviver = getResponseReviver(revivers, response, operationId, { disableFallback: this.options.disableFallback, log: console.error });
const reviver = getResponseReviver(revivers, response, operationId, { disableFallback: this.options.disableFallback });
const replyPlugins = this.options.replyPlugins
? this.options.replyPlugins.map((plugin) => plugin.load<T>({
dictionaries: root && root.dictionaries,
Expand Down
3 changes: 1 addition & 2 deletions packages/@ama-sdk/core/src/clients/api-angular-client.ts
Original file line number Diff line number Diff line change
Expand Up @@ -193,8 +193,7 @@ export class ApiAngularClient implements ApiClient {
exception = new EmptyResponseError(e.message || 'Fail to Fetch', undefined, { apiName, operationId, url, origin });
}

// eslint-disable-next-line no-console -- `console.error` is supposed to be the default value if the `options` argument is not provided, can be removed in Otter v12.
const reviver = getResponseReviver(revivers, response, operationId, { disableFallback: this.options.disableFallback, log: console.error });
const reviver = getResponseReviver(revivers, response, operationId, { disableFallback: this.options.disableFallback });
const replyPlugins = this.options.replyPlugins
? this.options.replyPlugins.map((plugin) => plugin.load<T>({
dictionaries: root && root.dictionaries,
Expand Down
4 changes: 2 additions & 2 deletions packages/@ama-sdk/core/src/fwk/api.helpers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@ export function tokenizeRequestOptions(tokenizedUrl: string, queryParameters: {
* @param endpoint
* @param options `{ disableFallback: false, log: console.error }` by default
* @param options.disableFallback `false` by default
* @param options.log `() => {}` by default -- warning: default value will change to `console.error` in Otter v12.
* @param options.log `console.error` by default
*/
export function getResponseReviver<T>(
revivers: { [statusCode: number]: ReviverType<T> | undefined } | undefined | ReviverType<T>,
Expand All @@ -124,7 +124,7 @@ export function getResponseReviver<T>(
options?: { disableFallback?: boolean; log?: (...args: any[]) => void }
): ReviverType<T> | undefined {
// eslint-disable-next-line no-console -- set as default value
const { disableFallback = false, log: logMsg = options ? () => {} : console.error } = options ?? {};
const { disableFallback = false, log: logMsg = console.error } = options ?? {};
const logPrefix = `API status code error for ${endpoint || 'unknown'} endpoint`;
if (!response || !response.ok) {
return undefined;
Expand Down
21 changes: 1 addition & 20 deletions packages/@ama-sdk/schematics/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,7 @@
[![Bundle Size](https://img.shields.io/bundlephobia/min/@ama-sdk/schematics?color=green&style=for-the-badge)](https://www.npmjs.com/package/@ama-sdk/schematics)

This package provides `schematics` generators to create an SDK based on an OpenAPI specifications.
There are two SDK generators in the Otter Framework: Typescript and Java. The Java generator is currently in maintenance
mode and only the Typescript generator is actively supported and will see future evolutions.

- [Typescript SDK](#typescript-sdk)
- [Java SDK](#java-client-core-sdk)
The Otter framework provides a Typescript SDK generator.

## Typescript SDK

Expand Down Expand Up @@ -287,21 +283,6 @@ For more information on the generated SDK and how the framework supports differe
- [Generated SDK hierarchy and extension](https://github.com/AmadeusITGroup/otter/blob/main/docs/api-sdk/SDK_MODELS_HIERARCHY.md)
- [Composition and Inheritance support](https://github.com/AmadeusITGroup/otter/blob/main/docs/api-sdk/COMPOSITION_INHERITANCE.md)

## Java Client Core SDK

> [!WARNING]
> This feature is on maintenance mode and will see no future evolution
Generate a Java Client Core SDK:

Make sure to have a `./swagger-spec.yaml` file at the root of your project and run:

```shell
yarn schematics @ama-sdk/schematics:java-client-core --spec-path ./swagger-spec.yaml --swagger-config-path ./swagger-codegen-config.json
```

[Default swagger config](schematics/java/client-core/swagger-codegen-java-client/config/swagger-codegen-config.json) will be used if `--swagger-config-path` is not provided.

## Command Line Interface

This package also comes with CLI scripts that can facilitate the upgrade and publication of an SDK.
Expand Down
5 changes: 0 additions & 5 deletions packages/@ama-sdk/schematics/collection.json
Original file line number Diff line number Diff line change
Expand Up @@ -31,11 +31,6 @@
"description": "Generate a typescript SDK repository shell",
"factory": "./schematics/typescript/shell/index#ngGenerateTypescriptSDK",
"schema": "./schematics/typescript/shell/schema.json"
},
"java-client-core": {
"description": "[Deprecated - Removed in v12] Generate a Java SDK source code based on swagger specification",
"factory": "./schematics/java/client-core/index#ngGenerateJavaClientCore",
"schema": "./schematics/java/client-core/schema.json"
}
}
}
3 changes: 1 addition & 2 deletions packages/@ama-sdk/schematics/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -17,9 +17,8 @@
"postbuild": "patch-package-json-main",
"build:builders": "tsc -b tsconfig.builders.json --pretty && yarn generate-cjs-manifest",
"install-swagger-cli": "mvn install:install-file -DgroupId=io.swagger -DartifactId=swagger-codegen-cli -Dversion=2.4.0-AMADEUS -Dpackaging=jar -Dfile=./schematics/resources/swagger-codegen-cli.jar",
"build:swagger": "yarn install-swagger-cli && run-p 'build:swagger-*' 'build:openapi-*'",
"build:swagger": "yarn install-swagger-cli && run-p 'build:openapi-*'",
"build:openapi-typescript-gen": "mvn clean package -f ./schematics/typescript/core/openapi-codegen-typescript/pom.xml",
"build:swagger-java-client-gen": "mvn clean package -f ./schematics/java/client-core/swagger-codegen-java-client/pom.xml",
"build:cli": "tsc -b tsconfig.cli.json --pretty && yarn generate-cjs-manifest",
"prepare:publish": "prepare-publish ./dist"
},
Expand Down
Loading

0 comments on commit 5cb20ec

Please sign in to comment.