Single Page Drag/Drop application to create AEM Dialogs.
at least -- npm v11.0.0 -- node v22.13.0
npm i --force
npm run dev
Changes in those configurations require a rerun of npm run dev.
- tabs (section)
- fieldset
- textfield
- textarea
- numberfield
- richtext
- datepicker
- hidden
- select
- checkbox
- switch
- buttongroup
- radio
- fileupload
- pathfield
- anchorbutton
- alert
- heading
If you have custom dialog components in your AEM project you could also add a representation into the Dialog Designer using a Custom field Component.
To implement a custom dialog field to use in the Dialog Designer you need to add an appropriately named .js file to the custom component folder (./src/javascript/app/data/coral-components/custom)
This js file now needs to be imported inside the (./src/javascript/app/data/coral-components/index.js)
import helloworld from './components/custom/helloworld';
Additionally, the import needs to be added to the coralComponents Array in the same file.
const coralComponents = [
...
helloworld,
];
Property | ValueType | Info |
---|---|---|
name | String | Name used in sidepanel |
tag | String | Two character abbreviation used in sidepanel tag |
category | String | constants.fieldCategories (name) |
tagColor | String | constants.fieldCategories (color) |
id | String | Unique id for the field component, has to match field component import name (./src/javascript/app/data/coral-components/index.js) |
fields | Array | see "Field Edit Definitions" |
previewOutput | String | HTML template string that represents a preview output of the actual field component.Has placeholder support. |
xmlOutput | String | XML template string that represents actual cq:dialog.xml output that supports placeholders. |
The sample is already part of the application (./src/javascript/app/data/coral-components/custom/helloworld.js).
/* eslint-disable no-undef */
import constants from '../../constants';
const helloworld = {
name: 'HelloWorld',
tag: 'HW',
category: constants.fieldCategories.CUSTOM.name,
tagColor: constants.fieldCategories.CUSTOM.color,
description: 'Hello World Sample',
id: 'helloworld',
fields: [
FIELD_DEFINITION_ID,
{
id: 'hello',
label: 'Hellotext',
description: '',
type: 'String',
defaultValue: 'Hello',
required: true,
},
{
id: 'world',
label: 'Worldtext',
description: '',
type: 'String',
defaultValue: 'World',
required: true,
},
],
previewOutput: `<div class="helloworld">
<span class="helloworld_hello">{hello}</span>
<span class="helloworld_world">{world}</span>
</div>`,
xmlOutput: `<{id}
jcr:primaryType="nt:unstructured"
sling:resourceType="/apps/components/dialogfields/helloworld"
hello="{hello}"
world="{world}"
/>`,
};
export default helloworld;
import constants from '../../constants';
import LABEL_TEMPLATE from '../../partials/label';
import TOOLTIP_WRAPPER_TEMPLATE from '../../partials/tooltip';
Default predefined Field Edit Definitions to use in fields [] are:
- FIELD_DEFINITION_ID
- FIELD_DEFINITION_LABEL
- FIELD_DEFINITION_REQUIRED
- FIELD_DEFINITION_DESCRIPTION
Those constants include the most commonly used definitions for most components.
To use the constants you need to add an ignore on undefined variables to your field
/* eslint-disable no-undef */
Though of course custom definitions are possible and necessary.
Example:
{
id: 'hello',
label: 'Hellotext',
description: '',
type: 'String',
defaultValue: 'Hello',
required: true,
},
Property | Value-Type | Info |
---|---|---|
id | String | Unique for the current field. Used to access inside previewOutput or xmlOutput via placeholder expression. |
label | String | Shown as label inside the edit field dialog on the current edit field property |
description | String | [optional] Shown as info tooltip inside the edit field dialog on the current edit field property |
type | String | [String, Boolean, Long, KeyValue] (constants.fieldValueTypes constants can be used as well here |
defaultValue | String | [optional] Default value for the edit field property inserted upon creation. |
required | Boolean | [optional] whether or not to Editfield property is mandatory or not. Default: false |
If necessary custom CSS for your custom field to better represent the real field can be added within ./src/scss/custom/index.scss. A sample can be found in ./src/scss/custom/helloworld.scss (while imported in the upper mentioned index.scss).
Format | Filename | Info |
---|---|---|
XML | _cq_dialog.xml | to directly use in AEM projects |
JSON | dialog.json | For saving on disk an future load feature in tools Library |
AEM Component Generator JSON | acg.json | to use with AEM Component Generator |
Please checkout our contributing guideline.