Skip to content

Commit

Permalink
Merge pull request #195 from ronaldssebalamu/Fix-typos-and-markdown-c…
Browse files Browse the repository at this point in the history
…ontents

Fix typos and markdown contents.
  • Loading branch information
stephengoldbaum authored Aug 18, 2023
2 parents 63fadd8 + 517e001 commit c7e2b1a
Showing 1 changed file with 42 additions and 29 deletions.
71 changes: 42 additions & 29 deletions docs/json-schema-enabled developers guide.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,39 +6,43 @@ title: json-schema-enabled Decorator
# The json-schema-enabled Decorator Developer's Guide
This is a developer's guide on how the json-schema-enabled decorator works and how it is applied to:
* types
* modules
It also details how configuration file is processed and how these configuration used for code generation
* modules

It also details how the configuration file is processed and how these configurations are used for code generation

## Overview of json-schema-enabled Decorator
The json-schema-enabled decorator is modeled as a boolean type in the JsonSchema module in the
Attribute model.
When a json-schema-enabled decorator value of true is applied to a type or module, then json-schema
backend code generation would be based on these. All annotated types, as well as all their transitive dependencies
are included in the generated schema
backend code generation would be based on these:
* All annotated types, as well as all their transitive dependencies
are included in the generated schema.
When applied to a type, the fully qualified name is used as the key in the attributed dictionary.
But when applied to a module, a tuple of (packgeName, moduleName) is used as the key
All decorator configurations for a project are place in the attributes-conf.json file placed next to the main IR.
But when applied to a module, a tuple of (packageName, moduleName) is used as the key
* All decorator configurations for a project are placed in the attributes-conf.json file placed next to the main IR.

## Decoration Configuration Modeling
The Custom Attribute configuration model is found in the [CustomAttributes](../../../src/Morphir/CustomAttribute) directory.
The main types of for the decorator configuration model are the CustomAttributeId,
The main types for the decorator configuration model are the CustomAttributeId,
the CustomAttributeConfig, the CustomAttributesConfigs, the CustomAttributesInfo
and the CustomAttributesDetails
* CustomAttributeId - a string type that represents the unique id of the decorator
* CustomAttributeConfig - a record type with one field: filePath which is of type FilePath and represents the attributes-conf.json file
* CustomAttributesConfigs - dictionary of all CustomAttributeConfigs keyed by the CustomAttributeID
* CustomAttributeInfo - dictionary of CustomAttributeInfo keyed by the CustomAttributesId
* CustomAttributeDetails - a record type of with the following fields:
* CustomAttributeDetails - a record type with the following fields:
* displayName - String display name of the custom attribute
* entryPoint - FQName or ModuleName being decorated
* iR - Distribution for the custom attribute IR
* data - the custom attribute dictionary (content of the <unique-id.json> file)

## Setting Up json-schema-enabled for a New Project
This section explains how the json-schema-enabled decorator is setup for a Morphir project
This section explains how the json-schema-enabled decorator is set up for a Morphir project

### Scenario 1
Decorator setup for a project without existing decorator(s)
Decorator setup for a project without an existing decorator(s)
Follow the steps below to add json-schema-enabled decorator to a Morphir project.

**Step 1** - Create the attributes-conf.json file next to the main IR. Enter the record for the
json-schema-enabled decorator as shown below

Expand All @@ -54,45 +58,54 @@ json-schema-enabled decorator as shown below

**Step 2** - Create a new Morphir model in next to the existing IR. This model would contain a single
module named JsonSchema with the SchemaEnabled type defined. This model is place in attributes model folder
**Step 3** - Run the make command on the attributes model to generate the attributes IR

**Step 3** - Run the make command on the attributes model to generate the attributes IR

**Step 4 (Optional)** - Create the attributes folder next to the main IR. Inside the folder, create the
json-schema-enabled.json file (the attributes dictionary). Leave it empty
**Step 5** - Start the Develop UI app. The select and type, value or module. Tab to the Custom Attributes tab

**Step 5** - Start the Develop UI app. Select and type, value, or module. Tab to the Custom Attributes tab
and apply the json-schema-enabled by selecting one of the options (yes/no)

**Step 6** - Run the morphir json-schema-gen command to generate the Json Schema

### Scenario 2
Decorator setup for a project with existing decorator(s)
**Step 1** - Open the custom-attributes.conf.json and add a new record for the new decorator
**Step 2** - Update the attributes model to include the new decorator type (either on the same or a new module)

**Step 1** - Open the custom-attributes.conf.json and add a new record for the new decorator

**Step 2** - Update the attributes model to include the new decorator type (either on the same or a new module)

**Step 3** - Run the make command to generate your updated IR
Steps 4 to 6 remains the same

Steps 4 to 6 remain the same


## Decorator Configuration Processing - JavaScript
This section explains how decorator configuration is processed and attached to types, values and modules in
This section explains how decorator configuration is processed and attached to types, values, and modules in
the main IR.
Processing on the decorator configuration begins with the launch of the Develop app.
The decorator configuration records are read from the attributes-conf.json file and processed record by record.
The decorator-conf.json file is key by a unque-id. The value is a an object with three properties:
The decorator-conf.json file is keyed by a unique-id. The value is an object with three properties:
* displayName: the display name of the decorator
* entryPoint: the FQName or ModuleName it applies to
* ir: filepath to the decorator IR
* ir: the filepath to the decorator IR

For each record:
retrieve the custom attributed dictionary by reading which is in a file name with the unique-id of the attribute
using the path field of the record, retrieve the IR of the current custom attribute
Build the decorator details which has four fields:
* displayName
* entryPoint
* data
* iR

A simple API is created that exposes the processed decorator configuration. This is avaialble via the
* Retrieve the custom attributed dictionary by reading which is in a file name with the unique-id of the attribute
using the path field of the record,
* Retrieve the IR of the current custom attribute
* Build the decorator details which have four fields:
* displayName
* entryPoint
* data
* iR

A simple API is created that exposes the processed decorator configuration. This is available via the
`/server/attributes` route.

## Decorator Configuration Processing - Elm
The Morphir Develop app makes a HTTP call to the decorator URL to fetch all the decorators. This is then decoded
into CustomAttributeConfigs which is dictionary of CustomAttributeId and CustomAttributeConfig which is a
The Morphir Develop app makes an HTTP call to the decorator URL to fetch all the decorators. This is then decoded
into CustomAttributeConfigs which is a dictionary of CustomAttributeId and CustomAttributeConfig which is a
dictionary of CustomAttributeId and CustomAttributeDetails.
These are then displayed in the UI using Morphir ValueEditors.

0 comments on commit c7e2b1a

Please sign in to comment.