@wavemaker/app-ng-runtime 12.0.0-next.45078 → 12.0.0-next.45081

Sign up to get free protection for your applications and to get access to all the features.
Files changed (47) hide show
  1. app-ng-runtime/build-task/bundles/index.umd.js +8 -1
  2. app-ng-runtime/build-task/esm2022/data/form/form-field/form-field.build.mjs +9 -2
  3. app-ng-runtime/build-task/fesm2022/index.mjs +8 -1
  4. app-ng-runtime/build-task/fesm2022/index.mjs.map +1 -1
  5. app-ng-runtime/components/advanced/custom/bundles/index.umd.js +49 -12
  6. app-ng-runtime/components/advanced/custom/custom-widget-container/custom-widget-container.directive.d.ts +11 -4
  7. app-ng-runtime/components/advanced/custom/esm2022/custom-widget-container/custom-widget-container.directive.mjs +51 -11
  8. app-ng-runtime/components/advanced/custom/fesm2022/index.mjs +50 -10
  9. app-ng-runtime/components/advanced/custom/fesm2022/index.mjs.map +1 -1
  10. app-ng-runtime/components/base/bundles/index.umd.js +13 -3
  11. app-ng-runtime/components/base/esm2022/widgets/common/base/base.component.mjs +14 -4
  12. app-ng-runtime/components/base/esm2022/widgets/framework/property-change-handler.mjs +2 -2
  13. app-ng-runtime/components/base/fesm2022/index.mjs +14 -4
  14. app-ng-runtime/components/base/fesm2022/index.mjs.map +1 -1
  15. app-ng-runtime/components/base/widgets/common/base/base.component.d.ts +1 -0
  16. app-ng-runtime/components/basic/search/bundles/index.umd.js +36 -24
  17. app-ng-runtime/components/basic/search/esm2022/search.component.mjs +33 -24
  18. app-ng-runtime/components/basic/search/esm2022/search.props.mjs +5 -2
  19. app-ng-runtime/components/basic/search/fesm2022/index.mjs +36 -24
  20. app-ng-runtime/components/basic/search/fesm2022/index.mjs.map +1 -1
  21. app-ng-runtime/components/basic/search/search.component.d.ts +3 -0
  22. app-ng-runtime/components/data/form/bundles/index.umd.js +23 -11
  23. app-ng-runtime/components/data/form/esm2022/form-field/form-field.directive.mjs +24 -12
  24. app-ng-runtime/components/data/form/fesm2022/index.mjs +23 -11
  25. app-ng-runtime/components/data/form/fesm2022/index.mjs.map +1 -1
  26. app-ng-runtime/components/data/form/form-field/form-field.directive.d.ts +1 -0
  27. app-ng-runtime/components/input/default/base-form-custom.component.d.ts +2 -1
  28. app-ng-runtime/components/input/default/bundles/index.umd.js +13 -4
  29. app-ng-runtime/components/input/default/dataset-aware-form.component.d.ts +2 -2
  30. app-ng-runtime/components/input/default/esm2022/base-form-custom.component.mjs +6 -1
  31. app-ng-runtime/components/input/default/esm2022/checkboxset/checkboxset.component.mjs +3 -1
  32. app-ng-runtime/components/input/default/esm2022/dataset-aware-form.component.mjs +5 -5
  33. app-ng-runtime/components/input/default/esm2022/radioset/radioset.component.mjs +3 -1
  34. app-ng-runtime/components/input/default/fesm2022/index.mjs +13 -4
  35. app-ng-runtime/components/input/default/fesm2022/index.mjs.map +1 -1
  36. app-ng-runtime/core/bundles/index.umd.js +6 -6
  37. app-ng-runtime/core/enums/enums.d.ts +2 -2
  38. app-ng-runtime/core/esm2022/enums/enums.mjs +2 -2
  39. app-ng-runtime/core/esm2022/utils/build-utils.mjs +6 -6
  40. app-ng-runtime/core/fesm2022/index.mjs +6 -6
  41. app-ng-runtime/core/fesm2022/index.mjs.map +1 -1
  42. app-ng-runtime/package.json +1 -1
  43. app-ng-runtime/runtime/base/bundles/index.umd.js +9 -0
  44. app-ng-runtime/runtime/base/components/base-custom-widget.component.d.ts +2 -0
  45. app-ng-runtime/runtime/base/esm2022/components/base-custom-widget.component.mjs +10 -1
  46. app-ng-runtime/runtime/base/fesm2022/index.mjs +9 -0
  47. app-ng-runtime/runtime/base/fesm2022/index.mjs.map +1 -1
@@ -1012,6 +1012,13 @@
1012
1012
  }
1013
1013
  };
1014
1014
  const getWidgetTemplate = (attrs, options) => {
1015
+ let customAttrs = ``;
1016
+ if (options.widgetType === "custom-widget") {
1017
+ for (let [key, value] of attrs) {
1018
+ if (key.startsWith('prop-'))
1019
+ customAttrs += key + '="' + value + '" ';
1020
+ }
1021
+ }
1015
1022
  const name = attrs.get('name');
1016
1023
  const customWidgetName = attrs.get('widgetname');
1017
1024
  const fieldName = (attrs.get('key') || name || '').trim();
@@ -1019,7 +1026,7 @@
1019
1026
  const tmplRef = options.isMaxWidget ? `#formWidgetMax` : `#formWidget`;
1020
1027
  const widgetName = name ? (options.isMaxWidget ? `name="${name}_formWidgetMax"` : `name="${name}_formWidget"`) : '';
1021
1028
  const conditionalClass = `[ngClass]="${attrs.get('ngclass')}"`;
1022
- const defaultTmpl = `[class.hidden]="!${options.pCounter}.isUpdateMode && ${options.counter}.viewmodewidget !== 'default'" ${formControl} ${options.eventsTmpl} ${conditionalClass} ${tmplRef} ${widgetName} ${customWidgetName ? `widgetname=${customWidgetName}` : ''}`;
1029
+ const defaultTmpl = `[class.hidden]="!${options.pCounter}.isUpdateMode && ${options.counter}.viewmodewidget !== 'default'" ${formControl} ${options.eventsTmpl} ${conditionalClass} ${tmplRef} ${widgetName} ${customWidgetName ? `widgetname=${customWidgetName} ${customAttrs}` : ''}`;
1023
1030
  return core.getFormWidgetTemplate(options.widgetType, defaultTmpl, attrs, { counter: options.counter, pCounter: options.pCounter });
1024
1031
  };
1025
1032
  const getTemplate = (attrs, widgetType, eventsTmpl, counter, pCounter, isInList) => {
@@ -52,6 +52,13 @@ const setDefaultPlaceholder = (attrs, widgetType, index) => {
52
52
  }
53
53
  };
54
54
  const getWidgetTemplate = (attrs, options) => {
55
+ let customAttrs = ``;
56
+ if (options.widgetType === "custom-widget") {
57
+ for (let [key, value] of attrs) {
58
+ if (key.startsWith('prop-'))
59
+ customAttrs += key + '="' + value + '" ';
60
+ }
61
+ }
55
62
  const name = attrs.get('name');
56
63
  const customWidgetName = attrs.get('widgetname');
57
64
  const fieldName = (attrs.get('key') || name || '').trim();
@@ -59,7 +66,7 @@ const getWidgetTemplate = (attrs, options) => {
59
66
  const tmplRef = options.isMaxWidget ? `#formWidgetMax` : `#formWidget`;
60
67
  const widgetName = name ? (options.isMaxWidget ? `name="${name}_formWidgetMax"` : `name="${name}_formWidget"`) : '';
61
68
  const conditionalClass = `[ngClass]="${attrs.get('ngclass')}"`;
62
- const defaultTmpl = `[class.hidden]="!${options.pCounter}.isUpdateMode && ${options.counter}.viewmodewidget !== 'default'" ${formControl} ${options.eventsTmpl} ${conditionalClass} ${tmplRef} ${widgetName} ${customWidgetName ? `widgetname=${customWidgetName}` : ''}`;
69
+ const defaultTmpl = `[class.hidden]="!${options.pCounter}.isUpdateMode && ${options.counter}.viewmodewidget !== 'default'" ${formControl} ${options.eventsTmpl} ${conditionalClass} ${tmplRef} ${widgetName} ${customWidgetName ? `widgetname=${customWidgetName} ${customAttrs}` : ''}`;
63
70
  return getFormWidgetTemplate(options.widgetType, defaultTmpl, attrs, { counter: options.counter, pCounter: options.pCounter });
64
71
  };
65
72
  const getTemplate = (attrs, widgetType, eventsTmpl, counter, pCounter, isInList) => {
@@ -158,4 +165,4 @@ const registerFormField = (isFormField) => {
158
165
  register('wm-form-field', registerFormField.bind(this, true));
159
166
  register('wm-filter-field', registerFormField.bind(this, false));
160
167
  export default () => { };
161
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.build.js","sourceRoot":"","sources":["../../../../../../projects/components/transpile/src/data/form/form-field/form-field.build.ts"],"names":[],"mappings":"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","sourcesContent":["import {getFormMarkupAttr, IBuildTaskDef, register} from '@wm/transpiler';\nimport {\n    FormWidgetType,\n    generateGUId,\n    getFormWidgetTemplate,\n    getRequiredFormWidget,\n    IDGenerator,\n    isMobileApp\n} from '@wm/core';\n\nimport {ALLFIELDS, isDataSetWidget} from '../../../utils/utils';\n\nconst tagName = 'div';\nconst idGen = new IDGenerator('formfield_');\n\nconst getEventsTemplate = (attrs) => {\n    const eventAttrs = new Map();\n    if (!attrs.has('focus.event')) {\n        attrs.set('focus.event', '');\n    }\n    if (!attrs.has('blur.event')) {\n        attrs.set('blur.event', '');\n    }\n    attrs.forEach((value, key) => {\n       if (key.endsWith('.event')) {\n           if (key === 'focus.event') {\n               value = `_onFocusField($event);${value}`;\n           } else if (key === 'blur.event') {\n               value = `_onBlurField($event);${value}`;\n           }\n           eventAttrs.set(key, value);\n           attrs.delete(key);\n       }\n    });\n    return getFormMarkupAttr(eventAttrs);\n};\n\nconst DEFAULT_PLACEHOLDERS = new Map([\n    [FormWidgetType.SELECT, ['Select Min value', 'Select Max value', 'Select value']],\n    [FormWidgetType.DATETIME, ['Select Min date time', 'Select Max date time', 'Select date time']],\n    [FormWidgetType.TIME, ['Select Min time', 'Select Max time', 'Select time']],\n    [FormWidgetType.DATE, ['Select Min date', 'Select Max date', 'Select date']],\n    [FormWidgetType.TEXTAREA, ['', '', 'Enter value']],\n    [FormWidgetType.RICHTEXT, ['', '', 'Enter value']],\n    [FormWidgetType.COLORPICKER, ['Select Color', 'Select Color', 'Select Color']],\n    [FormWidgetType.CHIPS, ['', '', 'Type here...']],\n    [FormWidgetType.PASSWORD, ['Enter Min value', 'Enter Max value', 'Enter value']],\n    [FormWidgetType.NUMBER, ['Enter Min value', 'Enter Max value', 'Enter value']],\n    [FormWidgetType.TEXT, ['Enter Min value', 'Enter Max value', 'Enter value']],\n    [FormWidgetType.CURRENCY, ['Enter Min value', 'Enter Max value', 'Enter value']],\n    [FormWidgetType.AUTOCOMPLETE, ['', '', 'Search']],\n]);\n\nconst setDefaultPlaceholder = (attrs, widgetType, index) => {\n    const prop = index === 1 ? 'maxplaceholder' : 'placeholder';\n    let placeholder = attrs.get(prop);\n    if (placeholder || placeholder === '') {\n        return;\n    }\n    placeholder = DEFAULT_PLACEHOLDERS.get(widgetType) && DEFAULT_PLACEHOLDERS.get(widgetType)[index];\n    if (placeholder) {\n        attrs.set(prop, placeholder);\n    }\n};\n\nconst getWidgetTemplate = (attrs, options) => {\n    const name = attrs.get('name');\n    const customWidgetName = attrs.get('widgetname');\n    const fieldName = (attrs.get('key') || name || '').trim();\n    const formControl = options.isMaxWidget ? `formControlName=\"${fieldName}_max\"` : (options.isInList ? `[formControlName]=\"${options.counter}._fieldName\"` : `formControlName=\"${fieldName}\"`);\n    const tmplRef = options.isMaxWidget ? `#formWidgetMax` : `#formWidget`;\n    const widgetName = name ? (options.isMaxWidget ? `name=\"${name}_formWidgetMax\"` : `name=\"${name}_formWidget\"`) : '';\n    const conditionalClass = `[ngClass]=\"${attrs.get('ngclass')}\"`;\n    const defaultTmpl = `[class.hidden]=\"!${options.pCounter}.isUpdateMode && ${options.counter}.viewmodewidget !== 'default'\" ${formControl} ${options.eventsTmpl} ${conditionalClass} ${tmplRef} ${widgetName} ${customWidgetName ? `widgetname=${customWidgetName}`:''}` ;\n    return getFormWidgetTemplate(options.widgetType, defaultTmpl, attrs, {counter: options.counter, pCounter: options.pCounter});\n};\n\n\nconst getTemplate = (attrs, widgetType, eventsTmpl, counter, pCounter, isInList) => {\n    const isRange = attrs.get('is-range') === 'true';\n    if (!isRange) {\n        return getWidgetTemplate(attrs, {widgetType, eventsTmpl, counter, pCounter, isInList});\n    }\n    const layoutClass = isMobileApp() ? 'col-xs-6' : 'col-sm-6';\n    return `<div class=\"${layoutClass}\">${getWidgetTemplate(attrs, {widgetType, eventsTmpl, counter, pCounter})}</div>\n                <div class=\"${layoutClass}\">${getWidgetTemplate(attrs, {widgetType, eventsTmpl, counter, pCounter, isMaxWidget: true})}</div>`;\n};\n\nconst getCaptionByWidget = (attrs, widgetType, counter) => {\n    if (attrs.get('is-related') === 'true') {\n        return `${counter}.getDisplayExpr()`;\n    }\n    if (widgetType === FormWidgetType.PASSWORD) {\n        return '\\'********\\'';\n    }\n    let caption = `${counter}.value`;\n    if (widgetType === FormWidgetType.DATETIME || widgetType === FormWidgetType.TIMESTAMP) {\n        caption += ` | toDate:${counter}.formWidget.datepattern || 'yyyy-MM-dd hh:mm:ss a'`;\n        return caption;\n    }\n    if (widgetType === FormWidgetType.TIME) {\n        caption += ` | toDate:${counter}.formWidget.timepattern || 'hh:mm a'`;\n        return caption;\n    }\n    if (widgetType === FormWidgetType.DATE) {\n        caption += ` | toDate:${counter}.formWidget.datepattern ||  'yyyy-MMM-dd'`;\n        return caption;\n    }\n    if (widgetType === FormWidgetType.RATING || widgetType === FormWidgetType.UPLOAD) {\n        return '';\n    }\n    if (isDataSetWidget(widgetType) && attrs.get('datafield') === ALLFIELDS) {\n        return `${counter}.getDisplayExpr()`;\n    }\n    return `${counter}.getCaption()`;\n};\n\nconst registerFormField = (isFormField): IBuildTaskDef => {\n    return {\n        requires: ['wm-form', 'wm-liveform', 'wm-livefilter', 'wm-list'],\n        pre: (attrs, shared, parentForm, parentLiveForm, parentFilter, parentList) => {\n            const counter = idGen.nextUid();\n            const parent = parentForm || parentLiveForm || parentFilter;\n            const pCounter = (parent && parent.get('form_reference')) || 'form';\n            const widgetType = attrs.get('widget') || FormWidgetType.TEXT;\n            const dataRole = isFormField ? 'form-field' : 'filter-field';\n            const formFieldErrorMsgId = 'wmform-field-error-' + generateGUId();\n            const validationMsg = isFormField ? `<p *ngIf=\"${counter}._control?.invalid && ${counter}._control?.touched && ${pCounter}.isUpdateMode\"\n                                   class=\"help-block text-danger\" aria-hidden=\"false\"\n                                   aria-live=\"assertive\" [attr.aria-label]=\"${counter}.validationmessage\" id=\"${formFieldErrorMsgId}\"><span aria-hidden=\"true\" [textContent]=\"${counter}.validationmessage\"></span></p>` : '';\n            const eventsTmpl = widgetType === FormWidgetType.UPLOAD ? '' : getEventsTemplate(attrs);\n            const controlLayout = isMobileApp() ? 'col-xs-12' : 'col-sm-12';\n            const isInList = pCounter === (parentList && parentList.get('parent_form_reference'));\n            attrs.set('__validationId', formFieldErrorMsgId);\n            attrs.set('__widgetType', widgetType);\n            attrs.delete('widget');\n            shared.set('counter', counter);\n\n            if (attrs.get('is-range') === 'true') {\n                setDefaultPlaceholder(attrs, widgetType, 0);\n                setDefaultPlaceholder(attrs, widgetType, 1);\n            } else {\n                setDefaultPlaceholder(attrs, widgetType, 2);\n            }\n\n            return `<${tagName} data-role=\"${dataRole}\" [formGroup]=\"${pCounter}.ngform\" wmFormField wmCaptionPosition #${counter}=\"wmFormField\" widgettype=\"${widgetType}\" ${getFormMarkupAttr(attrs)}>\n                        <div class=\"live-field form-group app-composite-widget clearfix caption-{{${pCounter}.captionposition}}\" widget=\"${widgetType}\">\n                            <label [hidden]=\"!${counter}.displayname\" class=\"app-label control-label formfield-label {{${pCounter}._captionClass}}\"\n                                        [ngStyle]=\"{width: ${pCounter}.captionsize}\" [ngClass]=\"{'text-danger': ${counter}._control?.invalid && ${counter}._control?.touched && ${pCounter}.isUpdateMode,\n                                         required: ${pCounter}.isUpdateMode && ${counter}.required}\" [textContent]=\"${counter}.displayname\"> </label>\n                            <div [ngClass]=\"${counter}.displayname ? ${pCounter}._widgetClass : '${controlLayout}'\">\n                                 <label class=\"form-control-static app-label\"\n                                       [hidden]=\"${pCounter}.isUpdateMode || ${counter}.viewmodewidget === 'default' || ${counter}.widgettype === 'upload'\" [innerHTML]=\"${getCaptionByWidget(attrs, widgetType, counter)}\"></label>\n                                ${getTemplate(attrs, widgetType, eventsTmpl, counter, pCounter, isInList)}\n                                <span aria-hidden=\"true\" *ngIf=\"${counter}.showPendingSpinner\" class=\"form-field-spinner fa fa-circle-o-notch fa-spin form-control-feedback\"></span>\n                                <p *ngIf=\"!(${counter}._control?.invalid && ${counter}._control?.touched) && ${pCounter}.isUpdateMode\"\n                                   class=\"help-block\" aria-hidden=\"true\" role=\"alert\" aria-live=\"polite\" [textContent]=\"${counter}.hint\"></p>\n                                ${validationMsg}\n                            </div>\n                        </div>`;\n        },\n        post: () => `</${tagName}>`,\n        provide: (attrs, shared) => {\n            const provider = new Map();\n            provider.set('form_reference', shared.get('counter'));\n            return provider;\n        },\n        imports: (attrs: Map<String, String>): string[] => {\n            const requiredWidget = getRequiredFormWidget(attrs.get('__widgetType') || attrs.get('type'));\n            attrs.delete('__widgetType');\n            return [requiredWidget, 'wm-form'];\n        }\n    };\n};\n\nregister('wm-form-field', registerFormField.bind(this, true));\nregister('wm-filter-field', registerFormField.bind(this, false));\n\nexport default () => {};\n"]}
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.build.js","sourceRoot":"","sources":["../../../../../../projects/components/transpile/src/data/form/form-field/form-field.build.ts"],"names":[],"mappings":"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","sourcesContent":["import {getFormMarkupAttr, IBuildTaskDef, register} from '@wm/transpiler';\nimport {\n    FormWidgetType,\n    generateGUId,\n    getFormWidgetTemplate,\n    getRequiredFormWidget,\n    IDGenerator,\n    isMobileApp\n} from '@wm/core';\n\nimport {ALLFIELDS, isDataSetWidget} from '../../../utils/utils';\nimport {forEach} from \"lodash-es\";\n\nconst tagName = 'div';\nconst idGen = new IDGenerator('formfield_');\n\nconst getEventsTemplate = (attrs) => {\n    const eventAttrs = new Map();\n    if (!attrs.has('focus.event')) {\n        attrs.set('focus.event', '');\n    }\n    if (!attrs.has('blur.event')) {\n        attrs.set('blur.event', '');\n    }\n    attrs.forEach((value, key) => {\n       if (key.endsWith('.event')) {\n           if (key === 'focus.event') {\n               value = `_onFocusField($event);${value}`;\n           } else if (key === 'blur.event') {\n               value = `_onBlurField($event);${value}`;\n           }\n           eventAttrs.set(key, value);\n           attrs.delete(key);\n       }\n    });\n    return getFormMarkupAttr(eventAttrs);\n};\n\nconst DEFAULT_PLACEHOLDERS = new Map([\n    [FormWidgetType.SELECT, ['Select Min value', 'Select Max value', 'Select value']],\n    [FormWidgetType.DATETIME, ['Select Min date time', 'Select Max date time', 'Select date time']],\n    [FormWidgetType.TIME, ['Select Min time', 'Select Max time', 'Select time']],\n    [FormWidgetType.DATE, ['Select Min date', 'Select Max date', 'Select date']],\n    [FormWidgetType.TEXTAREA, ['', '', 'Enter value']],\n    [FormWidgetType.RICHTEXT, ['', '', 'Enter value']],\n    [FormWidgetType.COLORPICKER, ['Select Color', 'Select Color', 'Select Color']],\n    [FormWidgetType.CHIPS, ['', '', 'Type here...']],\n    [FormWidgetType.PASSWORD, ['Enter Min value', 'Enter Max value', 'Enter value']],\n    [FormWidgetType.NUMBER, ['Enter Min value', 'Enter Max value', 'Enter value']],\n    [FormWidgetType.TEXT, ['Enter Min value', 'Enter Max value', 'Enter value']],\n    [FormWidgetType.CURRENCY, ['Enter Min value', 'Enter Max value', 'Enter value']],\n    [FormWidgetType.AUTOCOMPLETE, ['', '', 'Search']],\n]);\n\nconst setDefaultPlaceholder = (attrs, widgetType, index) => {\n    const prop = index === 1 ? 'maxplaceholder' : 'placeholder';\n    let placeholder = attrs.get(prop);\n    if (placeholder || placeholder === '') {\n        return;\n    }\n    placeholder = DEFAULT_PLACEHOLDERS.get(widgetType) && DEFAULT_PLACEHOLDERS.get(widgetType)[index];\n    if (placeholder) {\n        attrs.set(prop, placeholder);\n    }\n};\n\nconst getWidgetTemplate = (attrs, options) => {\n    let customAttrs = ``;\n    if(options.widgetType === \"custom-widget\") {\n        for (let [key, value] of attrs) {\n            if(key.startsWith('prop-'))\n                customAttrs += key + '=\"' + value + '\" ';\n        }\n    }\n    const name = attrs.get('name');\n    const customWidgetName = attrs.get('widgetname');\n    const fieldName = (attrs.get('key') || name || '').trim();\n    const formControl = options.isMaxWidget ? `formControlName=\"${fieldName}_max\"` : (options.isInList ? `[formControlName]=\"${options.counter}._fieldName\"` : `formControlName=\"${fieldName}\"`);\n    const tmplRef = options.isMaxWidget ? `#formWidgetMax` : `#formWidget`;\n    const widgetName = name ? (options.isMaxWidget ? `name=\"${name}_formWidgetMax\"` : `name=\"${name}_formWidget\"`) : '';\n    const conditionalClass = `[ngClass]=\"${attrs.get('ngclass')}\"`;\n    const defaultTmpl = `[class.hidden]=\"!${options.pCounter}.isUpdateMode && ${options.counter}.viewmodewidget !== 'default'\" ${formControl} ${options.eventsTmpl} ${conditionalClass} ${tmplRef} ${widgetName} ${customWidgetName ? `widgetname=${customWidgetName} ${customAttrs}`:''}` ;\n    return getFormWidgetTemplate(options.widgetType, defaultTmpl, attrs, {counter: options.counter, pCounter: options.pCounter});\n};\n\n\nconst getTemplate = (attrs, widgetType, eventsTmpl, counter, pCounter, isInList) => {\n    const isRange = attrs.get('is-range') === 'true';\n    if (!isRange) {\n        return getWidgetTemplate(attrs, {widgetType, eventsTmpl, counter, pCounter, isInList});\n    }\n    const layoutClass = isMobileApp() ? 'col-xs-6' : 'col-sm-6';\n    return `<div class=\"${layoutClass}\">${getWidgetTemplate(attrs, {widgetType, eventsTmpl, counter, pCounter})}</div>\n                <div class=\"${layoutClass}\">${getWidgetTemplate(attrs, {widgetType, eventsTmpl, counter, pCounter, isMaxWidget: true})}</div>`;\n};\n\nconst getCaptionByWidget = (attrs, widgetType, counter) => {\n    if (attrs.get('is-related') === 'true') {\n        return `${counter}.getDisplayExpr()`;\n    }\n    if (widgetType === FormWidgetType.PASSWORD) {\n        return '\\'********\\'';\n    }\n    let caption = `${counter}.value`;\n    if (widgetType === FormWidgetType.DATETIME || widgetType === FormWidgetType.TIMESTAMP) {\n        caption += ` | toDate:${counter}.formWidget.datepattern || 'yyyy-MM-dd hh:mm:ss a'`;\n        return caption;\n    }\n    if (widgetType === FormWidgetType.TIME) {\n        caption += ` | toDate:${counter}.formWidget.timepattern || 'hh:mm a'`;\n        return caption;\n    }\n    if (widgetType === FormWidgetType.DATE) {\n        caption += ` | toDate:${counter}.formWidget.datepattern ||  'yyyy-MMM-dd'`;\n        return caption;\n    }\n    if (widgetType === FormWidgetType.RATING || widgetType === FormWidgetType.UPLOAD) {\n        return '';\n    }\n    if (isDataSetWidget(widgetType) && attrs.get('datafield') === ALLFIELDS) {\n        return `${counter}.getDisplayExpr()`;\n    }\n    return `${counter}.getCaption()`;\n};\n\nconst registerFormField = (isFormField): IBuildTaskDef => {\n    return {\n        requires: ['wm-form', 'wm-liveform', 'wm-livefilter', 'wm-list'],\n        pre: (attrs, shared, parentForm, parentLiveForm, parentFilter, parentList) => {\n            const counter = idGen.nextUid();\n            const parent = parentForm || parentLiveForm || parentFilter;\n            const pCounter = (parent && parent.get('form_reference')) || 'form';\n            const widgetType = attrs.get('widget') || FormWidgetType.TEXT;\n            const dataRole = isFormField ? 'form-field' : 'filter-field';\n            const formFieldErrorMsgId = 'wmform-field-error-' + generateGUId();\n            const validationMsg = isFormField ? `<p *ngIf=\"${counter}._control?.invalid && ${counter}._control?.touched && ${pCounter}.isUpdateMode\"\n                                   class=\"help-block text-danger\" aria-hidden=\"false\"\n                                   aria-live=\"assertive\" [attr.aria-label]=\"${counter}.validationmessage\" id=\"${formFieldErrorMsgId}\"><span aria-hidden=\"true\" [textContent]=\"${counter}.validationmessage\"></span></p>` : '';\n            const eventsTmpl = widgetType === FormWidgetType.UPLOAD ? '' : getEventsTemplate(attrs);\n            const controlLayout = isMobileApp() ? 'col-xs-12' : 'col-sm-12';\n            const isInList = pCounter === (parentList && parentList.get('parent_form_reference'));\n            attrs.set('__validationId', formFieldErrorMsgId);\n            attrs.set('__widgetType', widgetType);\n            attrs.delete('widget');\n            shared.set('counter', counter);\n\n            if (attrs.get('is-range') === 'true') {\n                setDefaultPlaceholder(attrs, widgetType, 0);\n                setDefaultPlaceholder(attrs, widgetType, 1);\n            } else {\n                setDefaultPlaceholder(attrs, widgetType, 2);\n            }\n\n            return `<${tagName} data-role=\"${dataRole}\" [formGroup]=\"${pCounter}.ngform\" wmFormField wmCaptionPosition #${counter}=\"wmFormField\" widgettype=\"${widgetType}\" ${getFormMarkupAttr(attrs)}>\n                        <div class=\"live-field form-group app-composite-widget clearfix caption-{{${pCounter}.captionposition}}\" widget=\"${widgetType}\">\n                            <label [hidden]=\"!${counter}.displayname\" class=\"app-label control-label formfield-label {{${pCounter}._captionClass}}\"\n                                        [ngStyle]=\"{width: ${pCounter}.captionsize}\" [ngClass]=\"{'text-danger': ${counter}._control?.invalid && ${counter}._control?.touched && ${pCounter}.isUpdateMode,\n                                         required: ${pCounter}.isUpdateMode && ${counter}.required}\" [textContent]=\"${counter}.displayname\"> </label>\n                            <div [ngClass]=\"${counter}.displayname ? ${pCounter}._widgetClass : '${controlLayout}'\">\n                                 <label class=\"form-control-static app-label\"\n                                       [hidden]=\"${pCounter}.isUpdateMode || ${counter}.viewmodewidget === 'default' || ${counter}.widgettype === 'upload'\" [innerHTML]=\"${getCaptionByWidget(attrs, widgetType, counter)}\"></label>\n                                ${getTemplate(attrs, widgetType, eventsTmpl, counter, pCounter, isInList)}\n                                <span aria-hidden=\"true\" *ngIf=\"${counter}.showPendingSpinner\" class=\"form-field-spinner fa fa-circle-o-notch fa-spin form-control-feedback\"></span>\n                                <p *ngIf=\"!(${counter}._control?.invalid && ${counter}._control?.touched) && ${pCounter}.isUpdateMode\"\n                                   class=\"help-block\" aria-hidden=\"true\" role=\"alert\" aria-live=\"polite\" [textContent]=\"${counter}.hint\"></p>\n                                ${validationMsg}\n                            </div>\n                        </div>`;\n        },\n        post: () => `</${tagName}>`,\n        provide: (attrs, shared) => {\n            const provider = new Map();\n            provider.set('form_reference', shared.get('counter'));\n            return provider;\n        },\n        imports: (attrs: Map<String, String>): string[] => {\n            const requiredWidget = getRequiredFormWidget(attrs.get('__widgetType') || attrs.get('type'));\n            attrs.delete('__widgetType');\n            return [requiredWidget, 'wm-form'];\n        }\n    };\n};\n\nregister('wm-form-field', registerFormField.bind(this, true));\nregister('wm-filter-field', registerFormField.bind(this, false));\n\nexport default () => {};\n"]}
@@ -1012,6 +1012,13 @@ const setDefaultPlaceholder = (attrs, widgetType, index) => {
1012
1012
  }
1013
1013
  };
1014
1014
  const getWidgetTemplate = (attrs, options) => {
1015
+ let customAttrs = ``;
1016
+ if (options.widgetType === "custom-widget") {
1017
+ for (let [key, value] of attrs) {
1018
+ if (key.startsWith('prop-'))
1019
+ customAttrs += key + '="' + value + '" ';
1020
+ }
1021
+ }
1015
1022
  const name = attrs.get('name');
1016
1023
  const customWidgetName = attrs.get('widgetname');
1017
1024
  const fieldName = (attrs.get('key') || name || '').trim();
@@ -1019,7 +1026,7 @@ const getWidgetTemplate = (attrs, options) => {
1019
1026
  const tmplRef = options.isMaxWidget ? `#formWidgetMax` : `#formWidget`;
1020
1027
  const widgetName = name ? (options.isMaxWidget ? `name="${name}_formWidgetMax"` : `name="${name}_formWidget"`) : '';
1021
1028
  const conditionalClass = `[ngClass]="${attrs.get('ngclass')}"`;
1022
- const defaultTmpl = `[class.hidden]="!${options.pCounter}.isUpdateMode && ${options.counter}.viewmodewidget !== 'default'" ${formControl} ${options.eventsTmpl} ${conditionalClass} ${tmplRef} ${widgetName} ${customWidgetName ? `widgetname=${customWidgetName}` : ''}`;
1029
+ const defaultTmpl = `[class.hidden]="!${options.pCounter}.isUpdateMode && ${options.counter}.viewmodewidget !== 'default'" ${formControl} ${options.eventsTmpl} ${conditionalClass} ${tmplRef} ${widgetName} ${customWidgetName ? `widgetname=${customWidgetName} ${customAttrs}` : ''}`;
1023
1030
  return getFormWidgetTemplate(options.widgetType, defaultTmpl, attrs, { counter: options.counter, pCounter: options.pCounter });
1024
1031
  };
1025
1032
  const getTemplate = (attrs, widgetType, eventsTmpl, counter, pCounter, isInList) => {